summaryrefslogtreecommitdiffstats
path: root/fs/ceph/addr.c
diff options
context:
space:
mode:
authorYehuda Sadeh <yehuda@hq.newdream.net>2009-12-16 14:51:06 -0800
committerSage Weil <sage@newdream.net>2009-12-21 16:39:56 -0800
commitdbd646a851713bec5bfff40ecf624b2e78518fe5 (patch)
treee5c4e141b7ec03ed5d2766a6909b1f48a5ec6519 /fs/ceph/addr.c
parent169e16ce816ca417286daf1db25de424a9d65a0c (diff)
downloadlinux-dbd646a851713bec5bfff40ecf624b2e78518fe5.tar.gz
linux-dbd646a851713bec5bfff40ecf624b2e78518fe5.tar.bz2
linux-dbd646a851713bec5bfff40ecf624b2e78518fe5.zip
ceph: writepage grabs and releases inode
Fixes a deadlock that is triggered due to kswapd, while the page was locked and the iput couldn't tear down the address space. Signed-off-by: Yehuda Sadeh <yehuda@hq.newdream.net>
Diffstat (limited to 'fs/ceph/addr.c')
-rw-r--r--fs/ceph/addr.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/fs/ceph/addr.c b/fs/ceph/addr.c
index bf535815592d..d0cdceb0b90b 100644
--- a/fs/ceph/addr.c
+++ b/fs/ceph/addr.c
@@ -448,8 +448,13 @@ out:
static int ceph_writepage(struct page *page, struct writeback_control *wbc)
{
- int err = writepage_nounlock(page, wbc);
+ int err;
+ struct inode *inode = page->mapping->host;
+ BUG_ON(!inode);
+ igrab(inode);
+ err = writepage_nounlock(page, wbc);
unlock_page(page);
+ iput(inode);
return err;
}