aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86_64/kernel/time.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86_64/kernel/time.c')
-rw-r--r--arch/x86_64/kernel/time.c90
1 files changed, 45 insertions, 45 deletions
diff --git a/arch/x86_64/kernel/time.c b/arch/x86_64/kernel/time.c
index 8dc6f2173597..3c34e8def89d 100644
--- a/arch/x86_64/kernel/time.c
+++ b/arch/x86_64/kernel/time.c
@@ -220,7 +220,7 @@ unsigned long read_persistent_clock(void)
220 /* 220 /*
221 * We know that x86-64 always uses BCD format, no need to check the 221 * We know that x86-64 always uses BCD format, no need to check the
222 * config register. 222 * config register.
223 */ 223 */
224 224
225 BCD_TO_BIN(sec); 225 BCD_TO_BIN(sec);
226 BCD_TO_BIN(min); 226 BCD_TO_BIN(min);
@@ -233,11 +233,11 @@ unsigned long read_persistent_clock(void)
233 BCD_TO_BIN(century); 233 BCD_TO_BIN(century);
234 year += century * 100; 234 year += century * 100;
235 printk(KERN_INFO "Extended CMOS year: %d\n", century * 100); 235 printk(KERN_INFO "Extended CMOS year: %d\n", century * 100);
236 } else { 236 } else {
237 /* 237 /*
238 * x86-64 systems only exists since 2002. 238 * x86-64 systems only exists since 2002.
239 * This will work up to Dec 31, 2100 239 * This will work up to Dec 31, 2100
240 */ 240 */
241 year += 2000; 241 year += 2000;
242 } 242 }
243 243
@@ -249,45 +249,45 @@ unsigned long read_persistent_clock(void)
249#define TICK_COUNT 100000000 249#define TICK_COUNT 100000000
250static unsigned int __init tsc_calibrate_cpu_khz(void) 250static unsigned int __init tsc_calibrate_cpu_khz(void)
251{ 251{
252 int tsc_start, tsc_now; 252 int tsc_start, tsc_now;
253 int i, no_ctr_free; 253 int i, no_ctr_free;
254 unsigned long evntsel3 = 0, pmc3 = 0, pmc_now = 0; 254 unsigned long evntsel3 = 0, pmc3 = 0, pmc_now = 0;
255 unsigned long flags; 255 unsigned long flags;
256 256
257 for (i = 0; i < 4; i++) 257 for (i = 0; i < 4; i++)
258 if (avail_to_resrv_perfctr_nmi_bit(i)) 258 if (avail_to_resrv_perfctr_nmi_bit(i))
259 break; 259 break;
260 no_ctr_free = (i == 4); 260 no_ctr_free = (i == 4);
261 if (no_ctr_free) { 261 if (no_ctr_free) {
262 i = 3; 262 i = 3;
263 rdmsrl(MSR_K7_EVNTSEL3, evntsel3); 263 rdmsrl(MSR_K7_EVNTSEL3, evntsel3);
264 wrmsrl(MSR_K7_EVNTSEL3, 0); 264 wrmsrl(MSR_K7_EVNTSEL3, 0);
265 rdmsrl(MSR_K7_PERFCTR3, pmc3); 265 rdmsrl(MSR_K7_PERFCTR3, pmc3);
266 } else { 266 } else {
267 reserve_perfctr_nmi(MSR_K7_PERFCTR0 + i); 267 reserve_perfctr_nmi(MSR_K7_PERFCTR0 + i);
268 reserve_evntsel_nmi(MSR_K7_EVNTSEL0 + i); 268 reserve_evntsel_nmi(MSR_K7_EVNTSEL0 + i);
269 } 269 }
270 local_irq_save(flags); 270 local_irq_save(flags);
271 /* start meauring cycles, incrementing from 0 */ 271 /* start meauring cycles, incrementing from 0 */
272 wrmsrl(MSR_K7_PERFCTR0 + i, 0); 272 wrmsrl(MSR_K7_PERFCTR0 + i, 0);
273 wrmsrl(MSR_K7_EVNTSEL0 + i, 1 << 22 | 3 << 16 | 0x76); 273 wrmsrl(MSR_K7_EVNTSEL0 + i, 1 << 22 | 3 << 16 | 0x76);
274 rdtscl(tsc_start); 274 rdtscl(tsc_start);
275 do { 275 do {
276 rdmsrl(MSR_K7_PERFCTR0 + i, pmc_now); 276 rdmsrl(MSR_K7_PERFCTR0 + i, pmc_now);
277 tsc_now = get_cycles_sync(); 277 tsc_now = get_cycles_sync();
278 } while ((tsc_now - tsc_start) < TICK_COUNT); 278 } while ((tsc_now - tsc_start) < TICK_COUNT);
279 279
280 local_irq_restore(flags); 280 local_irq_restore(flags);
281 if (no_ctr_free) { 281 if (no_ctr_free) {
282 wrmsrl(MSR_K7_EVNTSEL3, 0); 282 wrmsrl(MSR_K7_EVNTSEL3, 0);
283 wrmsrl(MSR_K7_PERFCTR3, pmc3); 283 wrmsrl(MSR_K7_PERFCTR3, pmc3);
284 wrmsrl(MSR_K7_EVNTSEL3, evntsel3); 284 wrmsrl(MSR_K7_EVNTSEL3, evntsel3);
285 } else { 285 } else {
286 release_perfctr_nmi(MSR_K7_PERFCTR0 + i); 286 release_perfctr_nmi(MSR_K7_PERFCTR0 + i);
287 release_evntsel_nmi(MSR_K7_EVNTSEL0 + i); 287 release_evntsel_nmi(MSR_K7_EVNTSEL0 + i);
288 } 288 }
289 289
290 return pmc_now * tsc_khz / (tsc_now - tsc_start); 290 return pmc_now * tsc_khz / (tsc_now - tsc_start);
291} 291}
292 292
293/* 293/*
@@ -315,7 +315,7 @@ static unsigned int __init pit_calibrate_tsc(void)
315 end = get_cycles_sync(); 315 end = get_cycles_sync();
316 316
317 spin_unlock_irqrestore(&i8253_lock, flags); 317 spin_unlock_irqrestore(&i8253_lock, flags);
318 318
319 return (end - start) / 50; 319 return (end - start) / 50;
320} 320}
321 321
@@ -360,7 +360,7 @@ static struct irqaction irq0 = {
360 .handler = timer_interrupt, 360 .handler = timer_interrupt,
361 .flags = IRQF_DISABLED | IRQF_IRQPOLL, 361 .flags = IRQF_DISABLED | IRQF_IRQPOLL,
362 .mask = CPU_MASK_NONE, 362 .mask = CPU_MASK_NONE,
363 .name = "timer" 363 .name = "timer"
364}; 364};
365 365
366void __init time_init(void) 366void __init time_init(void)
@@ -373,7 +373,7 @@ void __init time_init(void)
373 373
374 if (hpet_use_timer) { 374 if (hpet_use_timer) {
375 /* set tick_nsec to use the proper rate for HPET */ 375 /* set tick_nsec to use the proper rate for HPET */
376 tick_nsec = TICK_NSEC_HPET; 376 tick_nsec = TICK_NSEC_HPET;
377 tsc_khz = hpet_calibrate_tsc(); 377 tsc_khz = hpet_calibrate_tsc();
378 timename = "HPET"; 378 timename = "HPET";
379 } else { 379 } else {