summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>2003-04-19 22:11:41 +0000
committeralc <alc@FreeBSD.org>2003-04-19 22:11:41 +0000
commitdc48d3db81e4e6fe22622e0d7918174a41a9e4e8 (patch)
treed9d7d5c327a08db059b8b872181c6a659ee359ca
parentef4e8a19cfc9fb054dbda2b5efdaef60ef82438c (diff)
downloadFreeBSD-src-dc48d3db81e4e6fe22622e0d7918174a41a9e4e8.zip
FreeBSD-src-dc48d3db81e4e6fe22622e0d7918174a41a9e4e8.tar.gz
- Lock the vm_object when performing vm_object_pip_subtract().
- Assert that the vm_object lock is held in vm_object_pip_subtract().
-rw-r--r--sys/kern/vfs_bio.c3
-rw-r--r--sys/vm/swap_pager.c4
-rw-r--r--sys/vm/vm_object.c1
3 files changed, 7 insertions, 1 deletions
diff --git a/sys/kern/vfs_bio.c b/sys/kern/vfs_bio.c
index 4125781..6fba76f 100644
--- a/sys/kern/vfs_bio.c
+++ b/sys/kern/vfs_bio.c
@@ -3106,6 +3106,8 @@ bufdone(struct buf *bp)
KASSERT(bp->b_offset != NOOFFSET,
("biodone: no buffer offset"));
+ if (obj != NULL)
+ VM_OBJECT_LOCK(obj);
#if defined(VFS_BIO_DEBUG)
if (obj->paging_in_progress < bp->b_npages) {
printf("biodone: paging in progress(%d) < bp->b_npages(%d)\n",
@@ -3194,7 +3196,6 @@ bufdone(struct buf *bp)
}
vm_page_unlock_queues();
if (obj != NULL) {
- VM_OBJECT_LOCK(obj);
vm_object_pip_wakeupn(obj, 0);
VM_OBJECT_UNLOCK(obj);
}
diff --git a/sys/vm/swap_pager.c b/sys/vm/swap_pager.c
index 997e682..2adaf6f 100644
--- a/sys/vm/swap_pager.c
+++ b/sys/vm/swap_pager.c
@@ -1693,7 +1693,9 @@ swp_pager_force_pagein(struct swblock *swap, int idx)
vm_object_pip_add(object, 1);
m = vm_page_grab(object, pindex + idx, VM_ALLOC_NORMAL|VM_ALLOC_RETRY);
if (m->valid == VM_PAGE_BITS_ALL) {
+ VM_OBJECT_LOCK(object);
vm_object_pip_subtract(object, 1);
+ VM_OBJECT_UNLOCK(object);
vm_page_lock_queues();
vm_page_activate(m);
vm_page_dirty(m);
@@ -1706,7 +1708,9 @@ swp_pager_force_pagein(struct swblock *swap, int idx)
if (swap_pager_getpages(object, &m, 1, 0) !=
VM_PAGER_OK)
panic("swap_pager_force_pagein: read from swap failed");/*XXX*/
+ VM_OBJECT_LOCK(object);
vm_object_pip_subtract(object, 1);
+ VM_OBJECT_UNLOCK(object);
vm_page_lock_queues();
vm_page_dirty(m);
diff --git a/sys/vm/vm_object.c b/sys/vm/vm_object.c
index 4f784b0..2a8a2ce 100644
--- a/sys/vm/vm_object.c
+++ b/sys/vm/vm_object.c
@@ -277,6 +277,7 @@ void
vm_object_pip_subtract(vm_object_t object, short i)
{
GIANT_REQUIRED;
+ VM_OBJECT_LOCK_ASSERT(object, MA_OWNED);
object->paging_in_progress -= i;
}
OpenPOWER on IntegriCloud