Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp896316imu; Mon, 5 Nov 2018 10:22:56 -0800 (PST) X-Google-Smtp-Source: AJdET5dPvKWKXdB/DXZq4F0YHVGGUaMLNfyN7IWYUvJxZoKkqeELdxzX0lVHJF2bLyDEonmGaVFS X-Received: by 2002:a63:c341:: with SMTP id e1-v6mr21045041pgd.452.1541442176103; Mon, 05 Nov 2018 10:22:56 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1541442176; cv=none; d=google.com; s=arc-20160816; b=us2PVF0jWmvs6rx0vs2DfHvKRBJDeriipQDB7y4NZCH/dahKs4Na6Ct1wo2tl8T9u3 qsAZKW1ZfVq1q4ajJtngIoRw0uHPKBjLwaP1q6Q74cIzuXyM4tGDcU87wLSn5f6MaqNE 865q/CvFpGl7Bszvr8BkbGy+VvdJ7S8SUEzpKktNsVy+DbJuOo5PCbqZ69m/CpuTHO15 tVEmVXMRjTROCU2Gz6dexI4pXX1p2gMYO4Yhnk12xMHlWIBPI+yhFDEAkTzFuzMSagh9 wP1LsJop/CegLnpGUgPXRxbAIi21qsjI7drhgPzgSTbcnb3fUfLDuDtwGym9KthjiPDI +bqw== 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 :dkim-signature; bh=IcHeJPDy1T6WJ8Fq/KWMAHt8XXMgVqCQgxCpPKbKBJs=; b=1EVQEE+BKC+qBpogBJ9912TX2ir3kXm/SgO7/tDncpzfLjhOhfbFwXj4ScTajWQafh B+RYzzasUXbXqCyDKCUOh07ZrtNKcdyFhg6WEHA6qJ6xRCW7RZVeYT2or3zS3Lj5syAX kchDv8tcD1t657PKBlNOJOlVCe8JDmiGqqiAB5MEiLm028YyLEmUxCCubrT4u1FQmNiw 1nyrsRDK+rgDddN1eVNYDSiwkst+HW6UWF0Ehdjymm0eAjUipPJULuV3S13mlWe1wQWX 2IG3d51JvL0BHIdiNyzc867NSagzIXdCzeZHIhfwBFi+A1fTTe7f7/rQeT2LpXunZsJf JFyg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@android.com header.s=20161025 header.b=M9wXyYqI; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=android.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 59-v6si24020271pla.195.2018.11.05.10.22.40; Mon, 05 Nov 2018 10:22:56 -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; dkim=pass header.i=@android.com header.s=20161025 header.b=M9wXyYqI; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=android.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2387911AbeKFDnC (ORCPT + 99 others); Mon, 5 Nov 2018 22:43:02 -0500 Received: from mail-pf1-f195.google.com ([209.85.210.195]:45180 "EHLO mail-pf1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2387862AbeKFDnC (ORCPT ); Mon, 5 Nov 2018 22:43:02 -0500 Received: by mail-pf1-f195.google.com with SMTP id p17-v6so4440318pfj.12 for ; Mon, 05 Nov 2018 10:22:08 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=android.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=IcHeJPDy1T6WJ8Fq/KWMAHt8XXMgVqCQgxCpPKbKBJs=; b=M9wXyYqIKEgqQIEmct5wd2kPiiSHE43E9Lkvrp7BmJdE9NKWkYx3+QVjmoU0tCY9uk M+wRAz4dAVV+MkuPtJ7+hPsAb2/On0bruoOvwk0/A3DGI4ZX0qg3siPeJrJwF4aOSt/6 sk/MXZNbtGWdPd6udNfraOmG5pTpChd1Yc2ayv/EhfyZsuMvlpcsedktv7YAoOpG5gAe 4mEkvdOKN1edoo+LaV9Uk4IgLd2+hFuqYj4cDNfukkyddBk4z7L1wYH4fklyLzq0deYA U0sQbHUuJTgDPhZOYqfdpKV3l1Cv0oJfo/0P/Rcogh/MF/1yzLlaz1vnufZbJU0B9Xxp n5Sw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=IcHeJPDy1T6WJ8Fq/KWMAHt8XXMgVqCQgxCpPKbKBJs=; b=n/4r9l5lVDwkc9nG0ozPHdHl37051e6FQzj6W0/tjtjENy8mJ5ug7JqDTXs0a9NVMY MznmOueXD49J05SNN5LvOn0einZVbwxcXHVuEWz8MpBk5Qrfp5ih3RwXfBFypAXrDYom FKWYh7+8O3H6+p5ya0TEI9yLWKCxKSUUvI+mWouw+4rsdWr4sHdPPuskrLAkdy47LlaC fIREJFNKMiQFcghYwTvskQ4FAGR2OJd6JHgdsSzJSChGXOoPUD+BfoSYnbT6vOlxq4V5 EWE1ADF2cLS0WaqhAHerdsLlKXUGbWZX83ZaoEv5aHASGANP/ri6m7b8CETSPKoXlskG 6NVw== X-Gm-Message-State: AGRZ1gLRaxLp70JTv3cZqy2sYniF7LiO6ynwXyod7kTFThw6NFXRIktf eUXIP+rU4hU3sCA5OhIApe69BGuJA68= X-Received: by 2002:a62:7d10:: with SMTP id y16-v6mr22939181pfc.245.1541442127796; Mon, 05 Nov 2018 10:22:07 -0800 (PST) Received: from nebulus.mtv.corp.google.com ([2620:0:1000:1612:b4fb:6752:f21f:3502]) by smtp.gmail.com with ESMTPSA id s184-v6sm53788626pfb.46.2018.11.05.10.22.06 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Mon, 05 Nov 2018 10:22:07 -0800 (PST) From: Mark Salyzyn To: linux-kernel@vger.kernel.org Cc: Mark Salyzyn , Miklos Szeredi , Jonathan Corbet , Vivek Goyal , "Eric W . Biederman" , Amir Goldstein , Randy Dunlap , Stephen Smalley , linux-unionfs@vger.kernel.org, linux-doc@vger.kernel.org, kernel-team@android.com Subject: [PATCH v6 1/2] overlayfs: check CAP_DAC_READ_SEARCH before issuing exportfs_decode_fh Date: Mon, 5 Nov 2018 10:21:41 -0800 Message-Id: <20181105182146.233025-2-salyzyn@android.com> X-Mailer: git-send-email 2.19.1.930.g4563a0d9d0-goog In-Reply-To: <20181105182146.233025-1-salyzyn@android.com> References: <20181105182146.233025-1-salyzyn@android.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 Assumption never checked, should fail if the mounter creds are not sufficient. Signed-off-by: Mark Salyzyn Cc: Miklos Szeredi Cc: Jonathan Corbet Cc: Vivek Goyal Cc: Eric W. Biederman Cc: Amir Goldstein Cc: Randy Dunlap Cc: Stephen Smalley Cc: linux-unionfs@vger.kernel.org Cc: linux-doc@vger.kernel.org Cc: linux-kernel@vger.kernel.org Cc: kernel-team@android.com v5: - dependency of "overlayfs: override_creds=off option bypass creator_cred" v6: - rebase --- fs/overlayfs/namei.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/fs/overlayfs/namei.c b/fs/overlayfs/namei.c index efd372312ef1..aa012b6bd46e 100644 --- a/fs/overlayfs/namei.c +++ b/fs/overlayfs/namei.c @@ -163,6 +163,11 @@ struct dentry *ovl_decode_real_fh(struct ovl_fh *fh, struct vfsmount *mnt, if (!uuid_equal(&fh->uuid, &mnt->mnt_sb->s_uuid)) return NULL; + if (!capable(CAP_DAC_READ_SEARCH)) { + origin = ERR_PTR(-EPERM); + goto out; + } + bytes = (fh->len - offsetof(struct ovl_fh, fid)); real = exportfs_decode_fh(mnt, (struct fid *)fh->fid, bytes >> 2, (int)fh->type, -- 2.19.1.930.g4563a0d9d0-goog