diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2010-08-06 12:39:22 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2010-08-06 12:39:22 -0400 |
commit | c4efd6b569b2646e1346a08a4c40286f8bcb5f11 (patch) | |
tree | bf33e8594ac4e628cc95f2ef25513788b8273601 /include | |
parent | 4aed2fd8e3181fea7c09ba79cf64e7e3f4413bf9 (diff) | |
parent | 0bcfe75807944106a3aa655a54bb610d62f3a7f5 (diff) |
Merge branch 'sched-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip
* 'sched-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip: (27 commits)
sched: Use correct macro to display sched_child_runs_first in /proc/sched_debug
sched: No need for bootmem special cases
sched: Revert nohz_ratelimit() for now
sched: Reduce update_group_power() calls
sched: Update rq->clock for nohz balanced cpus
sched: Fix spelling of sibling
sched, cpuset: Drop __cpuexit from cpu hotplug callbacks
sched: Fix the racy usage of thread_group_cputimer() in fastpath_timer_check()
sched: run_posix_cpu_timers: Don't check ->exit_state, use lock_task_sighand()
sched: thread_group_cputime: Simplify, document the "alive" check
sched: Remove the obsolete exit_state/signal hacks
sched: task_tick_rt: Remove the obsolete ->signal != NULL check
sched: __sched_setscheduler: Read the RLIMIT_RTPRIO value lockless
sched: Fix comments to make them DocBook happy
sched: Fix fix_small_capacity
powerpc: Exclude arch_sd_sibiling_asym_packing() on UP
powerpc: Enable asymmetric SMT scheduling on POWER7
sched: Add asymmetric group packing option for sibling domain
sched: Fix capacity calculations for SMT4
sched: Change nohz idle load balancing logic to push model
...
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/cpu.h | 25 | ||||
-rw-r--r-- | include/linux/cpuset.h | 6 | ||||
-rw-r--r-- | include/linux/perf_event.h | 2 | ||||
-rw-r--r-- | include/linux/sched.h | 59 | ||||
-rw-r--r-- | include/linux/topology.h | 1 |
5 files changed, 62 insertions, 31 deletions
diff --git a/include/linux/cpu.h b/include/linux/cpu.h index e287863ac053..de6b1722cdca 100644 --- a/include/linux/cpu.h +++ b/include/linux/cpu.h | |||
@@ -48,6 +48,31 @@ extern ssize_t arch_cpu_release(const char *, size_t); | |||
48 | #endif | 48 | #endif |
49 | struct notifier_block; | 49 | struct notifier_block; |
50 | 50 | ||
51 | /* | ||
52 | * CPU notifier priorities. | ||
53 | */ | ||
54 | enum { | ||
55 | /* | ||
56 | * SCHED_ACTIVE marks a cpu which is coming up active during | ||
57 | * CPU_ONLINE and CPU_DOWN_FAILED and must be the first | ||
58 | * notifier. CPUSET_ACTIVE adjusts cpuset according to | ||
59 | * cpu_active mask right after SCHED_ACTIVE. During | ||
60 | * CPU_DOWN_PREPARE, SCHED_INACTIVE and CPUSET_INACTIVE are | ||
61 | * ordered in the similar way. | ||
62 | * | ||
63 | * This ordering guarantees consistent cpu_active mask and | ||
64 | * migration behavior to all cpu notifiers. | ||
65 | */ | ||
66 | CPU_PRI_SCHED_ACTIVE = INT_MAX, | ||
67 | CPU_PRI_CPUSET_ACTIVE = INT_MAX - 1, | ||
68 | CPU_PRI_SCHED_INACTIVE = INT_MIN + 1, | ||
69 | CPU_PRI_CPUSET_INACTIVE = INT_MIN, | ||
70 | |||
71 | /* migration should happen before other stuff but after perf */ | ||
72 | CPU_PRI_PERF = 20, | ||
73 | CPU_PRI_MIGRATION = 10, | ||
74 | }; | ||
75 | |||
51 | #ifdef CONFIG_SMP | 76 | #ifdef CONFIG_SMP |
52 | /* Need to know about CPUs going up/down? */ | 77 | /* Need to know about CPUs going up/down? */ |
53 | #if defined(CONFIG_HOTPLUG_CPU) || !defined(MODULE) | 78 | #if defined(CONFIG_HOTPLUG_CPU) || !defined(MODULE) |
diff --git a/include/linux/cpuset.h b/include/linux/cpuset.h index 457ed765a116..f20eb8f16025 100644 --- a/include/linux/cpuset.h +++ b/include/linux/cpuset.h | |||
@@ -20,6 +20,7 @@ extern int number_of_cpusets; /* How many cpusets are defined in system? */ | |||
20 | 20 | ||
21 | extern int cpuset_init(void); | 21 | extern int cpuset_init(void); |
22 | extern void cpuset_init_smp(void); | 22 | extern void cpuset_init_smp(void); |
23 | extern void cpuset_update_active_cpus(void); | ||
23 | extern void cpuset_cpus_allowed(struct task_struct *p, struct cpumask *mask); | 24 | extern void cpuset_cpus_allowed(struct task_struct *p, struct cpumask *mask); |
24 | extern int cpuset_cpus_allowed_fallback(struct task_struct *p); | 25 | extern int cpuset_cpus_allowed_fallback(struct task_struct *p); |
25 | extern nodemask_t cpuset_mems_allowed(struct task_struct *p); | 26 | extern nodemask_t cpuset_mems_allowed(struct task_struct *p); |
@@ -132,6 +133,11 @@ static inline void set_mems_allowed(nodemask_t nodemask) | |||
132 | static inline int cpuset_init(void) { return 0; } | 133 | static inline int cpuset_init(void) { return 0; } |
133 | static inline void cpuset_init_smp(void) {} | 134 | static inline void cpuset_init_smp(void) {} |
134 | 135 | ||
136 | static inline void cpuset_update_active_cpus(void) | ||
137 | { | ||
138 | partition_sched_domains(1, NULL, NULL); | ||
139 | } | ||
140 | |||
135 | static inline void cpuset_cpus_allowed(struct task_struct *p, | 141 | static inline void cpuset_cpus_allowed(struct task_struct *p, |
136 | struct cpumask *mask) | 142 | struct cpumask *mask) |
137 | { | 143 | { |
diff --git a/include/linux/perf_event.h b/include/linux/perf_event.h index 937495c25073..716f99b682c1 100644 --- a/include/linux/perf_event.h +++ b/include/linux/perf_event.h | |||
@@ -1067,7 +1067,7 @@ static inline void perf_event_disable(struct perf_event *event) { } | |||
1067 | #define perf_cpu_notifier(fn) \ | 1067 | #define perf_cpu_notifier(fn) \ |
1068 | do { \ | 1068 | do { \ |
1069 | static struct notifier_block fn##_nb __cpuinitdata = \ | 1069 | static struct notifier_block fn##_nb __cpuinitdata = \ |
1070 | { .notifier_call = fn, .priority = 20 }; \ | 1070 | { .notifier_call = fn, .priority = CPU_PRI_PERF }; \ |
1071 | fn(&fn##_nb, (unsigned long)CPU_UP_PREPARE, \ | 1071 | fn(&fn##_nb, (unsigned long)CPU_UP_PREPARE, \ |
1072 | (void *)(unsigned long)smp_processor_id()); \ | 1072 | (void *)(unsigned long)smp_processor_id()); \ |
1073 | fn(&fn##_nb, (unsigned long)CPU_STARTING, \ | 1073 | fn(&fn##_nb, (unsigned long)CPU_STARTING, \ |
diff --git a/include/linux/sched.h b/include/linux/sched.h index 3992f50de614..9591907c4f79 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h | |||
@@ -272,19 +272,10 @@ extern int runqueue_is_locked(int cpu); | |||
272 | 272 | ||
273 | extern cpumask_var_t nohz_cpu_mask; | 273 | extern cpumask_var_t nohz_cpu_mask; |
274 | #if defined(CONFIG_SMP) && defined(CONFIG_NO_HZ) | 274 | #if defined(CONFIG_SMP) && defined(CONFIG_NO_HZ) |
275 | extern int select_nohz_load_balancer(int cpu); | 275 | extern void select_nohz_load_balancer(int stop_tick); |
276 | extern int get_nohz_load_balancer(void); | 276 | extern int get_nohz_timer_target(void); |
277 | extern int nohz_ratelimit(int cpu); | ||
278 | #else | 277 | #else |
279 | static inline int select_nohz_load_balancer(int cpu) | 278 | static inline void select_nohz_load_balancer(int stop_tick) { } |
280 | { | ||
281 | return 0; | ||
282 | } | ||
283 | |||
284 | static inline int nohz_ratelimit(int cpu) | ||
285 | { | ||
286 | return 0; | ||
287 | } | ||
288 | #endif | 279 | #endif |
289 | 280 | ||
290 | /* | 281 | /* |
@@ -801,7 +792,7 @@ enum cpu_idle_type { | |||
801 | #define SD_POWERSAVINGS_BALANCE 0x0100 /* Balance for power savings */ | 792 | #define SD_POWERSAVINGS_BALANCE 0x0100 /* Balance for power savings */ |
802 | #define SD_SHARE_PKG_RESOURCES 0x0200 /* Domain members share cpu pkg resources */ | 793 | #define SD_SHARE_PKG_RESOURCES 0x0200 /* Domain members share cpu pkg resources */ |
803 | #define SD_SERIALIZE 0x0400 /* Only a single load balancing instance */ | 794 | #define SD_SERIALIZE 0x0400 /* Only a single load balancing instance */ |
804 | 795 | #define SD_ASYM_PACKING 0x0800 /* Place busy groups earlier in the domain */ | |
805 | #define SD_PREFER_SIBLING 0x1000 /* Prefer to place tasks in a sibling domain */ | 796 | #define SD_PREFER_SIBLING 0x1000 /* Prefer to place tasks in a sibling domain */ |
806 | 797 | ||
807 | enum powersavings_balance_level { | 798 | enum powersavings_balance_level { |
@@ -836,6 +827,8 @@ static inline int sd_balance_for_package_power(void) | |||
836 | return SD_PREFER_SIBLING; | 827 | return SD_PREFER_SIBLING; |
837 | } | 828 | } |
838 | 829 | ||
830 | extern int __weak arch_sd_sibiling_asym_packing(void); | ||
831 | |||
839 | /* | 832 | /* |
840 | * Optimise SD flags for power savings: | 833 | * Optimise SD flags for power savings: |
841 | * SD_BALANCE_NEWIDLE helps agressive task consolidation and power savings. | 834 | * SD_BALANCE_NEWIDLE helps agressive task consolidation and power savings. |
@@ -857,7 +850,7 @@ struct sched_group { | |||
857 | * CPU power of this group, SCHED_LOAD_SCALE being max power for a | 850 | * CPU power of this group, SCHED_LOAD_SCALE being max power for a |
858 | * single CPU. | 851 | * single CPU. |
859 | */ | 852 | */ |
860 | unsigned int cpu_power; | 853 | unsigned int cpu_power, cpu_power_orig; |
861 | 854 | ||
862 | /* | 855 | /* |
863 | * The CPUs this group covers. | 856 | * The CPUs this group covers. |
@@ -1693,6 +1686,7 @@ extern void thread_group_times(struct task_struct *p, cputime_t *ut, cputime_t * | |||
1693 | #define PF_EXITING 0x00000004 /* getting shut down */ | 1686 | #define PF_EXITING 0x00000004 /* getting shut down */ |
1694 | #define PF_EXITPIDONE 0x00000008 /* pi exit done on shut down */ | 1687 | #define PF_EXITPIDONE 0x00000008 /* pi exit done on shut down */ |
1695 | #define PF_VCPU 0x00000010 /* I'm a virtual CPU */ | 1688 | #define PF_VCPU 0x00000010 /* I'm a virtual CPU */ |
1689 | #define PF_WQ_WORKER 0x00000020 /* I'm a workqueue worker */ | ||
1696 | #define PF_FORKNOEXEC 0x00000040 /* forked but didn't exec */ | 1690 | #define PF_FORKNOEXEC 0x00000040 /* forked but didn't exec */ |
1697 | #define PF_MCE_PROCESS 0x00000080 /* process policy on mce errors */ | 1691 | #define PF_MCE_PROCESS 0x00000080 /* process policy on mce errors */ |
1698 | #define PF_SUPERPRIV 0x00000100 /* used super-user privileges */ | 1692 | #define PF_SUPERPRIV 0x00000100 /* used super-user privileges */ |
@@ -1787,20 +1781,23 @@ static inline int set_cpus_allowed(struct task_struct *p, cpumask_t new_mask) | |||
1787 | #endif | 1781 | #endif |
1788 | 1782 | ||
1789 | /* | 1783 | /* |
1790 | * Architectures can set this to 1 if they have specified | 1784 | * Do not use outside of architecture code which knows its limitations. |
1791 | * CONFIG_HAVE_UNSTABLE_SCHED_CLOCK in their arch Kconfig, | 1785 | * |
1792 | * but then during bootup it turns out that sched_clock() | 1786 | * sched_clock() has no promise of monotonicity or bounded drift between |
1793 | * is reliable after all: | 1787 | * CPUs, use (which you should not) requires disabling IRQs. |
1788 | * | ||
1789 | * Please use one of the three interfaces below. | ||
1794 | */ | 1790 | */ |
1795 | #ifdef CONFIG_HAVE_UNSTABLE_SCHED_CLOCK | ||
1796 | extern int sched_clock_stable; | ||
1797 | #endif | ||
1798 | |||
1799 | /* ftrace calls sched_clock() directly */ | ||
1800 | extern unsigned long long notrace sched_clock(void); | 1791 | extern unsigned long long notrace sched_clock(void); |
1792 | /* | ||
1793 | * See the comment in kernel/sched_clock.c | ||
1794 | */ | ||
1795 | extern u64 cpu_clock(int cpu); | ||
1796 | extern u64 local_clock(void); | ||
1797 | extern u64 sched_clock_cpu(int cpu); | ||
1798 | |||
1801 | 1799 | ||
1802 | extern void sched_clock_init(void); | 1800 | extern void sched_clock_init(void); |
1803 | extern u64 sched_clock_cpu(int cpu); | ||
1804 | 1801 | ||
1805 | #ifndef CONFIG_HAVE_UNSTABLE_SCHED_CLOCK | 1802 | #ifndef CONFIG_HAVE_UNSTABLE_SCHED_CLOCK |
1806 | static inline void sched_clock_tick(void) | 1803 | static inline void sched_clock_tick(void) |
@@ -1815,17 +1812,19 @@ static inline void sched_clock_idle_wakeup_event(u64 delta_ns) | |||
1815 | { | 1812 | { |
1816 | } | 1813 | } |
1817 | #else | 1814 | #else |
1815 | /* | ||
1816 | * Architectures can set this to 1 if they have specified | ||
1817 | * CONFIG_HAVE_UNSTABLE_SCHED_CLOCK in their arch Kconfig, | ||
1818 | * but then during bootup it turns out that sched_clock() | ||
1819 | * is reliable after all: | ||
1820 | */ | ||
1821 | extern int sched_clock_stable; | ||
1822 | |||
1818 | extern void sched_clock_tick(void); | 1823 | extern void sched_clock_tick(void); |
1819 | extern void sched_clock_idle_sleep_event(void); | 1824 | extern void sched_clock_idle_sleep_event(void); |
1820 | extern void sched_clock_idle_wakeup_event(u64 delta_ns); | 1825 | extern void sched_clock_idle_wakeup_event(u64 delta_ns); |
1821 | #endif | 1826 | #endif |
1822 | 1827 | ||
1823 | /* | ||
1824 | * For kernel-internal use: high-speed (but slightly incorrect) per-cpu | ||
1825 | * clock constructed from sched_clock(): | ||
1826 | */ | ||
1827 | extern unsigned long long cpu_clock(int cpu); | ||
1828 | |||
1829 | extern unsigned long long | 1828 | extern unsigned long long |
1830 | task_sched_runtime(struct task_struct *task); | 1829 | task_sched_runtime(struct task_struct *task); |
1831 | extern unsigned long long thread_group_sched_runtime(struct task_struct *task); | 1830 | extern unsigned long long thread_group_sched_runtime(struct task_struct *task); |
diff --git a/include/linux/topology.h b/include/linux/topology.h index c44df50a05ab..b572e432d2f3 100644 --- a/include/linux/topology.h +++ b/include/linux/topology.h | |||
@@ -103,6 +103,7 @@ int arch_update_cpu_topology(void); | |||
103 | | 1*SD_SHARE_PKG_RESOURCES \ | 103 | | 1*SD_SHARE_PKG_RESOURCES \ |
104 | | 0*SD_SERIALIZE \ | 104 | | 0*SD_SERIALIZE \ |
105 | | 0*SD_PREFER_SIBLING \ | 105 | | 0*SD_PREFER_SIBLING \ |
106 | | arch_sd_sibling_asym_packing() \ | ||
106 | , \ | 107 | , \ |
107 | .last_balance = jiffies, \ | 108 | .last_balance = jiffies, \ |
108 | .balance_interval = 1, \ | 109 | .balance_interval = 1, \ |