Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp4235618pxf; Tue, 30 Mar 2021 02:47:13 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzTUQGJ9Nd3DAAh1FM0/w0Zd4RYYadzHtX/qhluTQIymcI0ndICme8SlD6zffNVaWL9CYKW X-Received: by 2002:aa7:c804:: with SMTP id a4mr32063101edt.251.1617097633035; Tue, 30 Mar 2021 02:47:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617097633; cv=none; d=google.com; s=arc-20160816; b=sO7t+bFVh3BV978uCtl9AxDcFsxrndmGKzhlU8vAkzDMX3Dck7nbTCOKEUVMTU9tnc O7Oq52ThFK085Tqar7lSuhW22Uk13wDLBSQDuVnZJJBsw497wgbpzLgtEAsunzXzO+Al 7JEmNRPERA4oQBxIb7ZHSsE6G9RAdwZshY8Dp2nuVFU1vCDhlMpbvXSv2oGtWwF3Nds+ 5p9GY00uTubns5ZN5/QNKVWmaLS68Jh7RjYFNGoO1myihGcSvnnCw0L5015JQBv1Hcic oG2L0U5kyc9TdTmDk8vTrRyuYYVI23F5yWkLA3+doAu6FqShORcZjf8RunpPKEkOPqAP CviA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=5ntQHbgYOq+j5qDwfBn5J6zmpuQX8jcWzQvBwEKOOFw=; b=g16niWS/XpMrg+GcbKUGJv9oF9H9F1OM0WCudq1fp3FShrFK8TFP4ba/XxiNRMozci tuNyrZYH4w7P3mKlKs45PKkCdEB10Ou6afaDuK7k2TQBuW4eOweSu4m8oJNNjN4N2rTH +CrWUvQQyh9YGZ6bb7VibUPppNwRJ1DqY5ehr6ZihTp8a8whhc7BnJtMSAdfHLSdPs7k kZvWGqXWyJk8yu9nxYnQUtupa+Fj1lHJ6nQiw22Y36JJ0elzHbklWDTyDNgrt5S1ND+/ eor9mNkI1G20z3JCkhG0paijb8sI/gn74xW9YTHfAnNAK3jeQRqKP/IDH2vdl/LOK64H vEzw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id bm7si13875085edb.188.2021.03.30.02.46.50; Tue, 30 Mar 2021 02:47:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231576AbhC3JnS (ORCPT + 99 others); Tue, 30 Mar 2021 05:43:18 -0400 Received: from smtp-190a.mail.infomaniak.ch ([185.125.25.10]:33303 "EHLO smtp-190a.mail.infomaniak.ch" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231481AbhC3JnB (ORCPT ); Tue, 30 Mar 2021 05:43:01 -0400 Received: from smtp-3-0001.mail.infomaniak.ch (unknown [10.4.36.108]) by smtp-3-3000.mail.infomaniak.ch (Postfix) with ESMTPS id 4F8kyW6mfzzMpvrk; Tue, 30 Mar 2021 11:42:59 +0200 (CEST) Received: from ns3096276.ip-94-23-54.eu (unknown [23.97.221.149]) by smtp-3-0001.mail.infomaniak.ch (Postfix) with ESMTPA id 4F8kyV6y72zlh8TT; Tue, 30 Mar 2021 11:42:58 +0200 (CEST) Subject: Re: [PATCH v1] ovl: Fix leaked dentry To: Miklos Szeredi Cc: linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org, linux-unionfs@vger.kernel.org, Amir Goldstein , Vivek Goyal , stable@vger.kernel.org, syzbot , =?UTF-8?Q?Micka=c3=abl_Sala=c3=bcn?= References: <20210329164907.2133175-1-mic@digikod.net> From: =?UTF-8?Q?Micka=c3=abl_Sala=c3=bcn?= Message-ID: Date: Tue, 30 Mar 2021 11:44:00 +0200 User-Agent: MIME-Version: 1.0 In-Reply-To: <20210329164907.2133175-1-mic@digikod.net> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 29/03/2021 18:49, Mickaël Salaün wrote: > From: Mickaël Salaün > > Since commit 6815f479ca90 ("ovl: use only uppermetacopy state in > ovl_lookup()"), overlayfs doesn't put temporary dentry when there is a > metacopy error, which leads to dentry leaks when shutting down the > related superblock: > > overlayfs: refusing to follow metacopy origin for (/file0) > ... > BUG: Dentry (____ptrval____){i=3f33,n=file3} still in use (1) [unmount of overlay overlay] > ... > WARNING: CPU: 1 PID: 432 at umount_check.cold+0x107/0x14d > CPU: 1 PID: 432 Comm: unmount-overlay Not tainted 5.12.0-rc5 #1 > ... > RIP: 0010:umount_check.cold+0x107/0x14d > ... > Call Trace: > d_walk+0x28c/0x950 > ? dentry_lru_isolate+0x2b0/0x2b0 > ? __kasan_slab_free+0x12/0x20 > do_one_tree+0x33/0x60 > shrink_dcache_for_umount+0x78/0x1d0 > generic_shutdown_super+0x70/0x440 > kill_anon_super+0x3e/0x70 > deactivate_locked_super+0xc4/0x160 > deactivate_super+0xfa/0x140 > cleanup_mnt+0x22e/0x370 > __cleanup_mnt+0x1a/0x30 > task_work_run+0x139/0x210 > do_exit+0xb0c/0x2820 > ? __kasan_check_read+0x1d/0x30 > ? find_held_lock+0x35/0x160 > ? lock_release+0x1b6/0x660 > ? mm_update_next_owner+0xa20/0xa20 > ? reacquire_held_locks+0x3f0/0x3f0 > ? __sanitizer_cov_trace_const_cmp4+0x22/0x30 > do_group_exit+0x135/0x380 > __do_sys_exit_group.isra.0+0x20/0x20 > __x64_sys_exit_group+0x3c/0x50 > do_syscall_64+0x45/0x70 > entry_SYSCALL_64_after_hwframe+0x44/0xae > ... > VFS: Busy inodes after unmount of overlay. Self-destruct in 5 seconds. Have a nice day... > > This fix has been tested with a syzkaller reproducer. > > Cc: Amir Goldstein > Cc: Miklos Szeredi > Cc: Vivek Goyal > Cc: # v5.7+ The bogus commit 6815f479ca90 was applied on v5.7-rc2 but it is only available since v5.8+ . > Reported-by: syzbot > Fixes: 6815f479ca90 ("ovl: use only uppermetacopy state in ovl_lookup()") > Signed-off-by: Mickaël Salaün > Link: https://lore.kernel.org/r/20210329164907.2133175-1-mic@digikod.net > --- > fs/overlayfs/namei.c | 1 + > 1 file changed, 1 insertion(+) > > diff --git a/fs/overlayfs/namei.c b/fs/overlayfs/namei.c > index 3fe05fb5d145..424c594afd79 100644 > --- a/fs/overlayfs/namei.c > +++ b/fs/overlayfs/namei.c > @@ -921,6 +921,7 @@ struct dentry *ovl_lookup(struct inode *dir, struct dentry *dentry, > if ((uppermetacopy || d.metacopy) && !ofs->config.metacopy) { > err = -EPERM; > pr_warn_ratelimited("refusing to follow metacopy origin for (%pd2)\n", dentry); > + dput(this); > goto out_put; > } > > > base-commit: a5e13c6df0e41702d2b2c77c8ad41677ebb065b3 >