diff options
Diffstat (limited to 'arch/x86')
-rw-r--r-- | arch/x86/kernel/time_64.c | 2 | ||||
-rw-r--r-- | arch/x86/kernel/tsc_32.c | 5 |
2 files changed, 7 insertions, 0 deletions
diff --git a/arch/x86/kernel/time_64.c b/arch/x86/kernel/time_64.c index c737849e2ef7..12b4a71bd074 100644 --- a/arch/x86/kernel/time_64.c +++ b/arch/x86/kernel/time_64.c | |||
@@ -123,6 +123,8 @@ void __init time_init(void) | |||
123 | (boot_cpu_data.x86_vendor == X86_VENDOR_AMD)) | 123 | (boot_cpu_data.x86_vendor == X86_VENDOR_AMD)) |
124 | cpu_khz = calculate_cpu_khz(); | 124 | cpu_khz = calculate_cpu_khz(); |
125 | 125 | ||
126 | lpj_tsc = ((unsigned long)tsc_khz * 1000)/HZ; | ||
127 | |||
126 | if (unsynchronized_tsc()) | 128 | if (unsynchronized_tsc()) |
127 | mark_tsc_unstable("TSCs unsynchronized"); | 129 | mark_tsc_unstable("TSCs unsynchronized"); |
128 | 130 | ||
diff --git a/arch/x86/kernel/tsc_32.c b/arch/x86/kernel/tsc_32.c index 068759db63dd..be729035b30b 100644 --- a/arch/x86/kernel/tsc_32.c +++ b/arch/x86/kernel/tsc_32.c | |||
@@ -401,6 +401,7 @@ static inline void check_geode_tsc_reliable(void) { } | |||
401 | void __init tsc_init(void) | 401 | void __init tsc_init(void) |
402 | { | 402 | { |
403 | int cpu; | 403 | int cpu; |
404 | u64 lpj; | ||
404 | 405 | ||
405 | if (!cpu_has_tsc || tsc_disabled) { | 406 | if (!cpu_has_tsc || tsc_disabled) { |
406 | /* Disable the TSC in case of !cpu_has_tsc */ | 407 | /* Disable the TSC in case of !cpu_has_tsc */ |
@@ -421,6 +422,10 @@ void __init tsc_init(void) | |||
421 | return; | 422 | return; |
422 | } | 423 | } |
423 | 424 | ||
425 | lpj = ((u64)tsc_khz * 1000); | ||
426 | do_div(lpj, HZ); | ||
427 | lpj_tsc = lpj; | ||
428 | |||
424 | printk("Detected %lu.%03lu MHz processor.\n", | 429 | printk("Detected %lu.%03lu MHz processor.\n", |
425 | (unsigned long)cpu_khz / 1000, | 430 | (unsigned long)cpu_khz / 1000, |
426 | (unsigned long)cpu_khz % 1000); | 431 | (unsigned long)cpu_khz % 1000); |