On Tue, Mar 22, 2011 at 8:26 AM, Miklos Szeredi <miklos@xxxxxxxxxx> wrote: > > Add a new inode operation i_op->open(). This is for stacked > filesystems that want to return a struct file from a different > filesystem. Hmm.. > + struct inode *inode = nd->path.dentry->d_inode; > + > + if (inode->i_op->open) { > + int flags = filp->f_flags; > + put_filp(filp); > + filp = inode->i_op->open(nd->path.dentry, flags, cred); > + } else { > + filp = __dentry_open(&nd->path, filp, NULL, cred); > + } This seems broken. Why don't you just pass in the filp to the ->open routine, and drop that "flags" argument. Maybe other filesystems want to use ->open, but don't want to put_filp() on the filp we already allocated, only to allocate a new one? It seems like you made that unnecessarily hard on purpose, with no advantage to the interface. Linus -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html