提交 ce6595a2 编写于 作者: A Al Viro

kill the last users of user_{path,lpath,path_dir}()

old wrappers with few callers remaining; put them out of their misery...
Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
上级 6b61aed0
...@@ -63,11 +63,8 @@ static long coda_pioctl(struct file *filp, unsigned int cmd, ...@@ -63,11 +63,8 @@ static long coda_pioctl(struct file *filp, unsigned int cmd,
* Look up the pathname. Note that the pathname is in * Look up the pathname. Note that the pathname is in
* user memory, and namei takes care of this * user memory, and namei takes care of this
*/ */
if (data.follow) error = user_path_at(AT_FDCWD, data.path,
error = user_path(data.path, &path); data.follow ? LOOKUP_FOLLOW : 0, &path);
else
error = user_lpath(data.path, &path);
if (error) if (error)
return error; return error;
......
...@@ -3044,7 +3044,7 @@ long do_mount(const char *dev_name, const char __user *dir_name, ...@@ -3044,7 +3044,7 @@ long do_mount(const char *dev_name, const char __user *dir_name,
return -EINVAL; return -EINVAL;
/* ... and get the mountpoint */ /* ... and get the mountpoint */
retval = user_path(dir_name, &path); retval = user_path_at(AT_FDCWD, dir_name, LOOKUP_FOLLOW, &path);
if (retval) if (retval)
return retval; return retval;
...@@ -3591,11 +3591,13 @@ SYSCALL_DEFINE2(pivot_root, const char __user *, new_root, ...@@ -3591,11 +3591,13 @@ SYSCALL_DEFINE2(pivot_root, const char __user *, new_root,
if (!may_mount()) if (!may_mount())
return -EPERM; return -EPERM;
error = user_path_dir(new_root, &new); error = user_path_at(AT_FDCWD, new_root,
LOOKUP_FOLLOW | LOOKUP_DIRECTORY, &new);
if (error) if (error)
goto out0; goto out0;
error = user_path_dir(put_old, &old); error = user_path_at(AT_FDCWD, put_old,
LOOKUP_FOLLOW | LOOKUP_DIRECTORY, &old);
if (error) if (error)
goto out1; goto out1;
......
...@@ -67,7 +67,7 @@ xfs_find_handle( ...@@ -67,7 +67,7 @@ xfs_find_handle(
return -EBADF; return -EBADF;
inode = file_inode(f.file); inode = file_inode(f.file);
} else { } else {
error = user_lpath((const char __user *)hreq->path, &path); error = user_path_at(AT_FDCWD, hreq->path, 0, &path);
if (error) if (error)
return error; return error;
inode = d_inode(path.dentry); inode = d_inode(path.dentry);
......
...@@ -48,22 +48,6 @@ static inline int user_path_at(int dfd, const char __user *name, unsigned flags, ...@@ -48,22 +48,6 @@ static inline int user_path_at(int dfd, const char __user *name, unsigned flags,
return user_path_at_empty(dfd, name, flags, path, NULL); return user_path_at_empty(dfd, name, flags, path, NULL);
} }
static inline int user_path(const char __user *name, struct path *path)
{
return user_path_at_empty(AT_FDCWD, name, LOOKUP_FOLLOW, path, NULL);
}
static inline int user_lpath(const char __user *name, struct path *path)
{
return user_path_at_empty(AT_FDCWD, name, 0, path, NULL);
}
static inline int user_path_dir(const char __user *name, struct path *path)
{
return user_path_at_empty(AT_FDCWD, name,
LOOKUP_FOLLOW | LOOKUP_DIRECTORY, path, NULL);
}
extern int kern_path(const char *, unsigned, struct path *); extern int kern_path(const char *, unsigned, struct path *);
extern struct dentry *kern_path_create(int, const char *, struct path *, unsigned int); extern struct dentry *kern_path_create(int, const char *, struct path *, unsigned int);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册