Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2833264pxv; Mon, 12 Jul 2021 03:04:53 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyyJYbowC7vaq094mKfSHRxnux2P4SSN7x9+A+Pb/M82Clhi8F3B54wP3uPcXYhMYFaY1PN X-Received: by 2002:a5d:85c1:: with SMTP id e1mr38094399ios.18.1626084293000; Mon, 12 Jul 2021 03:04:53 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626084292; cv=none; d=google.com; s=arc-20160816; b=NDJJFf7iexj6aEhTHYUDcXQm/M4V2DqMU3knMk9X4zv5XXv9fZnajJrZcmEZQD1h2K adKxRN0Q5a4IMW/MNLqUIMWEv7qWrjWv2VGPTQ4begBObmcKZrfvHwFkdOQ0oUKFAwwN lcT4c/UNhjddWFI2Jc8kNV1qh7jCRb5+uGtJATt9FN1XZGRrHx3OS5M38fr09ZGw92VC M+nUw87MepM/nqA9z8JdQVa1oBTxf7ExtNnH8qnlu1/c98yIWuYfgtKO5bhm1G6uvuLk GXSY2ENveTK7vxqA60Q9TS6JwYYyNN4oHuny7mWTxWQm9z9G0mKC+c4KwNFf93jgcfRS gj1Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Pvswf+Lx5++ZaYavm2atKPOWv4FZJrGZmAjf3oUS2vw=; b=l9uFbTBCRNnvxjzRxsxBgxOMCfKUsiXOC+Rb889CZARVe/BWCMsKUqNnPfDCJ4fWRQ XJ3khScPW3LGBfyzQvpYM3iQjT7pBt9sXYHvrwkE2i3LJ9A5Wb1BIghsDjd2o9PuK5nY AIqj7CF6z6lknvTZ/NyyHwzh5RnPp2VVbRRePuLlO5Ov/HrtZIqo56n3MNSIsfezCQ0T R2j3NIhAQ1FTyWZ1uFPI2JJLVaVzVm18lFZZYGWdSV1z47Vaf+obLBWe2lT/nFlpYGod GlCLg6xBHcOBRYzrZWS2rsWae+JaMiQLfUpYor6Gmif2I+FAo6a39HD9j0KRbboe+EmM lLaQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=1DA3our2; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id r17si18859304iov.104.2021.07.12.03.04.41; Mon, 12 Jul 2021 03:04:52 -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; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=1DA3our2; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S245308AbhGLH1d (ORCPT + 99 others); Mon, 12 Jul 2021 03:27:33 -0400 Received: from mail.kernel.org ([198.145.29.99]:34850 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242837AbhGLHA2 (ORCPT ); Mon, 12 Jul 2021 03:00:28 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 0223F60233; Mon, 12 Jul 2021 06:57:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626073059; bh=DEM2YR0kYmML1Z7DuhT1d4Acs45PbKhtsc7SVSzqIkU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=1DA3our21kcfCxMcljbZwKbbc/dwkEEUIE4qQ/s33V13i2R85ipyOyuUmiOBPf4Oo 7FODb2bQDFIfgGxujMl6hTYfNePKkW76GYZEvqFOmgwCZve7g6HbsQZsvlub2TRwmL FDxhauLDUWB74WatOQYzHP8H1GbWCUk+QQXaqXsM= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Greg Kurz , Max Reitz , Miklos Szeredi Subject: [PATCH 5.12 112/700] fuse: Fix crash in fuse_dentry_automount() error path Date: Mon, 12 Jul 2021 08:03:15 +0200 Message-Id: <20210712060940.666974643@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210712060924.797321836@linuxfoundation.org> References: <20210712060924.797321836@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Greg Kurz commit d92d88f0568e97c437eeb79d9c9609bd8277406f upstream. If fuse_fill_super_submount() returns an error, the error path triggers a crash: [ 26.206673] BUG: kernel NULL pointer dereference, address: 0000000000000000 [...] [ 26.226362] RIP: 0010:__list_del_entry_valid+0x25/0x90 [...] [ 26.247938] Call Trace: [ 26.248300] fuse_mount_remove+0x2c/0x70 [fuse] [ 26.248892] virtio_kill_sb+0x22/0x160 [virtiofs] [ 26.249487] deactivate_locked_super+0x36/0xa0 [ 26.250077] fuse_dentry_automount+0x178/0x1a0 [fuse] The crash happens because fuse_mount_remove() assumes that the FUSE mount was already added to list under the FUSE connection, but this only done after fuse_fill_super_submount() has returned success. This means that until fuse_fill_super_submount() has returned success, the FUSE mount isn't actually owned by the superblock. We should thus reclaim ownership by clearing sb->s_fs_info, which will skip the call to fuse_mount_remove(), and perform rollback, like virtio_fs_get_tree() already does for the root sb. Fixes: bf109c64040f ("fuse: implement crossmounts") Cc: stable@vger.kernel.org # v5.10+ Signed-off-by: Greg Kurz Reviewed-by: Max Reitz Signed-off-by: Miklos Szeredi Signed-off-by: Greg Kroah-Hartman --- fs/fuse/dir.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) --- a/fs/fuse/dir.c +++ b/fs/fuse/dir.c @@ -339,8 +339,12 @@ static struct vfsmount *fuse_dentry_auto /* Initialize superblock, making @mp_fi its root */ err = fuse_fill_super_submount(sb, mp_fi); - if (err) + if (err) { + fuse_conn_put(fc); + kfree(fm); + sb->s_fs_info = NULL; goto out_put_sb; + } sb->s_flags |= SB_ACTIVE; fsc->root = dget(sb->s_root);