diff options
Diffstat (limited to 'include/linux/sched.h')
-rw-r--r-- | include/linux/sched.h | 53 |
1 files changed, 36 insertions, 17 deletions
diff --git a/include/linux/sched.h b/include/linux/sched.h index bc9326dcdde1..28c774ff3cc7 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h | |||
@@ -77,6 +77,7 @@ struct sched_param { | |||
77 | #include <linux/proportions.h> | 77 | #include <linux/proportions.h> |
78 | #include <linux/seccomp.h> | 78 | #include <linux/seccomp.h> |
79 | #include <linux/rcupdate.h> | 79 | #include <linux/rcupdate.h> |
80 | #include <linux/rculist.h> | ||
80 | #include <linux/rtmutex.h> | 81 | #include <linux/rtmutex.h> |
81 | 82 | ||
82 | #include <linux/time.h> | 83 | #include <linux/time.h> |
@@ -96,8 +97,8 @@ struct exec_domain; | |||
96 | struct futex_pi_state; | 97 | struct futex_pi_state; |
97 | struct robust_list_head; | 98 | struct robust_list_head; |
98 | struct bio; | 99 | struct bio; |
99 | struct bts_tracer; | ||
100 | struct fs_struct; | 100 | struct fs_struct; |
101 | struct bts_context; | ||
101 | struct perf_counter_context; | 102 | struct perf_counter_context; |
102 | 103 | ||
103 | /* | 104 | /* |
@@ -117,6 +118,7 @@ struct perf_counter_context; | |||
117 | * 11 bit fractions. | 118 | * 11 bit fractions. |
118 | */ | 119 | */ |
119 | extern unsigned long avenrun[]; /* Load averages */ | 120 | extern unsigned long avenrun[]; /* Load averages */ |
121 | extern void get_avenrun(unsigned long *loads, unsigned long offset, int shift); | ||
120 | 122 | ||
121 | #define FSHIFT 11 /* nr of bits of precision */ | 123 | #define FSHIFT 11 /* nr of bits of precision */ |
122 | #define FIXED_1 (1<<FSHIFT) /* 1.0 as fixed-point */ | 124 | #define FIXED_1 (1<<FSHIFT) /* 1.0 as fixed-point */ |
@@ -136,8 +138,8 @@ DECLARE_PER_CPU(unsigned long, process_counts); | |||
136 | extern int nr_processes(void); | 138 | extern int nr_processes(void); |
137 | extern unsigned long nr_running(void); | 139 | extern unsigned long nr_running(void); |
138 | extern unsigned long nr_uninterruptible(void); | 140 | extern unsigned long nr_uninterruptible(void); |
139 | extern unsigned long nr_active(void); | ||
140 | extern unsigned long nr_iowait(void); | 141 | extern unsigned long nr_iowait(void); |
142 | extern void calc_global_load(void); | ||
141 | extern u64 cpu_nr_migrations(int cpu); | 143 | extern u64 cpu_nr_migrations(int cpu); |
142 | 144 | ||
143 | extern unsigned long get_parent_ip(unsigned long addr); | 145 | extern unsigned long get_parent_ip(unsigned long addr); |
@@ -844,7 +846,17 @@ struct sched_group { | |||
844 | */ | 846 | */ |
845 | u32 reciprocal_cpu_power; | 847 | u32 reciprocal_cpu_power; |
846 | 848 | ||
847 | unsigned long cpumask[]; | 849 | /* |
850 | * The CPUs this group covers. | ||
851 | * | ||
852 | * NOTE: this field is variable length. (Allocated dynamically | ||
853 | * by attaching extra space to the end of the structure, | ||
854 | * depending on how many CPUs the kernel has booted up with) | ||
855 | * | ||
856 | * It is also be embedded into static data structures at build | ||
857 | * time. (See 'struct static_sched_group' in kernel/sched.c) | ||
858 | */ | ||
859 | unsigned long cpumask[0]; | ||
848 | }; | 860 | }; |
849 | 861 | ||
850 | static inline struct cpumask *sched_group_cpus(struct sched_group *sg) | 862 | static inline struct cpumask *sched_group_cpus(struct sched_group *sg) |
@@ -930,8 +942,17 @@ struct sched_domain { | |||
930 | char *name; | 942 | char *name; |
931 | #endif | 943 | #endif |
932 | 944 | ||
933 | /* span of all CPUs in this domain */ | 945 | /* |
934 | unsigned long span[]; | 946 | * Span of all CPUs in this domain. |
947 | * | ||
948 | * NOTE: this field is variable length. (Allocated dynamically | ||
949 | * by attaching extra space to the end of the structure, | ||
950 | * depending on how many CPUs the kernel has booted up with) | ||
951 | * | ||
952 | * It is also be embedded into static data structures at build | ||
953 | * time. (See 'struct static_sched_domain' in kernel/sched.c) | ||
954 | */ | ||
955 | unsigned long span[0]; | ||
935 | }; | 956 | }; |
936 | 957 | ||
937 | static inline struct cpumask *sched_domain_span(struct sched_domain *sd) | 958 | static inline struct cpumask *sched_domain_span(struct sched_domain *sd) |
@@ -1216,18 +1237,11 @@ struct task_struct { | |||
1216 | struct list_head ptraced; | 1237 | struct list_head ptraced; |
1217 | struct list_head ptrace_entry; | 1238 | struct list_head ptrace_entry; |
1218 | 1239 | ||
1219 | #ifdef CONFIG_X86_PTRACE_BTS | ||
1220 | /* | 1240 | /* |
1221 | * This is the tracer handle for the ptrace BTS extension. | 1241 | * This is the tracer handle for the ptrace BTS extension. |
1222 | * This field actually belongs to the ptracer task. | 1242 | * This field actually belongs to the ptracer task. |
1223 | */ | 1243 | */ |
1224 | struct bts_tracer *bts; | 1244 | struct bts_context *bts; |
1225 | /* | ||
1226 | * The buffer to hold the BTS data. | ||
1227 | */ | ||
1228 | void *bts_buffer; | ||
1229 | size_t bts_size; | ||
1230 | #endif /* CONFIG_X86_PTRACE_BTS */ | ||
1231 | 1245 | ||
1232 | /* PID/PID hash table linkage. */ | 1246 | /* PID/PID hash table linkage. */ |
1233 | struct pid_link pids[PIDTYPE_MAX]; | 1247 | struct pid_link pids[PIDTYPE_MAX]; |
@@ -1440,7 +1454,9 @@ struct task_struct { | |||
1440 | #ifdef CONFIG_TRACING | 1454 | #ifdef CONFIG_TRACING |
1441 | /* state flags for use by tracers */ | 1455 | /* state flags for use by tracers */ |
1442 | unsigned long trace; | 1456 | unsigned long trace; |
1443 | #endif | 1457 | /* bitmask of trace recursion */ |
1458 | unsigned long trace_recursion; | ||
1459 | #endif /* CONFIG_TRACING */ | ||
1444 | }; | 1460 | }; |
1445 | 1461 | ||
1446 | /* Future-safe accessor for struct task_struct's cpus_allowed. */ | 1462 | /* Future-safe accessor for struct task_struct's cpus_allowed. */ |
@@ -2013,8 +2029,10 @@ extern void set_task_comm(struct task_struct *tsk, char *from); | |||
2013 | extern char *get_task_comm(char *to, struct task_struct *tsk); | 2029 | extern char *get_task_comm(char *to, struct task_struct *tsk); |
2014 | 2030 | ||
2015 | #ifdef CONFIG_SMP | 2031 | #ifdef CONFIG_SMP |
2032 | extern void wait_task_context_switch(struct task_struct *p); | ||
2016 | extern unsigned long wait_task_inactive(struct task_struct *, long match_state); | 2033 | extern unsigned long wait_task_inactive(struct task_struct *, long match_state); |
2017 | #else | 2034 | #else |
2035 | static inline void wait_task_context_switch(struct task_struct *p) {} | ||
2018 | static inline unsigned long wait_task_inactive(struct task_struct *p, | 2036 | static inline unsigned long wait_task_inactive(struct task_struct *p, |
2019 | long match_state) | 2037 | long match_state) |
2020 | { | 2038 | { |
@@ -2022,7 +2040,8 @@ static inline unsigned long wait_task_inactive(struct task_struct *p, | |||
2022 | } | 2040 | } |
2023 | #endif | 2041 | #endif |
2024 | 2042 | ||
2025 | #define next_task(p) list_entry(rcu_dereference((p)->tasks.next), struct task_struct, tasks) | 2043 | #define next_task(p) \ |
2044 | list_entry_rcu((p)->tasks.next, struct task_struct, tasks) | ||
2026 | 2045 | ||
2027 | #define for_each_process(p) \ | 2046 | #define for_each_process(p) \ |
2028 | for (p = &init_task ; (p = next_task(p)) != &init_task ; ) | 2047 | for (p = &init_task ; (p = next_task(p)) != &init_task ; ) |
@@ -2061,8 +2080,8 @@ int same_thread_group(struct task_struct *p1, struct task_struct *p2) | |||
2061 | 2080 | ||
2062 | static inline struct task_struct *next_thread(const struct task_struct *p) | 2081 | static inline struct task_struct *next_thread(const struct task_struct *p) |
2063 | { | 2082 | { |
2064 | return list_entry(rcu_dereference(p->thread_group.next), | 2083 | return list_entry_rcu(p->thread_group.next, |
2065 | struct task_struct, thread_group); | 2084 | struct task_struct, thread_group); |
2066 | } | 2085 | } |
2067 | 2086 | ||
2068 | static inline int thread_group_empty(struct task_struct *p) | 2087 | static inline int thread_group_empty(struct task_struct *p) |