This is a note to let you know that I've just added the patch titled eventfs: Have the inodes all for files and directories all be the same to the 6.7-stable tree which can be found at: http://www.kernel.org/git/?p=linux/kernel/git/stable/stable-queue.git;a=summary The filename of the patch is: eventfs-have-the-inodes-all-for-files-and-directories-all-be-the-same.patch and it can be found in the queue-6.7 subdirectory. If you, or anyone else, feels it should not be added to the stable tree, please let <stable@xxxxxxxxxxxxxxx> know about it. >From SRS0=eEWY=JP=rostedt.homelinux.com=rostedt@xxxxxxxxxx Tue Feb 6 12:35:24 2024 From: Steven Rostedt <rostedt@xxxxxxxxxxx> Date: Tue, 06 Feb 2024 06:32:06 -0500 Subject: eventfs: Have the inodes all for files and directories all be the same To: linux-kernel@xxxxxxxxxxxxxxx, stable@xxxxxxxxxxxxxxx Cc: Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx>, Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>, Sasha Levin <sashal@xxxxxxxxxx>, Masami Hiramatsu <mhiramat@xxxxxxxxxx>, Mark Rutland <mark.rutland@xxxxxxx>, Mathieu Desnoyers <mathieu.desnoyers@xxxxxxxxxxxx>, Christian Brauner <brauner@xxxxxxxxxx>, Al Viro <viro@xxxxxxxxxxxxxxxxxx>, Ajay Kaher <ajay.kaher@xxxxxxxxxxxx> Message-ID: <20240206113359.393228331@xxxxxxxxxxxxxxxxxxxxx> From: "Steven Rostedt (Google)" <rostedt@xxxxxxxxxxx> commit 53c41052ba3121761e6f62a813961164532a214f upstream. The dentries and inodes are created in the readdir for the sole purpose of getting a consistent inode number. Linus stated that is unnecessary, and that all inodes can have the same inode number. For a virtual file system they are pretty meaningless. Instead use a single unique inode number for all files and one for all directories. Link: https://lore.kernel.org/all/20240116133753.2808d45e@xxxxxxxxxxxxxxxxxx/ Link: https://lore.kernel.org/linux-trace-kernel/20240116211353.412180363@xxxxxxxxxxx Cc: Masami Hiramatsu <mhiramat@xxxxxxxxxx> Cc: Mark Rutland <mark.rutland@xxxxxxx> Cc: Mathieu Desnoyers <mathieu.desnoyers@xxxxxxxxxxxx> Cc: Christian Brauner <brauner@xxxxxxxxxx> Cc: Al Viro <viro@xxxxxxxxxxxxxxxxxx> Cc: Ajay Kaher <ajay.kaher@xxxxxxxxxxxx> Suggested-by: Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx> Signed-off-by: Steven Rostedt (Google) <rostedt@xxxxxxxxxxx> Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx> --- fs/tracefs/event_inode.c | 10 ++++++++++ 1 file changed, 10 insertions(+) --- a/fs/tracefs/event_inode.c +++ b/fs/tracefs/event_inode.c @@ -32,6 +32,10 @@ */ static DEFINE_MUTEX(eventfs_mutex); +/* Choose something "unique" ;-) */ +#define EVENTFS_FILE_INODE_INO 0x12c4e37 +#define EVENTFS_DIR_INODE_INO 0x134b2f5 + /* * The eventfs_inode (ei) itself is protected by SRCU. It is released from * its parent's list and will have is_freed set (under eventfs_mutex). @@ -314,6 +318,9 @@ static struct dentry *create_file(const inode->i_fop = fop; inode->i_private = data; + /* All files will have the same inode number */ + inode->i_ino = EVENTFS_FILE_INODE_INO; + ti = get_tracefs(inode); ti->flags |= TRACEFS_EVENT_INODE; d_instantiate(dentry, inode); @@ -350,6 +357,9 @@ static struct dentry *create_dir(struct inode->i_op = &eventfs_root_dir_inode_operations; inode->i_fop = &eventfs_file_operations; + /* All directories will have the same inode number */ + inode->i_ino = EVENTFS_DIR_INODE_INO; + ti = get_tracefs(inode); ti->flags |= TRACEFS_EVENT_INODE; Patches currently in stable-queue which might be from rostedt@xxxxxxxxxx are queue-6.7/eventfs-keep-all-directory-links-at-1.patch queue-6.7/eventfs-save-directory-inodes-in-the-eventfs_inode-structure.patch queue-6.7/tracefs-zero-out-the-tracefs_inode-when-allocating-it.patch queue-6.7/eventfs-read-ei-entries-before-ei-children-in-eventfs_iterate.patch queue-6.7/eventfs-remove-lookup-parameter-from-create_dir-file_dentry.patch queue-6.7/eventfs-remove-fsnotify-functions-from-lookup.patch queue-6.7/eventfs-stop-using-dcache_readdir-for-getdents.patch queue-6.7/tracefs-avoid-using-the-ei-dentry-pointer-unnecessarily.patch queue-6.7/eventfs-initialize-the-tracefs-inode-properly.patch queue-6.7/eventfs-do-ctx-pos-update-for-all-iterations-in-eventfs_iterate.patch queue-6.7/tracefs-dentry-lookup-crapectomy.patch queue-6.7/eventfs-have-the-inodes-all-for-files-and-directories-all-be-the-same.patch queue-6.7/eventfs-use-kcalloc-instead-of-kzalloc.patch queue-6.7/eventfs-shortcut-eventfs_iterate-by-skipping-entries-already-read.patch queue-6.7/eventfs-do-not-create-dentries-nor-inodes-in-iterate_shared.patch queue-6.7/eventfs-have-eventfs_iterate-stop-immediately-if-ei-is_freed-is-set.patch queue-6.7/eventfs-restructure-eventfs_inode-structure-to-be-more-condensed.patch queue-6.7/eventfs-warn-if-an-eventfs_inode-is-freed-without-is_freed-being-set.patch queue-6.7/eventfs-get-rid-of-dentry-pointers-without-refcounts.patch queue-6.7/eventfs-remove-unused-d_parent-pointer-field.patch queue-6.7/eventfs-clean-up-dentry-ops-and-add-revalidate-function.patch