diff options
author | alc <alc@FreeBSD.org> | 2004-07-15 18:00:43 +0000 |
---|---|---|
committer | alc <alc@FreeBSD.org> | 2004-07-15 18:00:43 +0000 |
commit | 123cfa6b6464882431662931da12282fdae27c31 (patch) | |
tree | 69cdf9b62bb15fd8fb4fcd13d7dc53217029e5ad /sys/alpha | |
parent | c9b72f6bbfe07882de4c1ff97b23d8419bb01672 (diff) | |
download | FreeBSD-src-123cfa6b6464882431662931da12282fdae27c31.zip FreeBSD-src-123cfa6b6464882431662931da12282fdae27c31.tar.gz |
Push down the acquisition and release of the page queues lock into
pmap_protect() and pmap_remove(). In general, they require the lock in
order to modify a page's pv list or flags. In some cases, however,
pmap_protect() can avoid acquiring the lock.
Diffstat (limited to 'sys/alpha')
-rw-r--r-- | sys/alpha/alpha/pmap.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/sys/alpha/alpha/pmap.c b/sys/alpha/alpha/pmap.c index fdd2e95..6b5f252 100644 --- a/sys/alpha/alpha/pmap.c +++ b/sys/alpha/alpha/pmap.c @@ -1573,6 +1573,8 @@ pmap_remove(pmap_t pmap, vm_offset_t sva, vm_offset_t eva) */ if (pmap->pm_stats.resident_count == 0) return; + + vm_page_lock_queues(); PMAP_LOCK(pmap); /* @@ -1600,6 +1602,7 @@ pmap_remove(pmap_t pmap, vm_offset_t sva, vm_offset_t eva) nva = va + PAGE_SIZE; } out: + vm_page_unlock_queues(); PMAP_UNLOCK(pmap); } @@ -1700,6 +1703,7 @@ pmap_protect(pmap_t pmap, vm_offset_t sva, vm_offset_t eva, vm_prot_t prot) if ((sva & PAGE_MASK) || (eva & PAGE_MASK)) panic("pmap_protect: unaligned addresses"); + vm_page_lock_queues(); PMAP_LOCK(pmap); while (sva < eva) { @@ -1751,6 +1755,7 @@ pmap_protect(pmap_t pmap, vm_offset_t sva, vm_offset_t eva, vm_prot_t prot) sva += PAGE_SIZE; } + vm_page_unlock_queues(); PMAP_UNLOCK(pmap); } |