Make i386_set_ldt work on i386/XEN, step 1/5.
Lock the vm page queue mutex around calls to pte_store. As with many other uses of the vm page queue mutex in i386/xen/pmap.c, this is bogus and needs to be replaced at some future date by a spin lock dedicated to protecting the queue of pending xen page mapping hypervisor calls. (But for now, bogus locking is better than a panic.) MFC after: 3 days
This commit is contained in:
parent
58ffb73ca3
commit
d262f2dcfc
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=216843
@ -3647,7 +3647,9 @@ pmap_map_readonly(pmap_t pmap, vm_offset_t va, int len)
|
||||
for (i = 0; i < npages; i++) {
|
||||
pt_entry_t *pte;
|
||||
pte = pmap_pte(pmap, (vm_offset_t)(va + i*PAGE_SIZE));
|
||||
vm_page_lock_queues();
|
||||
pte_store(pte, xpmap_mtop(*pte & ~(PG_RW|PG_M)));
|
||||
vm_page_unlock_queues();
|
||||
PMAP_MARK_PRIV(xpmap_mtop(*pte));
|
||||
pmap_pte_release(pte);
|
||||
}
|
||||
@ -3661,7 +3663,9 @@ pmap_map_readwrite(pmap_t pmap, vm_offset_t va, int len)
|
||||
pt_entry_t *pte;
|
||||
pte = pmap_pte(pmap, (vm_offset_t)(va + i*PAGE_SIZE));
|
||||
PMAP_MARK_UNPRIV(xpmap_mtop(*pte));
|
||||
vm_page_lock_queues();
|
||||
pte_store(pte, xpmap_mtop(*pte) | (PG_RW|PG_M));
|
||||
vm_page_unlock_queues();
|
||||
pmap_pte_release(pte);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user