diff options
author | Andreas Gruenbacher <agruen@suse.de> | 2009-12-17 21:24:27 -0500 |
---|---|---|
committer | Eric Paris <eparis@redhat.com> | 2010-07-28 09:58:56 -0400 |
commit | 32c3263221bd63316815286dccacdc7abfd7f3c4 (patch) | |
tree | 9dad12d5b966cf42d7506e10fb2e3c8d955415d3 /fs/notify | |
parent | 22aa425dec9e47051624714ae283eb2b6a473013 (diff) |
fanotify: Add pids to events
Pass the process identifiers of the triggering processes to fanotify
listeners: this information is useful for event filtering and logging.
Signed-off-by: Andreas Gruenbacher <agruen@suse.de>
Signed-off-by: Eric Paris <eparis@redhat.com>
Diffstat (limited to 'fs/notify')
-rw-r--r-- | fs/notify/fanotify/fanotify.c | 5 | ||||
-rw-r--r-- | fs/notify/fanotify/fanotify_user.c | 1 | ||||
-rw-r--r-- | fs/notify/notification.c | 3 |
3 files changed, 7 insertions, 2 deletions
diff --git a/fs/notify/fanotify/fanotify.c b/fs/notify/fanotify/fanotify.c index 5b0b6b485a9c..881067dc7923 100644 --- a/fs/notify/fanotify/fanotify.c +++ b/fs/notify/fanotify/fanotify.c | |||
@@ -10,8 +10,9 @@ static bool should_merge(struct fsnotify_event *old, struct fsnotify_event *new) | |||
10 | { | 10 | { |
11 | pr_debug("%s: old=%p new=%p\n", __func__, old, new); | 11 | pr_debug("%s: old=%p new=%p\n", __func__, old, new); |
12 | 12 | ||
13 | if ((old->to_tell == new->to_tell) && | 13 | if (old->to_tell == new->to_tell && |
14 | (old->data_type == new->data_type)) { | 14 | old->data_type == new->data_type && |
15 | old->tgid == new->tgid) { | ||
15 | switch (old->data_type) { | 16 | switch (old->data_type) { |
16 | case (FSNOTIFY_EVENT_PATH): | 17 | case (FSNOTIFY_EVENT_PATH): |
17 | if ((old->path.mnt == new->path.mnt) && | 18 | if ((old->path.mnt == new->path.mnt) && |
diff --git a/fs/notify/fanotify/fanotify_user.c b/fs/notify/fanotify/fanotify_user.c index cf9c30009825..66e38fc052b2 100644 --- a/fs/notify/fanotify/fanotify_user.c +++ b/fs/notify/fanotify/fanotify_user.c | |||
@@ -103,6 +103,7 @@ static ssize_t fill_event_metadata(struct fsnotify_group *group, | |||
103 | metadata->event_len = FAN_EVENT_METADATA_LEN; | 103 | metadata->event_len = FAN_EVENT_METADATA_LEN; |
104 | metadata->vers = FANOTIFY_METADATA_VERSION; | 104 | metadata->vers = FANOTIFY_METADATA_VERSION; |
105 | metadata->mask = fanotify_outgoing_mask(event->mask); | 105 | metadata->mask = fanotify_outgoing_mask(event->mask); |
106 | metadata->pid = pid_vnr(event->tgid); | ||
106 | metadata->fd = create_fd(group, event); | 107 | metadata->fd = create_fd(group, event); |
107 | 108 | ||
108 | return metadata->fd; | 109 | return metadata->fd; |
diff --git a/fs/notify/notification.c b/fs/notify/notification.c index 066f1f988bac..7fc8d004084c 100644 --- a/fs/notify/notification.c +++ b/fs/notify/notification.c | |||
@@ -93,6 +93,7 @@ void fsnotify_put_event(struct fsnotify_event *event) | |||
93 | BUG_ON(!list_empty(&event->private_data_list)); | 93 | BUG_ON(!list_empty(&event->private_data_list)); |
94 | 94 | ||
95 | kfree(event->file_name); | 95 | kfree(event->file_name); |
96 | put_pid(event->tgid); | ||
96 | kmem_cache_free(fsnotify_event_cachep, event); | 97 | kmem_cache_free(fsnotify_event_cachep, event); |
97 | } | 98 | } |
98 | } | 99 | } |
@@ -346,6 +347,7 @@ struct fsnotify_event *fsnotify_clone_event(struct fsnotify_event *old_event) | |||
346 | return NULL; | 347 | return NULL; |
347 | } | 348 | } |
348 | } | 349 | } |
350 | event->tgid = get_pid(old_event->tgid); | ||
349 | if (event->data_type == FSNOTIFY_EVENT_PATH) | 351 | if (event->data_type == FSNOTIFY_EVENT_PATH) |
350 | path_get(&event->path); | 352 | path_get(&event->path); |
351 | 353 | ||
@@ -385,6 +387,7 @@ struct fsnotify_event *fsnotify_create_event(struct inode *to_tell, __u32 mask, | |||
385 | event->name_len = strlen(event->file_name); | 387 | event->name_len = strlen(event->file_name); |
386 | } | 388 | } |
387 | 389 | ||
390 | event->tgid = get_pid(task_tgid(current)); | ||
388 | event->sync_cookie = cookie; | 391 | event->sync_cookie = cookie; |
389 | event->to_tell = to_tell; | 392 | event->to_tell = to_tell; |
390 | event->data_type = data_type; | 393 | event->data_type = data_type; |