diff options
author | Darrick J. Wong <darrick.wong@oracle.com> | 2020-10-25 17:15:51 -0700 |
---|---|---|
committer | Darrick J. Wong <darrick.wong@oracle.com> | 2020-10-26 18:32:25 -0700 |
commit | 63e82146ad0e062258892ed36afe1e4afb0c01c3 (patch) | |
tree | f0d371d67f2cdcc40015eb51caa40b3989e7ff7d /fs/xfs/scrub/parent_repair.c | |
parent | 3c543bb2bd33146991a10cb070c449f006c88e45 (diff) |
xfs: parent repair should try the dcache first
If we need to find a directory's parent, try the dcache first.
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Diffstat (limited to 'fs/xfs/scrub/parent_repair.c')
-rw-r--r-- | fs/xfs/scrub/parent_repair.c | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/fs/xfs/scrub/parent_repair.c b/fs/xfs/scrub/parent_repair.c index 9dc48d496af6..aa196acb5600 100644 --- a/fs/xfs/scrub/parent_repair.c +++ b/fs/xfs/scrub/parent_repair.c @@ -172,6 +172,37 @@ out_rele: return error; } +/* Does the dcache have a parent for this directory? */ +xfs_ino_t +xrep_parent_check_dcache( + struct xfs_inode *dp) +{ + struct inode *pip = NULL; + struct dentry *dentry, *parent; + xfs_ino_t ret = NULLFSINO; + + ASSERT(S_ISDIR(VFS_I(dp)->i_mode)); + + dentry = d_find_alias(VFS_I(dp)); + if (!dentry) + goto out; + + parent = dget_parent(dentry); + if (!parent) + goto out_dput; + + pip = igrab(d_inode(parent)); + dput(parent); + + ret = pip->i_ino; + xfs_irele(XFS_I(pip)); + +out_dput: + dput(dentry); +out: + return ret; +} + /* Is this an acceptable parent for the inode we're scrubbing? */ bool xrep_parent_acceptable( |