eventfs: Have eventfs_iterate() stop immediately if ei->is_freed is set
authorSteven Rostedt (Google) <rostedt@goodmis.org>
Thu, 4 Jan 2024 21:57:12 +0000 (16:57 -0500)
committerSteven Rostedt (Google) <rostedt@goodmis.org>
Thu, 4 Jan 2024 22:11:57 +0000 (17:11 -0500)
commite109deadb73318cf4a3bd61287d969f705df278f
tree0a62348a5aeb58034c055bb97be8ba08f90475d5
parent8186fff7ab649085e2c60d032d9a20a85af1d87c
eventfs: Have eventfs_iterate() stop immediately if ei->is_freed is set

If ei->is_freed is set in eventfs_iterate(), it means that the directory
that is being iterated on is in the process of being freed. Just exit the
loop immediately when that is ever detected, and separate out the return
of the entry->callback() from ei->is_freed.

Link: https://lore.kernel.org/linux-trace-kernel/20240104220048.016261289@goodmis.org
Cc: Masami Hiramatsu <mhiramat@kernel.org>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Al Viro <viro@zeniv.linux.org.uk>
Cc: Christian Brauner <brauner@kernel.org>
Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Steven Rostedt (Google) <rostedt@goodmis.org>
fs/tracefs/event_inode.c