[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20250319193028.29514-9-raghavendra.kt@amd.com>
Date: Wed, 19 Mar 2025 19:30:23 +0000
From: Raghavendra K T <raghavendra.kt@....com>
To: <raghavendra.kt@....com>
CC: <AneeshKumar.KizhakeVeetil@....com>, <Hasan.Maruf@....com>,
<Michael.Day@....com>, <akpm@...ux-foundation.org>, <bharata@....com>,
<dave.hansen@...el.com>, <david@...hat.com>, <dongjoo.linux.dev@...il.com>,
<feng.tang@...el.com>, <gourry@...rry.net>, <hannes@...xchg.org>,
<honggyu.kim@...com>, <hughd@...gle.com>, <jhubbard@...dia.com>,
<jon.grimm@....com>, <k.shutemov@...il.com>, <kbusch@...a.com>,
<kmanaouil.dev@...il.com>, <leesuyeon0506@...il.com>, <leillc@...gle.com>,
<liam.howlett@...cle.com>, <linux-kernel@...r.kernel.org>,
<linux-mm@...ck.org>, <mgorman@...hsingularity.net>, <mingo@...hat.com>,
<nadav.amit@...il.com>, <nphamcs@...il.com>, <peterz@...radead.org>,
<riel@...riel.com>, <rientjes@...gle.com>, <rppt@...nel.org>,
<santosh.shukla@....com>, <shivankg@....com>, <shy828301@...il.com>,
<sj@...nel.org>, <vbabka@...e.cz>, <weixugc@...gle.com>,
<willy@...radead.org>, <ying.huang@...ux.alibaba.com>, <ziy@...dia.com>,
<Jonathan.Cameron@...wei.com>, <dave@...olabs.net>
Subject: [RFC PATCH V1 08/13] mm: Add initial scan delay
This is to prevent unnecessary scanning of short lived tasks
spending in scanning.
Signed-off-by: Raghavendra K T <raghavendra.kt@....com>
---
mm/kmmscand.c | 6 +++++-
1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/mm/kmmscand.c b/mm/kmmscand.c
index a19b1f31271d..84140b9e8ce2 100644
--- a/mm/kmmscand.c
+++ b/mm/kmmscand.c
@@ -28,6 +28,7 @@
static struct task_struct *kmmscand_thread __read_mostly;
static DEFINE_MUTEX(kmmscand_mutex);
+extern unsigned int sysctl_numa_balancing_scan_delay;
/*
* Total VMA size to cover during scan.
@@ -880,6 +881,7 @@ void __kmmscand_enter(struct mm_struct *mm)
{
struct kmmscand_mm_slot *kmmscand_slot;
struct mm_slot *slot;
+ unsigned long now;
int wakeup;
/* __kmmscand_exit() must not run from under us */
@@ -890,10 +892,12 @@ void __kmmscand_enter(struct mm_struct *mm)
if (!kmmscand_slot)
return;
+ now = jiffies;
kmmscand_slot->address = 0;
kmmscand_slot->scan_period = kmmscand_mm_scan_period_ms;
kmmscand_slot->scan_size = kmmscand_scan_size;
- kmmscand_slot->next_scan = 0;
+ kmmscand_slot->next_scan = now +
+ msecs_to_jiffies(sysctl_numa_balancing_scan_delay);
kmmscand_slot->scan_delta = 0;
slot = &kmmscand_slot->slot;
--
2.34.1
Powered by blists - more mailing lists