diff options
Diffstat (limited to 'arch/x86/kernel/tsc.c')
| -rw-r--r-- | arch/x86/kernel/tsc.c | 24 | 
1 files changed, 12 insertions, 12 deletions
| diff --git a/arch/x86/kernel/tsc.c b/arch/x86/kernel/tsc.c index ef32297ff17e..74392d9d51e0 100644 --- a/arch/x86/kernel/tsc.c +++ b/arch/x86/kernel/tsc.c @@ -317,7 +317,7 @@ static unsigned long calc_hpet_ref(u64 deltatsc, u64 hpet1, u64 hpet2)  	hpet2 -= hpet1;  	tmp = ((u64)hpet2 * hpet_readl(HPET_PERIOD));  	do_div(tmp, 1000000); -	do_div(deltatsc, tmp); +	deltatsc = div64_u64(deltatsc, tmp);  	return (unsigned long) deltatsc;  } @@ -1067,6 +1067,7 @@ static struct clocksource clocksource_tsc_early = {  	.resume			= tsc_resume,  	.mark_unstable		= tsc_cs_mark_unstable,  	.tick_stable		= tsc_cs_tick_stable, +	.list			= LIST_HEAD_INIT(clocksource_tsc_early.list),  };  /* @@ -1086,6 +1087,7 @@ static struct clocksource clocksource_tsc = {  	.resume			= tsc_resume,  	.mark_unstable		= tsc_cs_mark_unstable,  	.tick_stable		= tsc_cs_tick_stable, +	.list			= LIST_HEAD_INIT(clocksource_tsc.list),  };  void mark_tsc_unstable(char *reason) @@ -1098,13 +1100,9 @@ void mark_tsc_unstable(char *reason)  		clear_sched_clock_stable();  	disable_sched_clock_irqtime();  	pr_info("Marking TSC unstable due to %s\n", reason); -	/* Change only the rating, when not registered */ -	if (clocksource_tsc.mult) { -		clocksource_mark_unstable(&clocksource_tsc); -	} else { -		clocksource_tsc.flags |= CLOCK_SOURCE_UNSTABLE; -		clocksource_tsc.rating = 0; -	} + +	clocksource_mark_unstable(&clocksource_tsc_early); +	clocksource_mark_unstable(&clocksource_tsc);  }  EXPORT_SYMBOL_GPL(mark_tsc_unstable); @@ -1244,7 +1242,7 @@ static void tsc_refine_calibration_work(struct work_struct *work)  	/* Don't bother refining TSC on unstable systems */  	if (tsc_unstable) -		return; +		goto unreg;  	/*  	 * Since the work is started early in boot, we may be @@ -1297,11 +1295,12 @@ static void tsc_refine_calibration_work(struct work_struct *work)  out:  	if (tsc_unstable) -		return; +		goto unreg;  	if (boot_cpu_has(X86_FEATURE_ART))  		art_related_clocksource = &clocksource_tsc;  	clocksource_register_khz(&clocksource_tsc, tsc_khz); +unreg:  	clocksource_unregister(&clocksource_tsc_early);  } @@ -1311,8 +1310,8 @@ static int __init init_tsc_clocksource(void)  	if (!boot_cpu_has(X86_FEATURE_TSC) || tsc_disabled > 0 || !tsc_khz)  		return 0; -	if (check_tsc_unstable()) -		return 0; +	if (tsc_unstable) +		goto unreg;  	if (tsc_clocksource_reliable)  		clocksource_tsc.flags &= ~CLOCK_SOURCE_MUST_VERIFY; @@ -1328,6 +1327,7 @@ static int __init init_tsc_clocksource(void)  		if (boot_cpu_has(X86_FEATURE_ART))  			art_related_clocksource = &clocksource_tsc;  		clocksource_register_khz(&clocksource_tsc, tsc_khz); +unreg:  		clocksource_unregister(&clocksource_tsc_early);  		return 0;  	} | 
