summaryrefslogtreecommitdiffstats
path: root/sys
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>2004-07-18 21:19:10 +0000
committeralc <alc@FreeBSD.org>2004-07-18 21:19:10 +0000
commit8fe12ef8db88fe5b261b6c7b14bbc330def59245 (patch)
tree808222ebb56df2b8a000b49ac6d467af567e1429 /sys
parent36406aeaf385ec59d079801fe282cffe37b01ead (diff)
downloadFreeBSD-src-8fe12ef8db88fe5b261b6c7b14bbc330def59245.zip
FreeBSD-src-8fe12ef8db88fe5b261b6c7b14bbc330def59245.tar.gz
Utilize pmap_pte_quick() rather than pmap_pte() in pmap_protect(). The
reason being that pmap_pte_quick() requires the page queues lock, which is already held, rather than Giant.
Diffstat (limited to 'sys')
-rw-r--r--sys/i386/i386/pmap.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/sys/i386/i386/pmap.c b/sys/i386/i386/pmap.c
index bbb4be3..5a4af6a 100644
--- a/sys/i386/i386/pmap.c
+++ b/sys/i386/i386/pmap.c
@@ -1805,6 +1805,7 @@ pmap_protect(pmap_t pmap, vm_offset_t sva, vm_offset_t eva, vm_prot_t prot)
anychanged = 0;
vm_page_lock_queues();
+ sched_pin();
PMAP_LOCK(pmap);
for (; sva < eva; sva = pdnxt) {
unsigned pdirindex;
@@ -1839,7 +1840,7 @@ pmap_protect(pmap_t pmap, vm_offset_t sva, vm_offset_t eva, vm_prot_t prot)
pt_entry_t *pte;
vm_page_t m;
- if ((pte = pmap_pte(pmap, sva)) == NULL)
+ if ((pte = pmap_pte_quick(pmap, sva)) == NULL)
continue;
pbits = *pte;
if (pbits & PG_MANAGED) {
@@ -1868,6 +1869,7 @@ pmap_protect(pmap_t pmap, vm_offset_t sva, vm_offset_t eva, vm_prot_t prot)
}
if (anychanged)
pmap_invalidate_all(pmap);
+ sched_unpin();
vm_page_unlock_queues();
PMAP_UNLOCK(pmap);
}
OpenPOWER on IntegriCloud