diff options
Diffstat (limited to 'arch/x86/kernel/tsc.c')
| -rw-r--r-- | arch/x86/kernel/tsc.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/arch/x86/kernel/tsc.c b/arch/x86/kernel/tsc.c index 26a863a9c2a8..a1c2cd768538 100644 --- a/arch/x86/kernel/tsc.c +++ b/arch/x86/kernel/tsc.c | |||
| @@ -104,10 +104,14 @@ int __init notsc_setup(char *str) | |||
| 104 | 104 | ||
| 105 | __setup("notsc", notsc_setup); | 105 | __setup("notsc", notsc_setup); |
| 106 | 106 | ||
| 107 | static int no_sched_irq_time; | ||
| 108 | |||
| 107 | static int __init tsc_setup(char *str) | 109 | static int __init tsc_setup(char *str) |
| 108 | { | 110 | { |
| 109 | if (!strcmp(str, "reliable")) | 111 | if (!strcmp(str, "reliable")) |
| 110 | tsc_clocksource_reliable = 1; | 112 | tsc_clocksource_reliable = 1; |
| 113 | if (!strncmp(str, "noirqtime", 9)) | ||
| 114 | no_sched_irq_time = 1; | ||
| 111 | return 1; | 115 | return 1; |
| 112 | } | 116 | } |
| 113 | 117 | ||
| @@ -801,6 +805,7 @@ void mark_tsc_unstable(char *reason) | |||
| 801 | if (!tsc_unstable) { | 805 | if (!tsc_unstable) { |
| 802 | tsc_unstable = 1; | 806 | tsc_unstable = 1; |
| 803 | sched_clock_stable = 0; | 807 | sched_clock_stable = 0; |
| 808 | disable_sched_clock_irqtime(); | ||
| 804 | printk(KERN_INFO "Marking TSC unstable due to %s\n", reason); | 809 | printk(KERN_INFO "Marking TSC unstable due to %s\n", reason); |
| 805 | /* Change only the rating, when not registered */ | 810 | /* Change only the rating, when not registered */ |
| 806 | if (clocksource_tsc.mult) | 811 | if (clocksource_tsc.mult) |
| @@ -987,6 +992,9 @@ void __init tsc_init(void) | |||
| 987 | /* now allow native_sched_clock() to use rdtsc */ | 992 | /* now allow native_sched_clock() to use rdtsc */ |
| 988 | tsc_disabled = 0; | 993 | tsc_disabled = 0; |
| 989 | 994 | ||
| 995 | if (!no_sched_irq_time) | ||
| 996 | enable_sched_clock_irqtime(); | ||
| 997 | |||
| 990 | lpj = ((u64)tsc_khz * 1000); | 998 | lpj = ((u64)tsc_khz * 1000); |
| 991 | do_div(lpj, HZ); | 999 | do_div(lpj, HZ); |
| 992 | lpj_fine = lpj; | 1000 | lpj_fine = lpj; |
