diff options
| author | Alan Cox <alc@FreeBSD.org> | 2002-07-28 19:01:38 +0000 |
|---|---|---|
| committer | Alan Cox <alc@FreeBSD.org> | 2002-07-28 19:01:38 +0000 |
| commit | 6a684ecf05fc7da0e405e81cd2b425d7436d1ee4 (patch) | |
| tree | 73bdd0e7361ad63be3ada3a444382b8703934375 | |
| parent | 0f258b75d39faa5b367174a19c139aea445da841 (diff) | |
Notes
| -rw-r--r-- | sys/vm/vm_object.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/sys/vm/vm_object.c b/sys/vm/vm_object.c index 25c53ec7e4f3..9dd3df7027db 100644 --- a/sys/vm/vm_object.c +++ b/sys/vm/vm_object.c @@ -1435,8 +1435,10 @@ vm_object_backing_scan(vm_object_t object, int op) * Page is out of the parent object's range, we * can simply destroy it. */ + vm_page_lock_queues(); vm_page_protect(p, VM_PROT_NONE); vm_page_free(p); + vm_page_unlock_queues(); p = next; continue; } @@ -1453,8 +1455,10 @@ vm_object_backing_scan(vm_object_t object, int op) * * Leave the parent's page alone */ + vm_page_lock_queues(); vm_page_protect(p, VM_PROT_NONE); vm_page_free(p); + vm_page_unlock_queues(); p = next; continue; } @@ -1756,10 +1760,11 @@ again: if (p->valid & p->dirty) continue; } - + vm_page_lock_queues(); vm_page_busy(p); vm_page_protect(p, VM_PROT_NONE); vm_page_free(p); + vm_page_unlock_queues(); } } } else { @@ -1790,10 +1795,11 @@ again: continue; } } - + vm_page_lock_queues(); vm_page_busy(p); vm_page_protect(p, VM_PROT_NONE); vm_page_free(p); + vm_page_unlock_queues(); } start += 1; size -= 1; |
