Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp5731126ybv; Tue, 18 Feb 2020 02:57:26 -0800 (PST) X-Google-Smtp-Source: APXvYqxNDTvyqvGMkMTD/Zus/ULS78cxgLQuN/LPKCRrRGFJlXK1MeOfNuNZ7i2rQu2eLnrbIg0q X-Received: by 2002:aca:33d5:: with SMTP id z204mr776352oiz.120.1582023446589; Tue, 18 Feb 2020 02:57:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582023446; cv=none; d=google.com; s=arc-20160816; b=gd7mQ3LV+UVT99mQpX3FclfqEFAvCKLN+iNEXbKnuGj1joYIeyx4bGDbA06/xBHPiJ LHLSdMEJegcw2JXtMjh/SyEmwVFvNom4P9gmkZRijm+qNhvzG5+/+kQODxCn1n+EwHA0 WrBoxtGYr7EU9Y5gTJGVOQ8ZMmUW8q/zybolQGUJ9qDqi3V88AcX+wCYndwlE2xrQ+Ja RFMVnkHQDZIw/FAtLm17FuqrTk2UIkhFRK1qK8W40f8iFBMqQuxbtvaujqzue2Ekqmgq ppz+J/q+wzkRN628d6nCSh5BK8W+maRxt8ZgcV3aKkXXGGwPa+FlyzIAwHtbGGyMtktE W2Zw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from; bh=Xkux124NZnnCTBEyTuBvySeDzU85o39Ds4Xz3+KlLH0=; b=KCoCThNfRe+eHOv7gWfD1XDwP0iq5M7JQA530nkv5ogEoGK9FlsySjuGNEokCbHz+Z SI4pER7Ahwva1uSCey6hx6oIx3l/hKIyD4RVsO7Jaz1xLN2KN9FTf7UlaFx0LoLssd2k mRwRPPd71bR4X2seMjVi59COO44lZ7YCIfvLcSe7FAZdarKeaMPCIS7KQluyRA3UvZDh 6E3H9KEgbZ7qIESA3QxUkPw6WBYMMUkzwaASpohSXSDIPq4ZCIfgIWgJ5v/gaSTasJ6S ex6Sr63yC+2/ahodt389waZkij9hfFlbLdb3FO8S0oigH9+sqAndDC9r4DR0YzubC1Ep BoCg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-ext4-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p23si1628220otk.119.2020.02.18.02.57.11; Tue, 18 Feb 2020 02:57:26 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-ext4-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-ext4-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-ext4-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726327AbgBRK4j (ORCPT + 99 others); Tue, 18 Feb 2020 05:56:39 -0500 Received: from szxga04-in.huawei.com ([45.249.212.190]:10636 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726496AbgBRK4i (ORCPT ); Tue, 18 Feb 2020 05:56:38 -0500 Received: from DGGEMS405-HUB.china.huawei.com (unknown [172.30.72.58]) by Forcepoint Email with ESMTP id 6D391E9C42D8BE5EA82B; Tue, 18 Feb 2020 18:56:35 +0800 (CST) Received: from huawei.com (10.175.124.28) by DGGEMS405-HUB.china.huawei.com (10.3.19.205) with Microsoft SMTP Server id 14.3.439.0; Tue, 18 Feb 2020 18:56:25 +0800 From: "zhangyi (F)" To: CC: , , , , Subject: [PATCH 4.4 2/2] jbd2: do not clear the BH_Mapped flag when forgetting a metadata buffer Date: Tue, 18 Feb 2020 18:55:15 +0800 Message-ID: <20200218105515.6548-2-yi.zhang@huawei.com> X-Mailer: git-send-email 2.17.2 In-Reply-To: <20200218105515.6548-1-yi.zhang@huawei.com> References: <20200218105515.6548-1-yi.zhang@huawei.com> MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.175.124.28] X-CFilter-Loop: Reflected Sender: linux-ext4-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-ext4@vger.kernel.org [ Upstream commit c96dceeabf765d0b1b1f29c3bf50a5c01315b820 ] Commit 904cdbd41d74 ("jbd2: clear dirty flag when revoking a buffer from an older transaction") set the BH_Freed flag when forgetting a metadata buffer which belongs to the committing transaction, it indicate the committing process clear dirty bits when it is done with the buffer. But it also clear the BH_Mapped flag at the same time, which may trigger below NULL pointer oops when block_size < PAGE_SIZE. rmdir 1 kjournald2 mkdir 2 jbd2_journal_commit_transaction commit transaction N jbd2_journal_forget set_buffer_freed(bh1) jbd2_journal_commit_transaction commit transaction N+1 ... clear_buffer_mapped(bh1) ext4_getblk(bh2 ummapped) ... grow_dev_page init_page_buffers bh1->b_private=NULL bh2->b_private=NULL jbd2_journal_put_journal_head(jh1) __journal_remove_journal_head(hb1) jh1 is NULL and trigger oops *) Dir entry block bh1 and bh2 belongs to one page, and the bh2 has already been unmapped. For the metadata buffer we forgetting, we should always keep the mapped flag and clear the dirty flags is enough, so this patch pick out the these buffers and keep their BH_Mapped flag. Link: https://lore.kernel.org/r/20200213063821.30455-3-yi.zhang@huawei.com Fixes: 904cdbd41d74 ("jbd2: clear dirty flag when revoking a buffer from an older transaction") Reviewed-by: Jan Kara Signed-off-by: zhangyi (F) Signed-off-by: Theodore Ts'o Cc: stable@kernel.org --- fs/jbd2/commit.c | 25 +++++++++++++++++++++---- 1 file changed, 21 insertions(+), 4 deletions(-) diff --git a/fs/jbd2/commit.c b/fs/jbd2/commit.c index 3bf86d912b76..7fe61edb1bb9 100644 --- a/fs/jbd2/commit.c +++ b/fs/jbd2/commit.c @@ -996,12 +996,29 @@ restart_loop: * pagesize and it is attached to the last partial page. */ if (buffer_freed(bh) && !jh->b_next_transaction) { + struct address_space *mapping; + clear_buffer_freed(bh); clear_buffer_jbddirty(bh); - clear_buffer_mapped(bh); - clear_buffer_new(bh); - clear_buffer_req(bh); - bh->b_bdev = NULL; + + /* + * Block device buffers need to stay mapped all the + * time, so it is enough to clear buffer_jbddirty and + * buffer_freed bits. For the file mapping buffers (i.e. + * journalled data) we need to unmap buffer and clear + * more bits. We also need to be careful about the check + * because the data page mapping can get cleared under + * out hands, which alse need not to clear more bits + * because the page and buffers will be freed and can + * never be reused once we are done with them. + */ + mapping = READ_ONCE(bh->b_page->mapping); + if (mapping && !sb_is_blkdev_sb(mapping->host->i_sb)) { + clear_buffer_mapped(bh); + clear_buffer_new(bh); + clear_buffer_req(bh); + bh->b_bdev = NULL; + } } if (buffer_jbddirty(bh)) { -- 2.17.2