Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp2059856ybv; Fri, 14 Feb 2020 10:39:52 -0800 (PST) X-Google-Smtp-Source: APXvYqyrsLHD/gWvbWOvdH222dBG3jNPeMps/40Uaf3kmxUr5Q685tx7TX5/k5RDkfhJ+AZHylmk X-Received: by 2002:a9d:3f5:: with SMTP id f108mr3477245otf.103.1581705591909; Fri, 14 Feb 2020 10:39:51 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581705591; cv=none; d=google.com; s=arc-20160816; b=UV/8JVbrbTe2RbhsMaWqtV5O8DPGc7xr8fSsij5sxeAIk/NHE04N/xT5SkGK/Hm5Rx q2Kh1qLl+P78GrirtOjPRBCtnMZv/BUOgrmWKqrE4mBgl87y/bnvRYZ0WLHk4GwWGCPQ qoHt4R8e2W282j8MEgBQZDjc/Bj4/n5fd/ioAJ/14l9BwgACrv1OmB3Ir5u5aMfTRgKZ 2PNZyzM3aONsjJ+0/hy9xOHuuDzek2Oa42eoZl4MO55ywcdbLUd1thKLeowYFOd029CY b5/j/U2k62dYydRM7ws+kj2WSAB4bYtTUV04Qns/9cCyhR1s1m65p1kAZY80s3oQuyOh VFHg== 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=9A7d9snHoJ9TS+pxkqAZTnutgq4++j2KrR1Xzqfr4rQ=; b=yy7PJele8KkPJJsUHYgOhA9vR9+uaM3xQ6hDOXUVYkC0WVfTNUgxpLn4591a6YVn1c 5yf6qoo5hPMr2u8kPJ9A283gdbJnfzhMIe+i5KyL7zYXYU9WKaLb22UDZ2TGIITPFKG1 WhDYxLAruxl2piWiTDWIbtEYTzzvlD1NRnZltBTStI0G7ErUAdCXKcjhC+ZjS659qbsy xT/zJhA2c2GA7rFweQX3MGjtDP2CzEwnxsGkgp6+dFxZMaLwIGpKeGFcMlpKmdNz7kMl MsIxhB3xdCnE2U9cPItpZzI67VQ1ITEETt7mW6atE+xKVhaRnBuG74WRC/vOUpzWVguK ENUQ== 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 i6si3751269otj.24.2020.02.14.10.39.39; Fri, 14 Feb 2020 10:39:51 -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 S2389630AbgBNSiP (ORCPT + 99 others); Fri, 14 Feb 2020 13:38:15 -0500 Received: from youngberry.canonical.com ([91.189.89.112]:33749 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1730822AbgBNSiP (ORCPT ); Fri, 14 Feb 2020 13:38:15 -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 1j2fqc-0000uO-1J; Fri, 14 Feb 2020 18:37:54 +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 17/28] inode: inode_owner_or_capable(): handle fsid mappings Date: Fri, 14 Feb 2020 19:35:43 +0100 Message-Id: <20200214183554.1133805-18-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 Switch inode_owner_or_capable() to 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. 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 */ unchanged --- fs/inode.c | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/fs/inode.c b/fs/inode.c index 7d57068b6b7a..81d7a30b381d 100644 --- a/fs/inode.c +++ b/fs/inode.c @@ -21,6 +21,7 @@ #include #include #include +#include #include #include "internal.h" @@ -2087,8 +2088,12 @@ bool inode_owner_or_capable(const struct inode *inode) return true; ns = current_user_ns(); - if (kuid_has_mapping(ns, inode->i_uid) && ns_capable(ns, CAP_FOWNER)) + if (is_userns_visible(inode->i_sb->s_iflags)) { + if (kuid_has_mapping(ns, inode->i_uid) && ns_capable(ns, CAP_FOWNER)) + return true; + } else if (kfsuid_has_mapping(ns, inode->i_uid) && ns_capable(ns, CAP_FOWNER)) { return true; + } return false; } EXPORT_SYMBOL(inode_owner_or_capable); -- 2.25.0