Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp2826379pxv; Mon, 12 Jul 2021 02:54:40 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyJJ/ql3aKc6zCyHu9r+tUoMH43C5uLo/7V0yTZTWAmcXFxHQBvQyrsfTCxIuDXftd//lCX X-Received: by 2002:a02:ccec:: with SMTP id l12mr3789867jaq.61.1626083680840; Mon, 12 Jul 2021 02:54:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626083680; cv=none; d=google.com; s=arc-20160816; b=Mr3Fklnx1lHuKCAU6Fh9UuEsrOH0iK3SsRo52Q91IGa9NCRmhlZnPXHJMAzAjr74DU 2cN9QZQLmUJsN92afrJnFCp0DmCPxd2XQuPED1fq7xAiFj4PmN4EGF/OfJ4if3lhQIAP GtRJguQbXE2+lrceZOlHcxUAku5i7eH1wEKMgaKkwH9O6BHTtUMs6Qrmoh2LKcCwXJbi NEXoSJYbeOq/R8ycCQWbuzW2ZliJmTg1ETAqoXBkQxbnCZRzbJ5D08PNGDMWTTO+k2PQ hMl0QlbdlwauX5rgNbWXVy93rfH6ZAMbxqBBK9ak3oDH4nOPZrsQm8SypU2hwcDk+NOQ 9ALg== 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=uRqn1zfPT3a2eiYgqbHCOZExgPgBbEMosePVeIvMwB4=; b=hc8lT/fizkzeyZ6PUCILEdoWB9fL5wHtzInZ8NL67Kl9RNgMkWxf5Ung8CUcZ5qqJX wtYeBkYXW34GVUtns4tQifC1R/OisNZMQndPlACqV1V6tTXMZq3/RB4f8UckpgHlJbXw 7KI1EbSPEhl0l1LoQDQGzXmR7JiZmv263XXO2QnEDL/2s+SHu+sA1tDGqBYPCNksBdlq 09gjo17Z8bzmeKSjff2arGp0Uu+b7mk5+8nA0iFy8edAhmKkQC3QTCFggnPNeCL9nrcG 3Mdq9T8mc5299N+NHNcQ2jim7ZSVssZNgBqmt4x7zCda7t1pOEohKGVdxqYV5hfY7fc3 3IXQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=H31CyL7O; 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 c18si7049630iod.12.2021.07.12.02.54.29; Mon, 12 Jul 2021 02:54:40 -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=H31CyL7O; 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 S239782AbhGLGzf (ORCPT + 99 others); Mon, 12 Jul 2021 02:55:35 -0400 Received: from mail.kernel.org ([198.145.29.99]:36944 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S235645AbhGLGk0 (ORCPT ); Mon, 12 Jul 2021 02:40:26 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 97BB8610CA; Mon, 12 Jul 2021 06:37:37 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626071858; bh=ciWyHrI8F7a80Uv5lQKOIXTB6COewZixlNvZJ/T0PrQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=H31CyL7Owdq0gychK+vH3TkF+LkRvZvAhjgjL7GeKcFHf7Wh12EkSMCANOb2U8VEO 7FWrN384Yb+GfrpIXQKKa39fSvJPzjIDuyAoDNo9DGXpZ1jUPiyznfx3xhE0lBY7K5 UtbADpnjUlZHcvzHtIRpIZNIxsB0Cki3AKvjT4Jw= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Roman Gushchin , Jan Kara , Jan Kara , Alexander Viro , Dave Chinner , Dennis Zhou , Tejun Heo , Jens Axboe , Andrew Morton , Linus Torvalds , Sasha Levin Subject: [PATCH 5.10 208/593] writeback, cgroup: increment isw_nr_in_flight before grabbing an inode Date: Mon, 12 Jul 2021 08:06:08 +0200 Message-Id: <20210712060905.837847389@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: Roman Gushchin [ Upstream commit 8826ee4fe75051f8cbfa5d4a9aa70565938e724c ] isw_nr_in_flight is used to determine whether the inode switch queue should be flushed from the umount path. Currently it's increased after grabbing an inode and even scheduling the switch work. It means the umount path can walk past cleanup_offline_cgwb() with active inode references, which can result in a "Busy inodes after unmount." message and use-after-free issues (with inode->i_sb which gets freed). Fix it by incrementing isw_nr_in_flight before doing anything with the inode and decrementing in the case when switching wasn't scheduled. The problem hasn't yet been seen in the real life and was discovered by Jan Kara by looking into the code. Link: https://lkml.kernel.org/r/20210608230225.2078447-4-guro@fb.com Signed-off-by: Roman Gushchin Suggested-by: Jan Kara Reviewed-by: Jan Kara Cc: Alexander Viro Cc: Dave Chinner Cc: Dennis Zhou Cc: Tejun Heo Cc: Jens Axboe Signed-off-by: Andrew Morton Signed-off-by: Linus Torvalds Signed-off-by: Sasha Levin --- fs/fs-writeback.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/fs/fs-writeback.c b/fs/fs-writeback.c index 0d0f014b09ec..afda7a7263b7 100644 --- a/fs/fs-writeback.c +++ b/fs/fs-writeback.c @@ -505,6 +505,8 @@ static void inode_switch_wbs(struct inode *inode, int new_wb_id) if (!isw) return; + atomic_inc(&isw_nr_in_flight); + /* find and pin the new wb */ rcu_read_lock(); memcg_css = css_from_id(new_wb_id, &memory_cgrp_subsys); @@ -535,11 +537,10 @@ static void inode_switch_wbs(struct inode *inode, int new_wb_id) * Let's continue after I_WB_SWITCH is guaranteed to be visible. */ call_rcu(&isw->rcu_head, inode_switch_wbs_rcu_fn); - - atomic_inc(&isw_nr_in_flight); return; out_free: + atomic_dec(&isw_nr_in_flight); if (isw->new_wb) wb_put(isw->new_wb); kfree(isw); -- 2.30.2