diff options
-rw-r--r-- | Documentation/kernel-parameters.txt | 4 | ||||
-rw-r--r-- | arch/x86/Kconfig | 11 | ||||
-rw-r--r-- | arch/x86/kernel/tsc.c | 8 |
3 files changed, 23 insertions, 0 deletions
diff --git a/Documentation/kernel-parameters.txt b/Documentation/kernel-parameters.txt index 8dd7248508a9..ed05a4a0d242 100644 --- a/Documentation/kernel-parameters.txt +++ b/Documentation/kernel-parameters.txt | |||
@@ -2435,6 +2435,10 @@ and is between 256 and 4096 characters. It is defined in the file | |||
2435 | disables clocksource verification at runtime. | 2435 | disables clocksource verification at runtime. |
2436 | Used to enable high-resolution timer mode on older | 2436 | Used to enable high-resolution timer mode on older |
2437 | hardware, and in virtualized environment. | 2437 | hardware, and in virtualized environment. |
2438 | [x86] noirqtime: Do not use TSC to do irq accounting. | ||
2439 | Used to run time disable IRQ_TIME_ACCOUNTING on any | ||
2440 | platforms where RDTSC is slow and this accounting | ||
2441 | can add overhead. | ||
2438 | 2442 | ||
2439 | turbografx.map[2|3]= [HW,JOY] | 2443 | turbografx.map[2|3]= [HW,JOY] |
2440 | TurboGraFX parallel port interface | 2444 | TurboGraFX parallel port interface |
diff --git a/arch/x86/Kconfig b/arch/x86/Kconfig index cea0cd9a316f..f4c70c246ffe 100644 --- a/arch/x86/Kconfig +++ b/arch/x86/Kconfig | |||
@@ -795,6 +795,17 @@ config SCHED_MC | |||
795 | making when dealing with multi-core CPU chips at a cost of slightly | 795 | making when dealing with multi-core CPU chips at a cost of slightly |
796 | increased overhead in some places. If unsure say N here. | 796 | increased overhead in some places. If unsure say N here. |
797 | 797 | ||
798 | config IRQ_TIME_ACCOUNTING | ||
799 | bool "Fine granularity task level IRQ time accounting" | ||
800 | default n | ||
801 | ---help--- | ||
802 | Select this option to enable fine granularity task irq time | ||
803 | accounting. This is done by reading a timestamp on each | ||
804 | transitions between softirq and hardirq state, so there can be a | ||
805 | small performance impact. | ||
806 | |||
807 | If in doubt, say N here. | ||
808 | |||
798 | source "kernel/Kconfig.preempt" | 809 | source "kernel/Kconfig.preempt" |
799 | 810 | ||
800 | config X86_UP_APIC | 811 | config X86_UP_APIC |
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; |