summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/sparc/sparc/mem.c25
-rw-r--r--sys/arch/sparc/sparc/pmap.c13
2 files changed, 22 insertions, 16 deletions
diff --git a/sys/arch/sparc/sparc/mem.c b/sys/arch/sparc/sparc/mem.c
index 0da42036100..80497e5c259 100644
--- a/sys/arch/sparc/sparc/mem.c
+++ b/sys/arch/sparc/sparc/mem.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: mem.c,v 1.9 1999/11/16 10:04:48 art Exp $ */
+/* $OpenBSD: mem.c,v 1.10 1999/11/16 12:21:41 art Exp $ */
/* $NetBSD: mem.c,v 1.13 1996/03/30 21:12:16 christos Exp $ */
/*
@@ -58,10 +58,12 @@
#include <machine/conf.h>
#include <vm/vm.h>
+#include <vm/vm_kern.h>
extern vaddr_t prom_vstart;
extern vaddr_t prom_vend;
caddr_t zeropage;
+vaddr_t mem_page;
/*ARGSUSED*/
int
@@ -108,10 +110,9 @@ mmrw(dev, uio, flags)
struct iovec *iov;
int error = 0;
static int physlock;
- extern caddr_t vmmap;
if (minor(dev) == 0) {
- /* lock against other uses of shared vmmap */
+ /* lock against other uses of shared mem_page */
while (physlock > 0) {
physlock++;
error = tsleep((caddr_t)&physlock, PZERO | PCATCH,
@@ -120,6 +121,15 @@ mmrw(dev, uio, flags)
return (error);
}
physlock = 1;
+#if defined(UVM)
+ if (mem_page == 0)
+ mem_page = uvm_km_valloc_wait(kernel_map, NBPG);
+#else
+ if (mem_page == 0)
+ mem_page = kmem_alloc_pageable(kernel_map, NBPG);
+#endif
+ if (mem_page == 0)
+ panic("mmrw: out of space in kernel_map");
}
while (uio->uio_resid > 0 && error == 0) {
iov = uio->uio_iov;
@@ -134,19 +144,18 @@ mmrw(dev, uio, flags)
/* minor device 0 is physical memory */
case 0:
- pa = uio->uio_offset;
+ pa = (paddr_t)uio->uio_offset;
if (!pmap_pa_exists(pa)) {
error = EFAULT;
goto unlock;
}
- pmap_enter(pmap_kernel(), (vaddr_t)vmmap,
+ pmap_enter(pmap_kernel(), mem_page,
trunc_page(pa), uio->uio_rw == UIO_READ ?
VM_PROT_READ : VM_PROT_WRITE, TRUE, 0);
o = uio->uio_offset & PGOFSET;
c = min(uio->uio_resid, (int)(NBPG - o));
- error = uiomove((caddr_t)vmmap + o, c, uio);
- pmap_remove(pmap_kernel(), (vaddr_t)vmmap,
- (vaddr_t)vmmap + NBPG);
+ error = uiomove((caddr_t)mem_page + o, c, uio);
+ pmap_remove(pmap_kernel(), mem_page, mem_page + NBPG);
continue;
/* minor device 1 is kernel memory */
diff --git a/sys/arch/sparc/sparc/pmap.c b/sys/arch/sparc/sparc/pmap.c
index 1a9716df51c..f24652e811b 100644
--- a/sys/arch/sparc/sparc/pmap.c
+++ b/sys/arch/sparc/sparc/pmap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmap.c,v 1.43 1999/11/16 10:49:56 art Exp $ */
+/* $OpenBSD: pmap.c,v 1.44 1999/11/16 12:21:41 art Exp $ */
/* $NetBSD: pmap.c,v 1.118 1998/05/19 19:00:18 thorpej Exp $ */
/*
@@ -354,7 +354,6 @@ char *ctxbusyvector; /* [4m] tells what contexts are busy (XXX)*/
#endif
caddr_t vpage[2]; /* two reserved MD virtual pages */
-caddr_t vmmap; /* one reserved MI vpage for /dev/mem */
caddr_t vdumppages; /* 32KB worth of reserved dump pages */
smeg_t tregion; /* [4/3mmu] Region for temporary mappings */
@@ -2784,8 +2783,8 @@ pmap_bootstrap4_4c(nctx, nregion, nsegment)
* the next whole page) and continuing through the number
* of available pages are free, but they start at a higher
* virtual address. This gives us two mappable MD pages
- * for pmap_zero_page and pmap_copy_page, and one MI page
- * for /dev/mem, all with no associated physical memory.
+ * for pmap_zero_page and pmap_copy_page, and some pages
+ * for dumpsys(), all with no associated physical memory.
*/
p = (caddr_t)(((u_int)p + NBPG - 1) & ~PGOFSET);
avail_start = (paddr_t)p - KERNBASE;
@@ -2793,7 +2792,6 @@ pmap_bootstrap4_4c(nctx, nregion, nsegment)
i = (int)p;
vpage[0] = p, p += NBPG;
vpage[1] = p, p += NBPG;
- vmmap = p, p += NBPG;
p = reserve_dumppages(p);
virtual_avail = (vaddr_t)p;
@@ -3182,13 +3180,12 @@ pmap_bootstrap4m(void)
/*
* Reserve virtual address space for two mappable MD pages
- * for pmap_zero_page and pmap_copy_page, one MI page
- * for /dev/mem, and some more for dumpsys().
+ * for pmap_zero_page and pmap_copy_page, and some more for
+ * dumpsys().
*/
q = p;
vpage[0] = p, p += NBPG;
vpage[1] = p, p += NBPG;
- vmmap = p, p += NBPG;
p = reserve_dumppages(p);
virtual_avail = (vaddr_t)p;