Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp2060902ybv; Fri, 14 Feb 2020 10:41:01 -0800 (PST) X-Google-Smtp-Source: APXvYqwaUR/se11qmFuBW5c6MoFkWLKzT+QaWFihkdlVP3CJgWKAOXx9V4VmlcYLyD6gwVfVwWN2 X-Received: by 2002:a05:6830:4a4:: with SMTP id l4mr3422302otd.91.1581705660914; Fri, 14 Feb 2020 10:41:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581705660; cv=none; d=google.com; s=arc-20160816; b=gUOx4JQd6KXFMp+7Gxa/KJcoLtnpP8LxtYjnKcgi6PV2tbBL7T8eLZv0kdfR7hV5Cp J74m9BYJDloV/6Auu0hfBrPcw/Ae8L9xoVPgCeCupg8Ldi57H0SBieGOiNG4x1BUkajU 1tKwjGGiWyIoc6Dtau/F/8hJ35iysKX2WlC364bEHDUiIQv6aS4nf96QITMLGcpYxcD1 EdNcFMTCe2sdGcUn6DOw+fAFnUhO0Zze475zHdPEDolX2FXQoN7nv/pJUnDdRaFoLr8C skKMajdKwwKNBKm/XrG8eZaoG5AlcE9w03RKl/SBUqVtxk0ZREhkFMU7xthItndIojSg dqnw== 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=q7SmmdtIM4yNYhKOvvg1JIyKMZrelLJBOm1fc6NamEw=; b=pUDewPan5xn8PzgqAHlhImRx2i5IqhkeuSoy924pm2UQFrM0Ac5cgxrytuWpuQCrTu SCc5cYHJSyM9fzKvPRz4nP9I13b4pkof4s8A5gHuX2yro2vh35hAtqGplDEQoGuq1nY6 zlRdl7+MBMZoUFts4iXQAZd647wxLHy9AKukCcHeL3UI+DQHAbXhPBDJUVmkIGMm9zxD GRLCuYgbAOrkTpak5JMzfPLD9zn12vvefk7zeJWXVkOR+bkSOF6UwEFSmsat1YpeCsO6 gGSaqc5NCm2VTg5mx6DkfB3XjvKqlkQoxH1OWQrIoy2QHF5a7K9mxMNVe0cZTTzCBHdO CW1g== 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 q9si2771464oij.125.2020.02.14.10.40.49; Fri, 14 Feb 2020 10:41:00 -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 S2388570AbgBNSkq (ORCPT + 99 others); Fri, 14 Feb 2020 13:40:46 -0500 Received: from youngberry.canonical.com ([91.189.89.112]:33837 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729781AbgBNSkp (ORCPT ); Fri, 14 Feb 2020 13:40:45 -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 1j2fqj-0000uO-8o; Fri, 14 Feb 2020 18:38:01 +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 22/28] attr: notify_change(): handle fsid mappings Date: Fri, 14 Feb 2020 19:35:48 +0100 Message-Id: <20200214183554.1133805-23-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 notify_change() 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/attr.c | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/fs/attr.c b/fs/attr.c index b4bbdbd4c8ca..b3fe9d9582d2 100644 --- a/fs/attr.c +++ b/fs/attr.c @@ -17,6 +17,8 @@ #include #include #include +#include +#include static bool chown_ok(const struct inode *inode, kuid_t uid) { @@ -310,12 +312,21 @@ int notify_change(struct dentry * dentry, struct iattr * attr, struct inode **de * Verify that uid/gid changes are valid in the target * namespace of the superblock. */ - if (ia_valid & ATTR_UID && - !kuid_has_mapping(inode->i_sb->s_user_ns, attr->ia_uid)) - return -EOVERFLOW; - if (ia_valid & ATTR_GID && - !kgid_has_mapping(inode->i_sb->s_user_ns, attr->ia_gid)) - return -EOVERFLOW; + if (is_userns_visible(inode->i_sb->s_iflags)) { + if (ia_valid & ATTR_UID && + !kuid_has_mapping(inode->i_sb->s_user_ns, attr->ia_uid)) + return -EOVERFLOW; + if (ia_valid & ATTR_GID && + !kgid_has_mapping(inode->i_sb->s_user_ns, attr->ia_gid)) + return -EOVERFLOW; + } else { + if (ia_valid & ATTR_UID && + !kfsuid_has_mapping(inode->i_sb->s_user_ns, attr->ia_uid)) + return -EOVERFLOW; + if (ia_valid & ATTR_GID && + !kfsgid_has_mapping(inode->i_sb->s_user_ns, attr->ia_gid)) + return -EOVERFLOW; + } /* Don't allow modifications of files with invalid uids or * gids unless those uids & gids are being made valid. -- 2.25.0