Skip to content

Commit

Permalink
sched/numa: Export info needed for NUMA balancing on complex topologies
Browse files Browse the repository at this point in the history
Export some information that is necessary to do placement of
tasks on systems with multi-level NUMA topologies.

Signed-off-by: Rik van Riel <[email protected]>
Signed-off-by: Peter Zijlstra (Intel) <[email protected]>
Cc: [email protected]
Cc: [email protected]
Cc: Linus Torvalds <[email protected]>
Link: http://lkml.kernel.org/r/[email protected]
Signed-off-by: Ingo Molnar <[email protected]>
  • Loading branch information
Rik van Riel authored and Ingo Molnar committed Oct 28, 2014
1 parent f3a7e1a commit 9942f79
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 1 deletion.
4 changes: 3 additions & 1 deletion kernel/sched/core.c
Original file line number Diff line number Diff line change
Expand Up @@ -6129,6 +6129,7 @@ static void claim_allocations(int cpu, struct sched_domain *sd)
#ifdef CONFIG_NUMA
static int sched_domains_numa_levels;
static int *sched_domains_numa_distance;
int sched_max_numa_distance;
static struct cpumask ***sched_domains_numa_masks;
static int sched_domains_curr_level;
#endif
Expand Down Expand Up @@ -6300,7 +6301,7 @@ static void sched_numa_warn(const char *str)
printk(KERN_WARNING "\n");
}

static bool find_numa_distance(int distance)
bool find_numa_distance(int distance)
{
int i;

Expand Down Expand Up @@ -6447,6 +6448,7 @@ static void sched_init_numa(void)
sched_domain_topology = tl;

sched_domains_numa_levels = level;
sched_max_numa_distance = sched_domains_numa_distance[level - 1];
}

static void sched_domains_numa_masks_set(int cpu)
Expand Down
5 changes: 5 additions & 0 deletions kernel/sched/sched.h
Original file line number Diff line number Diff line change
Expand Up @@ -678,6 +678,11 @@ static inline u64 rq_clock_task(struct rq *rq)
return rq->clock_task;
}

#ifdef CONFIG_NUMA
extern int sched_max_numa_distance;
extern bool find_numa_distance(int distance);
#endif

#ifdef CONFIG_NUMA_BALANCING
extern void sched_setnuma(struct task_struct *p, int node);
extern int migrate_task_to(struct task_struct *p, int cpu);
Expand Down

0 comments on commit 9942f79

Please sign in to comment.