summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/hppa/hppa/pmap.c37
1 files changed, 29 insertions, 8 deletions
diff --git a/sys/arch/hppa/hppa/pmap.c b/sys/arch/hppa/hppa/pmap.c
index 3ed57ce6e53..b26777d60f8 100644
--- a/sys/arch/hppa/hppa/pmap.c
+++ b/sys/arch/hppa/hppa/pmap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmap.c,v 1.26 1999/11/25 17:34:32 mickey Exp $ */
+/* $OpenBSD: pmap.c,v 1.27 1999/11/25 17:39:46 mickey Exp $ */
/*
* Copyright (c) 1998,1999 Michael Shalayeff
@@ -588,13 +588,16 @@ pmap_clear_pv(paddr_t pa, struct pv_entry *cpv)
printf("pmap_clear_pv(%x,%p)\n", pa, cpv);
#endif
- if (!(pv = pmap_find_pv(pa)))
+ if (!(pv = pmap_find_pv(pa)) || !pv->pv_pmap)
return;
s = splimp();
for (; pv; pv = pv->pv_next) {
if (pv == cpv)
continue;
+#ifdef PMAPDEBUG
+ printf("pmap_clear_pv: %x:%x\n", pv->pv_space, pv->pv_va);
+#endif
/*
* have to clear the icache first since fic uses the dtlb.
*/
@@ -1142,7 +1145,12 @@ pmap_page_protect(pg, prot)
case VM_PROT_READ:
case VM_PROT_READ|VM_PROT_EXECUTE:
s = splimp();
- for (pv = pmap_find_pv(pa); pv; pv = pv->pv_next) {
+ if (!(pv = pmap_find_pv(pa)) || !pv->pv_pmap) {
+ splx(s);
+ break;
+ }
+
+ for ( ; pv; pv = pv->pv_next) {
/*
* Compare new protection with old to see if
* anything needs to be changed.
@@ -1413,7 +1421,7 @@ pmap_clear_modify(pg)
#endif
s = splimp();
- if (!(pv = pmap_find_pv(pa))) {
+ if (!(pv = pmap_find_pv(pa)) || !pv->pv_pmap) {
splx(s);
return FALSE;
}
@@ -1447,7 +1455,12 @@ pmap_is_modified(pg)
printf("pmap_is_modified(%x)\n", pa);
#endif
s = splhigh();
- for (pv = pmap_find_pv(pa); pv && !(pv->pv_tlbprot & TLB_DIRTY);)
+ if (!(pv = pmap_find_pv(pa)) || !pv->pv_pmap) {
+ splx(s);
+ return FALSE;
+ }
+
+ for (; pv && !(pv->pv_tlbprot & TLB_DIRTY);)
pv = pv->pv_next;
splx(s);
@@ -1511,7 +1524,12 @@ pmap_is_referenced(pg)
#endif
s = splhigh();
- for (pv = pmap_find_pv(pa); pv && !(pv->pv_tlbprot & TLB_REF);)
+ if (!(pv = pmap_find_pv(pa)) || !pv->pv_pmap) {
+ splx(s);
+ return FALSE;
+ }
+
+ for (; pv && !(pv->pv_tlbprot & TLB_REF);)
pv = pv->pv_next;
splx(s);
@@ -1526,9 +1544,12 @@ pmap_changebit(pa, set, reset)
register struct pv_entry *pv;
int s;
- pv = pmap_find_pv(pa);
-
s = splimp();
+ if (!(pv = pmap_find_pv(pa)) || !pv->pv_pmap) {
+ splx(s);
+ return;
+ }
+
while (pv) {
pv->pv_tlbprot |= set;
pv->pv_tlbprot &= ~reset;