[PATCH] fix waitqueue leak in devfs_d_revalidate_wait

From: Christoph Hellwig (hch@lst.de)
Date: Tue Mar 18 2003 - 04:56:25 EST


devfs_d_revalidate_wait adds to a waitqueue but never removes from it
again so we there's one entry full of reused stack space added on
each call (I wonder how this ever worked).

The function has a few more bugs (it effectivly does a sleep_on instead
of checking for the actual even and can't deal with negative dentries
at all), but I just had breakfast and don't want to poke into devfs
internals deeper - I still hope Adam's smalldevfs will get merged
anyway..

--- 1.74/fs/devfs/base.c Mon Mar 17 01:33:08 2003
+++ edited/fs/devfs/base.c Tue Mar 18 09:37:29 2003
@@ -2336,6 +2232,8 @@
     wait_queue_head_t wait_queue;
 };
 
+/* XXX: this doesn't handle the case where we got a negative dentry
+ but a devfs entry has been registered in the meanwhile */
 static int devfs_d_revalidate_wait (struct dentry *dentry, int flags)
 {
     struct inode *dir = dentry->d_parent->d_inode;
@@ -2380,6 +2278,7 @@
         add_wait_queue (&lookup_info->wait_queue, &wait);
         read_unlock (&parent->u.dir.lock);
         schedule ();
+ remove_wait_queue (&lookup_info->wait_queue, &wait);
     }
     else read_unlock (&parent->u.dir.lock);
     return 1;
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/



This archive was generated by hypermail 2b29 : Sun Mar 23 2003 - 22:00:23 EST