Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2718655pxv; Sun, 11 Jul 2021 23:43:15 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzS7VxLEt0onTx6Pe+ohGQy5w4FJX82G/CM9HWUhmaZfjcVh1od5G0aCrEJkyN6czPNqASk X-Received: by 2002:a05:6402:53:: with SMTP id f19mr63377952edu.200.1626072194858; Sun, 11 Jul 2021 23:43:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626072194; cv=none; d=google.com; s=arc-20160816; b=x6gaMFkYfPQ0iJ7PQCrJ69WLuny+mGQpjVTV5tmGKWuExla7HpHzFMSbWjCdS7QqFS FXoLGAAFsSE5jd6890tYPKzCqZtiK4EUf321la4g16OzFjJ3IlDZOdrg+qjDvLjB+qFQ 9a5AoEx5tmlM4hzO4XeA3zNoqkwr2jPlALYjTzqCzQK1kcDokERd5h1p0KCntvDLM9ys NZ0AWZLsKTWSZ6EBob0Zj3swrCGLHa/AdDpjeu9kmPuzVyqUZBePzFBMOuATaSasVAM7 tTpQ4c7Gs6EbNRVv9oUYtovv6wbllrxieBGMjnavjRvxb0XNdw2OodhHTdU1doC0+9tu McBw== 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=keLUEJjIkf7yRCdyct4sYwFNL2Buy6xFlygH6kRcFuQ=; b=Gup/UY8MxYvG4iAD6BtUzFcjsPuyI04kUmDr79tTq0A/hDs9k9368gc6ewYS9w00ei RjRb45QdUlcCozHBEzIqSBWP4Y9nFXxhV1XcpwARL+uxaJgo5FgqaaUQXlwMRRRY5tch Yu3oUEEj/fxhmW/leLWBszReEWyoX+3j4QjhgN4Cw4nZ270VTBKfXukd/3NhCm+YfNtH 4+5mws6DptQdyCRcPuoeCs8AzV9+CboRfwNzHrysv9sgOlPsiN17qHpXQoUnHxZDqavI 9mZ87Ss7HoLtahlm7nZAmZ+xHBojrjKK+qTUYdFRa4Unly0mvihHMf1cDGU/FlK4tkUI N4LQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=r1qFFTCy; 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 b3si14307828ejb.219.2021.07.11.23.42.52; Sun, 11 Jul 2021 23:43:14 -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=r1qFFTCy; 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 S238690AbhGLGoI (ORCPT + 99 others); Mon, 12 Jul 2021 02:44:08 -0400 Received: from mail.kernel.org ([198.145.29.99]:54296 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237787AbhGLGew (ORCPT ); Mon, 12 Jul 2021 02:34:52 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 06498610CC; Mon, 12 Jul 2021 06:31:33 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626071494; bh=8wEe6pPYayhsMqChzZqG9CLsksACtKrtM/ZsWywEUz0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=r1qFFTCywpKbD/LlsUw7hfXGKJlWT5/KSWMhmdPrXsDnbgTxUeHnJ/GROxJsCQ6z+ ZXs1g1qKN9eAd+rGgZirx0G0aTj5bXxflDNP1faCVqTSJ8pdr19N11hx0U9lYp2yzt WJLhsLkTRoDO6tdHMSFEzWc506a7Q4QG4p17qA5Y= 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.10 093/593] fuse: Fix crash in fuse_dentry_automount() error path Date: Mon, 12 Jul 2021 08:04:13 +0200 Message-Id: <20210712060853.436592806@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210712060843.180606720@linuxfoundation.org> References: <20210712060843.180606720@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 @@ -340,8 +340,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);