From: Oleg Drokin <green@linuxhacker.ru>
To: Trond Myklebust <trond.myklebust@fys.uio.no>
Cc: linux-kernel@vger.kernel.org, viro@zeniv.linux.org.uk
Subject: Re: d_instantiate_unique / NFS inode leakage?
Date: Thu, 5 Jan 2006 10:09:33 +0200 [thread overview]
Message-ID: <20060105080933.GK5743@linuxhacker.ru> (raw)
In-Reply-To: <1136424407.7847.37.camel@lade.trondhjem.org>
Hello!
On Thu, Jan 05, 2006 at 02:26:47AM +0100, Trond Myklebust wrote:
> > Searching for inode leakage in NFS code (seen in 2.6.14 and 2.6.15 at least,
> > have not tried earlier versions), I see suspicious place in
> > d_instantiate_unique (the only user happens to be NFS).
> > There if we have found aliased dentry that we return, inode reference is
> > not dropped and inode is not attached anywhere, so it seems the reference
> > to inode is leaked in that case.
> Yep, that looks like it ought to be the correct behaviour. Could you
> please also add a note to this effect in the DocBook header for
> d_instantiate_unique?
Sure.
--- fs/dcache.c.orig 2006-01-05 02:28:57.000000000 +0200
+++ fs/dcache.c 2006-01-05 10:04:02.000000000 +0200
@@ -808,10 +808,14 @@ void d_instantiate(struct dentry *entry,
*
* Fill in inode information in the entry. On success, it returns NULL.
* If an unhashed alias of "entry" already exists, then we return the
- * aliased dentry instead.
+ * aliased dentry instead and drop one reference to inode.
*
* Note that in order to avoid conflicts with rename() etc, the caller
* had better be holding the parent directory semaphore.
+ *
+ * This also assumes that the inode count has been incremented
+ * (or otherwise set) by the caller to indicate that it is now
+ * in use by the dcache.
*/
struct dentry *d_instantiate_unique(struct dentry *entry, struct inode *inode)
{
@@ -838,6 +842,7 @@ struct dentry *d_instantiate_unique(stru
dget_locked(alias);
spin_unlock(&dcache_lock);
BUG_ON(!d_unhashed(alias));
+ iput(inode);
return alias;
}
list_add(&entry->d_alias, &inode->i_dentry);
Bye,
Oleg
next prev parent reply other threads:[~2006-01-05 8:08 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-01-05 1:00 d_instantiate_unique / NFS inode leakage? Oleg Drokin
2006-01-05 1:26 ` Trond Myklebust
2006-01-05 8:09 ` Oleg Drokin [this message]
2006-01-06 20:07 ` Trond Myklebust
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20060105080933.GK5743@linuxhacker.ru \
--to=green@linuxhacker.ru \
--cc=linux-kernel@vger.kernel.org \
--cc=trond.myklebust@fys.uio.no \
--cc=viro@zeniv.linux.org.uk \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.