diff options
author | Arun R Bharadwaj <arun@linux.vnet.ibm.com> | 2009-04-16 02:45:34 -0400 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2009-05-13 10:52:42 -0400 |
commit | cd1bb94b4a0531e8211a3774f17de831f8285f76 (patch) | |
tree | 0a031dd2bd984cbfec88a3ced6b2c6e3326efb88 | |
parent | 5c333864a6ba811052d52ef14fbed056b9ac3512 (diff) |
timers: /proc/sys sysctl hook to enable timer migration
* Arun R Bharadwaj <arun@linux.vnet.ibm.com> [2009-04-16 12:11:36]:
This patch creates the /proc/sys sysctl interface at
/proc/sys/kernel/timer_migration
Timer migration is enabled by default.
To disable timer migration, when CONFIG_SCHED_DEBUG = y,
echo 0 > /proc/sys/kernel/timer_migration
Signed-off-by: Arun R Bharadwaj <arun@linux.vnet.ibm.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
-rw-r--r-- | include/linux/sched.h | 1 | ||||
-rw-r--r-- | kernel/sched.c | 2 | ||||
-rw-r--r-- | kernel/sysctl.c | 8 |
3 files changed, 11 insertions, 0 deletions
diff --git a/include/linux/sched.h b/include/linux/sched.h index b4c38bc8049c..618504010400 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h | |||
@@ -1766,6 +1766,7 @@ extern unsigned int sysctl_sched_child_runs_first; | |||
1766 | extern unsigned int sysctl_sched_features; | 1766 | extern unsigned int sysctl_sched_features; |
1767 | extern unsigned int sysctl_sched_migration_cost; | 1767 | extern unsigned int sysctl_sched_migration_cost; |
1768 | extern unsigned int sysctl_sched_nr_migrate; | 1768 | extern unsigned int sysctl_sched_nr_migrate; |
1769 | extern unsigned int sysctl_timer_migration; | ||
1769 | 1770 | ||
1770 | int sched_nr_latency_handler(struct ctl_table *table, int write, | 1771 | int sched_nr_latency_handler(struct ctl_table *table, int write, |
1771 | struct file *file, void __user *buffer, size_t *length, | 1772 | struct file *file, void __user *buffer, size_t *length, |
diff --git a/kernel/sched.c b/kernel/sched.c index 9c5b4d3f97ab..7f1dd56af863 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
@@ -8731,6 +8731,8 @@ void __init sched_init_smp(void) | |||
8731 | } | 8731 | } |
8732 | #endif /* CONFIG_SMP */ | 8732 | #endif /* CONFIG_SMP */ |
8733 | 8733 | ||
8734 | const_debug unsigned int sysctl_timer_migration = 1; | ||
8735 | |||
8734 | int in_sched_functions(unsigned long addr) | 8736 | int in_sched_functions(unsigned long addr) |
8735 | { | 8737 | { |
8736 | return in_lock_functions(addr) || | 8738 | return in_lock_functions(addr) || |
diff --git a/kernel/sysctl.c b/kernel/sysctl.c index e3d2c7dd59b9..b3ce58137303 100644 --- a/kernel/sysctl.c +++ b/kernel/sysctl.c | |||
@@ -324,6 +324,14 @@ static struct ctl_table kern_table[] = { | |||
324 | .mode = 0644, | 324 | .mode = 0644, |
325 | .proc_handler = &proc_dointvec, | 325 | .proc_handler = &proc_dointvec, |
326 | }, | 326 | }, |
327 | { | ||
328 | .ctl_name = CTL_UNNUMBERED, | ||
329 | .procname = "timer_migration", | ||
330 | .data = &sysctl_timer_migration, | ||
331 | .maxlen = sizeof(unsigned int), | ||
332 | .mode = 0644, | ||
333 | .proc_handler = &proc_dointvec, | ||
334 | }, | ||
327 | #endif | 335 | #endif |
328 | { | 336 | { |
329 | .ctl_name = CTL_UNNUMBERED, | 337 | .ctl_name = CTL_UNNUMBERED, |