fs: add do_readlinkat() helper; remove internal call to sys_readlinkat()
authorDominik Brodowski <linux@dominikbrodowski.net>
Sun, 11 Mar 2018 10:34:27 +0000 (11:34 +0100)
committerDominik Brodowski <linux@dominikbrodowski.net>
Mon, 2 Apr 2018 18:15:34 +0000 (20:15 +0200)
Using the do_readlinkat() helper removes an in-kernel call to the
sys_readlinkat() syscall.

This patch is part of a series which removes in-kernel calls to syscalls.
On this basis, the syscall entry path can be streamlined. For details, see
http://lkml.kernel.org/r/20180325162527.GA17492@light.dominikbrodowski.net

Cc: Alexander Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
fs/stat.c

index 873785dae022d9607ccb7b44fb56ea055a870283..f8e6fb2c36576219e9ec81b44828ffc2b058fec1 100644 (file)
--- a/fs/stat.c
+++ b/fs/stat.c
@@ -379,8 +379,8 @@ SYSCALL_DEFINE2(newfstat, unsigned int, fd, struct stat __user *, statbuf)
        return error;
 }
 
-SYSCALL_DEFINE4(readlinkat, int, dfd, const char __user *, pathname,
-               char __user *, buf, int, bufsiz)
+static int do_readlinkat(int dfd, const char __user *pathname,
+                        char __user *buf, int bufsiz)
 {
        struct path path;
        int error;
@@ -415,10 +415,16 @@ retry:
        return error;
 }
 
+SYSCALL_DEFINE4(readlinkat, int, dfd, const char __user *, pathname,
+               char __user *, buf, int, bufsiz)
+{
+       return do_readlinkat(dfd, pathname, buf, bufsiz);
+}
+
 SYSCALL_DEFINE3(readlink, const char __user *, path, char __user *, buf,
                int, bufsiz)
 {
-       return sys_readlinkat(AT_FDCWD, path, buf, bufsiz);
+       return do_readlinkat(AT_FDCWD, path, buf, bufsiz);
 }