Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp5256529pxv; Tue, 6 Jul 2021 22:34:35 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxUFnwC+P5s+MFur3NfpTyeWiLma1+vjzbtNcdPxVUc4fZpjEvOY195Fv/Nt1W/1pQB+HnY X-Received: by 2002:a05:6402:1cb8:: with SMTP id cz24mr16776449edb.319.1625636075387; Tue, 06 Jul 2021 22:34:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625636075; cv=none; d=google.com; s=arc-20160816; b=QPrF9K4Vw1uFLrcsuWNa8rb9Bg5+pIJ7TIr2O09uB5hEsiG8HkskOOjSMd/P28WWGp kzGymJSiBNsXtbCNzXBxf60uKphDEVk0KFvRPvQOtw+4VWUsNnaJS+v0i/zpCsvpyJEQ zcDRlYmxUs8eSYINbNteFmVmq5rf55JXUH2oaMtfXWGCtUV+bKe2ROtH4h5+kh6BLHVn ELSO3uGbBGBCSugRIPHVn8LUVzztno2BKLIFOLZS95j9LdhF0IJmDcPUAfZTh2twUecs 9kZRmtvjmra207ayz1YkUk08J0422b7p1BtyvLLKDRQ9x+WlYHlW9AA4RzSLx3YMvwRV Lh1w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=42GHIlhI2+kOM9/rOuPewsjDoZw0u7ySAH1pOdikXfs=; b=yxT7etoiIHRDwU90dSCTs2osWXriGEAK8tRLVnaEVMlpu6XJFUg7fae7dsnW2J31eh 6+XZoHJABCD5uHibidbbFtKTPUI8Dk9PmCCU6I8VgPlHZeMtmnsuwI8zKeqjb0MdLK1+ voTmOh6I/g6CtkKFTxO6gljrDjJupeldYQdzKmbxqrOHYq1tJc+kGkcEiBoiQQqIMIM/ X6W6tJr1RT8ke6HSyF0+uBsppigovBCYIzfJoi3lmCV4b/9wTD5HDbGpkFu6EyUHeCBv GgD2VLFW0QIh4sX8cLsrtjmFJ+MOpYWF0dEtLN5qFOsR8fzpFIkuirAU4vVVG8GBFhLs VzCA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="uTNJH2+/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id l1si17650928edv.191.2021.07.06.22.34.11; Tue, 06 Jul 2021 22:34:35 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="uTNJH2+/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S230139AbhGGFgD (ORCPT + 99 others); Wed, 7 Jul 2021 01:36:03 -0400 Received: from mail.kernel.org ([198.145.29.99]:59006 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229717AbhGGFgC (ORCPT ); Wed, 7 Jul 2021 01:36:02 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 993AA61CB2; Wed, 7 Jul 2021 05:33:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1625636002; bh=KFF9XhfYMcQdezNbI8jrfO+gkJEQeYaMCo1RJKgwsnA=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=uTNJH2+/iXm43q2Fi3l8eOsrnqV/F2/4QMKZ5AlDP41fK1Rub9G7wASZ5wRtTHH1x lehtHJs31E3tkeJV7vXiOlwI2peIt93vzLXHODf4n2STR2B87w43Pdswhc2kBFjr1M rqcJgXw9Uwv5O2XgJy/vRiII3+nFUSel7Kc1WPe4lI/1Ejh0W5L0kXywXtsYHJR92L A2KVjHC+7UWxPiwneMNIQas6fJzuGs3vjZwBls2IroY7GRE9bD+ARtY9FaqVx1lt8Q o32WaFZgGcYwCv/7W1fJl+Mp1NkXBPPS76ZzJKFqGrjZHaKVcKv5qqi40l4QvfAAD0 qvRfquUuYRk9Q== Date: Tue, 6 Jul 2021 22:33:21 -0700 From: Jaegeuk Kim To: Daeho Jeong Cc: linux-kernel@vger.kernel.org, linux-f2fs-devel@lists.sourceforge.net, kernel-team@android.com, Daeho Jeong Subject: Re: [f2fs-dev] [PATCH] f2fs: add sysfs nodes to get GC info for each GC urgent mode Message-ID: References: <20210702214458.3876398-1-daeho43@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210702214458.3876398-1-daeho43@gmail.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 07/02, Daeho Jeong wrote: > From: Daeho Jeong > > Added gc_urgent_dirty_segs and gc_urgent_dirty_segs_mode sysfs nodes. > 1) "gc_urgent_dirty_segs" shows how many dirty segments have been > reclaimed by GC during a specific GC urgent mode. > 2) "gc_urgent_dirty_segs_mode" is used to control for which gc urgent > mode the "gc_urgent_dirty_segs" node shows. > (1: GC urgent high, 2: GC urgent low) > > Signed-off-by: Daeho Jeong > --- > Documentation/ABI/testing/sysfs-fs-f2fs | 14 ++++++++ > fs/f2fs/f2fs.h | 5 +++ > fs/f2fs/gc.c | 4 +++ > fs/f2fs/sysfs.c | 46 +++++++++++++++++++++++++ > 4 files changed, 69 insertions(+) > > diff --git a/Documentation/ABI/testing/sysfs-fs-f2fs b/Documentation/ABI/testing/sysfs-fs-f2fs > index 95155e4ec7fe..9851c3f2efad 100644 > --- a/Documentation/ABI/testing/sysfs-fs-f2fs > +++ b/Documentation/ABI/testing/sysfs-fs-f2fs > @@ -493,3 +493,17 @@ Contact: "Chao Yu" > Description: When ATGC is on, it controls age threshold to bypass GCing young > candidates whose age is not beyond the threshold, by default it was > initialized as 604800 seconds (equals to 7 days). > + > +What: /sys/fs/f2fs//gc_urgent_dirty_segs > +Date: July 2021 > +Contact: "Daeho Jeong" > +Description: Show how many dirty segments have been reclaimed by GC during > + a specific GC urgent mode (1: GC urgent high, 2: GC urgent low) > + You can re-initialize this value to "0". > + > +What: /sys/fs/f2fs//gc_urgent_dirty_segs_mode > +Date: July 2021 > +Contact: "Daeho Jeong" > +Description: You can control for which gc urgent mode the "gc_urgent_dirty_segs" > + node shows (1: GC urgent high, 2: GC urgent low). You can set the > + value to "0" when you want not to select one of them. > diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h > index 16ce1ade9fa6..d838c373f188 100644 > --- a/fs/f2fs/f2fs.h > +++ b/fs/f2fs/f2fs.h > @@ -1728,6 +1728,11 @@ struct f2fs_sb_info { > struct kmem_cache *inline_xattr_slab; /* inline xattr entry */ > unsigned int inline_xattr_slab_size; /* default inline xattr slab size */ > > + /* For reclaimed dirty segs statistics per each GC urgent mode */ > + unsigned int gc_dirty_segs_mode; /* GC state for reclaimed dirty segments */ > + u64 gc_urgent_high_dirty_segs; /* Reclaimed dirty segs in GC_URGENT_HIGH */ > + u64 gc_urgent_low_dirty_segs; /* Reclaimed dirty segs in GC_URGENT_LOW */ How about modifying like this? And, can we add this in debug/f2fs/status? enum { GC_NORMAL, GC_URGENT_HIGH, GC_URGENT_LOW, GC_IDLE_CB, GC_IDLE_GREEDY, GC_IDLE_AT, }; #define GC_URGENT_MAX (GC_URGENT_LOW + 1) unsigned int reclaimed_segs[GC_URGENT_MAX]; > + > #ifdef CONFIG_F2FS_FS_COMPRESSION > struct kmem_cache *page_array_slab; /* page array entry */ > unsigned int page_array_slab_size; /* default page array slab size */ > diff --git a/fs/f2fs/gc.c b/fs/f2fs/gc.c > index da5947b30142..233e2a500379 100644 > --- a/fs/f2fs/gc.c > +++ b/fs/f2fs/gc.c > @@ -1648,6 +1648,10 @@ static int do_garbage_collect(struct f2fs_sb_info *sbi, > force_migrate); > > stat_inc_seg_count(sbi, type, gc_type); > + if (sbi->gc_dirty_segs_mode == GC_URGENT_HIGH) if (sbi->gc_mode < GC_URGENT_MAX) sbi->gc_reclaimed_segs[sbi->gc_mode]++; > + sbi->gc_urgent_high_dirty_segs++; > + else if (sbi->gc_dirty_segs_mode == GC_URGENT_LOW) > + sbi->gc_urgent_low_dirty_segs++; > migrated++; > > freed: > diff --git a/fs/f2fs/sysfs.c b/fs/f2fs/sysfs.c > index 6642246206bd..9ede97fe12cf 100644 > --- a/fs/f2fs/sysfs.c > +++ b/fs/f2fs/sysfs.c > @@ -307,6 +307,25 @@ static ssize_t f2fs_sbi_show(struct f2fs_attr *a, > return sysfs_emit(buf, "%u\n", sbi->compr_new_inode); > #endif > > + if (!strcmp(a->attr.name, "gc_urgent_dirty_segs_mode")) { > + if (sbi->gc_dirty_segs_mode == GC_NORMAL) > + return sysfs_emit(buf, "0\n"); "0:gc_normal"? > + else if (sbi->gc_dirty_segs_mode == GC_URGENT_HIGH) > + return sysfs_emit(buf, "1\n"); "1:gc_urgent_high"? > + else if (sbi->gc_dirty_segs_mode == GC_URGENT_LOW) > + return sysfs_emit(buf, "2\n"); "2:gc_urgent_low"? > + } > + > + if (!strcmp(a->attr.name, "gc_urgent_dirty_segs")) { > + if (sbi->gc_dirty_segs_mode == GC_URGENT_HIGH) > + return sysfs_emit(buf, "%llu\n", > + sbi->gc_urgent_high_dirty_segs); > + if (sbi->gc_dirty_segs_mode == GC_URGENT_LOW) > + return sysfs_emit(buf, "%llu\n", > + sbi->gc_urgent_low_dirty_segs); > + return sysfs_emit(buf, "0\n"); > + } > + > ui = (unsigned int *)(ptr + a->offset); > > return sprintf(buf, "%u\n", *ui); > @@ -515,6 +534,28 @@ static ssize_t __sbi_store(struct f2fs_attr *a, > return count; > } > > + if (!strcmp(a->attr.name, "gc_urgent_dirty_segs_mode")) { > + if (t == 0) > + sbi->gc_dirty_segs_mode = GC_NORMAL; > + else if (t == 1) > + sbi->gc_dirty_segs_mode = GC_URGENT_HIGH; > + else if (t == 2) > + sbi->gc_dirty_segs_mode = GC_URGENT_LOW; > + else > + return -EINVAL; > + return count; > + } > + > + if (!strcmp(a->attr.name, "gc_urgent_dirty_segs")) { > + if (t != 0 || sbi->gc_dirty_segs_mode == GC_NORMAL) > + return -EINVAL; > + if (sbi->gc_dirty_segs_mode == GC_URGENT_HIGH) > + sbi->gc_urgent_high_dirty_segs = 0; > + else if (sbi->gc_dirty_segs_mode == GC_URGENT_LOW) > + sbi->gc_urgent_low_dirty_segs = 0; > + return count; > + } > + > *ui = (unsigned int)t; > > return count; > @@ -740,6 +781,9 @@ F2FS_RW_ATTR(ATGC_INFO, atgc_management, atgc_candidate_count, max_candidate_cou > F2FS_RW_ATTR(ATGC_INFO, atgc_management, atgc_age_weight, age_weight); > F2FS_RW_ATTR(ATGC_INFO, atgc_management, atgc_age_threshold, age_threshold); > > +F2FS_RW_ATTR(F2FS_SBI, f2fs_sb_info, gc_urgent_dirty_segs_mode, gc_dirty_segs_mode); > +F2FS_RW_ATTR(F2FS_SBI, f2fs_sb_info, gc_urgent_dirty_segs, gc_urgent_high_dirty_segs); > + > #define ATTR_LIST(name) (&f2fs_attr_##name.attr) > static struct attribute *f2fs_attrs[] = { > ATTR_LIST(gc_urgent_sleep_time), > @@ -812,6 +856,8 @@ static struct attribute *f2fs_attrs[] = { > ATTR_LIST(atgc_candidate_count), > ATTR_LIST(atgc_age_weight), > ATTR_LIST(atgc_age_threshold), > + ATTR_LIST(gc_urgent_dirty_segs_mode), > + ATTR_LIST(gc_urgent_dirty_segs), > NULL, > }; > ATTRIBUTE_GROUPS(f2fs); > -- > 2.32.0.93.g670b81a890-goog > > > > _______________________________________________ > Linux-f2fs-devel mailing list > Linux-f2fs-devel@lists.sourceforge.net > https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel