Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp3088340rwb; Mon, 15 Aug 2022 17:50:40 -0700 (PDT) X-Google-Smtp-Source: AA6agR6hXv9tO2cqNdD2Q7WtKazPZxUvn/Qna4fjAIzhmqkS8aB5h5V7cprBUr+B+bc0LSy9RxQk X-Received: by 2002:a05:6402:1771:b0:43d:3fab:dd73 with SMTP id da17-20020a056402177100b0043d3fabdd73mr16579762edb.136.1660611040174; Mon, 15 Aug 2022 17:50:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660611040; cv=none; d=google.com; s=arc-20160816; b=zPhGZakCHcU8Lwas21JkhWHOSing1/T9VihUAVrkXaolj7Gjw211j+1gPBqTO69mdw fAowGNid5OeTd8hh/1sUVFrHWdF7una8yCgonnLNh+FIhWxESZ+fZH4KBkvsyxx7Nq+H oXvky9/QRRvyJQ87KOgMslwGAlOssLm8h6Cnbyvej/R2+Bh2+lKxTUN1CMID8k1Lrqrd QLpJh+KBZfxwbSe2KGKVLjwsZH1SKtax9MHaFIqX439ODJ0vtAQBGVZ2xX3bd4OKJP+v tL0m7XocEoxUHCiaQ3k8/Ca5+Aqj5m0sMydgSPajGqGuXetJ8NlHoRntiHFBer9niAyn NOhA== 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=9bbMn/oCWzNxZrk1QNiMoitZORaYyhVFhipTcTiCttE=; b=p7/Qmc02HmbMi+2EkS+BrA6z22UxivbJzWc/0glxP5Ux8MFmpqyTAtrTgZ1qP3X7vU on+ROIE82X6JMYDBKmhGkgoj13G6b6dp259Aq7VfIrnQsGx/REkgUabmoNd8QAzmwStc vSYhddwBKNJerJmvMBswSrFdnaBc/8AKpAuCqlxsC9HuAZUj4RLZVJlTRBOkW6DmUfLs p2uI+6diI7HTgZA5t4r0n0t5lv1LqclO03v/qRn55bSe5U1E5cM0/2sL4obr4XvhZNJs 8zMZluTb1cGx7YLqb68wpu5hjcSpsZ5jxCXlzYB+oooeDoFA6/WXtUKk8rU2GuvQNWXc U+Nw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=oIbewXdU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id r2-20020a056402034200b0043e64d81518si8334371edw.619.2022.08.15.17.50.14; Mon, 15 Aug 2022 17:50:40 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=oIbewXdU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 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 S1354521AbiHOXs2 (ORCPT + 99 others); Mon, 15 Aug 2022 19:48:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60968 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1354232AbiHOXll (ORCPT ); Mon, 15 Aug 2022 19:41:41 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E4E4E614A; Mon, 15 Aug 2022 13:11:18 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 786796077B; Mon, 15 Aug 2022 20:11:18 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 63E5AC433C1; Mon, 15 Aug 2022 20:11:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1660594277; bh=ECYLy6ZnFKRuF+2gIewQOS7C8kcMwJoNV5HEHpGO02I=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=oIbewXdUyfAcOZNuwzEBddBydJ1oW4G7l1IuZfpd5YkHs0mEBVL4xBB8JSlFehD2M Otu0v7gG1pgIwlYaXS1SeFKKuRq1cjsxYiAmI+AQcUyuii5c5h2JRW8f9jHFRGLVgB uCwvKE5+str4VFLe1OKhlTRqYVHyXJ7nhb6M9xBA= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Theodore Tso , stable@kernel.org, Andreas Dilger , Sasha Levin Subject: [PATCH 5.18 1054/1095] ext4: update s_overhead_clusters in the superblock during an on-line resize Date: Mon, 15 Aug 2022 20:07:33 +0200 Message-Id: <20220815180512.668476663@linuxfoundation.org> X-Mailer: git-send-email 2.37.2 In-Reply-To: <20220815180429.240518113@linuxfoundation.org> References: <20220815180429.240518113@linuxfoundation.org> User-Agent: quilt/0.67 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Theodore Ts'o [ Upstream commit de394a86658ffe4e89e5328fd4993abfe41b7435 ] When doing an online resize, the on-disk superblock on-disk wasn't updated. This means that when the file system is unmounted and remounted, and the on-disk overhead value is non-zero, this would result in the results of statfs(2) to be incorrect. This was partially fixed by Commits 10b01ee92df5 ("ext4: fix overhead calculation to account for the reserved gdt blocks"), 85d825dbf489 ("ext4: force overhead calculation if the s_overhead_cluster makes no sense"), and eb7054212eac ("ext4: update the cached overhead value in the superblock"). However, since it was too expensive to forcibly recalculate the overhead for bigalloc file systems at every mount, this didn't fix the problem for bigalloc file systems. This commit should address the problem when resizing file systems with the bigalloc feature enabled. Signed-off-by: Theodore Ts'o Cc: stable@kernel.org Reviewed-by: Andreas Dilger Link: https://lore.kernel.org/r/20220629040026.112371-1-tytso@mit.edu Signed-off-by: Theodore Ts'o Signed-off-by: Sasha Levin --- fs/ext4/resize.c | 1 + 1 file changed, 1 insertion(+) diff --git a/fs/ext4/resize.c b/fs/ext4/resize.c index 8b70a4701293..e5c2713aa11a 100644 --- a/fs/ext4/resize.c +++ b/fs/ext4/resize.c @@ -1484,6 +1484,7 @@ static void ext4_update_super(struct super_block *sb, * Update the fs overhead information */ ext4_calculate_overhead(sb); + es->s_overhead_clusters = cpu_to_le32(sbi->s_overhead); if (test_opt(sb, DEBUG)) printk(KERN_DEBUG "EXT4-fs: added group %u:" -- 2.35.1