diff options
author | Jan Kara <jack@suse.cz> | 2016-11-10 11:51:50 -0500 |
---|---|---|
committer | Jan Kara <jack@suse.cz> | 2017-04-10 11:37:36 -0400 |
commit | 9385a84d7e1f658bb2d96ab798393e4b16268aaa (patch) | |
tree | dd5d112c6bb46d97069645a2e34a38c5998e1234 /kernel | |
parent | abc77577a669f424c5d0c185b9994f2621c52aa4 (diff) |
fsnotify: Pass fsnotify_iter_info into handle_event handler
Pass fsnotify_iter_info into ->handle_event() handler so that it can
release and reacquire SRCU lock via fsnotify_prepare_user_wait() and
fsnotify_finish_user_wait() functions. These functions also make sure
current marks are appropriately pinned so that iteration protected by
srcu in fsnotify() stays safe.
Reviewed-by: Miklos Szeredi <mszeredi@redhat.com>
Reviewed-by: Amir Goldstein <amir73il@gmail.com>
Signed-off-by: Jan Kara <jack@suse.cz>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/audit_fsnotify.c | 3 | ||||
-rw-r--r-- | kernel/audit_tree.c | 3 | ||||
-rw-r--r-- | kernel/audit_watch.c | 3 |
3 files changed, 6 insertions, 3 deletions
diff --git a/kernel/audit_fsnotify.c b/kernel/audit_fsnotify.c index 7ea57e516029..e8b371ff1e91 100644 --- a/kernel/audit_fsnotify.c +++ b/kernel/audit_fsnotify.c | |||
@@ -168,7 +168,8 @@ static int audit_mark_handle_event(struct fsnotify_group *group, | |||
168 | struct fsnotify_mark *inode_mark, | 168 | struct fsnotify_mark *inode_mark, |
169 | struct fsnotify_mark *vfsmount_mark, | 169 | struct fsnotify_mark *vfsmount_mark, |
170 | u32 mask, const void *data, int data_type, | 170 | u32 mask, const void *data, int data_type, |
171 | const unsigned char *dname, u32 cookie) | 171 | const unsigned char *dname, u32 cookie, |
172 | struct fsnotify_iter_info *iter_info) | ||
172 | { | 173 | { |
173 | struct audit_fsnotify_mark *audit_mark; | 174 | struct audit_fsnotify_mark *audit_mark; |
174 | const struct inode *inode = NULL; | 175 | const struct inode *inode = NULL; |
diff --git a/kernel/audit_tree.c b/kernel/audit_tree.c index 2fa8d61b6fd2..d59ed4c9037a 100644 --- a/kernel/audit_tree.c +++ b/kernel/audit_tree.c | |||
@@ -989,7 +989,8 @@ static int audit_tree_handle_event(struct fsnotify_group *group, | |||
989 | struct fsnotify_mark *inode_mark, | 989 | struct fsnotify_mark *inode_mark, |
990 | struct fsnotify_mark *vfsmount_mark, | 990 | struct fsnotify_mark *vfsmount_mark, |
991 | u32 mask, const void *data, int data_type, | 991 | u32 mask, const void *data, int data_type, |
992 | const unsigned char *file_name, u32 cookie) | 992 | const unsigned char *file_name, u32 cookie, |
993 | struct fsnotify_iter_info *iter_info) | ||
993 | { | 994 | { |
994 | return 0; | 995 | return 0; |
995 | } | 996 | } |
diff --git a/kernel/audit_watch.c b/kernel/audit_watch.c index f79e4658433d..6caaf087801f 100644 --- a/kernel/audit_watch.c +++ b/kernel/audit_watch.c | |||
@@ -472,7 +472,8 @@ static int audit_watch_handle_event(struct fsnotify_group *group, | |||
472 | struct fsnotify_mark *inode_mark, | 472 | struct fsnotify_mark *inode_mark, |
473 | struct fsnotify_mark *vfsmount_mark, | 473 | struct fsnotify_mark *vfsmount_mark, |
474 | u32 mask, const void *data, int data_type, | 474 | u32 mask, const void *data, int data_type, |
475 | const unsigned char *dname, u32 cookie) | 475 | const unsigned char *dname, u32 cookie, |
476 | struct fsnotify_iter_info *iter_info) | ||
476 | { | 477 | { |
477 | const struct inode *inode; | 478 | const struct inode *inode; |
478 | struct audit_parent *parent; | 479 | struct audit_parent *parent; |