aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/notify/fanotify/fanotify_user.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/fs/notify/fanotify/fanotify_user.c b/fs/notify/fanotify/fanotify_user.c
index ca54957b1f61..dccd7985e65a 100644
--- a/fs/notify/fanotify/fanotify_user.c
+++ b/fs/notify/fanotify/fanotify_user.c
@@ -110,6 +110,8 @@ static int fill_event_metadata(struct fsnotify_group *group,
110 struct fanotify_event_metadata *metadata, 110 struct fanotify_event_metadata *metadata,
111 struct fsnotify_event *event) 111 struct fsnotify_event *event)
112{ 112{
113 int ret = 0;
114
113 pr_debug("%s: group=%p metadata=%p event=%p\n", __func__, 115 pr_debug("%s: group=%p metadata=%p event=%p\n", __func__,
114 group, metadata, event); 116 group, metadata, event);
115 117
@@ -117,9 +119,15 @@ static int fill_event_metadata(struct fsnotify_group *group,
117 metadata->vers = FANOTIFY_METADATA_VERSION; 119 metadata->vers = FANOTIFY_METADATA_VERSION;
118 metadata->mask = event->mask & FAN_ALL_OUTGOING_EVENTS; 120 metadata->mask = event->mask & FAN_ALL_OUTGOING_EVENTS;
119 metadata->pid = pid_vnr(event->tgid); 121 metadata->pid = pid_vnr(event->tgid);
120 metadata->fd = create_fd(group, event); 122 if (unlikely(event->mask & FAN_Q_OVERFLOW))
123 metadata->fd = FAN_NOFD;
124 else {
125 metadata->fd = create_fd(group, event);
126 if (metadata->fd < 0)
127 ret = metadata->fd;
128 }
121 129
122 return metadata->fd; 130 return ret;
123} 131}
124 132
125#ifdef CONFIG_FANOTIFY_ACCESS_PERMISSIONS 133#ifdef CONFIG_FANOTIFY_ACCESS_PERMISSIONS
@@ -261,7 +269,7 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group,
261 if (ret < 0) 269 if (ret < 0)
262 goto out; 270 goto out;
263 271
264 fd = ret; 272 fd = fanotify_event_metadata.fd;
265 ret = prepare_for_access_response(group, event, fd); 273 ret = prepare_for_access_response(group, event, fd);
266 if (ret) 274 if (ret)
267 goto out_close_fd; 275 goto out_close_fd;
@@ -275,7 +283,8 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group,
275out_kill_access_response: 283out_kill_access_response:
276 remove_access_response(group, event, fd); 284 remove_access_response(group, event, fd);
277out_close_fd: 285out_close_fd:
278 sys_close(fd); 286 if (fd != FAN_NOFD)
287 sys_close(fd);
279out: 288out:
280#ifdef CONFIG_FANOTIFY_ACCESS_PERMISSIONS 289#ifdef CONFIG_FANOTIFY_ACCESS_PERMISSIONS
281 if (event->mask & FAN_ALL_PERM_EVENTS) { 290 if (event->mask & FAN_ALL_PERM_EVENTS) {