]> git.proxmox.com Git - mirror_ubuntu-zesty-kernel.git/blame - include/linux/cpuset.h
mm: filter based on a nodemask as well as a gfp_mask
[mirror_ubuntu-zesty-kernel.git] / include / linux / cpuset.h
CommitLineData
1da177e4
LT
1#ifndef _LINUX_CPUSET_H
2#define _LINUX_CPUSET_H
3/*
4 * cpuset interface
5 *
6 * Copyright (C) 2003 BULL SA
825a46af 7 * Copyright (C) 2004-2006 Silicon Graphics, Inc.
1da177e4
LT
8 *
9 */
10
11#include <linux/sched.h>
12#include <linux/cpumask.h>
13#include <linux/nodemask.h>
8793d854 14#include <linux/cgroup.h>
1da177e4
LT
15
16#ifdef CONFIG_CPUSETS
17
202f72d5
PJ
18extern int number_of_cpusets; /* How many cpusets are defined in system? */
19
c417f024 20extern int cpuset_init_early(void);
1da177e4
LT
21extern int cpuset_init(void);
22extern void cpuset_init_smp(void);
f9a86fcb
MT
23extern void cpuset_cpus_allowed(struct task_struct *p, cpumask_t *mask);
24extern void cpuset_cpus_allowed_locked(struct task_struct *p, cpumask_t *mask);
909d75a3 25extern nodemask_t cpuset_mems_allowed(struct task_struct *p);
9276b1bc 26#define cpuset_current_mems_allowed (current->mems_allowed)
1da177e4 27void cpuset_init_current_mems_allowed(void);
cf2a473c 28void cpuset_update_task_memory_state(void);
19770b32 29int cpuset_nodemask_valid_mems_allowed(nodemask_t *nodemask);
202f72d5 30
02a0e53d
PJ
31extern int __cpuset_zone_allowed_softwall(struct zone *z, gfp_t gfp_mask);
32extern int __cpuset_zone_allowed_hardwall(struct zone *z, gfp_t gfp_mask);
33
34static int inline cpuset_zone_allowed_softwall(struct zone *z, gfp_t gfp_mask)
35{
36 return number_of_cpusets <= 1 ||
37 __cpuset_zone_allowed_softwall(z, gfp_mask);
38}
39
40static int inline cpuset_zone_allowed_hardwall(struct zone *z, gfp_t gfp_mask)
202f72d5 41{
02a0e53d
PJ
42 return number_of_cpusets <= 1 ||
43 __cpuset_zone_allowed_hardwall(z, gfp_mask);
202f72d5
PJ
44}
45
bbe373f2
DR
46extern int cpuset_mems_allowed_intersects(const struct task_struct *tsk1,
47 const struct task_struct *tsk2);
3e0d98b9
PJ
48
49#define cpuset_memory_pressure_bump() \
50 do { \
51 if (cpuset_memory_pressure_enabled) \
52 __cpuset_memory_pressure_bump(); \
53 } while (0)
54extern int cpuset_memory_pressure_enabled;
55extern void __cpuset_memory_pressure_bump(void);
56
54047320 57extern const struct file_operations proc_cpuset_operations;
df5f8314
EB
58struct seq_file;
59extern void cpuset_task_status_allowed(struct seq_file *m,
60 struct task_struct *task);
1da177e4 61
505970b9
PJ
62extern void cpuset_lock(void);
63extern void cpuset_unlock(void);
64
825a46af
PJ
65extern int cpuset_mem_spread_node(void);
66
67static inline int cpuset_do_page_mem_spread(void)
68{
69 return current->flags & PF_SPREAD_PAGE;
70}
71
72static inline int cpuset_do_slab_mem_spread(void)
73{
74 return current->flags & PF_SPREAD_SLAB;
75}
76
38837fc7
PJ
77extern void cpuset_track_online_nodes(void);
78
8793d854
PM
79extern int current_cpuset_is_being_rebound(void);
80
1da177e4
LT
81#else /* !CONFIG_CPUSETS */
82
c417f024 83static inline int cpuset_init_early(void) { return 0; }
1da177e4
LT
84static inline int cpuset_init(void) { return 0; }
85static inline void cpuset_init_smp(void) {}
1da177e4 86
f9a86fcb 87static inline void cpuset_cpus_allowed(struct task_struct *p, cpumask_t *mask)
1da177e4 88{
f9a86fcb 89 *mask = cpu_possible_map;
1da177e4 90}
f9a86fcb
MT
91static inline void cpuset_cpus_allowed_locked(struct task_struct *p,
92 cpumask_t *mask)
470fd646 93{
f9a86fcb 94 *mask = cpu_possible_map;
470fd646 95}
1da177e4 96
909d75a3
PJ
97static inline nodemask_t cpuset_mems_allowed(struct task_struct *p)
98{
99 return node_possible_map;
100}
101
0e1e7c7a 102#define cpuset_current_mems_allowed (node_states[N_HIGH_MEMORY])
1da177e4 103static inline void cpuset_init_current_mems_allowed(void) {}
cf2a473c 104static inline void cpuset_update_task_memory_state(void) {}
1da177e4 105
19770b32 106static inline int cpuset_nodemask_valid_mems_allowed(nodemask_t *nodemask)
1da177e4
LT
107{
108 return 1;
109}
110
02a0e53d
PJ
111static inline int cpuset_zone_allowed_softwall(struct zone *z, gfp_t gfp_mask)
112{
113 return 1;
114}
115
116static inline int cpuset_zone_allowed_hardwall(struct zone *z, gfp_t gfp_mask)
1da177e4
LT
117{
118 return 1;
119}
120
bbe373f2
DR
121static inline int cpuset_mems_allowed_intersects(const struct task_struct *tsk1,
122 const struct task_struct *tsk2)
ef08e3b4
PJ
123{
124 return 1;
125}
126
3e0d98b9
PJ
127static inline void cpuset_memory_pressure_bump(void) {}
128
df5f8314
EB
129static inline void cpuset_task_status_allowed(struct seq_file *m,
130 struct task_struct *task)
1da177e4 131{
1da177e4
LT
132}
133
505970b9
PJ
134static inline void cpuset_lock(void) {}
135static inline void cpuset_unlock(void) {}
136
825a46af
PJ
137static inline int cpuset_mem_spread_node(void)
138{
139 return 0;
140}
141
142static inline int cpuset_do_page_mem_spread(void)
143{
144 return 0;
145}
146
147static inline int cpuset_do_slab_mem_spread(void)
148{
149 return 0;
150}
151
38837fc7
PJ
152static inline void cpuset_track_online_nodes(void) {}
153
8793d854
PM
154static inline int current_cpuset_is_being_rebound(void)
155{
156 return 0;
157}
158
1da177e4
LT
159#endif /* !CONFIG_CPUSETS */
160
161#endif /* _LINUX_CPUSET_H */