On Tue, Aug 12, 2008 at 02:46:46PM +0100, David Woodhouse wrote:
> +static inline struct dentry *d_obtain_alias(struct inode *inode)
> +{
> +     struct dentry *d = d_alloc_anon(inode);
> +     if (!d)
> +             iput(inode);
> +     return d;
> +}
> +#endif

I'm not sure when al wants to merge with Linus, but the for-next naming
makes it sound like the tree is the .28 queue.  Also please take the
full implementation of d_obtain_alias from

        
http://git.kernel.org/?p=linux/kernel/git/viro/vfs-2.6.git;a=commitdiff;h=10cdb734be3c4175b977ba18eafbaba8e5716291

please.  Your light implementation will crash and burn when btrfs_iget
returns an error.

> +/* The size of encoded fh is the type number of the fh itself */
> +#define BTRFS_FID_NON_CONNECTABLE            5
> +#define BTRFS_FID_CONNECTABLE                        8

That was an assumption in the very old code, but I think it's a very
bad idea.  Just give your filehandles a uniqueue type number, e.g. in
the 0x4? range so that people looking at nfs traffic using a packet
analyzer know what kind of fhs they are actually dealing with.

> +     if (IS_ERR(inode))
> +             return (void *)inode;
> +
> +     if (generation != inode->i_generation) {
> +             iput(inode);
> +             return ERR_PTR(-ESTALE);
> +     }
> +
> +     result = d_alloc_anon(inode);
> +     if (!result) {
> +             iput(inode);
> +             return ERR_PTR(-ENOMEM);
> +     }

Didn't you intend to use d_obtain_alias?

--
To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to