diff options
Diffstat (limited to 'arch/x86_64/kernel/apic.c')
-rw-r--r-- | arch/x86_64/kernel/apic.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/arch/x86_64/kernel/apic.c b/arch/x86_64/kernel/apic.c index 943ec4d1bd8e..d198f7d82e5a 100644 --- a/arch/x86_64/kernel/apic.c +++ b/arch/x86_64/kernel/apic.c | |||
@@ -839,14 +839,15 @@ static void setup_APIC_timer(unsigned int clocks) | |||
839 | 839 | ||
840 | static int __init calibrate_APIC_clock(void) | 840 | static int __init calibrate_APIC_clock(void) |
841 | { | 841 | { |
842 | int apic, apic_start, tsc, tsc_start; | 842 | unsigned apic, apic_start; |
843 | unsigned long tsc, tsc_start; | ||
843 | int result; | 844 | int result; |
844 | /* | 845 | /* |
845 | * Put whatever arbitrary (but long enough) timeout | 846 | * Put whatever arbitrary (but long enough) timeout |
846 | * value into the APIC clock, we just want to get the | 847 | * value into the APIC clock, we just want to get the |
847 | * counter running for calibration. | 848 | * counter running for calibration. |
848 | */ | 849 | */ |
849 | __setup_APIC_LVTT(1000000000); | 850 | __setup_APIC_LVTT(4000000000); |
850 | 851 | ||
851 | apic_start = apic_read(APIC_TMCCT); | 852 | apic_start = apic_read(APIC_TMCCT); |
852 | #ifdef CONFIG_X86_PM_TIMER | 853 | #ifdef CONFIG_X86_PM_TIMER |
@@ -857,13 +858,13 @@ static int __init calibrate_APIC_clock(void) | |||
857 | } else | 858 | } else |
858 | #endif | 859 | #endif |
859 | { | 860 | { |
860 | rdtscl(tsc_start); | 861 | rdtscll(tsc_start); |
861 | 862 | ||
862 | do { | 863 | do { |
863 | apic = apic_read(APIC_TMCCT); | 864 | apic = apic_read(APIC_TMCCT); |
864 | rdtscl(tsc); | 865 | rdtscll(tsc); |
865 | } while ((tsc - tsc_start) < TICK_COUNT && | 866 | } while ((tsc - tsc_start) < TICK_COUNT && |
866 | (apic - apic_start) < TICK_COUNT); | 867 | (apic_start - apic) < TICK_COUNT); |
867 | 868 | ||
868 | result = (apic_start - apic) * 1000L * tsc_khz / | 869 | result = (apic_start - apic) * 1000L * tsc_khz / |
869 | (tsc - tsc_start); | 870 | (tsc - tsc_start); |