summaryrefslogtreecommitdiffstats
path: root/net/sunrpc/rpc_pipe.c
diff options
context:
space:
mode:
authorTrond Myklebust <Trond.Myklebust@netapp.com>2009-08-09 21:14:17 +0200
committerTrond Myklebust <Trond.Myklebust@netapp.com>2009-08-09 21:14:17 +0200
commitb5bb61da2efe7519eedd6a8f3830ab33ab774b83 (patch)
tree811176448a5413ddbb01dca36c69bb390c8479cd /net/sunrpc/rpc_pipe.c
parentSUNRPC: Allow rpc_pipefs_ops to have null values for upcall and downcall (diff)
downloadlinux-b5bb61da2efe7519eedd6a8f3830ab33ab774b83.tar.xz
linux-b5bb61da2efe7519eedd6a8f3830ab33ab774b83.zip
SUNRPC: Clean up rpc_pipefs lookup code...
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
Diffstat (limited to 'net/sunrpc/rpc_pipe.c')
-rw-r--r--net/sunrpc/rpc_pipe.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/net/sunrpc/rpc_pipe.c b/net/sunrpc/rpc_pipe.c
index 8fa718201e3f..2940b926648c 100644
--- a/net/sunrpc/rpc_pipe.c
+++ b/net/sunrpc/rpc_pipe.c
@@ -484,12 +484,12 @@ static const struct dentry_operations rpc_dentry_operations = {
.d_delete = rpc_delete_dentry,
};
-static int
-rpc_lookup_parent(char *path, struct nameidata *nd)
+static int __rpc_lookup_path(const char *pathname, unsigned flags,
+ struct nameidata *nd)
{
struct vfsmount *mnt;
- if (path[0] == '\0')
+ if (pathname[0] == '\0')
return -ENOENT;
mnt = rpc_get_mount();
@@ -499,15 +499,20 @@ rpc_lookup_parent(char *path, struct nameidata *nd)
return PTR_ERR(mnt);
}
- if (vfs_path_lookup(mnt->mnt_root, mnt, path, LOOKUP_PARENT, nd)) {
+ if (vfs_path_lookup(mnt->mnt_root, mnt, pathname, flags, nd)) {
printk(KERN_WARNING "%s: %s failed to find path %s\n",
- __FILE__, __func__, path);
+ __FILE__, __func__, pathname);
rpc_put_mount();
return -ENOENT;
}
return 0;
}
+static int rpc_lookup_parent(const char *pathname, struct nameidata *nd)
+{
+ return __rpc_lookup_path(pathname, LOOKUP_PARENT, nd);
+}
+
static void
rpc_release_path(struct nameidata *nd)
{