Add a BUG_ON() to check for passing an unreferenced dentry to dput(). This is analogous to the similar check in dget(), and will make reference-counting bugs in filesystems more immediately obvious. (I just spent a while debugging an oops that turned out to be due to broken fs reference counting.)
Signed-off-by: Paul Menage <[EMAIL PROTECTED]> --- fs/dcache.c | 1 + 1 file changed, 1 insertion(+) Index: container-2.6.23-rc3-mm1/fs/dcache.c =================================================================== --- container-2.6.23-rc3-mm1.orig/fs/dcache.c +++ container-2.6.23-rc3-mm1/fs/dcache.c @@ -176,6 +176,7 @@ void dput(struct dentry *dentry) if (!dentry) return; + BUG_ON(!atomic_read(&dentry->d_count)); repeat: if (atomic_read(&dentry->d_count) == 1) might_sleep(); - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/