fsnotify: fix inotify tail drop check with path entries
fsnotify drops new events when they are the same as the tail event on the queue to be sent to userspace. The problem is that if the event comes with a path we forget to break out of the switch statement and fall into the code path which matches on events that do not have any type of file backed information (things like IN_UNMOUNT and IN_Q_OVERFLOW). The problem is that this code thinks all such events should be dropped. Fix is to add a break. Signed-off-by: Eric Paris <eparis@redhat.com>
This commit is contained in:
parent
4a148ba988
commit
c05594b621
@ -151,6 +151,7 @@ static bool event_compare(struct fsnotify_event *old, struct fsnotify_event *new
|
|||||||
if ((old->path.mnt == new->path.mnt) &&
|
if ((old->path.mnt == new->path.mnt) &&
|
||||||
(old->path.dentry == new->path.dentry))
|
(old->path.dentry == new->path.dentry))
|
||||||
return true;
|
return true;
|
||||||
|
break;
|
||||||
case (FSNOTIFY_EVENT_NONE):
|
case (FSNOTIFY_EVENT_NONE):
|
||||||
return true;
|
return true;
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user