Commit 03930979 authored by Eric Paris's avatar Eric Paris

fsnotify: remove the global masks

Because we walk the object->fsnotify_marks list instead of the global
fsnotify groups list we don't need the fsnotify_inode_mask and
fsnotify_vfsmount_mask as these were simply shortcuts in fsnotify() for
performance.  They are now extra checks, rip them out.
Signed-off-by: default avatarEric Paris <eparis@redhat.com>
parent 2612abb5
...@@ -227,11 +227,6 @@ int fsnotify(struct inode *to_tell, __u32 mask, void *data, int data_is, ...@@ -227,11 +227,6 @@ int fsnotify(struct inode *to_tell, __u32 mask, void *data, int data_is,
if (mask & FS_MODIFY) if (mask & FS_MODIFY)
__fsnotify_flush_ignored_mask(to_tell, data, data_is); __fsnotify_flush_ignored_mask(to_tell, data, data_is);
/* if none of the directed listeners or vfsmount listeners care */
if (!(test_mask & fsnotify_inode_mask) &&
!(test_mask & fsnotify_vfsmount_mask))
return 0;
if (data_is == FSNOTIFY_EVENT_FILE) if (data_is == FSNOTIFY_EVENT_FILE)
mnt = ((struct file *)data)->f_path.mnt; mnt = ((struct file *)data)->f_path.mnt;
......
...@@ -10,10 +10,6 @@ ...@@ -10,10 +10,6 @@
extern struct list_head fsnotify_inode_groups; extern struct list_head fsnotify_inode_groups;
/* all groups which receive vfsmount fsnotify events */ /* all groups which receive vfsmount fsnotify events */
extern struct list_head fsnotify_vfsmount_groups; extern struct list_head fsnotify_vfsmount_groups;
/* all bitwise OR of all event types (FS_*) for all fsnotify_inode_groups */
extern __u32 fsnotify_inode_mask;
/* all bitwise OR of all event types (FS_*) for all fsnotify_vfsmount_groups */
extern __u32 fsnotify_vfsmount_mask;
/* destroy all events sitting in this groups notification queue */ /* destroy all events sitting in this groups notification queue */
extern void fsnotify_flush_notify(struct fsnotify_group *group); extern void fsnotify_flush_notify(struct fsnotify_group *group);
......
...@@ -34,54 +34,21 @@ static DEFINE_MUTEX(fsnotify_grp_mutex); ...@@ -34,54 +34,21 @@ static DEFINE_MUTEX(fsnotify_grp_mutex);
LIST_HEAD(fsnotify_inode_groups); LIST_HEAD(fsnotify_inode_groups);
/* all groups registered to receive mount point filesystem notifications */ /* all groups registered to receive mount point filesystem notifications */
LIST_HEAD(fsnotify_vfsmount_groups); LIST_HEAD(fsnotify_vfsmount_groups);
/* bitwise OR of all events (FS_*) interesting to some group on this system */
__u32 fsnotify_inode_mask;
/* bitwise OR of all events (FS_*) interesting to some group on this system */
__u32 fsnotify_vfsmount_mask;
/*
* When a new group registers or changes it's set of interesting events
* this function updates the fsnotify_mask to contain all interesting events
*/
void fsnotify_recalc_global_mask(void)
{
struct fsnotify_group *group;
__u32 inode_mask = 0;
__u32 vfsmount_mask = 0;
mutex_lock(&fsnotify_grp_mutex);
list_for_each_entry_rcu(group, &fsnotify_inode_groups, inode_group_list)
inode_mask |= group->mask;
list_for_each_entry_rcu(group, &fsnotify_vfsmount_groups, vfsmount_group_list)
vfsmount_mask |= group->mask;
fsnotify_inode_mask = inode_mask;
fsnotify_vfsmount_mask = vfsmount_mask;
mutex_unlock(&fsnotify_grp_mutex);
}
/* /*
* Update the group->mask by running all of the marks associated with this * Update the group->mask by running all of the marks associated with this
* group and finding the bitwise | of all of the mark->mask. If we change * group and finding the bitwise | of all of the mark->mask.
* the group->mask we need to update the global mask of events interesting
* to the system.
*/ */
void fsnotify_recalc_group_mask(struct fsnotify_group *group) void fsnotify_recalc_group_mask(struct fsnotify_group *group)
{ {
__u32 mask = 0; __u32 mask = 0;
__u32 old_mask = group->mask;
struct fsnotify_mark *mark; struct fsnotify_mark *mark;
spin_lock(&group->mark_lock); spin_lock(&group->mark_lock);
list_for_each_entry(mark, &group->marks_list, g_list) list_for_each_entry(mark, &group->marks_list, g_list)
mask |= mark->mask; mask |= mark->mask;
spin_unlock(&group->mark_lock);
group->mask = mask; group->mask = mask;
spin_unlock(&group->mark_lock);
if (old_mask != mask)
fsnotify_recalc_global_mask();
} }
void fsnotify_add_vfsmount_group(struct fsnotify_group *group) void fsnotify_add_vfsmount_group(struct fsnotify_group *group)
...@@ -217,8 +184,6 @@ void fsnotify_put_group(struct fsnotify_group *group) ...@@ -217,8 +184,6 @@ void fsnotify_put_group(struct fsnotify_group *group)
mutex_unlock(&fsnotify_grp_mutex); mutex_unlock(&fsnotify_grp_mutex);
/* and now it is really dead. _Nothing_ could be seeing it */
fsnotify_recalc_global_mask();
fsnotify_destroy_group(group); fsnotify_destroy_group(group);
} }
......
...@@ -365,8 +365,6 @@ static inline void __fsnotify_d_instantiate(struct dentry *dentry, struct inode ...@@ -365,8 +365,6 @@ static inline void __fsnotify_d_instantiate(struct dentry *dentry, struct inode
/* called from fsnotify listeners, such as fanotify or dnotify */ /* called from fsnotify listeners, such as fanotify or dnotify */
/* must call when a group changes its ->mask */
extern void fsnotify_recalc_global_mask(void);
/* get a reference to an existing or create a new group */ /* get a reference to an existing or create a new group */
extern struct fsnotify_group *fsnotify_alloc_group(const struct fsnotify_ops *ops); extern struct fsnotify_group *fsnotify_alloc_group(const struct fsnotify_ops *ops);
/* run all marks associated with this group and update group->mask */ /* run all marks associated with this group and update group->mask */
......
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