summaryrefslogtreecommitdiff
path: root/sys/arch/sparc
diff options
context:
space:
mode:
authorTheo de Raadt <deraadt@cvs.openbsd.org>1999-12-08 12:27:18 +0000
committerTheo de Raadt <deraadt@cvs.openbsd.org>1999-12-08 12:27:18 +0000
commitdb919ef56dced82ec8bf8bb79296652463318f83 (patch)
tree2790120ac83b8548c5250168cb70a02882998383 /sys/arch/sparc
parent8abcb90befd035bc4b13913138ad3c0c04d6b220 (diff)
undo even more damage
Diffstat (limited to 'sys/arch/sparc')
-rw-r--r--sys/arch/sparc/sparc/pmap.c217
1 files changed, 1 insertions, 216 deletions
diff --git a/sys/arch/sparc/sparc/pmap.c b/sys/arch/sparc/sparc/pmap.c
index b406b31ab7e..e42fbada193 100644
--- a/sys/arch/sparc/sparc/pmap.c
+++ b/sys/arch/sparc/sparc/pmap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmap.c,v 1.49 1999/12/08 12:15:03 deraadt Exp $ */
+/* $OpenBSD: pmap.c,v 1.50 1999/12/08 12:27:17 deraadt Exp $ */
/* $NetBSD: pmap.c,v 1.118 1998/05/19 19:00:18 thorpej Exp $ */
/*
@@ -597,29 +597,15 @@ static void mmu_setup4m_L3 __P((int, struct segmap *));
/* function pointer declarations */
/* from pmap.h: */
-#ifdef PMAP_NEW
-boolean_t (*pmap_clear_modify_p) __P((struct vm_page *));
-boolean_t (*pmap_clear_reference_p) __P((struct vm_page *));
-#else
void (*pmap_clear_modify_p) __P((paddr_t pa));
void (*pmap_clear_reference_p) __P((paddr_t pa));
-#endif
void (*pmap_copy_page_p) __P((paddr_t, paddr_t));
void (*pmap_enter_p) __P((pmap_t, vaddr_t, paddr_t, vm_prot_t,
boolean_t, vm_prot_t));
paddr_t (*pmap_extract_p) __P((pmap_t, vaddr_t));
-#ifdef PMAP_NEW
-boolean_t (*pmap_is_modified_p) __P((struct vm_page *));
-boolean_t (*pmap_is_referenced_p) __P((struct vm_page *));
-void (*pmap_kenter_pa_p) __P((vaddr_t, paddr_t, vm_prot_t));
-void (*pmap_kenter_pgs_p) __P((vaddr_t, struct vm_page **, int));
-void (*pmap_kremove_p) __P((vaddr_t, vsize_t));
-void (*pmap_page_protect_p) __P((struct vm_page *, vm_prot_t));
-#else
boolean_t (*pmap_is_modified_p) __P((paddr_t pa));
boolean_t (*pmap_is_referenced_p) __P((paddr_t pa));
void (*pmap_page_protect_p) __P((paddr_t, vm_prot_t));
-#endif
void (*pmap_protect_p) __P((pmap_t, vaddr_t, vaddr_t, vm_prot_t));
void (*pmap_zero_page_p) __P((paddr_t));
void (*pmap_changeprot_p) __P((pmap_t, vaddr_t, vm_prot_t, int));
@@ -2793,11 +2779,6 @@ pmap_bootstrap4_4c(nctx, nregion, nsegment)
pmap_extract_p = pmap_extract4_4c;
pmap_is_modified_p = pmap_is_modified4_4c;
pmap_is_referenced_p = pmap_is_referenced4_4c;
-#ifdef PMAP_NEW
- pmap_kenter_pa_p = pmap_kenter_pa4_4c;
- pmap_kenter_pgs_p = pmap_kenter_pgs4_4c;
- pmap_kremove_p = pmap_kremove4_4c;
-#endif
pmap_page_protect_p = pmap_page_protect4_4c;
pmap_protect_p = pmap_protect4_4c;
pmap_zero_page_p = pmap_zero_page4_4c;
@@ -3110,11 +3091,6 @@ pmap_bootstrap4m(void)
pmap_extract_p = pmap_extract4m;
pmap_is_modified_p = pmap_is_modified4m;
pmap_is_referenced_p = pmap_is_referenced4m;
-#ifdef PMAP_NEW
- pmap_kenter_pa_p = pmap_kenter_pa4m;
- pmap_kenter_pgs_p = pmap_kenter_pgs4m;
- pmap_kremove_p = pmap_kremove4m;
-#endif
pmap_page_protect_p = pmap_page_protect4m;
pmap_protect_p = pmap_protect4m;
pmap_zero_page_p = pmap_zero_page4m;
@@ -3551,19 +3527,13 @@ pmap_map(va, pa, endpa, prot)
* If size is nonzero, the map is useless. (ick)
*/
struct pmap *
-#ifdef PMAP_NEW
-pmap_create()
-#else
pmap_create(size)
vsize_t size;
-#endif
{
struct pmap *pm;
-#ifndef PMAP_NEW
if (size)
return (NULL);
-#endif
pm = (struct pmap *)malloc(sizeof *pm, M_VMPMAP, M_WAITOK);
#ifdef DEBUG
if (pmapdebug & PDB_CREATE)
@@ -4326,13 +4296,8 @@ pmap_rmu4m(pm, va, endva, vr, vs)
#if defined(SUN4) || defined(SUN4C)
void
-#ifdef PMAP_NEW
-pmap_page_protect4_4c(pg, prot)
- struct vm_page *pg;
-#else
pmap_page_protect4_4c(pa, prot)
paddr_t pa;
-#endif
vm_prot_t prot;
{
struct pvlist *pv, *pv0, *npv;
@@ -4341,9 +4306,6 @@ pmap_page_protect4_4c(pa, prot)
int flags, nleft, i, s, ctx;
struct regmap *rp;
struct segmap *sp;
-#ifdef PMAP_NEW
- paddr_t pa = VM_PAGE_TO_PHYS(pg);
-#endif
#ifdef DEBUG
if (!pmap_pa_exists(pa))
@@ -4732,13 +4694,8 @@ useless:
* to read-only (in which case pv_changepte does the trick).
*/
void
-#ifdef PMAP_NEW
-pmap_page_protect4m(pg, prot)
- struct vm_page *pg;
-#else
pmap_page_protect4m(pa, prot)
paddr_t pa;
-#endif
vm_prot_t prot;
{
struct pvlist *pv, *pv0, *npv;
@@ -4747,9 +4704,6 @@ pmap_page_protect4m(pa, prot)
int flags, nleft, s, ctx;
struct regmap *rp;
struct segmap *sp;
-#ifdef PMAP_NEW
- paddr_t pa = VM_PAGE_TO_PHYS(pg);
-#endif
#ifdef DEBUG
if (!pmap_pa_exists(pa))
@@ -5380,41 +5334,6 @@ printf("%s[%d]: pmap_enu: changing existing va(0x%x)=>pa entry\n",
splx(s);
}
-#ifdef PMAP_NEW
-void
-pmap_kenter_pa4_4c(va, pa, prot)
- vaddr_t va;
- paddr_t pa;
- vm_prot_t prot;
-{
- pmap_enter4_4c(pmap_kernel(), va, pa, prot, TRUE, 0);
-}
-
-void
-pmap_kenter_pgs4_4c(va, pgs, npgs)
- vaddr_t va;
- struct vm_page **pgs;
- int npgs;
-{
- int i;
-
- for (i = 0; i < npgs; i++, va += PAGE_SIZE) {
- pmap_enter4_4c(pmap_kernel(), va, VM_PAGE_TO_PHYS(pgs[i]),
- VM_PROT_READ|VM_PROT_WRITE, TRUE, 0);
- }
-}
-
-void
-pmap_kremove4_4c(va, len)
- vaddr_t va;
- vsize_t len;
-{
- for (len >>= PAGE_SHIFT; len > 0; len--, va += PAGE_SIZE) {
- pmap_remove(pmap_kernel(), va, va + PAGE_SIZE);
- }
-}
-#endif
-
#endif /*sun4,4c*/
#if defined(SUN4M) /* Sun4M versions of enter routines */
@@ -5730,42 +5649,6 @@ printf("%s[%d]: pmap_enu: changing existing va(0x%x)=>pa(pte=0x%x) entry\n",
splx(s);
}
-
-#ifdef PMAP_NEW
-void
-pmap_kenter_pa4m(va, pa, prot)
- vaddr_t va;
- paddr_t pa;
- vm_prot_t prot;
-{
- pmap_enter4m(pmap_kernel(), va, pa, prot, TRUE, 0);
-}
-
-void
-pmap_kenter_pgs4m(va, pgs, npgs)
- vaddr_t va;
- struct vm_page **pgs;
- int npgs;
-{
- int i;
-
- for (i = 0; i < npgs; i++, va += PAGE_SIZE) {
- pmap_enter4m(pmap_kernel(), va, VM_PAGE_TO_PHYS(pgs[i]),
- VM_PROT_READ|VM_PROT_WRITE, TRUE, 0);
- }
-}
-
-void
-pmap_kremove4m(va, len)
- vaddr_t va;
- vsize_t len;
-{
- for (len >>= PAGE_SHIFT; len > 0; len--, va += PAGE_SIZE) {
- pmap_remove(pmap_kernel(), va, va + PAGE_SIZE);
- }
-}
-#endif /* PMAP_NEW */
-
#endif /* sun4m */
/*
@@ -6021,52 +5904,27 @@ pmap_collect(pm)
/*
* Clear the modify bit for the given physical page.
*/
-#ifdef PMAP_NEW
-boolean_t
-pmap_clear_modify4_4c(pg)
- struct vm_page *pg;
-#else
void
pmap_clear_modify4_4c(pa)
paddr_t pa;
-#endif
{
struct pvlist *pv;
-#ifdef PMAP_NEW
- paddr_t pa;
- boolean_t ret = 0;
-#endif
pv = pvhead(atop(pa));
if ((pa & (PMAP_TNC_4 & ~PMAP_NC)) == 0 && pv) {
(void) pv_syncflags4_4c(pv);
-#ifdef PMAP_NEW
- ret = pv->pv_flags & PV_MOD;
-#endif
pv->pv_flags &= ~PV_MOD;
}
-#ifdef PMAP_NEW
- return ret;
-#endif
}
/*
* Tell whether the given physical page has been modified.
*/
-#ifdef PMAP_NEW
-boolean_t
-pmap_is_modified4_4c(pg)
- struct vm_page *pg;
-#else
int
pmap_is_modified4_4c(pa)
paddr_t pa;
-#endif
{
struct pvlist *pv;
-#ifdef PMAP_NEW
- paddr_t pa = VM_PAGE_TO_PHYS(pg);
-#endif
pv = pvhead(atop(pa));
if ((pa & (PMAP_TNC_4 & ~PMAP_NC)) == 0 && pv) {
@@ -6079,52 +5937,27 @@ pmap_is_modified4_4c(pa)
/*
* Clear the reference bit for the given physical page.
*/
-#ifdef PMAP_NEW
-boolean_t
-pmap_clear_reference4_4c(pg)
- struct vm_page *pg;
-#else
void
pmap_clear_reference4_4c(pa)
paddr_t pa;
-#endif
{
struct pvlist *pv;
-#ifdef PMAP_NEW
- paddr_t pa = VM_PAGE_TO_PHYS(pg);
- boolean_t ret = 0;
-#endif
pv = pvhead(atop(pa));
if ((pa & (PMAP_TNC_4 & ~PMAP_NC)) == 0 && pv) {
(void) pv_syncflags4_4c(pv);
-#ifdef PMAP_NEW
- ret = pv->pv_flags & PV_REF;
-#endif
pv->pv_flags &= ~PV_REF;
}
-#ifdef PMAP_NEW
- return ret;
-#endif
}
/*
* Tell whether the given physical page has been referenced.
*/
-#ifdef PMAP_NEW
-boolean_t
-pmap_is_referenced4_4c(pg)
- struct vm_page *pg;
-#else
int
pmap_is_referenced4_4c(pa)
paddr_t pa;
-#endif
{
struct pvlist *pv;
-#ifdef PMAP_NEW
- paddr_t pa = VM_PAGE_TO_PHYS(pg);
-#endif
pv = pvhead(atop(pa));
if ((pa & (PMAP_TNC_4 & ~PMAP_NC)) == 0 && pv) {
@@ -6149,52 +5982,27 @@ pmap_is_referenced4_4c(pa)
/*
* Clear the modify bit for the given physical page.
*/
-#ifdef PMAP_NEW
-boolean_t
-pmap_clear_modify4m(pg)
- struct vm_page *pg;
-#else
void
pmap_clear_modify4m(pa) /* XXX %%%: Should service from swpagetbl for 4m */
paddr_t pa;
-#endif
{
struct pvlist *pv;
-#ifdef PMAP_NEW
- paddr_t pa = VM_PAGE_TO_PHYS(pg);
- boolean_t ret = 0;
-#endif
pv = pvhead(atop(pa));
if ((pa & (PMAP_TNC_SRMMU & ~PMAP_NC)) == 0 && pv) {
(void) pv_syncflags4m(pv);
-#ifdef PMAP_NEW
- ret = pv->pv_flags & PV_MOD4M;
-#endif
pv->pv_flags &= ~PV_MOD4M;
}
-#ifdef PMAP_NEW
- return ret;
-#endif
}
/*
* Tell whether the given physical page has been modified.
*/
-#ifdef PMAP_NEW
-boolean_t
-pmap_is_modified4m(pg)
- struct vm_page *pg;
-#else
int
pmap_is_modified4m(pa) /* Test performance with SUN4M && SUN4/4C. XXX */
paddr_t pa;
-#endif
{
struct pvlist *pv;
-#ifdef PMAP_NEW
- paddr_t pa = VM_PAGE_TO_PHYS(pg);
-#endif
pv = pvhead(atop(pa));
if ((pa & (PMAP_TNC_SRMMU & ~PMAP_NC)) == 0 && pv) {
@@ -6207,50 +6015,27 @@ pmap_is_modified4m(pa) /* Test performance with SUN4M && SUN4/4C. XXX */
/*
* Clear the reference bit for the given physical page.
*/
-#ifdef PMAP_NEW
-boolean_t
-pmap_clear_reference4m(pg)
- struct vm_page *pg;
-#else
void
pmap_clear_reference4m(pa)
paddr_t pa;
-#endif
{
struct pvlist *pv;
-#ifdef PMAP_NEW
- paddr_t pa = VM_PAGE_TO_PHYS(pg);
- boolean_t ret = 0;
-#endif
pv = pvhead(atop(pa));
if ((pa & (PMAP_TNC_SRMMU & ~PMAP_NC)) == 0 && pv) {
(void) pv_syncflags4m(pv);
-#ifdef PMAP_NEW
- ret = pv->pv_flags & PV_REF4M;
-#endif
pv->pv_flags &= ~PV_REF4M;
}
- return ret;
}
/*
* Tell whether the given physical page has been referenced.
*/
-#ifdef PMAP_NEW
-boolean_t
-pmap_is_referenced4m(pg)
- struct vm_page *pg;
-#else
int
pmap_is_referenced4m(pa)
paddr_t pa;
-#endif
{
struct pvlist *pv;
-#ifdef PMAP_NEW
- paddr_t pa = VM_PAGE_TO_PHYS(pg);
-#endif
pv = pvhead(atop(pa));
if ((pa & (PMAP_TNC_SRMMU & ~PMAP_NC)) == 0 && pv) {