]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/commitdiff
ceph: use ihold() when i_lock is held
authorSage Weil <sage@newdream.net>
Tue, 3 May 2011 16:28:08 +0000 (09:28 -0700)
committerSage Weil <sage@newdream.net>
Tue, 3 May 2011 16:28:08 +0000 (09:28 -0700)
See 0444d76ae64fffc7851797fc1b6ebdbb44ac504a.

Signed-off-by: Sage Weil <sage@newdream.net>
fs/ceph/caps.c

index 5323c330bbf3d4acad87fe6a48701b9ee7f27589..010ba9c52e9b691a1ff84cfd950cca50d8043fae 100644 (file)
@@ -1357,7 +1357,7 @@ void __ceph_mark_dirty_caps(struct ceph_inode_info *ci, int mask)
                list_add(&ci->i_dirty_item, &mdsc->cap_dirty);
                spin_unlock(&mdsc->cap_dirty_lock);
                if (ci->i_flushing_caps == 0) {
-                       igrab(inode);
+                       ihold(inode);
                        dirty |= I_DIRTY_SYNC;
                }
        }
@@ -1991,7 +1991,7 @@ static void __take_cap_refs(struct ceph_inode_info *ci, int got)
                ci->i_wr_ref++;
        if (got & CEPH_CAP_FILE_BUFFER) {
                if (ci->i_wrbuffer_ref == 0)
-                       igrab(&ci->vfs_inode);
+                       ihold(&ci->vfs_inode);
                ci->i_wrbuffer_ref++;
                dout("__take_cap_refs %p wrbuffer %d -> %d (?)\n",
                     &ci->vfs_inode, ci->i_wrbuffer_ref-1, ci->i_wrbuffer_ref);