* [PATCH v3] mm/damon/core: remove unnecessary si_meminfo invoke. [not found] <7b38eb40-1d74-4308-ae9a-b6aa91a46833@vivo.com> @ 2023-09-20 1:57 ` Huan Yang 2023-09-20 7:19 ` SeongJae Park 0 siblings, 1 reply; 2+ messages in thread From: Huan Yang @ 2023-09-20 1:57 UTC (permalink / raw) To: SeongJae Park, Andrew Morton, damon, linux-mm, linux-kernel Cc: opensource.kernel, Huan Yang si_meminfo() will read and assign more info not just free/ram pages. For just DAMOS_WMARK_FREE_MEM_RATE use, only get free and ram pages is ok to save cpu. Signed-off-by: Huan Yang <link@vivo.com> --- Change from v1: v1 fold free mem rate logic into __damos_get_wmark_free_mem_rate and not invoke si_meminfo, just get free/ram_pages in global. v2 cancel this __damos_get_wmark_free_mem_rate and just calculate rate in damos_wmark_metric_value to keep it simple. v3 fix changelog format, fix code style. mm/damon/core.c | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/mm/damon/core.c b/mm/damon/core.c index bcd2bd9d6c10..6ceb52298904 100644 --- a/mm/damon/core.c +++ b/mm/damon/core.c @@ -1280,12 +1280,10 @@ static bool kdamond_need_stop(struct damon_ctx *ctx) static unsigned long damos_wmark_metric_value(enum damos_wmark_metric metric) { - struct sysinfo i; - switch (metric) { case DAMOS_WMARK_FREE_MEM_RATE: - si_meminfo(&i); - return i.freeram * 1000 / i.totalram; + return global_zone_page_state(NR_FREE_PAGES) * 1000 / + totalram_pages(); default: break; } -- 2.34.1 ^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH v3] mm/damon/core: remove unnecessary si_meminfo invoke. 2023-09-20 1:57 ` [PATCH v3] mm/damon/core: remove unnecessary si_meminfo invoke Huan Yang @ 2023-09-20 7:19 ` SeongJae Park 0 siblings, 0 replies; 2+ messages in thread From: SeongJae Park @ 2023-09-20 7:19 UTC (permalink / raw) To: Huan Yang Cc: SeongJae Park, Andrew Morton, damon, linux-mm, linux-kernel, opensource.kernel Hi Huan, On Wed, 20 Sep 2023 09:57:27 +0800 Huan Yang <link@vivo.com> wrote: > si_meminfo() will read and assign more info not just free/ram pages. > For just DAMOS_WMARK_FREE_MEM_RATE use, only get free and ram pages > is ok to save cpu. > > Signed-off-by: Huan Yang <link@vivo.com> Reviewed-by: SeongJae Park <sj@kernel.org> Thanks, SJ > --- > Change from v1: > v1 fold free mem rate logic into __damos_get_wmark_free_mem_rate and not > invoke si_meminfo, just get free/ram_pages in global. > v2 cancel this __damos_get_wmark_free_mem_rate and just calculate rate > in damos_wmark_metric_value to keep it simple. > v3 fix changelog format, fix code style. > > > mm/damon/core.c | 6 ++---- > 1 file changed, 2 insertions(+), 4 deletions(-) > > diff --git a/mm/damon/core.c b/mm/damon/core.c > index bcd2bd9d6c10..6ceb52298904 100644 > --- a/mm/damon/core.c > +++ b/mm/damon/core.c > @@ -1280,12 +1280,10 @@ static bool kdamond_need_stop(struct damon_ctx *ctx) > > static unsigned long damos_wmark_metric_value(enum damos_wmark_metric metric) > { > - struct sysinfo i; > - > switch (metric) { > case DAMOS_WMARK_FREE_MEM_RATE: > - si_meminfo(&i); > - return i.freeram * 1000 / i.totalram; > + return global_zone_page_state(NR_FREE_PAGES) * 1000 / > + totalram_pages(); > default: > break; > } > -- > 2.34.1 ^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2023-09-20 7:19 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <7b38eb40-1d74-4308-ae9a-b6aa91a46833@vivo.com>
2023-09-20 1:57 ` [PATCH v3] mm/damon/core: remove unnecessary si_meminfo invoke Huan Yang
2023-09-20 7:19 ` SeongJae Park
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox