summaryrefslogtreecommitdiff
path: root/lib/kobject.c
diff options
context:
space:
mode:
authorIan Kent <raven@themaw.net>2022-10-18 10:32:49 +0800
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2022-10-20 13:54:31 +0200
commit92b57842f43014e6ca81ddf6d5d59e9ddf762e12 (patch)
tree98f87028177b7abd25c8a0cd7866bac87996b0a1 /lib/kobject.c
parentaa1d058d48f292aa138e33ad12b7b4d18b5407cd (diff)
kernfs: dont take i_lock on revalidate
In kernfs_dop_revalidate() when the passed in dentry is negative the dentry directory is checked to see if it has changed and if so the negative dentry is discarded so it can refreshed. During this check the dentry inode i_lock is taken to mitigate against a possible concurrent rename. But if it's racing with a rename, becuase the dentry is negative, it can't be the source it must be the target and it must be going to do a d_move() otherwise the rename will return an error. In this case the parent dentry of the target will not change, it will be the same over the d_move(), only the source dentry parent may change so the inode i_lock isn't needed. Cc: Tejun Heo <tj@kernel.org> Signed-off-by: Ian Kent <raven@themaw.net> Link: https://lore.kernel.org/r/166606036967.13363.9336408133975631967.stgit@donald.themaw.net Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'lib/kobject.c')
0 files changed, 0 insertions, 0 deletions