Sunil Mushran
2009-Apr-21 04:34 UTC
[Ocfs2-devel] [PATCH 1/1] ocfs2: Add missing iput() during error handling in ocfs2_dentry_attach_lock()
In ocfs2_dentry_attach_lock(), if unable to get the dentry lock(), we need to call iput(inode) because a failure here means no d_instantiate(), which means the normally matching iput() will not be called during dput(dentry). This patch fixes the oops that accompanies the following message: (3996,1):dlm_empty_lockres:2708 ERROR: lockres W00000000000000000a1046b06a4382 still has local locks! kernel BUG in dlm_empty_lockres at /rpmbuild/smushran/BUILD/ocfs2-1.4.2/fs/ocfs2/dlm/dlmmaster.c:2709! Signed-off-by: Sunil Mushran <sunil.mushran at oracle.com> --- fs/ocfs2/dcache.c | 15 +++++++++++++++ 1 files changed, 15 insertions(+), 0 deletions(-) diff --git a/fs/ocfs2/dcache.c b/fs/ocfs2/dcache.c index 7d60448..b574431 100644 --- a/fs/ocfs2/dcache.c +++ b/fs/ocfs2/dcache.c @@ -290,6 +290,21 @@ out_attach: else mlog_errno(ret); + /* + * In case of error, manually free the allocation and do the iput(). + * We need to do this because error here means no d_instantiate(), + * which means iput() will not be called during dput(dentry). + */ + if (ret < 0 && !alias) { + ocfs2_lock_res_free(&dl->dl_lockres); + BUG_ON(dl->dl_count != 1); + spin_lock(&dentry_attach_lock); + dentry->d_fsdata = NULL; + spin_unlock(&dentry_attach_lock); + kfree(dl); + iput(inode); + } + dput(alias); return ret; -- 1.5.6.3
Mark Fasheh
2009-Apr-21 22:00 UTC
[Ocfs2-devel] [PATCH 1/1] ocfs2: Add missing iput() during error handling in ocfs2_dentry_attach_lock()
On Mon, Apr 20, 2009 at 09:34:18PM -0700, Sunil Mushran wrote:> In ocfs2_dentry_attach_lock(), if unable to get the dentry lock(), we need to > call iput(inode) because a failure here means no d_instantiate(), which means > the normally matching iput() will not be called during dput(dentry). > > This patch fixes the oops that accompanies the following message: > (3996,1):dlm_empty_lockres:2708 ERROR: lockres W00000000000000000a1046b06a4382 still has local locks! > kernel BUG in dlm_empty_lockres at /rpmbuild/smushran/BUILD/ocfs2-1.4.2/fs/ocfs2/dlm/dlmmaster.c:2709! > > Signed-off-by: Sunil Mushran <sunil.mushran at oracle.com>Acked-by: Mark Fasheh <mfasheh at suse.com> --Mark -- Mark Fasheh
Possibly Parallel Threads
- [PATCH 1/3] ocfs2: Add missing iput() during error handling in ocfs2_dentry_attach_lock()
- [GIT PULL] ocfs2 fixes
- [PATCH] ocfs2: flush dentry lock drop when sync ocfs2 volume.
- [PATCH v3] Btrfs: fix error check of btrfs_lookup_dentry()
- [PATCH] Btrfs: fix error check of btrfs_lookup_dentry()