diff options
-rw-r--r-- | fs/notify/fanotify/fanotify_user.c | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/fs/notify/fanotify/fanotify_user.c b/fs/notify/fanotify/fanotify_user.c index ca54957b1f6..dccd7985e65 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, | |||
275 | out_kill_access_response: | 283 | out_kill_access_response: |
276 | remove_access_response(group, event, fd); | 284 | remove_access_response(group, event, fd); |
277 | out_close_fd: | 285 | out_close_fd: |
278 | sys_close(fd); | 286 | if (fd != FAN_NOFD) |
287 | sys_close(fd); | ||
279 | out: | 288 | out: |
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) { |