Commit d3424c9b authored by Matthew Bobrowski's avatar Matthew Bobrowski Committed by Jan Kara

fanotify: minor cosmetic adjustments to fid labels

With the idea to support additional info record types in the future
i.e. fanotify_event_info_pidfd, it's a good idea to rename some of the
labels assigned to some of the existing fid related functions,
parameters, etc which more accurately represent the intent behind
their usage.

For example, copy_info_to_user() was defined with a generic function
label, which arguably reads as being supportive of different info
record types, however the parameter list for this function is
explicitly tailored towards the creation and copying of the
fanotify_event_info_fid records. This same point applies to the macro
defined as FANOTIFY_INFO_HDR_LEN.

With fanotify_event_info_len(), we change the parameter label so that
the function implies that it can be extended to calculate the length
for additional info record types.

Link: https://lore.kernel.org/r/7c3ec33f3c718dac40764305d4d494d858f59c51.1628398044.git.repnop@google.comSigned-off-by: default avatarMatthew Bobrowski <repnop@google.com>
Reviewed-by: default avatarAmir Goldstein <amir73il@gmail.com>
Signed-off-by: default avatarJan Kara <jack@suse.cz>
parent 490b9ba8
...@@ -104,7 +104,7 @@ struct kmem_cache *fanotify_path_event_cachep __read_mostly; ...@@ -104,7 +104,7 @@ struct kmem_cache *fanotify_path_event_cachep __read_mostly;
struct kmem_cache *fanotify_perm_event_cachep __read_mostly; struct kmem_cache *fanotify_perm_event_cachep __read_mostly;
#define FANOTIFY_EVENT_ALIGN 4 #define FANOTIFY_EVENT_ALIGN 4
#define FANOTIFY_INFO_HDR_LEN \ #define FANOTIFY_FID_INFO_HDR_LEN \
(sizeof(struct fanotify_event_info_fid) + sizeof(struct file_handle)) (sizeof(struct fanotify_event_info_fid) + sizeof(struct file_handle))
static int fanotify_fid_info_len(int fh_len, int name_len) static int fanotify_fid_info_len(int fh_len, int name_len)
...@@ -114,10 +114,11 @@ static int fanotify_fid_info_len(int fh_len, int name_len) ...@@ -114,10 +114,11 @@ static int fanotify_fid_info_len(int fh_len, int name_len)
if (name_len) if (name_len)
info_len += name_len + 1; info_len += name_len + 1;
return roundup(FANOTIFY_INFO_HDR_LEN + info_len, FANOTIFY_EVENT_ALIGN); return roundup(FANOTIFY_FID_INFO_HDR_LEN + info_len,
FANOTIFY_EVENT_ALIGN);
} }
static int fanotify_event_info_len(unsigned int fid_mode, static int fanotify_event_info_len(unsigned int info_mode,
struct fanotify_event *event) struct fanotify_event *event)
{ {
struct fanotify_info *info = fanotify_event_info(event); struct fanotify_info *info = fanotify_event_info(event);
...@@ -128,7 +129,8 @@ static int fanotify_event_info_len(unsigned int fid_mode, ...@@ -128,7 +129,8 @@ static int fanotify_event_info_len(unsigned int fid_mode,
if (dir_fh_len) { if (dir_fh_len) {
info_len += fanotify_fid_info_len(dir_fh_len, info->name_len); info_len += fanotify_fid_info_len(dir_fh_len, info->name_len);
} else if ((fid_mode & FAN_REPORT_NAME) && (event->mask & FAN_ONDIR)) { } else if ((info_mode & FAN_REPORT_NAME) &&
(event->mask & FAN_ONDIR)) {
/* /*
* With group flag FAN_REPORT_NAME, if name was not recorded in * With group flag FAN_REPORT_NAME, if name was not recorded in
* event on a directory, we will report the name ".". * event on a directory, we will report the name ".".
...@@ -303,8 +305,9 @@ static int process_access_response(struct fsnotify_group *group, ...@@ -303,8 +305,9 @@ static int process_access_response(struct fsnotify_group *group,
return -ENOENT; return -ENOENT;
} }
static int copy_info_to_user(__kernel_fsid_t *fsid, struct fanotify_fh *fh, static int copy_fid_info_to_user(__kernel_fsid_t *fsid, struct fanotify_fh *fh,
int info_type, const char *name, size_t name_len, int info_type, const char *name,
size_t name_len,
char __user *buf, size_t count) char __user *buf, size_t count)
{ {
struct fanotify_event_info_fid info = { }; struct fanotify_event_info_fid info = { };
...@@ -466,9 +469,10 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group, ...@@ -466,9 +469,10 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group,
if (fanotify_event_dir_fh_len(event)) { if (fanotify_event_dir_fh_len(event)) {
info_type = info->name_len ? FAN_EVENT_INFO_TYPE_DFID_NAME : info_type = info->name_len ? FAN_EVENT_INFO_TYPE_DFID_NAME :
FAN_EVENT_INFO_TYPE_DFID; FAN_EVENT_INFO_TYPE_DFID;
ret = copy_info_to_user(fanotify_event_fsid(event), ret = copy_fid_info_to_user(fanotify_event_fsid(event),
fanotify_info_dir_fh(info), fanotify_info_dir_fh(info),
info_type, fanotify_info_name(info), info_type,
fanotify_info_name(info),
info->name_len, buf, count); info->name_len, buf, count);
if (ret < 0) if (ret < 0)
goto out_close_fd; goto out_close_fd;
...@@ -515,9 +519,10 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group, ...@@ -515,9 +519,10 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group,
info_type = FAN_EVENT_INFO_TYPE_FID; info_type = FAN_EVENT_INFO_TYPE_FID;
} }
ret = copy_info_to_user(fanotify_event_fsid(event), ret = copy_fid_info_to_user(fanotify_event_fsid(event),
fanotify_event_object_fh(event), fanotify_event_object_fh(event),
info_type, dot, dot_len, buf, count); info_type, dot, dot_len,
buf, count);
if (ret < 0) if (ret < 0)
goto out_close_fd; goto out_close_fd;
......
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