I think this covers (fixes) the last batch of freeing active/held/busy page
problem. BY MISTAKE, the vm_page_unqueue (or equiv) was removed from the vm_fault code. Really bad things appear to happen if a page is on a queue while it is being faulted.
This commit is contained in:
parent
0c6fd6b34b
commit
2640e59c23
@ -66,7 +66,7 @@
|
||||
* any improvements or extensions that they make and grant Carnegie the
|
||||
* rights to redistribute these changes.
|
||||
*
|
||||
* $Id: vm_fault.c,v 1.44 1996/05/18 03:37:35 dyson Exp $
|
||||
* $Id: vm_fault.c,v 1.45 1996/05/19 07:36:45 dyson Exp $
|
||||
*/
|
||||
|
||||
/*
|
||||
@ -292,6 +292,8 @@ RetryFault:;
|
||||
goto RetryFault;
|
||||
}
|
||||
|
||||
vm_page_unqueue(m);
|
||||
|
||||
if (m->valid &&
|
||||
((m->valid & VM_PAGE_BITS_ALL) != VM_PAGE_BITS_ALL) &&
|
||||
m->object != kernel_object && m->object != kmem_object) {
|
||||
|
Loading…
Reference in New Issue
Block a user