summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2001-08-12 19:28:39 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2001-08-12 19:28:39 +0000
commit5233cb221d37d2ce3690bcaf11ae129e8e17f9b7 (patch)
treeeb6a918defb64693cff59ddda40b339b9b10284c /sys
parent6de55785316db6b018141b07e4dd3ddd7ef49945 (diff)
Replace VM_{MAX,MIN}_USER_ADDRESS with VM_{MAX,MIN}_ADDRESS.
Change a while() loop with a clearer for() loop. Fix pmap_page_protect to correctly handle the VM_PROT_READ|VM_PROT_WRITE case.
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/mvme88k/mvme88k/pmap.c27
1 files changed, 13 insertions, 14 deletions
diff --git a/sys/arch/mvme88k/mvme88k/pmap.c b/sys/arch/mvme88k/mvme88k/pmap.c
index 6251479227d..580820d3a7f 100644
--- a/sys/arch/mvme88k/mvme88k/pmap.c
+++ b/sys/arch/mvme88k/mvme88k/pmap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmap.c,v 1.38 2001/08/12 00:17:45 miod Exp $ */
+/* $OpenBSD: pmap.c,v 1.39 2001/08/12 19:28:38 miod Exp $ */
/*
* Copyright (c) 1996 Nivas Madhur
* All rights reserved.
@@ -1597,11 +1597,11 @@ pmap_free_tables(pmap_t pmap)
sdttbl = pmap->sdt_vaddr; /* addr of segment table */
/*
This contortion is here instead of the natural loop
- because of integer overflow/wraparound if VM_MAX_USER_ADDRESS
+ because of integer overflow/wraparound if VM_MAX_ADDRESS
is near 0xffffffff
*/
- i = VM_MIN_USER_ADDRESS / PDT_TABLE_GROUP_VA_SPACE;
- j = VM_MAX_USER_ADDRESS / PDT_TABLE_GROUP_VA_SPACE;
+ i = VM_MIN_ADDRESS / PDT_TABLE_GROUP_VA_SPACE;
+ j = VM_MAX_ADDRESS / PDT_TABLE_GROUP_VA_SPACE;
if ( j < 1024 ) j++;
/* Segment table Loop */
@@ -3018,17 +3018,17 @@ pmap_collect(pmap_t pmap)
/*
This contortion is here instead of the natural loop
- because of integer overflow/wraparound if VM_MAX_USER_ADDRESS
+ because of integer overflow/wraparound if VM_MAX_ADDRESS
is near 0xffffffff
*/
- i = VM_MIN_USER_ADDRESS / PDT_TABLE_GROUP_VA_SPACE;
- j = VM_MAX_USER_ADDRESS / PDT_TABLE_GROUP_VA_SPACE;
+ i = VM_MIN_ADDRESS / PDT_TABLE_GROUP_VA_SPACE;
+ j = VM_MAX_ADDRESS / PDT_TABLE_GROUP_VA_SPACE;
if ( j < 1024 ) j++;
/* Segment table loop */
for ( ; i < j; i++, sdtp += PDT_TABLE_GROUP_SIZE) {
- sdt_va = VM_MIN_USER_ADDRESS + PDT_TABLE_GROUP_VA_SPACE*i;
+ sdt_va = VM_MIN_ADDRESS + PDT_TABLE_GROUP_VA_SPACE*i;
gdttbl = pmap_pte(pmap, (vm_offset_t)sdt_va);
@@ -3051,9 +3051,9 @@ pmap_collect(pmap_t pmap)
/* figure out end of range. Watch for wraparound */
- sdt_vt = sdt_va <= VM_MAX_USER_ADDRESS-PDT_TABLE_GROUP_VA_SPACE ?
+ sdt_vt = sdt_va <= VM_MAX_ADDRESS-PDT_TABLE_GROUP_VA_SPACE ?
sdt_va+PDT_TABLE_GROUP_VA_SPACE :
- VM_MAX_USER_ADDRESS;
+ VM_MAX_ADDRESS;
/* invalidate all maps in this range */
pmap_remove_range (pmap, (vm_offset_t)sdt_va,(vm_offset_t)sdt_vt);
@@ -3356,8 +3356,7 @@ clear_modify_Retry:
}
/* for each listed pmap, turn off the page modified bit */
- pvep = pvl;
- while (pvep != PV_ENTRY_NULL) {
+ for (pvep = pvl; pvep != PV_ENTRY_NULL; pvep = pvep->next) {
pmap = pvep->pmap;
va = pvep->va;
if (!simple_lock_try(&pmap->lock)) {
@@ -3388,7 +3387,6 @@ clear_modify_Retry:
splx(spl_sav);
simple_unlock(&pmap->lock);
- pvep = pvep->next;
}
UNLOCK_PVH(phys);
SPLX(spl);
@@ -3714,6 +3712,7 @@ pmap_page_protect(struct vm_page *pg, vm_prot_t prot)
case VM_PROT_READ|VM_PROT_EXECUTE:
pmap_copy_on_write(phys);
break;
+ case VM_PROT_READ|VM_PROT_WRITE:
case VM_PROT_ALL:
break;
default:
@@ -4163,7 +4162,7 @@ check_pmap_consistency(char *who)
printf("check_pmap_consistency: pmap struct loop error.\n");
panic(who);
}
- check_map(p, VM_MIN_USER_ADDRESS, VM_MAX_USER_ADDRESS, who);
+ check_map(p, VM_MIN_ADDRESS, VM_MAX_ADDRESS, who);
}
/* run through all managed paes, check pv_list for each one */