Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp345377yba; Mon, 20 May 2019 09:41:27 -0700 (PDT) X-Google-Smtp-Source: APXvYqzHROQcWT/abOHkMDjtWMInAIEwilidjtb72E/u2CiE08SLxn4QTKzZjcuuhG9sCtS7NXme X-Received: by 2002:a63:6a41:: with SMTP id f62mr75638682pgc.392.1558370487372; Mon, 20 May 2019 09:41:27 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558370487; cv=none; d=google.com; s=arc-20160816; b=Rihub8iFvFQ1iC214wXfljZQHzk6X9WJ1854m9cFDTSXBD5Aeuy8/CGy7g4lPCSj/e FoUYWnm0to/7Da55brvrFjNKFu/Yc7SRvUaigim1ytXpwWEhoppLQtGXtVYaWlp9TMI0 7PC5HDBidduaz9oSUm0+1FyRLeKLzTOQmyp3kqej1JEx6O1DE8TQ4ig2UlgShfWnCSnq aTo+53giTZKa5pPD8/3o0rv3LCRwcK7fUNXu5SDA6XfA7pcBR+M+S9eXdjwsSmmTNXPU KGjPfhf+/xEBMhSK7PNkWnJpDVZB11tSOJrj3uMmucVWnE6zbLW2I9c5iQC+wJyaExC0 MrJg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=C13btA6vOHfOsT7o7sl8fNMoUrFNL0j2vFFqYEMJAhw=; b=Xn7JoDrmGAJGSLNhKFgDtOVUjhgUe57M3kmA/7eSfIBiuUQ9P127H2LV31AxpMVJ12 vTWHfIPqKABpSoIsXBDHmM47OFekYj24/h7F8M0ebZyijJ9lz4Gc4WiDwmGw+mJOR+Wi bALAhrb+afTEA4qCmDx6R/MpTNXsHa7dpBRf10iGDYg+RuielyQdgimluaZy/bksS655 AeecRKUstIXiLEAImgc3GIWVuBMqzXe+gCYsBiiLDY4mia7yjQNotFfgSatEf4alJfvs zmhUt7+av9pC/1NgZUVp/Dzv1gmcLuSowU1Z1zrUBQXvPtY/mrPhnAtONJTMC/5QCR6M bzqw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=LWnldoyi; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-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 q88si20823562pfa.250.2019.05.20.09.41.12; Mon, 20 May 2019 09:41:27 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=LWnldoyi; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389787AbfETMa4 (ORCPT + 99 others); Mon, 20 May 2019 08:30:56 -0400 Received: from mail.kernel.org ([198.145.29.99]:47220 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390171AbfETMav (ORCPT ); Mon, 20 May 2019 08:30:51 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D5EAF20815; Mon, 20 May 2019 12:30:49 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1558355450; bh=ZXVkfLk/ZylDjGcKc1UBt57K6WYRGjjsuXyokA4kBNU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=LWnldoyi+igcSSANVmPIA/ha3C5Xf8Xz5HgA4pRTVzWnGzqgKhZShaFvF4SUrooqL gJSHQGFtozkcWi2UlNmMNGv6wMqB2m+OYoOaUjvzduYUc7vKUag9MpIxlZY6DWxOX3 qUE45Fb6+FOddDp4x0iIxdR6bE7xqisBnv7LVO44= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Andreas Dilger , Theodore Tso Subject: [PATCH 5.0 123/123] ext4: dont update s_rev_level if not required Date: Mon, 20 May 2019 14:15:03 +0200 Message-Id: <20190520115253.355001829@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190520115245.439864225@linuxfoundation.org> References: <20190520115245.439864225@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Andreas Dilger commit c9e716eb9b3455a83ed7c5f5a81256a3da779a95 upstream. Don't update the superblock s_rev_level during mount if it isn't actually necessary, only if superblock features are being set by the kernel. This was originally added for ext3 since it always set the INCOMPAT_RECOVER and HAS_JOURNAL features during mount, but this is not needed since no journal mode was added to ext4. That will allow Geert to mount his 20-year-old ext2 rev 0.0 m68k filesystem, as a testament of the backward compatibility of ext4. Fixes: 0390131ba84f ("ext4: Allow ext4 to run without a journal") Signed-off-by: Andreas Dilger Signed-off-by: Theodore Ts'o Signed-off-by: Greg Kroah-Hartman --- fs/ext4/ext4.h | 6 +++++- fs/ext4/inode.c | 1 - fs/ext4/super.c | 1 - 3 files changed, 5 insertions(+), 3 deletions(-) --- a/fs/ext4/ext4.h +++ b/fs/ext4/ext4.h @@ -1665,6 +1665,8 @@ static inline void ext4_clear_state_flag #define EXT4_FEATURE_INCOMPAT_INLINE_DATA 0x8000 /* data in inode */ #define EXT4_FEATURE_INCOMPAT_ENCRYPT 0x10000 +extern void ext4_update_dynamic_rev(struct super_block *sb); + #define EXT4_FEATURE_COMPAT_FUNCS(name, flagname) \ static inline bool ext4_has_feature_##name(struct super_block *sb) \ { \ @@ -1673,6 +1675,7 @@ static inline bool ext4_has_feature_##na } \ static inline void ext4_set_feature_##name(struct super_block *sb) \ { \ + ext4_update_dynamic_rev(sb); \ EXT4_SB(sb)->s_es->s_feature_compat |= \ cpu_to_le32(EXT4_FEATURE_COMPAT_##flagname); \ } \ @@ -1690,6 +1693,7 @@ static inline bool ext4_has_feature_##na } \ static inline void ext4_set_feature_##name(struct super_block *sb) \ { \ + ext4_update_dynamic_rev(sb); \ EXT4_SB(sb)->s_es->s_feature_ro_compat |= \ cpu_to_le32(EXT4_FEATURE_RO_COMPAT_##flagname); \ } \ @@ -1707,6 +1711,7 @@ static inline bool ext4_has_feature_##na } \ static inline void ext4_set_feature_##name(struct super_block *sb) \ { \ + ext4_update_dynamic_rev(sb); \ EXT4_SB(sb)->s_es->s_feature_incompat |= \ cpu_to_le32(EXT4_FEATURE_INCOMPAT_##flagname); \ } \ @@ -2675,7 +2680,6 @@ do { \ #endif -extern void ext4_update_dynamic_rev(struct super_block *sb); extern int ext4_update_compat_feature(handle_t *handle, struct super_block *sb, __u32 compat); extern int ext4_update_rocompat_feature(handle_t *handle, --- a/fs/ext4/inode.c +++ b/fs/ext4/inode.c @@ -5355,7 +5355,6 @@ static int ext4_do_update_inode(handle_t err = ext4_journal_get_write_access(handle, EXT4_SB(sb)->s_sbh); if (err) goto out_brelse; - ext4_update_dynamic_rev(sb); ext4_set_feature_large_file(sb); ext4_handle_sync(handle); err = ext4_handle_dirty_super(handle, sb); --- a/fs/ext4/super.c +++ b/fs/ext4/super.c @@ -2259,7 +2259,6 @@ static int ext4_setup_super(struct super es->s_max_mnt_count = cpu_to_le16(EXT4_DFL_MAX_MNT_COUNT); le16_add_cpu(&es->s_mnt_count, 1); ext4_update_tstamp(es, s_mtime); - ext4_update_dynamic_rev(sb); if (sbi->s_journal) ext4_set_feature_journal_needs_recovery(sb);