diff options
author | Steven Rostedt (Google) <rostedt@goodmis.org> | 2023-11-01 13:25:49 -0400 |
---|---|---|
committer | Steven Rostedt (Google) <rostedt@goodmis.org> | 2023-11-02 00:18:36 -0400 |
commit | 407c6726ca71b33330d2d6345d9ea7ebc02575e9 (patch) | |
tree | 5d330a8d18e7a6b99a592727eaf9007d728ba622 /lib/seq_buf.c | |
parent | 62d65cac119d08d39f751b4e3e2063ed996edc05 (diff) | |
download | lwn-407c6726ca71b33330d2d6345d9ea7ebc02575e9.tar.gz lwn-407c6726ca71b33330d2d6345d9ea7ebc02575e9.zip |
eventfs: Use simple_recursive_removal() to clean up dentries
Looking at how dentry is removed via the tracefs system, I found that
eventfs does not do everything that it did under tracefs. The tracefs
removal of a dentry calls simple_recursive_removal() that does a lot more
than a simple d_invalidate().
As it should be a requirement that any eventfs_inode that has a dentry, so
does its parent. When removing a eventfs_inode, if it has a dentry, a call
to simple_recursive_removal() on that dentry should clean up all the
dentries underneath it.
Add WARN_ON_ONCE() to check for the parent having a dentry if any children
do.
Link: https://lore.kernel.org/all/20231101022553.GE1957730@ZenIV/
Link: https://lkml.kernel.org/r/20231101172650.552471568@goodmis.org
Cc: stable@vger.kernel.org
Cc: Masami Hiramatsu <mhiramat@kernel.org>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Fixes: 5bdcd5f5331a2 ("eventfs: Implement removal of meta data from eventfs")
Signed-off-by: Steven Rostedt (Google) <rostedt@goodmis.org>
Diffstat (limited to 'lib/seq_buf.c')
0 files changed, 0 insertions, 0 deletions