From: Chao Yu <chao@kernel.org>
To: Zhiguo Niu <zhiguo.niu@unisoc.com>, jaegeuk@kernel.org
Cc: linux-f2fs-devel@lists.sourceforge.net,
linux-kernel@vger.kernel.org, niuzhiguo84@gmail.com,
ke.wang@unisoc.com
Subject: Re: [PATCH] f2fs: enable atgc if atgc_age_threshold from user is less than elapsed_time
Date: Mon, 27 May 2024 11:49:07 +0800 [thread overview]
Message-ID: <1d67715b-5f88-4940-969d-e098fd80ae2a@kernel.org> (raw)
In-Reply-To: <1716204978-29455-1-git-send-email-zhiguo.niu@unisoc.com>
On 2024/5/20 19:36, Zhiguo Niu wrote:
> Now atgc can be enabled based on the following conditions:
> -ATGC mount option is set
> -elapsed_time is more than atgc_age_threshold already
> but these conditions are check when umounted->mounted device again.
> If the device has not be umounted->mounted for a long time, atgc can
> not work even the above conditions met.
Zhiguo, I didn't get it, can you please explain more about this issue?
Thanks,
>
> It is better to enable atgc dynamiclly when user change atgc_age_threshold
> meanwhile this vale is less than elapsed_time and ATGC mount option is on.
>
> Signed-off-by: Zhiguo Niu <zhiguo.niu@unisoc.com>
> ---
> fs/f2fs/f2fs.h | 1 +
> fs/f2fs/segment.c | 9 ++++-----
> fs/f2fs/sysfs.c | 16 ++++++++++++++++
> 3 files changed, 21 insertions(+), 5 deletions(-)
>
> diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h
> index 1974b6a..e441d2d 100644
> --- a/fs/f2fs/f2fs.h
> +++ b/fs/f2fs/f2fs.h
> @@ -3694,6 +3694,7 @@ void f2fs_clear_prefree_segments(struct f2fs_sb_info *sbi,
> int f2fs_init_inmem_curseg(struct f2fs_sb_info *sbi);
> void f2fs_save_inmem_curseg(struct f2fs_sb_info *sbi);
> void f2fs_restore_inmem_curseg(struct f2fs_sb_info *sbi);
> +int f2fs_init_atgc_curseg(struct f2fs_sb_info *sbi);
> int f2fs_allocate_segment_for_resize(struct f2fs_sb_info *sbi, int type,
> unsigned int start, unsigned int end);
> int f2fs_allocate_new_section(struct f2fs_sb_info *sbi, int type, bool force);
> diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c
> index 71dc8042..44923d4 100644
> --- a/fs/f2fs/segment.c
> +++ b/fs/f2fs/segment.c
> @@ -2931,14 +2931,11 @@ static int get_atssr_segment(struct f2fs_sb_info *sbi, int type,
> return ret;
> }
>
> -static int __f2fs_init_atgc_curseg(struct f2fs_sb_info *sbi)
> +int f2fs_init_atgc_curseg(struct f2fs_sb_info *sbi)
> {
> struct curseg_info *curseg = CURSEG_I(sbi, CURSEG_ALL_DATA_ATGC);
> int ret = 0;
>
> - if (!sbi->am.atgc_enabled)
> - return 0;
> -
> f2fs_down_read(&SM_I(sbi)->curseg_lock);
>
> mutex_lock(&curseg->curseg_mutex);
> @@ -2955,7 +2952,9 @@ static int __f2fs_init_atgc_curseg(struct f2fs_sb_info *sbi)
> }
> int f2fs_init_inmem_curseg(struct f2fs_sb_info *sbi)
> {
> - return __f2fs_init_atgc_curseg(sbi);
> + if (!sbi->am.atgc_enabled)
> + return 0;
> + return f2fs_init_atgc_curseg(sbi);
> }
>
> static void __f2fs_save_inmem_curseg(struct f2fs_sb_info *sbi, int type)
> diff --git a/fs/f2fs/sysfs.c b/fs/f2fs/sysfs.c
> index 09d3ecf..72676c5 100644
> --- a/fs/f2fs/sysfs.c
> +++ b/fs/f2fs/sysfs.c
> @@ -673,6 +673,22 @@ static ssize_t __sbi_store(struct f2fs_attr *a,
> return count;
> }
>
> + if (!strcmp(a->attr.name, "atgc_age_threshold")) {
> + if (t < 0)
> + return -EINVAL;
> + sbi->am.age_threshold = t;
> + if (sbi->am.atgc_enabled)
> + return count;
> +
> + if (test_opt(sbi, ATGC) &&
> + le64_to_cpu(sbi->ckpt->elapsed_time) >= t) {
> + if (f2fs_init_atgc_curseg(sbi))
> + return -EINVAL;
> + sbi->am.atgc_enabled = true;
> + }
> + return count;
> + }
> +
> if (!strcmp(a->attr.name, "gc_segment_mode")) {
> if (t < MAX_GC_MODE)
> sbi->gc_segment_mode = t;
next prev parent reply other threads:[~2024-05-27 3:49 UTC|newest]
Thread overview: 13+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-05-20 11:36 [PATCH] f2fs: enable atgc if atgc_age_threshold from user is less than elapsed_time Zhiguo Niu
2024-05-27 3:49 ` Chao Yu [this message]
2024-05-27 4:07 ` Zhiguo Niu
2024-05-30 9:49 ` Zhiguo Niu
2024-05-31 2:04 ` Chao Yu
2024-05-31 2:15 ` Zhiguo Niu
2024-06-03 7:41 ` Chao Yu
2024-06-03 9:05 ` Zhiguo Niu
2024-06-05 3:48 ` Chao Yu
2024-06-05 5:59 ` Zhiguo Niu
2024-06-05 6:16 ` Zhiguo Niu
2024-06-05 6:26 ` Chao Yu
2024-06-05 7:14 ` Zhiguo Niu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1d67715b-5f88-4940-969d-e098fd80ae2a@kernel.org \
--to=chao@kernel.org \
--cc=jaegeuk@kernel.org \
--cc=ke.wang@unisoc.com \
--cc=linux-f2fs-devel@lists.sourceforge.net \
--cc=linux-kernel@vger.kernel.org \
--cc=niuzhiguo84@gmail.com \
--cc=zhiguo.niu@unisoc.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox