summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>2003-08-06 18:46:47 +0000
committeralc <alc@FreeBSD.org>2003-08-06 18:46:47 +0000
commit897888308a10e605749d26518864735e61f935f1 (patch)
tree4021d7d257aed9db82e6e067ccf8a3dc28b278a4
parent365502988206c9c05f5c0f902aeca3d570488284 (diff)
downloadFreeBSD-src-897888308a10e605749d26518864735e61f935f1.zip
FreeBSD-src-897888308a10e605749d26518864735e61f935f1.tar.gz
Acquire the page queues lock in pmap_insert_entry(). (I used to believe
that the page's busy flag could be relied upon to synchronize access to the pv list. I don't any longer. See, for example, the call to pmap_insert_entry() from pmap_copy().)
-rw-r--r--sys/i386/i386/pmap.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/sys/i386/i386/pmap.c b/sys/i386/i386/pmap.c
index 4da8911..e0daeb9 100644
--- a/sys/i386/i386/pmap.c
+++ b/sys/i386/i386/pmap.c
@@ -1592,6 +1592,7 @@ pmap_insert_entry(pmap_t pmap, vm_offset_t va, vm_page_t mpte, vm_page_t m)
pv_entry_t pv;
s = splvm();
+ vm_page_lock_queues();
pv = get_pv_entry();
pv->pv_va = va;
pv->pv_pmap = pmap;
@@ -1601,6 +1602,7 @@ pmap_insert_entry(pmap_t pmap, vm_offset_t va, vm_page_t mpte, vm_page_t m)
TAILQ_INSERT_TAIL(&m->md.pv_list, pv, pv_list);
m->md.pv_list_count++;
+ vm_page_unlock_queues();
splx(s);
}
OpenPOWER on IntegriCloud