diff options
author | Dale Rahn <drahn@cvs.openbsd.org> | 2001-02-12 06:26:31 +0000 |
---|---|---|
committer | Dale Rahn <drahn@cvs.openbsd.org> | 2001-02-12 06:26:31 +0000 |
commit | e08ba64545b776a4e1a827b41eb097d624e77996 (patch) | |
tree | 9e0a8db37bab59ee7b69e93e3e02a4a75b50d626 /sys | |
parent | 5c36d2ed9f9ae73a69527eda0de564b0b3f0b02c (diff) |
One more step to UVM. It is necessary to map the I/O buffers, using uvm or vm.
These changes taken from alpha/i386 combination.
Diffstat (limited to 'sys')
-rw-r--r-- | sys/arch/powerpc/powerpc/machdep.c | 25 |
1 files changed, 22 insertions, 3 deletions
diff --git a/sys/arch/powerpc/powerpc/machdep.c b/sys/arch/powerpc/powerpc/machdep.c index d15f6d09c3e..6264727eff8 100644 --- a/sys/arch/powerpc/powerpc/machdep.c +++ b/sys/arch/powerpc/powerpc/machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: machdep.c,v 1.51 2001/01/18 23:00:42 drahn Exp $ */ +/* $OpenBSD: machdep.c,v 1.52 2001/02/12 06:26:30 drahn Exp $ */ /* $NetBSD: machdep.c,v 1.4 1996/10/16 19:33:11 ws Exp $ */ /* @@ -471,17 +471,27 @@ cpu_startup() if (allocsys(v) - v != sz) panic("startup: table size inconsistency"); -#if !defined (UVM) /* * Now allocate buffers proper. They are different than the above * in that they usually occupy more virtual memory than physical. */ sz = MAXBSIZE * nbuf; +#ifdef UVM + if (uvm_map(kernel_map, (vaddr_t *) &buffers, round_page(sz), + NULL, UVM_UNKNOWN_OFFSET, + UVM_MAPFLAG(UVM_PROT_NONE, UVM_PROT_NONE, UVM_INH_NONE, + UVM_ADV_NORMAL, 0)) != KERN_SUCCESS) + panic("cpu_startup: cannot allocate VM for buffers"); + /* + addr = (vaddr_t)buffers; + */ +#else buffer_map = kmem_suballoc(kernel_map, &minaddr, &maxaddr, sz, TRUE); buffers = (char *)minaddr; if (vm_map_find(buffer_map, vm_object_allocate(sz), (vm_offset_t)0, &minaddr, sz, FALSE) != KERN_SUCCESS) panic("startup: cannot allocate buffers"); +#endif base = bufpages / nbuf; residual = bufpages % nbuf; if (base >= MAXBSIZE) { @@ -492,14 +502,23 @@ cpu_startup() for (i = 0; i < nbuf; i++) { vm_size_t curbufsize; vm_offset_t curbuf; + struct vm_page *pg; curbuf = (vm_offset_t)buffers + i * MAXBSIZE; curbufsize = CLBYTES * (i < residual ? base + 1 : base); +#ifdef UVM + pg = uvm_pagealloc(NULL, 0, NULL, 0); + if (pg == NULL) + panic("cpu_startup: not enough memory for" + " buffer cache"); + pmap_kenter_pa(curbuf, VM_PAGE_TO_PHYS(pg), + VM_PROT_READ|VM_PROT_WRITE); +#else vm_map_pageable(buffer_map, curbuf, curbuf + curbufsize, FALSE); vm_map_simplify(buffer_map, curbuf); - } #endif + } /* * Allocate a submap for exec arguments. This map effectively |