* v2.6.31-rc6 inotify not reporting deleted files
@ 2009-08-26 9:06 Eric W. Biederman
2009-08-26 11:25 ` Eric Paris
2009-08-26 15:11 ` Eric Paris
0 siblings, 2 replies; 8+ messages in thread
From: Eric W. Biederman @ 2009-08-26 9:06 UTC (permalink / raw)
To: Eric Paris; +Cc: linux-kernel, linux-fsdevel, Rafael J. Wysocki
I don't have a small test case yet, but I have an application that
uses inotify and watches a file and takes action when that file has been
deleted. Running that application on 2.6.31-rc6 the application is
no longer seeing the file being deleted.
With luck a word to the wise is all that is required for you to reproduce
this. Otherwise I will spend some time tomorrow making a small reproducer.
Eric
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: v2.6.31-rc6 inotify not reporting deleted files
2009-08-26 9:06 v2.6.31-rc6 inotify not reporting deleted files Eric W. Biederman
@ 2009-08-26 11:25 ` Eric Paris
2009-08-26 15:11 ` Eric Paris
1 sibling, 0 replies; 8+ messages in thread
From: Eric Paris @ 2009-08-26 11:25 UTC (permalink / raw)
To: Eric W. Biederman; +Cc: linux-kernel, linux-fsdevel, Rafael J. Wysocki
On Wed, 2009-08-26 at 02:06 -0700, Eric W. Biederman wrote:
> I don't have a small test case yet, but I have an application that
> uses inotify and watches a file and takes action when that file has been
> deleted. Running that application on 2.6.31-rc6 the application is
> no longer seeing the file being deleted.
>
> With luck a word to the wise is all that is required for you to reproduce
> this. Otherwise I will spend some time tomorrow making a small reproducer.
I'm probably going to need a little more to go on. The most simple
tests seem to work for me...
kernel-2.6.31-0.167.rc6.git6.fc12.x86_64
Watch /tmp/ while deleting /tmp/tmp:
$ touch /tmp/tmp
$ inotifywait -m /tmp
Setting up watches.
Watches established.
/tmp/ DELETE tmp
^C
Watch /tmp/tmp while deleting /tmp/tmp
$ touch /tmp/tmp
$ inotifywait -m /tmp/tmp
Setting up watches.
Watches established.
/tmp/tmp ATTRIB
/tmp/tmp DELETE_SELF
/tmp/tmp IGNORED
Delete 2 files while inotifywait is asleep
$touch /tmp/tmp1 /tmp/tmp2
$inotifywait -m /tmp
Setting up watches.
Watches established.
^Z
[1]+ Stopped inotifywait -m /tmp
$ rm -f /tmp/tmp1
$ rm -f /tmp/tmp2
$ fg
inotifywait -m /tmp
/tmp/ DELETE tmp1
/tmp/ DELETE tmp2
^C
Delete 2 directories while inotifywait is asleep
$ mkdir /tmp/tmp1 /tmp/tmp2
$ inotifywait -m /tmp
Setting up watches.
Watches established.
^Z
[1]+ Stopped inotifywait -m /tmp
$ rmdir /tmp/tmp1
$ rmdir /tmp/tmp2
$ fg
inotifywait -m /tmp
/tmp/ DELETE,ISDIR tmp1
/tmp/ DELETE,ISDIR tmp2
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: v2.6.31-rc6 inotify not reporting deleted files
2009-08-26 9:06 v2.6.31-rc6 inotify not reporting deleted files Eric W. Biederman
2009-08-26 11:25 ` Eric Paris
@ 2009-08-26 15:11 ` Eric Paris
2009-08-26 20:12 ` Eric W. Biederman
2009-08-27 10:20 ` [PATCH] inotify: Ensure we alwasy write the terminating NULL Eric W. Biederman
1 sibling, 2 replies; 8+ messages in thread
From: Eric Paris @ 2009-08-26 15:11 UTC (permalink / raw)
To: Eric W. Biederman; +Cc: linux-kernel, linux-fsdevel, Rafael J. Wysocki
On Wed, 2009-08-26 at 02:06 -0700, Eric W. Biederman wrote:
> I don't have a small test case yet, but I have an application that
> uses inotify and watches a file and takes action when that file has been
> deleted. Running that application on 2.6.31-rc6 the application is
> no longer seeing the file being deleted.
Are you dealing with hard linked files?
-Eric
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: v2.6.31-rc6 inotify not reporting deleted files
2009-08-26 15:11 ` Eric Paris
@ 2009-08-26 20:12 ` Eric W. Biederman
2009-08-27 10:20 ` [PATCH] inotify: Ensure we alwasy write the terminating NULL Eric W. Biederman
1 sibling, 0 replies; 8+ messages in thread
From: Eric W. Biederman @ 2009-08-26 20:12 UTC (permalink / raw)
To: Eric Paris; +Cc: linux-kernel, linux-fsdevel, Rafael J. Wysocki
Eric Paris <eparis@redhat.com> writes:
> On Wed, 2009-08-26 at 02:06 -0700, Eric W. Biederman wrote:
>> I don't have a small test case yet, but I have an application that
>> uses inotify and watches a file and takes action when that file has been
>> deleted. Running that application on 2.6.31-rc6 the application is
>> no longer seeing the file being deleted.
>
> Are you dealing with hard linked files?
I shouldn't be. When I skimmed through everything last night it
looked like add a watch for create/delete/modify. Wait.
File created (see it) file deleted (miss it).
I will go verify I can cook up a reproducer, on my box where it
has been failing consistently.
Eric
^ permalink raw reply [flat|nested] 8+ messages in thread
* [PATCH] inotify: Ensure we alwasy write the terminating NULL.
2009-08-26 15:11 ` Eric Paris
2009-08-26 20:12 ` Eric W. Biederman
@ 2009-08-27 10:20 ` Eric W. Biederman
2009-08-27 11:57 ` Eric Paris
2009-08-28 13:29 ` Brian Rogers
1 sibling, 2 replies; 8+ messages in thread
From: Eric W. Biederman @ 2009-08-27 10:20 UTC (permalink / raw)
To: Eric Paris; +Cc: linux-kernel, linux-fsdevel, Rafael J. Wysocki
Before the rewrite copy_event_to_user always wrote a terqminating '\0'
byte to user space after the filename. Since the rewrite that
terminating byte was skipped if your filename is exactly a multiple of
event_size. Ouch!
So add one byte to name_size before we round up and use clear_user to
set userspace to zero like /dev/zero does instead of copying the
strange nul_inotify_event. I can't quite convince myself len_to_zero
will never exceed 16 and even if it doesn't clear_user should be more
efficient and a more accurate reflection of what the code is trying to
do.
Signed-off-by: Eric W. Biederman <ebiederm@aristanetworks.com>
---
fs/notify/inotify/inotify_user.c | 13 ++++++-------
1 files changed, 6 insertions(+), 7 deletions(-)
diff --git a/fs/notify/inotify/inotify_user.c b/fs/notify/inotify/inotify_user.c
index f30d9bb..90ae8ad 100644
--- a/fs/notify/inotify/inotify_user.c
+++ b/fs/notify/inotify/inotify_user.c
@@ -47,9 +47,6 @@
static struct vfsmount *inotify_mnt __read_mostly;
-/* this just sits here and wastes global memory. used to just pad userspace messages with zeros */
-static struct inotify_event nul_inotify_event;
-
/* these are configurable via /proc/sys/fs/inotify/ */
static int inotify_max_user_instances __read_mostly;
static int inotify_max_queued_events __read_mostly;
@@ -199,8 +196,10 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group,
inotify_free_event_priv(fsn_priv);
}
- /* round up event->name_len so it is a multiple of event_size */
- name_len = roundup(event->name_len, event_size);
+ /* round up event->name_len so it is a multiple of event_size
+ * plus an extra byte for the terminating '\0'.
+ */
+ name_len = roundup(event->name_len + 1, event_size);
inotify_event.len = name_len;
inotify_event.mask = inotify_mask_to_arg(event->mask);
@@ -224,8 +223,8 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group,
return -EFAULT;
buf += event->name_len;
- /* fill userspace with 0's from nul_inotify_event */
- if (copy_to_user(buf, &nul_inotify_event, len_to_zero))
+ /* fill userspace with 0's */
+ if (clear_user(buf, len_to_zero))
return -EFAULT;
buf += len_to_zero;
event_size += name_len;
--
1.6.2.5
^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH] inotify: Ensure we alwasy write the terminating NULL.
2009-08-27 10:20 ` [PATCH] inotify: Ensure we alwasy write the terminating NULL Eric W. Biederman
@ 2009-08-27 11:57 ` Eric Paris
2009-08-28 13:29 ` Brian Rogers
1 sibling, 0 replies; 8+ messages in thread
From: Eric Paris @ 2009-08-27 11:57 UTC (permalink / raw)
To: Eric W. Biederman; +Cc: linux-kernel, linux-fsdevel, Rafael J. Wysocki
On Thu, 2009-08-27 at 03:20 -0700, Eric W. Biederman wrote:
> Before the rewrite copy_event_to_user always wrote a terqminating '\0'
> byte to user space after the filename. Since the rewrite that
> terminating byte was skipped if your filename is exactly a multiple of
> event_size. Ouch!
All of my testing code was carefully using the len field rather than
counting on it being nul terminated. You are clearly right, it's
supposed to be nul terminated.
> So add one byte to name_size before we round up and use clear_user to
> set userspace to zero like /dev/zero does instead of copying the
> strange nul_inotify_event.
I already did this in linux-next but haven't passed it to Linus since
although stupid it's right and works. I guess I'll pass it along rolled
up in your patch now.
> I can't quite convince myself len_to_zero
> will never exceed 16 and even if it doesn't clear_user should be more
> efficient and a more accurate reflection of what the code is trying to
> do.
len_to_zero has to be <= sizeof(struct inotify_event) since it's defined
as:
size_t event_size = sizeof(struct inotify_event);
name_len = roundup(event->name_len, event_size);
unsigned int len_to_zero = name_len - event->name_len;
So name_len can never be more than 'event_size' larger than
event->name_len. Then len_to_zero could never be > 16.
Adding to my tree now.
-Eric
> Signed-off-by: Eric W. Biederman <ebiederm@aristanetworks.com>
> ---
> fs/notify/inotify/inotify_user.c | 13 ++++++-------
> 1 files changed, 6 insertions(+), 7 deletions(-)
>
> diff --git a/fs/notify/inotify/inotify_user.c b/fs/notify/inotify/inotify_user.c
> index f30d9bb..90ae8ad 100644
> --- a/fs/notify/inotify/inotify_user.c
> +++ b/fs/notify/inotify/inotify_user.c
> @@ -47,9 +47,6 @@
>
> static struct vfsmount *inotify_mnt __read_mostly;
>
> -/* this just sits here and wastes global memory. used to just pad userspace messages with zeros */
> -static struct inotify_event nul_inotify_event;
> -
> /* these are configurable via /proc/sys/fs/inotify/ */
> static int inotify_max_user_instances __read_mostly;
> static int inotify_max_queued_events __read_mostly;
> @@ -199,8 +196,10 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group,
> inotify_free_event_priv(fsn_priv);
> }
>
> - /* round up event->name_len so it is a multiple of event_size */
> - name_len = roundup(event->name_len, event_size);
> + /* round up event->name_len so it is a multiple of event_size
> + * plus an extra byte for the terminating '\0'.
> + */
> + name_len = roundup(event->name_len + 1, event_size);
> inotify_event.len = name_len;
>
> inotify_event.mask = inotify_mask_to_arg(event->mask);
> @@ -224,8 +223,8 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group,
> return -EFAULT;
> buf += event->name_len;
>
> - /* fill userspace with 0's from nul_inotify_event */
> - if (copy_to_user(buf, &nul_inotify_event, len_to_zero))
> + /* fill userspace with 0's */
> + if (clear_user(buf, len_to_zero))
> return -EFAULT;
> buf += len_to_zero;
> event_size += name_len;
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: [PATCH] inotify: Ensure we alwasy write the terminating NULL.
2009-08-27 10:20 ` [PATCH] inotify: Ensure we alwasy write the terminating NULL Eric W. Biederman
2009-08-27 11:57 ` Eric Paris
@ 2009-08-28 13:29 ` Brian Rogers
2009-08-28 14:18 ` Eric Paris
1 sibling, 1 reply; 8+ messages in thread
From: Brian Rogers @ 2009-08-28 13:29 UTC (permalink / raw)
To: Eric W. Biederman
Cc: Eric Paris, linux-kernel, linux-fsdevel, Rafael J. Wysocki
[-- Attachment #1: Type: text/plain, Size: 1308 bytes --]
Eric W. Biederman wrote:
> Before the rewrite copy_event_to_user always wrote a terqminating '\0'
> byte to user space after the filename. Since the rewrite that
> terminating byte was skipped if your filename is exactly a multiple of
> event_size. Ouch!
>
> So add one byte to name_size before we round up and use clear_user to
> set userspace to zero like /dev/zero does instead of copying the
> strange nul_inotify_event. I can't quite convince myself len_to_zero
> will never exceed 16 and even if it doesn't clear_user should be more
> efficient and a more accurate reflection of what the code is trying to
> do.
>
> Signed-off-by: Eric W. Biederman <ebiederm@aristanetworks.com>
>
I found that this change prevents my Ubuntu Karmic system from booting.
It just idles forever very early in the process. Probably a boot script
is waiting for an event that it doesn't receive properly.
> - name_len = roundup(event->name_len, event_size);
> + name_len = roundup(event->name_len + 1, event_size);
>
This means the test later on will now always evaluate to true:
> if (name_len) {
And in cases where that test previously would have failed, the code now
outputs a block full of zeros. Assuming that's bad and the test was
important, I coded the attached naive fix, which is working for me.
[-- Attachment #2: 0001-inotify-Fix-events-with-no-pathname.patch --]
[-- Type: text/x-patch, Size: 1320 bytes --]
>From 1be7a610013b47be1257d2b0296d872d6bed7416 Mon Sep 17 00:00:00 2001
From: Brian Rogers <brian@xyzw.org>
Date: Fri, 28 Aug 2009 04:46:51 -0700
Subject: [PATCH] inotify: Fix events with no pathname
When an event has no pathname, there's no need to pad it with a null byte and
therefore generate an inotify_event sized block of zeros. This fixes a
regression introduced by commit 0db501bd0610ee0c0aca84d927f90bcccd09e2bd where
my system wouldn't finish booting because some process was being confused by
this.
Signed-off-by: Brian Rogers <brian@xyzw.org>
---
fs/notify/inotify/inotify_user.c | 5 ++++-
1 files changed, 4 insertions(+), 1 deletions(-)
diff --git a/fs/notify/inotify/inotify_user.c b/fs/notify/inotify/inotify_user.c
index 0e781bc..d94ce8b 100644
--- a/fs/notify/inotify/inotify_user.c
+++ b/fs/notify/inotify/inotify_user.c
@@ -199,7 +199,10 @@ static ssize_t copy_event_to_user(struct fsnotify_group *group,
/* round up event->name_len so it is a multiple of event_size
* plus an extra byte for the terminating '\0'.
*/
- name_len = roundup(event->name_len + 1, event_size);
+ if (event->name_len > 0)
+ name_len = roundup(event->name_len + 1, event_size);
+ else
+ name_len = 0;
inotify_event.len = name_len;
inotify_event.mask = inotify_mask_to_arg(event->mask);
--
1.6.3.3
^ permalink raw reply related [flat|nested] 8+ messages in thread
* Re: [PATCH] inotify: Ensure we alwasy write the terminating NULL.
2009-08-28 13:29 ` Brian Rogers
@ 2009-08-28 14:18 ` Eric Paris
0 siblings, 0 replies; 8+ messages in thread
From: Eric Paris @ 2009-08-28 14:18 UTC (permalink / raw)
To: Brian Rogers
Cc: Eric W. Biederman, linux-kernel, linux-fsdevel, Rafael J. Wysocki
On Fri, 2009-08-28 at 06:29 -0700, Brian Rogers wrote:
> Eric W. Biederman wrote:
> > Before the rewrite copy_event_to_user always wrote a terqminating '\0'
> > byte to user space after the filename. Since the rewrite that
> > terminating byte was skipped if your filename is exactly a multiple of
> > event_size. Ouch!
> >
> > So add one byte to name_size before we round up and use clear_user to
> > set userspace to zero like /dev/zero does instead of copying the
> > strange nul_inotify_event. I can't quite convince myself len_to_zero
> > will never exceed 16 and even if it doesn't clear_user should be more
> > efficient and a more accurate reflection of what the code is trying to
> > do.
> >
> > Signed-off-by: Eric W. Biederman <ebiederm@aristanetworks.com>
> >
>
> I found that this change prevents my Ubuntu Karmic system from booting.
> It just idles forever very early in the process. Probably a boot script
> is waiting for an event that it doesn't receive properly.
>
> > - name_len = roundup(event->name_len, event_size);
> > + name_len = roundup(event->name_len + 1, event_size);
> >
>
> This means the test later on will now always evaluate to true:
> > if (name_len) {
>
> And in cases where that test previously would have failed, the code now
> outputs a block full of zeros. Assuming that's bad and the test was
> important, I coded the attached naive fix, which is working for me.
Thanks, I ask Linus to pull a (slightly modified) version. Don't know
if he'll get it before he runs out on vacation. Here's hoping.
-Eric
^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2009-08-28 14:18 UTC | newest]
Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-08-26 9:06 v2.6.31-rc6 inotify not reporting deleted files Eric W. Biederman
2009-08-26 11:25 ` Eric Paris
2009-08-26 15:11 ` Eric Paris
2009-08-26 20:12 ` Eric W. Biederman
2009-08-27 10:20 ` [PATCH] inotify: Ensure we alwasy write the terminating NULL Eric W. Biederman
2009-08-27 11:57 ` Eric Paris
2009-08-28 13:29 ` Brian Rogers
2009-08-28 14:18 ` Eric Paris
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox