From ae685f981a6b00347e71cb566dc2477ec1f3e315 Mon Sep 17 00:00:00 2001 From: Erez Zadok Date: Mon, 11 Aug 2014 22:19:30 -0400 Subject: [PATCH] Unionfs: fix d_revalidate for corner case In some cases, lower_dentry may goes to NULL. Return 0 here to mark it as invalid dentry. Signed-off-by: Erez Zadok Signed-off-by: Mengyang Li --- fs/unionfs/dentry.c | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/fs/unionfs/dentry.c b/fs/unionfs/dentry.c index f5b461dbd80..ee5326defa4 100644 --- a/fs/unionfs/dentry.c +++ b/fs/unionfs/dentry.c @@ -316,6 +316,11 @@ static int unionfs_d_revalidate(struct dentry *dentry, parent = unionfs_lock_parent(dentry, UNIONFS_DMUTEX_PARENT); unionfs_lock_dentry(dentry, UNIONFS_DMUTEX_CHILD); + if (!unionfs_lower_dentry(dentry)) { + err = 0; + goto out; + } + valid = __unionfs_d_revalidate(dentry, parent, false); if (valid) { unionfs_postcopyup_setmnt(dentry); @@ -324,6 +329,7 @@ static int unionfs_d_revalidate(struct dentry *dentry, d_drop(dentry); err = valid; } +out: unionfs_unlock_dentry(dentry); unionfs_unlock_parent(dentry, parent); unionfs_read_unlock(dentry->d_sb); -- 2.34.1