mirror of
https://github.com/torvalds/linux.git
synced 2024-11-24 13:11:40 +00:00
NFS: Reduce the stack footprint of nfs_follow_remote_path()
Signed-off-by: Trond Myklebust <Trond.Myklebust@netapp.com>
This commit is contained in:
parent
e1fb4d05d5
commit
04ffdbe2e6
@ -2672,38 +2672,44 @@ out_freepage:
|
|||||||
static int nfs_follow_remote_path(struct vfsmount *root_mnt,
|
static int nfs_follow_remote_path(struct vfsmount *root_mnt,
|
||||||
const char *export_path, struct vfsmount *mnt_target)
|
const char *export_path, struct vfsmount *mnt_target)
|
||||||
{
|
{
|
||||||
|
struct nameidata *nd = NULL;
|
||||||
struct mnt_namespace *ns_private;
|
struct mnt_namespace *ns_private;
|
||||||
struct nameidata nd;
|
|
||||||
struct super_block *s;
|
struct super_block *s;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
nd = kmalloc(sizeof(*nd), GFP_KERNEL);
|
||||||
|
if (nd == NULL)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
ns_private = create_mnt_ns(root_mnt);
|
ns_private = create_mnt_ns(root_mnt);
|
||||||
ret = PTR_ERR(ns_private);
|
ret = PTR_ERR(ns_private);
|
||||||
if (IS_ERR(ns_private))
|
if (IS_ERR(ns_private))
|
||||||
goto out_mntput;
|
goto out_mntput;
|
||||||
|
|
||||||
ret = vfs_path_lookup(root_mnt->mnt_root, root_mnt,
|
ret = vfs_path_lookup(root_mnt->mnt_root, root_mnt,
|
||||||
export_path, LOOKUP_FOLLOW, &nd);
|
export_path, LOOKUP_FOLLOW, nd);
|
||||||
|
|
||||||
put_mnt_ns(ns_private);
|
put_mnt_ns(ns_private);
|
||||||
|
|
||||||
if (ret != 0)
|
if (ret != 0)
|
||||||
goto out_err;
|
goto out_err;
|
||||||
|
|
||||||
s = nd.path.mnt->mnt_sb;
|
s = nd->path.mnt->mnt_sb;
|
||||||
atomic_inc(&s->s_active);
|
atomic_inc(&s->s_active);
|
||||||
mnt_target->mnt_sb = s;
|
mnt_target->mnt_sb = s;
|
||||||
mnt_target->mnt_root = dget(nd.path.dentry);
|
mnt_target->mnt_root = dget(nd->path.dentry);
|
||||||
|
|
||||||
/* Correct the device pathname */
|
/* Correct the device pathname */
|
||||||
nfs_fix_devname(&nd.path, mnt_target);
|
nfs_fix_devname(&nd->path, mnt_target);
|
||||||
|
|
||||||
path_put(&nd.path);
|
path_put(&nd->path);
|
||||||
|
kfree(nd);
|
||||||
down_write(&s->s_umount);
|
down_write(&s->s_umount);
|
||||||
return 0;
|
return 0;
|
||||||
out_mntput:
|
out_mntput:
|
||||||
mntput(root_mnt);
|
mntput(root_mnt);
|
||||||
out_err:
|
out_err:
|
||||||
|
kfree(nd);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user