diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2001-08-12 19:28:39 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2001-08-12 19:28:39 +0000 |
commit | 5233cb221d37d2ce3690bcaf11ae129e8e17f9b7 (patch) | |
tree | eb6a918defb64693cff59ddda40b339b9b10284c /sys | |
parent | 6de55785316db6b018141b07e4dd3ddd7ef49945 (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.c | 27 |
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 */ |