diff options
Diffstat (limited to 'sys/arch/i386')
-rw-r--r-- | sys/arch/i386/i386/pmap.c | 42 | ||||
-rw-r--r-- | sys/arch/i386/include/pmap.h | 5 |
2 files changed, 32 insertions, 15 deletions
diff --git a/sys/arch/i386/i386/pmap.c b/sys/arch/i386/i386/pmap.c index aa0061ecd5f..7987751b544 100644 --- a/sys/arch/i386/i386/pmap.c +++ b/sys/arch/i386/i386/pmap.c @@ -1,5 +1,5 @@ -/* $OpenBSD: pmap.c,v 1.53 2001/12/10 17:27:01 art Exp $ */ -/* $NetBSD: pmap.c,v 1.91 2000/06/02 17:46:37 thorpej Exp $ */ +/* $OpenBSD: pmap.c,v 1.54 2001/12/11 16:35:18 art Exp $ */ +/* $NetBSD: pmap.c,v 1.99 2000/09/05 21:56:41 thorpej Exp $ */ /* * @@ -433,11 +433,13 @@ static vaddr_t pmap_tmpmap_pa __P((paddr_t)); static pt_entry_t *pmap_tmpmap_pvepte __P((struct pv_entry *)); static void pmap_tmpunmap_pa __P((void)); static void pmap_tmpunmap_pvepte __P((struct pv_entry *)); +#if 0 static boolean_t pmap_transfer_ptes __P((struct pmap *, struct pmap_transfer_location *, struct pmap *, struct pmap_transfer_location *, int, boolean_t)); +#endif static boolean_t pmap_try_steal_pv __P((struct pv_head *, struct pv_entry *, struct pv_entry *)); @@ -933,7 +935,7 @@ pmap_bootstrap(kva_start) void pmap_init() { - int npages, lcv; + int npages, lcv, i; vaddr_t addr; vsize_t s; @@ -961,6 +963,11 @@ pmap_init() vm_physmem[lcv].pmseg.pvhead = (struct pv_head *) addr; addr = (vaddr_t)(vm_physmem[lcv].pmseg.pvhead + (vm_physmem[lcv].end - vm_physmem[lcv].start)); + for (i = 0; + i < (vm_physmem[lcv].end - vm_physmem[lcv].start); i++) { + simple_lock_init( + &vm_physmem[lcv].pmseg.pvhead[i].pvh_lock); + } } /* now allocate attrs */ @@ -1949,9 +1956,9 @@ pmap_ldt_cleanup(p) #endif /* USER_LDT */ /* - * pmap_activate: activate a process' pmap (fill in %cr3 info) + * pmap_activate: activate a process' pmap (fill in %cr3 and LDT info) * - * => called from cpu_fork() + * => called from cpu_switch() * => if proc is the curproc, then load it into the MMU */ @@ -2001,16 +2008,25 @@ pmap_extract(pmap, va, pap) vaddr_t va; paddr_t *pap; { - paddr_t retval; - pt_entry_t *ptes; + pt_entry_t *ptes, pte; + pd_entry_t pde; + + if (__predict_true((pde = pmap->pm_pdir[pdei(va)]) != 0)) { + if (pde & PG_PS) { + if (pap != NULL) + *pap = (pde & PG_LGFRAME) | (va & ~PG_LGFRAME); + return (TRUE); + } - if (pmap->pm_pdir[pdei(va)]) { ptes = pmap_map_ptes(pmap); - retval = (paddr_t)(ptes[i386_btop(va)] & PG_FRAME); + pte = ptes[i386_btop(va)]; pmap_unmap_ptes(pmap); - if (pap != NULL) - *pap = retval | (va & ~PG_FRAME); - return (TRUE); + + if (__predict_true((pte & PG_V) != 0)) { + if (pap != NULL) + *pap = (pte & PG_FRAME) | (va & ~PG_FRAME); + return (TRUE); + } } return (FALSE); } @@ -2923,6 +2939,7 @@ pmap_collect(pmap) pmap_update(pmap); } +#if 0 /* * pmap_transfer: transfer (move or copy) mapping from one pmap * to another. @@ -3387,6 +3404,7 @@ pmap_transfer_ptes(srcpmap, srcl, dstpmap, dstl, toxfer, move) /* * defined as macro call to pmap_transfer in pmap.h */ +#endif /* * pmap_enter: enter a mapping into a pmap diff --git a/sys/arch/i386/include/pmap.h b/sys/arch/i386/include/pmap.h index 68a81230988..85a94cf264d 100644 --- a/sys/arch/i386/include/pmap.h +++ b/sys/arch/i386/include/pmap.h @@ -1,4 +1,4 @@ -/* $OpenBSD: pmap.h,v 1.22 2001/12/08 02:24:06 art Exp $ */ +/* $OpenBSD: pmap.h,v 1.23 2001/12/11 16:35:18 art Exp $ */ /* $NetBSD: pmap.h,v 1.44 2000/04/24 17:18:18 thorpej Exp $ */ /* @@ -379,10 +379,9 @@ extern int pmap_pg_g; /* do we support PG_G? */ #define pmap_clear_modify(pg) pmap_change_attrs(pg, 0, PG_M) #define pmap_clear_reference(pg) pmap_change_attrs(pg, 0, PG_U) -#define pmap_copy(DP,SP,D,L,S) pmap_transfer(DP,SP,D,L,S, FALSE) +#define pmap_copy(DP,SP,D,L,S) #define pmap_is_modified(pg) pmap_test_attrs(pg, PG_M) #define pmap_is_referenced(pg) pmap_test_attrs(pg, PG_U) -#define pmap_move(DP,SP,D,L,S) pmap_transfer(DP,SP,D,L,S, TRUE) #define pmap_phys_address(ppn) i386_ptob(ppn) #define pmap_valid_entry(E) ((E) & PG_V) /* is PDE or PTE valid? */ |