c29a7baf09
NUMA emulation (aka fake NUMA) distributes the available memory to nodes without using real topology information about the physical memory of the machine. Splitting the system memory into nodes replicates the memory management structures for each node. Particularly each node has its own "mm locks" and its own "kswapd" task. For large systems, under certain conditions, this results in improved system performance and/or latency based on reduced pressure on the mm locks and the kswapd tasks. NUMA emulation distributes CPUs to nodes while respecting the original machine topology information. This is done by trying to avoid to separate CPUs which reside on the same book or even on the same MC. Because the current Linux scheduler code requires a stable cpu to node mapping, cores are pinned to nodes when the first CPU thread is set online. This patch is based on the initial implementation from Philipp Hachtmann. Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
36 lines
695 B
C
36 lines
695 B
C
/*
|
|
* NUMA support for s390
|
|
*
|
|
* Declare the NUMA core code structures and functions.
|
|
*
|
|
* Copyright IBM Corp. 2015
|
|
*/
|
|
|
|
#ifndef _ASM_S390_NUMA_H
|
|
#define _ASM_S390_NUMA_H
|
|
|
|
#ifdef CONFIG_NUMA
|
|
|
|
#include <linux/numa.h>
|
|
#include <linux/cpumask.h>
|
|
|
|
void numa_setup(void);
|
|
int numa_pfn_to_nid(unsigned long pfn);
|
|
int __node_distance(int a, int b);
|
|
void numa_update_cpu_topology(void);
|
|
|
|
extern cpumask_var_t node_to_cpumask_map[MAX_NUMNODES];
|
|
extern int numa_debug_enabled;
|
|
|
|
#else
|
|
|
|
static inline void numa_setup(void) { }
|
|
static inline void numa_update_cpu_topology(void) { }
|
|
static inline int numa_pfn_to_nid(unsigned long pfn)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
#endif /* CONFIG_NUMA */
|
|
#endif /* _ASM_S390_NUMA_H */
|