diff options
author | cognet <cognet@FreeBSD.org> | 2004-11-07 23:01:36 +0000 |
---|---|---|
committer | cognet <cognet@FreeBSD.org> | 2004-11-07 23:01:36 +0000 |
commit | 103e95586ea0c1e4225a4bc7c851cf22bd979fa5 (patch) | |
tree | bd6194dbac8ef344d695c3a883f0f92fa9bc572f /sys/arm | |
parent | e8fd5617c522ffcbe43eca509cc8a05d0fa4ef0e (diff) | |
download | FreeBSD-src-103e95586ea0c1e4225a4bc7c851cf22bd979fa5.zip FreeBSD-src-103e95586ea0c1e4225a4bc7c851cf22bd979fa5.tar.gz |
Import md bits for mem(4) on arm.
While I'm there, cleanup a bit pmap.h.
Diffstat (limited to 'sys/arm')
-rw-r--r-- | sys/arm/arm/mem.c | 153 | ||||
-rw-r--r-- | sys/arm/arm/pmap.c | 5 | ||||
-rw-r--r-- | sys/arm/include/memdev.h | 38 | ||||
-rw-r--r-- | sys/arm/include/pmap.h | 51 |
4 files changed, 202 insertions, 45 deletions
diff --git a/sys/arm/arm/mem.c b/sys/arm/arm/mem.c new file mode 100644 index 0000000..a9582a6 --- /dev/null +++ b/sys/arm/arm/mem.c @@ -0,0 +1,153 @@ +/*- + * Copyright (c) 1988 University of Utah. + * Copyright (c) 1982, 1986, 1990 The Regents of the University of California. + * All rights reserved. + * + * This code is derived from software contributed to Berkeley by + * the Systems Programming Group of the University of Utah Computer + * Science Department, and code derived from software contributed to + * Berkeley by William Jolitz. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 4. Neither the name of the University nor the names of its contributors + * may be used to endorse or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS + * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT + * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY + * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF + * SUCH DAMAGE. + * + * from: Utah $Hdr: mem.c 1.13 89/10/08$ + * from: @(#)mem.c 7.2 (Berkeley) 5/9/91 + */ + +#include <sys/cdefs.h> +__FBSDID("$FreeBSD$"); + +/* + * Memory special file + */ + +#include <sys/param.h> +#include <sys/conf.h> +#include <sys/fcntl.h> +#include <sys/ioccom.h> +#include <sys/kernel.h> +#include <sys/lock.h> +#include <sys/malloc.h> +#include <sys/memrange.h> +#include <sys/module.h> +#include <sys/mutex.h> +#include <sys/proc.h> +#include <sys/signalvar.h> +#include <sys/systm.h> +#include <sys/uio.h> + +#include <vm/vm.h> +#include <vm/pmap.h> +#include <vm/vm_extern.h> + +#include <machine/memdev.h> + +/* + * Used in /dev/mem drivers and elsewhere + */ +MALLOC_DEFINE(M_MEMDESC, "memdesc", "memory range descriptors"); + +/* ARGSUSED */ +int +memrw(struct cdev *dev, struct uio *uio, int flags) +{ + int o; + u_int c = 0, v; + struct iovec *iov; + int error = 0; + vm_offset_t addr, eaddr; + + GIANT_REQUIRED; + + while (uio->uio_resid > 0 && error == 0) { + iov = uio->uio_iov; + if (iov->iov_len == 0) { + uio->uio_iov++; + uio->uio_iovcnt--; + if (uio->uio_iovcnt < 0) + panic("memrw"); + continue; + } + if (minor(dev) == CDEV_MINOR_MEM) { + v = uio->uio_offset; + v &= ~PAGE_MASK; + pmap_kenter((vm_offset_t)_tmppt, v); + o = (int)uio->uio_offset & PAGE_MASK; + c = (u_int)(PAGE_SIZE - ((int)iov->iov_base & PAGE_MASK)); + c = min(c, (u_int)(PAGE_SIZE - o)); + c = min(c, (u_int)iov->iov_len); + error = uiomove((caddr_t)&_tmppt[o], (int)c, uio); + pmap_qremove((vm_offset_t)_tmppt, 1); + continue; + } + else if (minor(dev) == CDEV_MINOR_KMEM) { + c = iov->iov_len; + + /* + * Make sure that all of the pages are currently + * resident so that we don't create any zero-fill + * pages. + */ + addr = trunc_page(uio->uio_offset); + eaddr = round_page(uio->uio_offset + c); + + for (; addr < eaddr; addr += PAGE_SIZE) + if (pmap_extract(kernel_pmap, addr) == 0) + return (EFAULT); + + if (!kernacc((caddr_t)(int)uio->uio_offset, c, + uio->uio_rw == UIO_READ ? + VM_PROT_READ : VM_PROT_WRITE)) + return (EFAULT); + error = uiomove((caddr_t)(int)uio->uio_offset, (int)c, uio); + continue; + } + /* else panic! */ + } + return (error); +} + +/* + * allow user processes to MMAP some memory sections + * instead of going through read/write + */ +/* ARGSUSED */ + +int +memmmap(struct cdev *dev, vm_offset_t offset, vm_paddr_t *paddr, + int prot __unused) +{ + if (minor(dev) == CDEV_MINOR_MEM) + *paddr = offset; + else if (minor(dev) == CDEV_MINOR_KMEM) + *paddr = vtophys(offset); + /* else panic! */ + return (0); +} + +void +dev_mem_md_init(void) +{ +} diff --git a/sys/arm/arm/pmap.c b/sys/arm/arm/pmap.c index 59123a1..9d02e7c 100644 --- a/sys/arm/arm/pmap.c +++ b/sys/arm/arm/pmap.c @@ -275,6 +275,9 @@ struct msgbuf *msgbufp = 0; extern void bcopy_page(vm_offset_t, vm_offset_t); extern void bzero_page(vm_offset_t); + +char *_tmppt; + /* * Metadata for L1 translation tables. */ @@ -2496,6 +2499,8 @@ pmap_bootstrap(vm_offset_t firstaddr, vm_offset_t lastaddr, struct pv_addr *l1pt round_page(size * sizeof(struct l2_dtable)) / PAGE_SIZE, &pmap_kernel_l2dtable_kva, NULL); + pmap_alloc_specials(&virtual_avail, + 1, (vm_offset_t*)&_tmppt, NULL); SLIST_INIT(&l1_list); TAILQ_INIT(&l1_lru_list); mtx_init(&l1_lru_lock, "l1 list lock", NULL, MTX_DEF); diff --git a/sys/arm/include/memdev.h b/sys/arm/include/memdev.h new file mode 100644 index 0000000..9cf0b4a --- /dev/null +++ b/sys/arm/include/memdev.h @@ -0,0 +1,38 @@ +/*- + * Copyright (c) 2004 Mark R V Murray + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer + * in this position and unchanged. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR + * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, + * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT + * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + * + * $FreeBSD$ + */ + +#define CDEV_MAJOR 2 +#define CDEV_MINOR_MEM 0 +#define CDEV_MINOR_KMEM 1 + +d_open_t memopen; +d_read_t memrw; +d_mmap_t memmmap; +#define memioctl (d_ioctl_t *)NULL + +void dev_mem_md_init(void); diff --git a/sys/arm/include/pmap.h b/sys/arm/include/pmap.h index a4377b1..fc870c9 100644 --- a/sys/arm/include/pmap.h +++ b/sys/arm/include/pmap.h @@ -57,31 +57,7 @@ */ #define PTE_NOCACHE 0 #define PTE_CACHE 1 - -#define VADDR(pdi, pti) ((vm_offset_t)(((pdi)<<PDR_SHIFT)+((pti)<<PAGE_SHIFT))) -#define PTDIPDE(ptd) ((ptd)/1024) -#define PTDIPTE(ptd) ((ptd)%256) - -#ifndef NKPT -#define NKPT 120 /* actual number of kernel page tables */ -#endif - -#ifndef NKPDE -#define NKPDE 1019 /* Maximum number of kernel PDE */ -#endif - -#define NPDEPTD 16 /* Number of PDE in each PTD */ - -/* - * The *PTDI values control the layout of virtual memory - */ - -#define KPTDI (NPDEPG-NKPDE) /* ptd entry for kernel space begin */ -#define PTDPTDI (KPTDI-1) /* ptd entry that points to ptd! */ -#define KPTPTDI (PTDPTDI-1) /* ptd entry for kernel PTEs */ -#define UPTPTDI (KPTPTDI-3) /* ptd entry for uspace PTEs */ -#define UMAXPTDI (UPTPTDI-1) /* ptd entry for user space end */ -#define UMAXPTEOFF (NPTEPG) /* pte entry for user space end */ +#define PTE_PAGETABLE 2 #ifndef LOCORE @@ -99,7 +75,7 @@ #define pmap_page_is_mapped(m) (!TAILQ_EMPTY(&(m)->md.pv_list)) /* - * Pmap sutff + * Pmap stuff */ /* @@ -175,6 +151,7 @@ typedef struct pmap *pmap_t; #ifdef _KERNEL extern pmap_t kernel_pmap; #define pmap_kernel() kernel_pmap + #endif @@ -192,20 +169,6 @@ typedef struct pv_entry { #define PV_ENTRY_NULL ((pv_entry_t) 0) -#define PV_CI 0x01 /* all entries must be cache inhibited */ -#define PV_PTPAGE 0x02 /* entry maps a page table page */ - -/* - * Page hooks. - * For speed we store the both the virtual address and the page table - * entry address for each page hook. - */ -typedef struct { - vm_offset_t va; - pt_entry_t *pte; -} pagehook_t; - - #ifdef _KERNEL boolean_t pmap_get_pde_pte(pmap_t, vm_offset_t, pd_entry_t **, pt_entry_t **); @@ -496,11 +459,6 @@ void pmap_use_minicache(vm_offset_t, vm_size_t); #define pmap_pte_v(pte) l2pte_valid(*(pte)) #define pmap_pte_pa(pte) l2pte_pa(*(pte)) -/* Size of the kernel part of the L1 page table */ -#define KERNEL_PD_SIZE \ - (L1_TABLE_SIZE - (KERNEL_BASE >> L1_S_SHIFT) * sizeof(pd_entry_t)) -#define PTE_PAGETABLE 2 - /* * Flags that indicate attributes of pages or mappings of pages. * @@ -542,6 +500,9 @@ const struct pmap_devmap *pmap_devmap_find_va(vm_offset_t, vm_size_t); void pmap_devmap_bootstrap(vm_offset_t, const struct pmap_devmap *); void pmap_devmap_register(const struct pmap_devmap *); + +extern char *_tmppt; + #endif /* _KERNEL */ #endif /* !LOCORE */ |