Blame view

kernel/linux-rt-4.4.41/arch/x86/include/asm/numa.h 2.14 KB
5113f6f70   김현기   kernel add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
  #ifndef _ASM_X86_NUMA_H
  #define _ASM_X86_NUMA_H
  
  #include <linux/nodemask.h>
  
  #include <asm/topology.h>
  #include <asm/apicdef.h>
  
  #ifdef CONFIG_NUMA
  
  #define NR_NODE_MEMBLKS		(MAX_NUMNODES*2)
  
  /*
   * Too small node sizes may confuse the VM badly. Usually they
   * result from BIOS bugs. So dont recognize nodes as standalone
   * NUMA entities that have less than this amount of RAM listed:
   */
  #define NODE_MIN_SIZE (4*1024*1024)
  
  extern int numa_off;
  
  /*
   * __apicid_to_node[] stores the raw mapping between physical apicid and
   * node and is used to initialize cpu_to_node mapping.
   *
   * The mapping may be overridden by apic->numa_cpu_node() on 32bit and thus
   * should be accessed by the accessors - set_apicid_to_node() and
   * numa_cpu_node().
   */
  extern s16 __apicid_to_node[MAX_LOCAL_APIC];
  extern nodemask_t numa_nodes_parsed __initdata;
  
  extern int __init numa_add_memblk(int nodeid, u64 start, u64 end);
  extern void __init numa_set_distance(int from, int to, int distance);
  
  static inline void set_apicid_to_node(int apicid, s16 node)
  {
  	__apicid_to_node[apicid] = node;
  }
  
  extern int numa_cpu_node(int cpu);
  
  #else	/* CONFIG_NUMA */
  static inline void set_apicid_to_node(int apicid, s16 node)
  {
  }
  
  static inline int numa_cpu_node(int cpu)
  {
  	return NUMA_NO_NODE;
  }
  #endif	/* CONFIG_NUMA */
  
  #ifdef CONFIG_X86_32
  # include <asm/numa_32.h>
  #endif
  
  #ifdef CONFIG_NUMA
  extern void numa_set_node(int cpu, int node);
  extern void numa_clear_node(int cpu);
  extern void __init init_cpu_to_node(void);
  extern void numa_add_cpu(int cpu);
  extern void numa_remove_cpu(int cpu);
  #else	/* CONFIG_NUMA */
  static inline void numa_set_node(int cpu, int node)	{ }
  static inline void numa_clear_node(int cpu)		{ }
  static inline void init_cpu_to_node(void)		{ }
  static inline void numa_add_cpu(int cpu)		{ }
  static inline void numa_remove_cpu(int cpu)		{ }
  #endif	/* CONFIG_NUMA */
  
  #ifdef CONFIG_DEBUG_PER_CPU_MAPS
  void debug_cpumask_set_cpu(int cpu, int node, bool enable);
  #endif
  
  #ifdef CONFIG_NUMA_EMU
  #define FAKE_NODE_MIN_SIZE	((u64)32 << 20)
  #define FAKE_NODE_MIN_HASH_MASK	(~(FAKE_NODE_MIN_SIZE - 1UL))
  void numa_emu_cmdline(char *);
  #endif /* CONFIG_NUMA_EMU */
  
  #endif	/* _ASM_X86_NUMA_H */