[linux-cifs-client] [PATCH 1/4] cifs: make cifs_lookup return a dentry
Al Viro
viro at ZenIV.linux.org.uk
Sat May 22 08:46:15 MDT 2010
On Sat, May 22, 2010 at 10:08:36AM -0400, Jeff Layton wrote:
> On Sat, 22 May 2010 14:30:51 +0100
> Al Viro <viro at ZenIV.linux.org.uk> wrote:
>
> > On Fri, May 21, 2010 at 02:25:14PM -0400, Jeff Layton wrote:
> > > cifs_lookup doesn't actually return a dentry. It instantiates the one
> > > that's passed in, but callers don't have any way to know if the lookup
> > > succeeded.
> >
> > Huh? Of course they do - ->lookup() has every right to do just that;
> > d_add() and return NULL is perfectly legitimate.
>
> OK, bad description on my part... Is one way of doing this preferred
> over another?
Non-NULL, non ERR_PTR() strongly implies that you have found a different
dentry and tell the caller to use it instead; returning the argument (after
having cached it and bumped its refcount) will work, but it's pretty much
a deliberate obfuscation.
More information about the linux-cifs-client
mailing list