Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp2061896ybv; Fri, 14 Feb 2020 10:42:15 -0800 (PST) X-Google-Smtp-Source: APXvYqzWKIXAAR5sP6wv9QaWpgLOlcern5mLRJaEc1a6daQcdCldR0bjC/RV3H0yDEfthtkJq3lB X-Received: by 2002:a05:6808:9b4:: with SMTP id e20mr2702798oig.37.1581705734890; Fri, 14 Feb 2020 10:42:14 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581705734; cv=none; d=google.com; s=arc-20160816; b=w5GkDEvEXtX12h7Vs0HQ7RvTQaLVDLgaVl/xJVXi+g20kqaHOIQ1IFiapusc3KhqHv z4ZihcKDhcn0ofQsUte2M0qTmkyfZ9bWWH+GmILYbovv+nWE/IMKhK6FzFVzpJBmf8bF UqVonnVrNhsiVNH0QEumYeJFjvOU/9UUSGVUcj6/5BE3ovRSF/uc7TJnfCSMhQ8N97L+ F3M5Oqh3OYg5QhsDYG9Yz4yIix2YZJTz0vdom5AQ3OwETRSLkIU0IjGIG1EKE7NLI3Jz iZi3Swu5IiLbwQKEeimpXMu2zgxivylnRXTJrK1tWnF8VCH2wYs3NFf6XQAoHEh6bD1M wWmg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=wNubY6BSNm4rDlbdeuQuW0bv3PWZwa2DoCwrL7QRb44=; b=hENZAt0672HjGEVVGo9oi18okaEzdecm/sF1jhMnBcCHcTeBtst/hxu2W6mD7kxccQ 16f3PThYExNtTu20YPw/X7MbeX49i3tB78fKjbCxGa4rn/W5XoUo8KqQz4xdbX69zi55 Eu0IWgF1khtfAxLZfgiS53pWvKKJIXH2lIe1+sSYIKsg2+52o7mct2zO38DjTIASmfX3 8K7dUE36ShVvDcw3WIuQ/iiVk2KPbBny7G2zwfv1HfFKHt7AhQIUnwOCqzjhcmZTZ1J6 /h8xo5thTcEb6xPPJo8jzJoG1IqGIHrFfeqBu34MxbbUtvdj+rUB0Y1fE6EaJcyKiVp7 wPjQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=xl0Jo5Hd; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id m24si3320988otn.67.2020.02.14.10.42.02; Fri, 14 Feb 2020 10:42:14 -0800 (PST) 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=xl0Jo5Hd; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389734AbgBNSlx (ORCPT + 99 others); Fri, 14 Feb 2020 13:41:53 -0500 Received: from mail.kernel.org ([198.145.29.99]:41856 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388570AbgBNSlw (ORCPT ); Fri, 14 Feb 2020 13:41:52 -0500 Received: from localhost (unknown [104.132.1.66]) (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 4EE0A20848; Fri, 14 Feb 2020 18:41:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1581705711; bh=Vmr7dtwO8orqihgXko6Xr4/uDKtNzlidNtsbZUcAv7M=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=xl0Jo5HdSpIcwWHNL77+oXE3Th2FQk4KX5LnN5V4PR780fvjHJCou8UkGHM6pxu2K qHO8sc2mENydR3sHzXUMBTa/JonS2lXUkh5EZ1xDmCJTQZEIwNrFloM8m0Sug5XQBm sIvSbHM1ObBhvASjN2aggS+GlItB0VIvq/HFLuKs= Date: Fri, 14 Feb 2020 10:41:50 -0800 From: Jaegeuk Kim To: Chao Yu Cc: linux-f2fs-devel@lists.sourceforge.net, linux-kernel@vger.kernel.org, chao@kernel.org Subject: Re: [PATCH 3/4] f2fs: clean up lfs/adaptive mount option Message-ID: <20200214184150.GB60913@google.com> References: <20200214094413.12784-1-yuchao0@huawei.com> <20200214094413.12784-3-yuchao0@huawei.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20200214094413.12784-3-yuchao0@huawei.com> User-Agent: Mutt/1.10.1 (2018-07-13) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02/14, Chao Yu wrote: > This patch removes F2FS_MOUNT_ADAPTIVE and F2FS_MOUNT_LFS mount options, > and add F2FS_OPTION.fs_mode with below two status to indicate filesystem > mode. > > enum { > FS_MODE_ADAPTIVE, /* use both lfs/ssr allocation */ > FS_MODE_LFS, /* use lfs allocation only */ > }; > > It can enhance code readability and fs mode's scalability. > > Signed-off-by: Chao Yu > --- > fs/f2fs/data.c | 8 ++++---- > fs/f2fs/f2fs.h | 27 ++++++++++----------------- > fs/f2fs/file.c | 2 +- > fs/f2fs/gc.c | 2 +- > fs/f2fs/segment.c | 12 ++++++------ > fs/f2fs/super.c | 16 ++++++++-------- > 6 files changed, 30 insertions(+), 37 deletions(-) > > diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c > index ec4b030e2466..019c91f7b301 100644 > --- a/fs/f2fs/data.c > +++ b/fs/f2fs/data.c > @@ -445,7 +445,7 @@ static inline void __submit_bio(struct f2fs_sb_info *sbi, > if (type != DATA && type != NODE) > goto submit_io; > > - if (test_opt(sbi, LFS) && current->plug) > + if (f2fs_lfs_mode(sbi) && current->plug) > blk_finish_plug(current->plug); > > if (F2FS_IO_ALIGNED(sbi)) > @@ -1420,7 +1420,7 @@ int f2fs_map_blocks(struct inode *inode, struct f2fs_map_blocks *map, > end = pgofs + maxblocks; > > if (!create && f2fs_lookup_extent_cache(inode, pgofs, &ei)) { > - if (test_opt(sbi, LFS) && flag == F2FS_GET_BLOCK_DIO && > + if (f2fs_lfs_mode(sbi) && flag == F2FS_GET_BLOCK_DIO && > map->m_may_create) > goto next_dnode; > > @@ -1475,7 +1475,7 @@ int f2fs_map_blocks(struct inode *inode, struct f2fs_map_blocks *map, > > if (__is_valid_data_blkaddr(blkaddr)) { > /* use out-place-update for driect IO under LFS mode */ > - if (test_opt(sbi, LFS) && flag == F2FS_GET_BLOCK_DIO && > + if (f2fs_lfs_mode(sbi) && flag == F2FS_GET_BLOCK_DIO && > map->m_may_create) { > err = __allocate_data_block(&dn, map->m_seg_type); > if (err) > @@ -2403,7 +2403,7 @@ bool f2fs_should_update_outplace(struct inode *inode, struct f2fs_io_info *fio) > { > struct f2fs_sb_info *sbi = F2FS_I_SB(inode); > > - if (test_opt(sbi, LFS)) > + if (f2fs_lfs_mode(sbi)) > return true; > if (S_ISDIR(inode->i_mode)) > return true; > diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h > index 5152e9bf432b..d2d50827772c 100644 > --- a/fs/f2fs/f2fs.h > +++ b/fs/f2fs/f2fs.h > @@ -91,8 +91,6 @@ extern const char *f2fs_fault_name[FAULT_MAX]; > #define F2FS_MOUNT_FORCE_FG_GC 0x00004000 > #define F2FS_MOUNT_DATA_FLUSH 0x00008000 > #define F2FS_MOUNT_FAULT_INJECTION 0x00010000 > -#define F2FS_MOUNT_ADAPTIVE 0x00020000 > -#define F2FS_MOUNT_LFS 0x00040000 I don't think we can remove this simply. > #define F2FS_MOUNT_USRQUOTA 0x00080000 > #define F2FS_MOUNT_GRPQUOTA 0x00100000 > #define F2FS_MOUNT_PRJQUOTA 0x00200000 > @@ -138,6 +136,7 @@ struct f2fs_mount_info { > int whint_mode; > int alloc_mode; /* segment allocation policy */ > int fsync_mode; /* fsync policy */ > + int fs_mode; /* fs mode: LFS or ADAPTIVE */ > bool test_dummy_encryption; /* test dummy encryption */ > block_t unusable_cap; /* Amount of space allowed to be > * unusable when disabling checkpoint > @@ -1171,6 +1170,11 @@ enum { > GC_URGENT, > }; > > +enum { > + FS_MODE_ADAPTIVE, /* use both lfs/ssr allocation */ > + FS_MODE_LFS, /* use lfs allocation only */ > +}; > + > enum { > WHINT_MODE_OFF, /* not pass down write hints */ > WHINT_MODE_USER, /* try to pass down hints given by users */ > @@ -3907,20 +3911,9 @@ static inline bool f2fs_hw_is_readonly(struct f2fs_sb_info *sbi) > return false; > } > > - > -static inline void set_opt_mode(struct f2fs_sb_info *sbi, unsigned int mt) > +static inline bool f2fs_lfs_mode(struct f2fs_sb_info *sbi) > { > - clear_opt(sbi, ADAPTIVE); > - clear_opt(sbi, LFS); > - > - switch (mt) { > - case F2FS_MOUNT_ADAPTIVE: > - set_opt(sbi, ADAPTIVE); > - break; > - case F2FS_MOUNT_LFS: > - set_opt(sbi, LFS); > - break; > - } > + return F2FS_OPTION(sbi).fs_mode == FS_MODE_LFS; > } > > static inline bool f2fs_may_encrypt(struct inode *inode) > @@ -3975,7 +3968,7 @@ static inline int allow_outplace_dio(struct inode *inode, > struct f2fs_sb_info *sbi = F2FS_I_SB(inode); > int rw = iov_iter_rw(iter); > > - return (test_opt(sbi, LFS) && (rw == WRITE) && > + return (f2fs_lfs_mode(sbi) && (rw == WRITE) && > !block_unaligned_IO(inode, iocb, iter)); > } > > @@ -3997,7 +3990,7 @@ static inline bool f2fs_force_buffered_io(struct inode *inode, > */ > if (f2fs_sb_has_blkzoned(sbi)) > return true; > - if (test_opt(sbi, LFS) && (rw == WRITE)) { > + if (f2fs_lfs_mode(sbi) && (rw == WRITE)) { > if (block_unaligned_IO(inode, iocb, iter)) > return true; > if (F2FS_IO_ALIGNED(sbi)) > diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c > index 5a0f84751091..efca4ed17b7d 100644 > --- a/fs/f2fs/file.c > +++ b/fs/f2fs/file.c > @@ -1132,7 +1132,7 @@ static int __read_out_blkaddrs(struct inode *inode, block_t *blkaddr, > > if (!f2fs_is_checkpointed_data(sbi, *blkaddr)) { > > - if (test_opt(sbi, LFS)) { > + if (f2fs_lfs_mode(sbi)) { > f2fs_put_dnode(&dn); > return -EOPNOTSUPP; > } > diff --git a/fs/f2fs/gc.c b/fs/f2fs/gc.c > index 53312d7bc78b..8aebe2b9c655 100644 > --- a/fs/f2fs/gc.c > +++ b/fs/f2fs/gc.c > @@ -762,7 +762,7 @@ static int move_data_block(struct inode *inode, block_t bidx, > struct page *page, *mpage; > block_t newaddr; > int err = 0; > - bool lfs_mode = test_opt(fio.sbi, LFS); > + bool lfs_mode = f2fs_lfs_mode(fio.sbi); > > /* do not read out */ > page = f2fs_grab_cache_page(inode->i_mapping, bidx, false); > diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c > index cf0eb002cfd4..c3252603ff79 100644 > --- a/fs/f2fs/segment.c > +++ b/fs/f2fs/segment.c > @@ -172,7 +172,7 @@ bool f2fs_need_SSR(struct f2fs_sb_info *sbi) > int dent_secs = get_blocktype_secs(sbi, F2FS_DIRTY_DENTS); > int imeta_secs = get_blocktype_secs(sbi, F2FS_DIRTY_IMETA); > > - if (test_opt(sbi, LFS)) > + if (f2fs_lfs_mode(sbi)) > return false; > if (sbi->gc_mode == GC_URGENT) > return true; > @@ -1940,7 +1940,7 @@ void f2fs_clear_prefree_segments(struct f2fs_sb_info *sbi, > unsigned int start = 0, end = -1; > unsigned int secno, start_segno; > bool force = (cpc->reason & CP_DISCARD); > - bool need_align = test_opt(sbi, LFS) && __is_large_section(sbi); > + bool need_align = f2fs_lfs_mode(sbi) && __is_large_section(sbi); > > mutex_lock(&dirty_i->seglist_lock); > > @@ -1972,7 +1972,7 @@ void f2fs_clear_prefree_segments(struct f2fs_sb_info *sbi, > (end - 1) <= cpc->trim_end) > continue; > > - if (!test_opt(sbi, LFS) || !__is_large_section(sbi)) { > + if (!f2fs_lfs_mode(sbi) || !__is_large_section(sbi)) { > f2fs_issue_discard(sbi, START_BLOCK(sbi, start), > (end - start) << sbi->log_blocks_per_seg); > continue; > @@ -2830,7 +2830,7 @@ int f2fs_trim_fs(struct f2fs_sb_info *sbi, struct fstrim_range *range) > struct discard_policy dpolicy; > unsigned long long trimmed = 0; > int err = 0; > - bool need_align = test_opt(sbi, LFS) && __is_large_section(sbi); > + bool need_align = f2fs_lfs_mode(sbi) && __is_large_section(sbi); > > if (start >= MAX_BLKADDR(sbi) || range->len < sbi->blocksize) > return -EINVAL; > @@ -3193,7 +3193,7 @@ static void update_device_state(struct f2fs_io_info *fio) > static void do_write_page(struct f2fs_summary *sum, struct f2fs_io_info *fio) > { > int type = __get_segment_type(fio); > - bool keep_order = (test_opt(fio->sbi, LFS) && type == CURSEG_COLD_DATA); > + bool keep_order = (f2fs_lfs_mode(fio->sbi) && type == CURSEG_COLD_DATA); > > if (keep_order) > down_read(&fio->sbi->io_order_lock); > @@ -4678,7 +4678,7 @@ int f2fs_build_segment_manager(struct f2fs_sb_info *sbi) > if (sm_info->rec_prefree_segments > DEF_MAX_RECLAIM_PREFREE_SEGMENTS) > sm_info->rec_prefree_segments = DEF_MAX_RECLAIM_PREFREE_SEGMENTS; > > - if (!test_opt(sbi, LFS)) > + if (!f2fs_lfs_mode(sbi)) > sm_info->ipu_policy = 1 << F2FS_IPU_FSYNC; > sm_info->min_ipu_util = DEF_MIN_IPU_UTIL; > sm_info->min_fsync_blocks = DEF_MIN_FSYNC_BLOCKS; > diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c > index 65a7a432dfee..427409eff354 100644 > --- a/fs/f2fs/super.c > +++ b/fs/f2fs/super.c > @@ -600,10 +600,10 @@ static int parse_options(struct super_block *sb, char *options) > kvfree(name); > return -EINVAL; > } > - set_opt_mode(sbi, F2FS_MOUNT_ADAPTIVE); > + F2FS_OPTION(sbi).fs_mode = FS_MODE_ADAPTIVE; > } else if (strlen(name) == 3 && > !strncmp(name, "lfs", 3)) { > - set_opt_mode(sbi, F2FS_MOUNT_LFS); > + F2FS_OPTION(sbi).fs_mode = FS_MODE_LFS; > } else { > kvfree(name); > return -EINVAL; > @@ -904,7 +904,7 @@ static int parse_options(struct super_block *sb, char *options) > } > #endif > > - if (F2FS_IO_SIZE_BITS(sbi) && !test_opt(sbi, LFS)) { > + if (F2FS_IO_SIZE_BITS(sbi) && !f2fs_lfs_mode(sbi)) { > f2fs_err(sbi, "Should set mode=lfs with %uKB-sized IO", > F2FS_IO_SIZE_KB(sbi)); > return -EINVAL; > @@ -934,7 +934,7 @@ static int parse_options(struct super_block *sb, char *options) > } > } > > - if (test_opt(sbi, DISABLE_CHECKPOINT) && test_opt(sbi, LFS)) { > + if (test_opt(sbi, DISABLE_CHECKPOINT) && f2fs_lfs_mode(sbi)) { > f2fs_err(sbi, "LFS not compatible with checkpoint=disable\n"); > return -EINVAL; > } > @@ -1497,9 +1497,9 @@ static int f2fs_show_options(struct seq_file *seq, struct dentry *root) > seq_puts(seq, ",data_flush"); > > seq_puts(seq, ",mode="); > - if (test_opt(sbi, ADAPTIVE)) > + if (F2FS_OPTION(sbi).fs_mode == FS_MODE_ADAPTIVE) > seq_puts(seq, "adaptive"); > - else if (test_opt(sbi, LFS)) > + else if (F2FS_OPTION(sbi).fs_mode == FS_MODE_LFS) > seq_puts(seq, "lfs"); > seq_printf(seq, ",active_logs=%u", F2FS_OPTION(sbi).active_logs); > if (test_opt(sbi, RESERVE_ROOT)) > @@ -1586,9 +1586,9 @@ static void default_options(struct f2fs_sb_info *sbi) > set_opt(sbi, FLUSH_MERGE); > set_opt(sbi, DISCARD); > if (f2fs_sb_has_blkzoned(sbi)) > - set_opt_mode(sbi, F2FS_MOUNT_LFS); > + F2FS_OPTION(sbi).fs_mode = FS_MODE_LFS; > else > - set_opt_mode(sbi, F2FS_MOUNT_ADAPTIVE); > + F2FS_OPTION(sbi).fs_mode = FS_MODE_ADAPTIVE; > > #ifdef CONFIG_F2FS_FS_XATTR > set_opt(sbi, XATTR_USER); > -- > 2.18.0.rc1