Commit 24dca905 authored by Gabriel Krisman Bertazi's avatar Gabriel Krisman Bertazi Committed by Jan Kara

fsnotify: Protect fsnotify_handle_inode_event from no-inode events

FAN_FS_ERROR allows events without inodes - i.e. for file system-wide
errors.  Even though fsnotify_handle_inode_event is not currently used
by fanotify, this patch protects other backends from cases where neither
inode or dir are provided.  Also document the constraints of the
interface (inode and dir cannot be both NULL).

Link: https://lore.kernel.org/r/20211025192746.66445-12-krisman@collabora.comSuggested-by: default avatarAmir Goldstein <amir73il@gmail.com>
Signed-off-by: default avatarGabriel Krisman Bertazi <krisman@collabora.com>
Reviewed-by: default avatarAmir Goldstein <amir73il@gmail.com>
Reviewed-by: default avatarJan Kara <jack@suse.cz>
Signed-off-by: default avatarJan Kara <jack@suse.cz>
parent 29335033
...@@ -602,6 +602,9 @@ nfsd_file_fsnotify_handle_event(struct fsnotify_mark *mark, u32 mask, ...@@ -602,6 +602,9 @@ nfsd_file_fsnotify_handle_event(struct fsnotify_mark *mark, u32 mask,
struct inode *inode, struct inode *dir, struct inode *inode, struct inode *dir,
const struct qstr *name, u32 cookie) const struct qstr *name, u32 cookie)
{ {
if (WARN_ON_ONCE(!inode))
return 0;
trace_nfsd_file_fsnotify_handle_event(inode, mask); trace_nfsd_file_fsnotify_handle_event(inode, mask);
/* Should be no marks on non-regular files */ /* Should be no marks on non-regular files */
......
...@@ -252,6 +252,9 @@ static int fsnotify_handle_inode_event(struct fsnotify_group *group, ...@@ -252,6 +252,9 @@ static int fsnotify_handle_inode_event(struct fsnotify_group *group,
if (WARN_ON_ONCE(!ops->handle_inode_event)) if (WARN_ON_ONCE(!ops->handle_inode_event))
return 0; return 0;
if (WARN_ON_ONCE(!inode && !dir))
return 0;
if ((inode_mark->mask & FS_EXCL_UNLINK) && if ((inode_mark->mask & FS_EXCL_UNLINK) &&
path && d_unlinked(path->dentry)) path && d_unlinked(path->dentry))
return 0; return 0;
......
...@@ -136,6 +136,7 @@ struct mem_cgroup; ...@@ -136,6 +136,7 @@ struct mem_cgroup;
* @dir: optional directory associated with event - * @dir: optional directory associated with event -
* if @file_name is not NULL, this is the directory that * if @file_name is not NULL, this is the directory that
* @file_name is relative to. * @file_name is relative to.
* Either @inode or @dir must be non-NULL.
* @file_name: optional file name associated with event * @file_name: optional file name associated with event
* @cookie: inotify rename cookie * @cookie: inotify rename cookie
* *
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment