Received: by 10.213.65.68 with SMTP id h4csp143862imn; Thu, 15 Mar 2018 12:11:03 -0700 (PDT) X-Google-Smtp-Source: AG47ELscB3WeRsnUAi8XIS93UTLlsW1nGFd/ddkGDGP15aoE5JhQhB8aE1yxbSkn8vcSqdrcw4ug X-Received: by 2002:a17:902:3183:: with SMTP id x3-v6mr9317232plb.383.1521141063702; Thu, 15 Mar 2018 12:11:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521141063; cv=none; d=google.com; s=arc-20160816; b=kpPqAApNtT5/rDVTvJM7Ry6X6h7fDt+sG30e+MgjUUcTfn6VpIDApfuUypkWYJbSWW zUhc5yLJh7c4Xt/8YKxzvzSrBJVKwRTQ8qMdxzoh2QpPmWonQ6qhRYDnqkRE+8ptOpCE Q4NO1FgAA4EXmjkNxqtav0Demf5dnMPLCLfoSkajjFRcKb3rds0VoS+4Rt1leKIfN1KO PzxcgT8A8Yg2iMSAwBPpztCfBPmcCe8jRrGtCVy1l7j2S85CEZlW/9Yb5fNlIRK0zXC5 e38zbg+maVGEtzrPA/Bg6fJLv/CUOT80r/tA03VZXL1KNG1nMR60cxCzAmBXpAyUMnM4 galg== 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=CpwfEooRFcjDMljNBxBrzS5SshBZUnzS6zrlYkAmRq4=; b=owr+UUMyeaxxekst49Cujax1VZJxzcjA5ssyN2n+e8TJ3cGLuWPsDuzujz/FDtiB7u GwW0h3GHS5+uV9SxD+DJh6FgBH1XYx2FuvUy6qVP9KVx+715kOcIQ9C5p2A704sZCAet 6TepG7ao57HybB6HKvslQJLc8v4SWGj0IXxnwBpLbUKSwVZIOB4sP55jmlZAQ/upxE/H ZiNbg4VCnhgkmrxteOsFI8IAyE736UNS/DTLD8TE+8d0h9W2lI4+ZDI0A9gA8Qi/AXkk wpuvivB/xP3bDd5L7hX9XrONKmIE20IlA4pMnsXB+dXj/iiKkllS+n/IGMfHw+gi63JZ t58w== 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 r79si4212776pfb.126.2018.03.15.12.10.49; Thu, 15 Mar 2018 12:11:03 -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 S932885AbeCOTIA (ORCPT + 99 others); Thu, 15 Mar 2018 15:08:00 -0400 Received: from isilmar-4.linta.de ([136.243.71.142]:36184 "EHLO isilmar-4.linta.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932674AbeCOTGY (ORCPT ); Thu, 15 Mar 2018 15:06:24 -0400 Received: from light.dominikbrodowski.net (isilmar.linta [10.0.0.1]) by isilmar-4.linta.de (Postfix) with ESMTPS id F0E96200928; Thu, 15 Mar 2018 19:06:18 +0000 (UTC) Received: by light.dominikbrodowski.net (Postfix, from userid 1000) id 1EF0F2066B; 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 15/36] fs: add ksys_umount() helper; remove in-kernel call to sys_umount() Date: Thu, 15 Mar 2018 20:05:08 +0100 Message-Id: <20180315190529.20943-16-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 this helper allows us to avoid the in-kernel call to the sys_umount() syscall. Cc: Alexander Viro Signed-off-by: Dominik Brodowski --- fs/namespace.c | 9 +++++++-- include/linux/syscalls.h | 1 + init/do_mounts_initrd.c | 2 +- 3 files changed, 9 insertions(+), 3 deletions(-) diff --git a/fs/namespace.c b/fs/namespace.c index 642b8b229944..e398f32d7541 100644 --- a/fs/namespace.c +++ b/fs/namespace.c @@ -1680,7 +1680,7 @@ static inline bool may_mandlock(void) * unixes. Our API is identical to OSF/1 to avoid making a mess of AMD */ -SYSCALL_DEFINE2(umount, char __user *, name, int, flags) +int ksys_umount(char __user *name, int flags) { struct path path; struct mount *mnt; @@ -1720,6 +1720,11 @@ SYSCALL_DEFINE2(umount, char __user *, name, int, flags) return retval; } +SYSCALL_DEFINE2(umount, char __user *, name, int, flags) +{ + return ksys_umount(name, flags); +} + #ifdef __ARCH_WANT_SYS_OLDUMOUNT /* @@ -1727,7 +1732,7 @@ SYSCALL_DEFINE2(umount, char __user *, name, int, flags) */ SYSCALL_DEFINE1(oldumount, char __user *, name) { - return sys_umount(name, 0); + return ksys_umount(name, 0); } #endif diff --git a/include/linux/syscalls.h b/include/linux/syscalls.h index 69899ffa03e9..929dfc6c2906 100644 --- a/include/linux/syscalls.h +++ b/include/linux/syscalls.h @@ -950,5 +950,6 @@ asmlinkage long sys_statx(int dfd, const char __user *path, unsigned flags, int ksys_mount(char __user *dev_name, char __user *dir_name, char __user *type, unsigned long flags, void __user *data); +int ksys_umount(char __user *name, int flags); #endif diff --git a/init/do_mounts_initrd.c b/init/do_mounts_initrd.c index 7868a6039fb4..1c4da8353332 100644 --- a/init/do_mounts_initrd.c +++ b/init/do_mounts_initrd.c @@ -105,7 +105,7 @@ static void __init handle_initrd(void) else printk("failed\n"); printk(KERN_NOTICE "Unmounting old root\n"); - sys_umount("/old", MNT_DETACH); + ksys_umount("/old", MNT_DETACH); printk(KERN_NOTICE "Trying to free ramdisk memory ... "); if (fd < 0) { error = fd; -- 2.16.2