From: djwong Subject: Re: [PATCH 05/23] ext4: Calculate and verify superblock checksum Date: Mon, 30 Apr 2012 09:19:37 -0700 Message-ID: <20120430161937.GD6938@tux1.beaverton.ibm.com> References: <20120306204750.1663.96751.stgit@elm3b70.beaverton.ibm.com> <20120306204828.1663.39312.stgit@elm3b70.beaverton.ibm.com> <20120427200500.GA29481@thunk.org> Reply-To: djwong@us.ibm.com Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii To: "Ted Ts'o" , Andreas Dilger , Sunil Mushran , Martin K Petersen , Greg Freemyer , Amir Goldstein , linux-kernel , Andi Kleen , Mingming Cao , Joel Becker , linux-fsdevel , linux-ext4@vger.kernel.org, Coly Li Return-path: Content-Disposition: inline In-Reply-To: <20120427200500.GA29481@thunk.org> Sender: linux-fsdevel-owner@vger.kernel.org List-Id: linux-ext4.vger.kernel.org On Fri, Apr 27, 2012 at 04:05:00PM -0400, Ted Ts'o wrote: > On Tue, Mar 06, 2012 at 12:48:28PM -0800, Darrick J. Wong wrote: > > diff --git a/fs/ext4/ext4_jbd2.c b/fs/ext4/ext4_jbd2.c > > index aca1790..90f7c2e 100644 > > --- a/fs/ext4/ext4_jbd2.c > > +++ b/fs/ext4/ext4_jbd2.c > > @@ -138,16 +138,23 @@ int __ext4_handle_dirty_metadata(const char *where, unsigned int line, > > } > > > > int __ext4_handle_dirty_super(const char *where, unsigned int line, > > - handle_t *handle, struct super_block *sb) > > + handle_t *handle, struct super_block *sb, > > + int now) > > { > > struct buffer_head *bh = EXT4_SB(sb)->s_sbh; > > int err = 0; > > > > if (ext4_handle_valid(handle)) { > > + ext4_superblock_csum_set(sb, > > + (struct ext4_super_block *)bh->b_data); > > err = jbd2_journal_dirty_metadata(handle, bh); > > if (err) > > ext4_journal_abort_handle(where, line, __func__, > > bh, handle, err); > > + } else if (now) { > > + ext4_superblock_csum_set(sb, > > + (struct ext4_super_block *)bh->b_data); > > + mark_buffer_dirty(bh); > > } else > > sb->s_dirt = 1; > > return err; > > What's the point of having the ext4_handle_dirty_super_now() variant? > > I don't see the point of having this? I believe I was trying to get rid of the open-coded mark_buffer_dirty(sb) calls. There isn't much of reason to have the now=0 path, though; if a caller really wants to mark s_dirt and nothing else, there's ext4_mark_super_dirty() for that. That said, I wonder about that -- is it desirable to be able to say "I've changed the superblock, now update the checksum but don't do anything to write it out to disk right now"? After a few months' break, it seems clear to me that we could make the "else if (now)" clause the "else" clause and get rid of the now parameter. Anything that really wants to set s_dirt=1 with no further action can call ext4_mark_super_dirty(). --D > > - Ted > -- > To unsubscribe from this list: send the line "unsubscribe linux-ext4" in > the body of a message to majordomo@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html >