mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-19 15:33:56 +00:00
Another long standing vm bug found at Isilon:
Fix a race between vm_object_collapse and vm_fault. Reviewed by: alc@ MFC after: 3 days
This commit is contained in:
parent
4c83f2f32b
commit
e18cc7bf3e
Notes:
svn2git
2020-12-20 02:59:44 +00:00
svn path=/head/; revision=221714
@ -1467,6 +1467,24 @@ vm_object_backing_scan(vm_object_t object, int op)
|
||||
}
|
||||
|
||||
pp = vm_page_lookup(object, new_pindex);
|
||||
if (
|
||||
(op & OBSC_COLLAPSE_NOWAIT) != 0 &&
|
||||
(pp != NULL && pp->valid == 0)
|
||||
) {
|
||||
/*
|
||||
* The page in the parent is not (yet) valid.
|
||||
* We don't know anything about the state of
|
||||
* the original page. It might be mapped,
|
||||
* so we must avoid the next if here.
|
||||
*
|
||||
* This is due to a race in vm_fault() where
|
||||
* we must unbusy the original (backing_obj)
|
||||
* page before we can (re)lock the parent.
|
||||
* Hence we can get here.
|
||||
*/
|
||||
p = next;
|
||||
continue;
|
||||
}
|
||||
if (
|
||||
pp != NULL ||
|
||||
vm_pager_has_page(object, new_pindex, NULL, NULL)
|
||||
|
Loading…
Reference in New Issue
Block a user