summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorOwain Ainsworth <oga@cvs.openbsd.org>2009-03-30 16:09:37 +0000
committerOwain Ainsworth <oga@cvs.openbsd.org>2009-03-30 16:09:37 +0000
commit5422563144e0c36d2d8a27c337f96eca136e4c21 (patch)
treebf9d05cee14b919b2d70cf612efc5f4bc5534c3d
parent03a05ac0dd4aa667d4f0266446340a7f759631d0 (diff)
Remove the direct uncached map. All its users have been removed.
In the future, we need to mark the correct parts of the direct map uncached, but that's another diff. art@, kettenis@ ok.
-rw-r--r--sys/arch/amd64/amd64/pmap.c45
-rw-r--r--sys/arch/amd64/include/pmap.h11
2 files changed, 2 insertions, 54 deletions
diff --git a/sys/arch/amd64/amd64/pmap.c b/sys/arch/amd64/amd64/pmap.c
index 6d92e73acb0..d7bed6bc329 100644
--- a/sys/arch/amd64/amd64/pmap.c
+++ b/sys/arch/amd64/amd64/pmap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmap.c,v 1.38 2009/03/23 13:25:11 art Exp $ */
+/* $OpenBSD: pmap.c,v 1.39 2009/03/30 16:09:36 oga Exp $ */
/* $NetBSD: pmap.c,v 1.3 2003/05/08 18:13:13 thorpej Exp $ */
/*
@@ -643,42 +643,6 @@ pmap_bootstrap(paddr_t first_avail, paddr_t max_pa)
kpm->pm_pdir[PDIR_SLOT_DIRECT] = dmpdp | PG_V | PG_KW | PG_U |
PG_M;
- /*
- * Now do the same thing, but for the direct uncached map.
- */
- ndmpdp = (max_pa + NBPD_L3 - 1) >> L3_SHIFT;
- if (ndmpdp < NDML2_ENTRIES)
- ndmpdp = NDML2_ENTRIES; /* At least 4GB */
-
- dmpdp = first_avail; first_avail += PAGE_SIZE;
- dmpd = first_avail; first_avail += ndmpdp * PAGE_SIZE;
-
- for (i = 0; i < NPDPG * ndmpdp; i++) {
- paddr_t pdp;
- vaddr_t va;
-
- pdp = (paddr_t)&(((pd_entry_t *)dmpd)[i]);
- va = PMAP_DIRECT_MAP(pdp);
-
- *((pd_entry_t *)va) = (paddr_t)i << L2_SHIFT;
- *((pd_entry_t *)va) |= PG_RW | PG_V | PG_PS | PG_G | PG_N |
- PG_U | PG_M;
- }
-
- for (i = 0; i < ndmpdp; i++) {
- paddr_t pdp;
- vaddr_t va;
-
- pdp = (paddr_t)&(((pd_entry_t *)dmpdp)[i]);
- va = PMAP_DIRECT_MAP(pdp);
-
- *((pd_entry_t *)va) = dmpd + (i << PAGE_SHIFT);
- *((pd_entry_t *)va) |= PG_RW | PG_V | PG_U | PG_M;
- }
-
- kpm->pm_pdir[PDIR_SLOT_DIRECT_NC] = dmpdp | PG_V | PG_KW | PG_U |
- PG_M;
-
tlbflush();
msgbuf_vaddr = virtual_avail;
@@ -1028,7 +992,6 @@ pmap_pdp_ctor(void *arg, void *object, int flags)
(NTOPLEVEL_PDES - (PDIR_SLOT_KERN + npde)) * sizeof(pd_entry_t));
pdir[PDIR_SLOT_DIRECT] = pmap_kernel()->pm_pdir[PDIR_SLOT_DIRECT];
- pdir[PDIR_SLOT_DIRECT_NC] = pmap_kernel()->pm_pdir[PDIR_SLOT_DIRECT_NC];
#if VM_MIN_KERNEL_ADDRESS != KERNBASE
pdir[pl4_pi(KERNBASE)] = PDP_BASE[pl4_pi(KERNBASE)];
@@ -1241,12 +1204,6 @@ pmap_extract(struct pmap *pmap, vaddr_t va, paddr_t *pap)
return (TRUE);
}
- if (pmap == pmap_kernel() && va >= PMAP_DIRECT_BASE_NC &&
- va < PMAP_DIRECT_END_NC) {
- *pap = va - PMAP_DIRECT_BASE_NC;
- return (TRUE);
- }
-
pmap_map_ptes(pmap, &ptes, &pdes);
if (pmap_pdes_valid(va, pdes, &pde) == FALSE) {
return FALSE;
diff --git a/sys/arch/amd64/include/pmap.h b/sys/arch/amd64/include/pmap.h
index 59c586db19d..019aa2cfa59 100644
--- a/sys/arch/amd64/include/pmap.h
+++ b/sys/arch/amd64/include/pmap.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmap.h,v 1.20 2009/02/05 01:15:20 oga Exp $ */
+/* $OpenBSD: pmap.h,v 1.21 2009/03/30 16:09:36 oga Exp $ */
/* $NetBSD: pmap.h,v 1.1 2003/04/26 18:39:46 fvdl Exp $ */
/*
@@ -157,13 +157,11 @@
#define L4_SLOT_KERNBASE 511
#define L4_SLOT_APTE 510
#define L4_SLOT_DIRECT 509
-#define L4_SLOT_DIRECT_NC 508
#define PDIR_SLOT_KERN L4_SLOT_KERN
#define PDIR_SLOT_PTE L4_SLOT_PTE
#define PDIR_SLOT_APTE L4_SLOT_APTE
#define PDIR_SLOT_DIRECT L4_SLOT_DIRECT
-#define PDIR_SLOT_DIRECT_NC L4_SLOT_DIRECT_NC
/*
* the following defines give the virtual addresses of various MMU
@@ -178,8 +176,6 @@
#define APTE_BASE ((pt_entry_t *) (VA_SIGN_NEG((L4_SLOT_APTE * NBPD_L4))))
#define PMAP_DIRECT_BASE (VA_SIGN_NEG((L4_SLOT_DIRECT * NBPD_L4)))
#define PMAP_DIRECT_END (VA_SIGN_NEG(((L4_SLOT_DIRECT + 1) * NBPD_L4)))
-#define PMAP_DIRECT_BASE_NC (VA_SIGN_NEG((L4_SLOT_DIRECT_NC * NBPD_L4)))
-#define PMAP_DIRECT_END_NC (VA_SIGN_NEG(((L4_SLOT_DIRECT_NC + 1) * NBPD_L4)))
#define L1_BASE PTE_BASE
#define AL1_BASE APTE_BASE
@@ -567,11 +563,6 @@ vaddr_t pmap_map(vaddr_t, paddr_t, paddr_t, vm_prot_t);
#define pmap_map_direct(pg) PMAP_DIRECT_MAP(VM_PAGE_TO_PHYS(pg))
#define pmap_unmap_direct(va) PHYS_TO_VM_PAGE(PMAP_DIRECT_UNMAP(va))
-#define PMAP_DIRECT_NC_MAP(pa) ((vaddr_t)PMAP_DIRECT_BASE_NC + pa)
-#define PMAP_DIRECT_NC_UNMAP(va) ((paddr_t)va - PMAP_DIRECT_BASE_NC)
-#define pmap_map_nc_direct(pg) PMAP_DIRECT_NC_MAP(VM_PAGE_TO_PHYS(pg))
-#define pmap_unmap_nc_direct(va) PHYS_TO_VM_PAGE(PMAP_DIRECT_NC_UNMAP(va))
-
#define __HAVE_PMAP_DIRECT
#endif /* _KERNEL && !_LOCORE */