aboutsummaryrefslogtreecommitdiffstats
path: root/fs/notify/fanotify/fanotify_user.c
diff options
context:
space:
mode:
authorEric Paris <eparis@redhat.com>2009-12-17 21:24:33 -0500
committerEric Paris <eparis@redhat.com>2010-07-28 09:58:59 -0400
commit90b1e7a57880fb66437ab7db39e1e65ca0372822 (patch)
tree61b7195c84d9dfd057ed3dcb07c5fc831db6a3a9 /fs/notify/fanotify/fanotify_user.c
parent33d3dfff451a2ab6fe2f6aaabed9b24e91aad109 (diff)
fsnotify: allow marks to not pin inodes in core
inotify marks must pin inodes in core. dnotify doesn't technically need to since they are closed when the directory is closed. fanotify also need to pin inodes in core as it works today. But the next step is to introduce the concept of 'ignored masks' which is actually a mask of events for an inode of no interest. I claim that these should be liberally sent to the kernel and should not pin the inode in core. If the inode is brought back in the listener will get an event it may have thought excluded, but this is not a serious situation and one any listener should deal with. This patch lays the ground work for non-pinning inode marks by using lazy inode pinning. We do not pin a mark until it has a non-zero mask entry. If a listener new sets a mask we never pin the inode. Signed-off-by: Eric Paris <eparis@redhat.com>
Diffstat (limited to 'fs/notify/fanotify/fanotify_user.c')
-rw-r--r--fs/notify/fanotify/fanotify_user.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/fs/notify/fanotify/fanotify_user.c b/fs/notify/fanotify/fanotify_user.c
index 84155841a025..3320f0c57e31 100644
--- a/fs/notify/fanotify/fanotify_user.c
+++ b/fs/notify/fanotify/fanotify_user.c
@@ -302,7 +302,7 @@ static __u32 fanotify_mark_remove_from_mask(struct fsnotify_mark *fsn_mark, __u3
302 302
303 spin_lock(&fsn_mark->lock); 303 spin_lock(&fsn_mark->lock);
304 oldmask = fsn_mark->mask; 304 oldmask = fsn_mark->mask;
305 fsn_mark->mask = oldmask & ~mask; 305 fsnotify_set_mark_mask_locked(fsn_mark, (oldmask & ~mask));
306 spin_unlock(&fsn_mark->lock); 306 spin_unlock(&fsn_mark->lock);
307 307
308 if (!(oldmask & ~mask)) 308 if (!(oldmask & ~mask))
@@ -359,7 +359,7 @@ static __u32 fanotify_mark_add_to_mask(struct fsnotify_mark *fsn_mark, __u32 mas
359 359
360 spin_lock(&fsn_mark->lock); 360 spin_lock(&fsn_mark->lock);
361 oldmask = fsn_mark->mask; 361 oldmask = fsn_mark->mask;
362 fsn_mark->mask = oldmask | mask; 362 fsnotify_set_mark_mask_locked(fsn_mark, (oldmask | mask));
363 spin_unlock(&fsn_mark->lock); 363 spin_unlock(&fsn_mark->lock);
364 364
365 return mask & ~oldmask; 365 return mask & ~oldmask;