summaryrefslogtreecommitdiff
path: root/fs
diff options
context:
space:
mode:
authorChristoph Hellwig <hch@lst.de>2020-07-22 11:25:21 +0200
committerChristoph Hellwig <hch@lst.de>2020-07-31 08:17:52 +0200
commitdb63f1e315384590b979f8f74abd1b5363b69894 (patch)
tree5bcaeab28afa531c24c028f1b40e8d4cadd9ce53 /fs
parent20cce026c3e0972017b9cb4a7cccfb8cacf187d5 (diff)
downloadlwn-db63f1e315384590b979f8f74abd1b5363b69894.tar.gz
lwn-db63f1e315384590b979f8f74abd1b5363b69894.zip
init: add an init_chdir helper
Add a simple helper to chdir with a kernel space file name and switch the early init code over to it. Remove the now unused ksys_chdir. Signed-off-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'fs')
-rw-r--r--fs/init.c16
-rw-r--r--fs/open.c7
2 files changed, 17 insertions, 6 deletions
diff --git a/fs/init.c b/fs/init.c
index eabd9ed2b510..64d4e12eba93 100644
--- a/fs/init.c
+++ b/fs/init.c
@@ -7,6 +7,7 @@
#include <linux/mount.h>
#include <linux/namei.h>
#include <linux/fs.h>
+#include <linux/fs_struct.h>
#include <linux/init_syscalls.h>
#include "internal.h"
@@ -38,6 +39,21 @@ int __init init_umount(const char *name, int flags)
return path_umount(&path, flags);
}
+int __init init_chdir(const char *filename)
+{
+ struct path path;
+ int error;
+
+ error = kern_path(filename, LOOKUP_FOLLOW | LOOKUP_DIRECTORY, &path);
+ if (error)
+ return error;
+ error = inode_permission(path.dentry->d_inode, MAY_EXEC | MAY_CHDIR);
+ if (!error)
+ set_fs_pwd(current->fs, &path);
+ path_put(&path);
+ return error;
+}
+
int __init init_unlink(const char *pathname)
{
return do_unlinkat(AT_FDCWD, getname_kernel(pathname));
diff --git a/fs/open.c b/fs/open.c
index b316dd6a86a8..723e0ac89893 100644
--- a/fs/open.c
+++ b/fs/open.c
@@ -482,7 +482,7 @@ SYSCALL_DEFINE2(access, const char __user *, filename, int, mode)
return do_faccessat(AT_FDCWD, filename, mode, 0);
}
-int ksys_chdir(const char __user *filename)
+SYSCALL_DEFINE1(chdir, const char __user *, filename)
{
struct path path;
int error;
@@ -508,11 +508,6 @@ out:
return error;
}
-SYSCALL_DEFINE1(chdir, const char __user *, filename)
-{
- return ksys_chdir(filename);
-}
-
SYSCALL_DEFINE1(fchdir, unsigned int, fd)
{
struct fd f = fdget_raw(fd);