Re: [PATCH 3/3] f2fs: introduce __f2fs_commit_super
From: Jaegeuk Kim
Date:  Tue Dec 15 2015 - 17:19:54 EST
Hi Chao,
On Tue, Dec 15, 2015 at 05:20:50PM +0800, Chao Yu wrote:
> Introduce __f2fs_commit_super to include duplicated codes in
> f2fs_commit_super for cleanup.
> 
> Signed-off-by: Chao Yu <chao2.yu@xxxxxxxxxxx>
> ---
>  fs/f2fs/super.c | 28 +++++++++++++---------------
>  1 file changed, 13 insertions(+), 15 deletions(-)
> 
> diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c
> index 2d4fed8..56a160a 100644
> --- a/fs/f2fs/super.c
> +++ b/fs/f2fs/super.c
> @@ -1201,14 +1201,13 @@ next:
>  	return 0;
>  }
>  
> -int f2fs_commit_super(struct f2fs_sb_info *sbi, bool recover)
> +int __f2fs_commit_super(struct f2fs_sb_info *sbi, int block)
>  {
>  	struct f2fs_super_block *super = F2FS_RAW_SUPER(sbi);
>  	struct buffer_head *bh;
>  	int err;
>  
> -	/* write back-up superblock first */
> -	bh = sb_getblk(sbi->sb, sbi->valid_super_block ? 0 : 1);
> +	bh = sb_getblk(sbi->sb, block);
>  	if (!bh)
>  		return -EIO;
>  
> @@ -1222,23 +1221,22 @@ int f2fs_commit_super(struct f2fs_sb_info *sbi, bool recover)
>  	err = __sync_dirty_buffer(bh, WRITE_FLUSH_FUA);
>  	brelse(bh);
>  
> +	return err;
> +}
> +
> +int f2fs_commit_super(struct f2fs_sb_info *sbi, bool recover)
> +{
> +	int err;
> +
> +	/* write back-up superblock first */
> +	err = __f2fs_commit_super(sbi, sbi->valid_super_block ? 0 : 1);
> +
>  	/* if we are in recovery path, skip writing valid superblock */
>  	if (recover || err)
>  		return err;
>  
> -	bh = sb_getblk(sbi->sb, sbi->valid_super_block);
> -	if (!bh)
> -		return -EIO;
> -
>  	/* write current valid superblock */
> -	lock_buffer(bh);
> -	memcpy(bh->b_data + F2FS_SUPER_OFFSET, super, sizeof(*super));
> -	set_buffer_uptodate(bh);
> -	set_buffer_dirty(bh);
> -	unlock_buffer(bh);
> -
> -	err = __sync_dirty_buffer(bh, WRITE_FLUSH_FUA);
> -	brelse(bh);
> +	err = __f2fs_commit_super(sbi, sbi->valid_super_block);
I just merged this patch with:
	return __f2fs_commit_super().
Thanks,
>  
>  	return err;
>  }
> -- 
> 2.6.3
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/