Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp2913584rwb; Mon, 15 Aug 2022 13:57:36 -0700 (PDT) X-Google-Smtp-Source: AA6agR6fpJKjD05YwINPDxQReG5N3lAjC4ZIzhB5IEspe3Ulps6Gd+siblmQ+PCV526VOoR863vv X-Received: by 2002:a65:6c10:0:b0:41b:ab8f:ff71 with SMTP id y16-20020a656c10000000b0041bab8fff71mr15007548pgu.308.1660597056453; Mon, 15 Aug 2022 13:57:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660597056; cv=none; d=google.com; s=arc-20160816; b=zswI95HjUcDHYViLtoAHxAlB7fhUhVowUPVOLB5ZN2Iyb3YS3hogpN6jVZALXsyxba BlXEg+bU8rgiuOtsL1hmFex+BAEQm3X83YXXu35y8KRc33Le3N1QLn+lp/n+6jzWxCC+ 7dh471X2JZSHGQx1c2FSdCYifoxtPYUqR8qfmgv5cXaDESfapeK2eiSMXLgFkHglMIO8 3p+8jxLiwbT/BIN7UC861HmLcjYXxr1mDnByA6k3eZGKp2u3eftqQ4nby4EYZ/Y8Vjk+ Jiqqeh7R4SJpBF9wNvtrQZs9Xolb3gsf+Et7oWjo9pWsu+W96diacQCNzAhdJKyLZCNr aYvw== 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=naJse7diHwfg7qAd+ffAXjeW//CmH1JNUM8eoWM1jyY=; b=M3IEyjC7HD0LCRDXD7WX/+71NIhmdJd3BVm1W9mR8LjdQPx+huSQX9EEU07TfYeruU hT9P3Sq1vhfFme8P6G4LspT8YP4vHKkD/PNkJiSOCa7CYdfLigw/M8IIQ6d1jCCgcPAy 5xtzPSC75VNngbeZ14wrezDc2hBol/qeFXA4GxxXcDKiZm3LCeXMfSspz94UvTOtVE3K KS9S6iCBSw7YPjjVok2iPTlwCoRSJAHYqOm+M8qbiiNQA1yfXaWiunxNSfCjFg1BOdly ukn2i8rDaCjQweLFHwVcVNTUDUIajRx08YijFtutPdisqRSxBSU1zwlvm7fVX7yRZse4 cfQQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=HUWtJgXp; 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 bd32-20020a056a0027a000b0052f9dd05116si1508142pfb.171.2022.08.15.13.57.25; Mon, 15 Aug 2022 13:57:36 -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=HUWtJgXp; 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 S242540AbiHOT5X (ORCPT + 99 others); Mon, 15 Aug 2022 15:57:23 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42670 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345505AbiHOTxv (ORCPT ); Mon, 15 Aug 2022 15:53:51 -0400 Received: from sin.source.kernel.org (sin.source.kernel.org [IPv6:2604:1380:40e1:4800::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 7B1D9459A3; Mon, 15 Aug 2022 11:51:53 -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 sin.source.kernel.org (Postfix) with ESMTPS id CC2D3CE1277; Mon, 15 Aug 2022 18:51:51 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id B0332C433C1; Mon, 15 Aug 2022 18:51:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1660589510; bh=DYUehsMPqaq4yxszzIlykNT+p1BYZ2hwXXP23RFc51M=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=HUWtJgXpQIHXZ5FRHwspvuCIe94SuYBgoy5ypSdAuQqkpwL47h2SZn/kY19+dt2cc nRDSsemWVSIPDQDx1eUbNP6u1h4qC7ee+3QFuzhaRM4ouSErPBZSDaqKrW2ql3+qg8 uxfqz02B74UZKJRhK4KlAxIADhIrHQLomvvWGlQ4= 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.15 741/779] ext4: update s_overhead_clusters in the superblock during an on-line resize Date: Mon, 15 Aug 2022 20:06:25 +0200 Message-Id: <20220815180409.123189877@linuxfoundation.org> X-Mailer: git-send-email 2.37.2 In-Reply-To: <20220815180337.130757997@linuxfoundation.org> References: <20220815180337.130757997@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 56c9ef0687fc..fa3c854125bb 100644 --- a/fs/ext4/resize.c +++ b/fs/ext4/resize.c @@ -1472,6 +1472,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