diff options
author | Mel Gorman <mgorman@suse.de> | 2012-11-22 09:40:03 -0500 |
---|---|---|
committer | Mel Gorman <mgorman@suse.de> | 2012-12-11 09:42:56 -0500 |
commit | 5bca23035391928c4c7301835accca3551b96cc2 (patch) | |
tree | 2feb63abf318e6edfded8bb97b43ca29c3c5b312 /kernel/sched/features.h | |
parent | 3105b86a9fee7d2c2e76edb53bbbc4027599628f (diff) |
mm: sched: numa: Delay PTE scanning until a task is scheduled on a new node
Due to the fact that migrations are driven by the CPU a task is running
on there is no point tracking NUMA faults until one task runs on a new
node. This patch tracks the first node used by an address space. Until
it changes, PTE scanning is disabled and no NUMA hinting faults are
trapped. This should help workloads that are short-lived, do not care
about NUMA placement or have bound themselves to a single node.
This takes advantage of the logic in "mm: sched: numa: Implement slow
start for working set sampling" to delay when the checks are made. This
will take advantage of processes that set their CPU and node bindings
early in their lifetime. It will also potentially allow any initial load
balancing to take place.
Signed-off-by: Mel Gorman <mgorman@suse.de>
Diffstat (limited to 'kernel/sched/features.h')
-rw-r--r-- | kernel/sched/features.h | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/kernel/sched/features.h b/kernel/sched/features.h index d2373a3e3252..e7c25fff1e94 100644 --- a/kernel/sched/features.h +++ b/kernel/sched/features.h | |||
@@ -65,8 +65,10 @@ SCHED_FEAT(LB_MIN, false) | |||
65 | /* | 65 | /* |
66 | * Apply the automatic NUMA scheduling policy. Enabled automatically | 66 | * Apply the automatic NUMA scheduling policy. Enabled automatically |
67 | * at runtime if running on a NUMA machine. Can be controlled via | 67 | * at runtime if running on a NUMA machine. Can be controlled via |
68 | * numa_balancing= | 68 | * numa_balancing=. Allow PTE scanning to be forced on UMA machines |
69 | * for debugging the core machinery. | ||
69 | */ | 70 | */ |
70 | #ifdef CONFIG_NUMA_BALANCING | 71 | #ifdef CONFIG_NUMA_BALANCING |
71 | SCHED_FEAT(NUMA, false) | 72 | SCHED_FEAT(NUMA, false) |
73 | SCHED_FEAT(NUMA_FORCE, false) | ||
72 | #endif | 74 | #endif |