Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp2061797ybv; Fri, 14 Feb 2020 10:42:05 -0800 (PST) X-Google-Smtp-Source: APXvYqzy92WgzZ8+Sum4H8TkksSMSBqD4B60Jk0DPIMT53nQ5I2hKwGf3JlETW5Pok7Mq5bPeNLK X-Received: by 2002:a9d:74c4:: with SMTP id a4mr3473941otl.119.1581705725670; Fri, 14 Feb 2020 10:42:05 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581705725; cv=none; d=google.com; s=arc-20160816; b=ZXaXgSc9c3btlddn+9+f3tws99nce8JM+ocFmQIuR0XQqUiunCsvvBk5pypNQpL+d0 K8o19NSzdoPF07LqkNnckBCgWd5bgll2Pv7AyxlVh6mGtmDt1yX0QaFi65jy9SKyhs0x XxRtJp+/BvDSb3gpOAWX2BEIpoLBE0ryFVKZZKHwfT8pStiDYPwq1botWlCAp7FTES5d Hfuh+coT1sRkBARE/wTNtKsiQ3linNd6x3wrjY28tFcjNEpxaWCLyRKeiz/A/fyH7Vff BPJ+DlIyiJMmq3lCgsZGTqoMGjVWtD0oJMMzhUA9ThBMAvq9RW687e6vnBmUMZnSYY5B BE4g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=KzdxpOfUt/EjYobnwtU2aDvrRtywh5Lo+bI40Y+tvZ8=; b=jUCwsCWy/Xk6G6pRDirU7XhyKRiJcOpctO2bdvMUbzP6Bc16aJRoPA38E2IWKrhNMz 8aK5JRTR0yh4DJxt3x5s7oubS+Rogl2ydlCBRWB8ltrqjvMScyJYUKoLdG36xVfXrPsh zS0L6XLvlTw3UzH1uD1VDpKRYIt9JYHPngNWaxSmPQh1WBKOQ7reYequ533O3sLhmesT a92T3gHpmmSc7VQNJjmgOG7mIUKw08OyRwtRPGYTVjEjAcI6wtLX80kZtDFCmz1WQpvk OkkaVjpvwVdFjDF+3/LJeuPHFyGqq096QQ1lpZYaXnrxeEN+hQHp9Y+IOWVBmMuxNtqN IEsQ== 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 5si3334708oiy.102.2020.02.14.10.41.52; Fri, 14 Feb 2020 10:42:05 -0800 (PST) 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 S2389511AbgBNSlu (ORCPT + 99 others); Fri, 14 Feb 2020 13:41:50 -0500 Received: from youngberry.canonical.com ([91.189.89.112]:33897 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388570AbgBNSlt (ORCPT ); Fri, 14 Feb 2020 13:41:49 -0500 Received: from ip5f5bf7ec.dynamic.kabel-deutschland.de ([95.91.247.236] helo=wittgenstein.fritz.box) by youngberry.canonical.com with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.86_2) (envelope-from ) id 1j2fqg-0000uO-Qn; Fri, 14 Feb 2020 18:37:58 +0000 From: Christian Brauner To: =?UTF-8?q?St=C3=A9phane=20Graber?= , "Eric W. Biederman" , Aleksa Sarai , Jann Horn Cc: smbarber@chromium.org, Seth Forshee , Alexander Viro , Alexey Dobriyan , Serge Hallyn , James Morris , Kees Cook , Jonathan Corbet , Phil Estes , linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org, containers@lists.linux-foundation.org, linux-security-module@vger.kernel.org, linux-api@vger.kernel.org, Christian Brauner Subject: [PATCH v2 20/28] open: handle fsid mappings Date: Fri, 14 Feb 2020 19:35:46 +0100 Message-Id: <20200214183554.1133805-21-christian.brauner@ubuntu.com> X-Mailer: git-send-email 2.25.0 In-Reply-To: <20200214183554.1133805-1-christian.brauner@ubuntu.com> References: <20200214183554.1133805-1-christian.brauner@ubuntu.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Let chown_common() lookup fsids in the fsid mappings. If no fsid mappings are setup the behavior is unchanged, i.e. fsids are looked up in the id mappings. do_faccessat() just needs to translate from real ids into fsids. Filesystems that share a superblock in all user namespaces they are mounted in will retain their old semantics even with the introduction of fsidmappings. Signed-off-by: Christian Brauner --- /* v2 */ - Christian Brauner : - handle faccessat() too --- fs/open.c | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/fs/open.c b/fs/open.c index 0788b3715731..4e092845728f 100644 --- a/fs/open.c +++ b/fs/open.c @@ -32,6 +32,7 @@ #include #include #include +#include #include "internal.h" @@ -361,8 +362,10 @@ long do_faccessat(int dfd, const char __user *filename, int mode) if (!override_cred) return -ENOMEM; - override_cred->fsuid = override_cred->uid; - override_cred->fsgid = override_cred->gid; + override_cred->kfsuid = override_cred->uid; + override_cred->kfsgid = override_cred->gid; + override_cred->fsuid = kuid_to_kfsuid(override_cred->user_ns, override_cred->uid); + override_cred->fsgid = kgid_to_kfsgid(override_cred->user_ns, override_cred->gid); if (!issecure(SECURE_NO_SETUID_FIXUP)) { /* Clear the capabilities if we switch to a non-root user */ @@ -626,8 +629,13 @@ static int chown_common(const struct path *path, uid_t user, gid_t group) kuid_t uid; kgid_t gid; - uid = make_kuid(current_user_ns(), user); - gid = make_kgid(current_user_ns(), group); + if (is_userns_visible(inode->i_sb->s_iflags)) { + uid = make_kuid(current_user_ns(), user); + gid = make_kgid(current_user_ns(), group); + } else { + uid = make_kfsuid(current_user_ns(), user); + gid = make_kfsgid(current_user_ns(), group); + } retry_deleg: newattrs.ia_valid = ATTR_CTIME; -- 2.25.0