Received: by 10.213.65.68 with SMTP id h4csp145001imn; Thu, 15 Mar 2018 12:13:18 -0700 (PDT) X-Google-Smtp-Source: AG47ELtvmdVfnLpoe42BbNE0dy0jzddhhDvfaq7Ez1ErOicHkhbyLCKJqfG1vGuQ377Ln9+jHmqQ X-Received: by 2002:a17:902:6f01:: with SMTP id w1-v6mr1833129plk.196.1521141198896; Thu, 15 Mar 2018 12:13:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521141198; cv=none; d=google.com; s=arc-20160816; b=DHE5rSVq6faHRvLql1McJPFE5/WYB1e5YptNSPkkV3fiTQQM95ASdctE1Fomr4GGmT PMld8DWpzINW7zijBCXwLJQxGgB4cYlEYkvZLRUZKyaD3NrRjZLWH3K+JI9zAtKTKlEB FHa2/xk6EN8E8Tx+f9S3+3xtqGBgJTnaOkBOvh4Ey8EumGTIDqwyoU13uS7+GkX7S0Oi /qrR4pnacZ5IlhZxDebDZszAvPaMkG9tJBO91xaaMGa4bhqzlbAQxPIAhPY1v/zx1yBc dycm/lSXDLPqxHbrNHlJ0UHP1AcTn8kqp1vS7H8rlbrWhByuWkp7X4kUDrcoXsbcwKx+ X7RQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=1o4w1X4B7oncxUjpELp3el8frP9F0K4sc5Vn5aFi+5o=; b=N0fAdDWX3EQ9UgaqugfilR677NWLfjFlPxx+VgZ/WQ3hL3N0nW3iNIfkYnap/pnQE/ LKuyse6evWf+Qjuse28YjQuAYFBDRqixOCkr/L9Q4w0m5ZRMuhaG0lZdcNKHfHqpdsJF D6BVsekNdTcXhni07U/BoNFO/6Ul2W4CN5Gq8yGbjINTcu9eWmJZilb+qUUJ0QAm26SB zoZVcIiOg2XJrbQXUK9kJHS77qFDdVRQvsMXYL/3gQ4y9i1jaoYAzwIFvx8X8Tln+yD3 EQUNFjw15diZkrB/d9diOOnxdGtCileKWSBhB+k2R4HJ/0esyI9UK56EyNw9X8KLV0kS 2h4w== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v3-v6si4533804plb.522.2018.03.15.12.13.03; Thu, 15 Mar 2018 12:13:18 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932839AbeCOTLL (ORCPT + 99 others); Thu, 15 Mar 2018 15:11:11 -0400 Received: from isilmar-4.linta.de ([136.243.71.142]:36244 "EHLO isilmar-4.linta.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932650AbeCOTGW (ORCPT ); Thu, 15 Mar 2018 15:06:22 -0400 Received: from light.dominikbrodowski.net (isilmar.linta [10.0.0.1]) by isilmar-4.linta.de (Postfix) with ESMTPS id 95C2B200918; Thu, 15 Mar 2018 19:06:18 +0000 (UTC) Received: by light.dominikbrodowski.net (Postfix, from userid 1000) id D4C77209EF; Thu, 15 Mar 2018 20:05:39 +0100 (CET) From: Dominik Brodowski To: linux-kernel@vger.kernel.org, torvalds@linux-foundation.org, viro@zeniv.linux.org.uk Cc: luto@kernel.org, mingo@kernel.org, akpm@linux-foundation.org, arnd@arndb.de Subject: [PATCH v2 30/36] fs: add do_linkat() helper and ksys_link() wrapper; remove in-kernel calls to syscall Date: Thu, 15 Mar 2018 20:05:23 +0100 Message-Id: <20180315190529.20943-31-linux@dominikbrodowski.net> X-Mailer: git-send-email 2.16.2 In-Reply-To: <20180315190529.20943-1-linux@dominikbrodowski.net> References: <20180315190529.20943-1-linux@dominikbrodowski.net> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Using the fs-internal do_linkat() helper allows us to get rid of fs-internal calls to the sys_linkat() syscall. Introducing the ksys_link() wrapper allows us to avoid the in-kernel calls to sys_link() syscall. Cc: Al Viro Cc: Andrew Morton Signed-off-by: Dominik Brodowski --- fs/internal.h | 2 ++ fs/namei.c | 12 +++++++++--- include/linux/syscalls.h | 9 +++++++++ init/initramfs.c | 2 +- 4 files changed, 21 insertions(+), 4 deletions(-) diff --git a/fs/internal.h b/fs/internal.h index 4f0b67054c54..91e6fc93fcb5 100644 --- a/fs/internal.h +++ b/fs/internal.h @@ -62,6 +62,8 @@ long do_rmdir(int dfd, const char __user *pathname); long do_unlinkat(int dfd, struct filename *name); long do_symlinkat(const char __user *oldname, int newdfd, const char __user *newname); +int do_linkat(int olddfd, const char __user *oldname, int newdfd, + const char __user *newname, int flags); /* * namespace.c diff --git a/fs/namei.c b/fs/namei.c index 8459a18cdd18..10148235829f 100644 --- a/fs/namei.c +++ b/fs/namei.c @@ -4250,8 +4250,8 @@ EXPORT_SYMBOL(vfs_link); * with linux 2.0, and to avoid hard-linking to directories * and other special files. --ADM */ -SYSCALL_DEFINE5(linkat, int, olddfd, const char __user *, oldname, - int, newdfd, const char __user *, newname, int, flags) +int do_linkat(int olddfd, const char __user *oldname, int newdfd, + const char __user *newname, int flags) { struct dentry *new_dentry; struct path old_path, new_path; @@ -4315,9 +4315,15 @@ SYSCALL_DEFINE5(linkat, int, olddfd, const char __user *, oldname, return error; } +SYSCALL_DEFINE5(linkat, int, olddfd, const char __user *, oldname, + int, newdfd, const char __user *, newname, int, flags) +{ + return do_linkat(olddfd, oldname, newdfd, newname, flags); +} + SYSCALL_DEFINE2(link, const char __user *, oldname, const char __user *, newname) { - return sys_linkat(AT_FDCWD, oldname, AT_FDCWD, newname, 0); + return do_linkat(AT_FDCWD, oldname, AT_FDCWD, newname, 0); } /** diff --git a/include/linux/syscalls.h b/include/linux/syscalls.h index a003ffedff52..eb8745869833 100644 --- a/include/linux/syscalls.h +++ b/include/linux/syscalls.h @@ -1014,4 +1014,13 @@ static inline long ksys_mknod(const char __user *filename, umode_t mode, return do_mknodat(AT_FDCWD, filename, mode, dev); } +extern int do_linkat(int olddfd, const char __user *oldname, int newdfd, + const char __user *newname, int flags); + +static inline long ksys_link(const char __user *oldname, + const char __user *newname) +{ + return do_linkat(AT_FDCWD, oldname, AT_FDCWD, newname, 0); +} + #endif diff --git a/init/initramfs.c b/init/initramfs.c index 2972ed0ab399..5855ab632b4e 100644 --- a/init/initramfs.c +++ b/init/initramfs.c @@ -306,7 +306,7 @@ static int __init maybe_link(void) if (nlink >= 2) { char *old = find_link(major, minor, ino, mode, collected); if (old) - return (sys_link(old, collected) < 0) ? -1 : 1; + return (ksys_link(old, collected) < 0) ? -1 : 1; } return 0; } -- 2.16.2