aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Johnston <markj@FreeBSD.org>2022-01-03 15:14:41 +0000
committerMark Johnston <markj@FreeBSD.org>2022-01-06 13:46:33 +0000
commit08161fd3b207105847bdd1dd8729ea4cbda6e537 (patch)
tree556750982fc5ac2c847da314cdcb5b4dc852f629
parent1d15c6b3e51637471ace760006e377d59e34a6dc (diff)
x86: Skip late calibration if our reference timer has low quality
Some AMD Geode-based systems end up using the 8254 PIT to calibrate the TSC during late calibration, which doesn't work because that timecounter's mask (65535) is much smaller than its frequency (1193182). Moreover, early calibration is done against the 8254 timer anyway. Work around the problem by simply using early calibration results if no high-quality timecounters exist. PR: 260868 Fixes: 22875f88799e ("x86: Implement deferred TSC calibration") Reported and tested by: mike@sentex.net, Stefan Hegnauer <stefan.hegnauer@gmx.ch> Reviewed by: imp, kib Sponsored by: The FreeBSD Foundation (cherry picked from commit 0e494a9e3fd86ef54899dcbe0268866629096c1e)
-rw-r--r--sys/x86/x86/tsc.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/sys/x86/x86/tsc.c b/sys/x86/x86/tsc.c
index 6debe3ecca6d..6f0ef697cb2f 100644
--- a/sys/x86/x86/tsc.c
+++ b/sys/x86/x86/tsc.c
@@ -708,7 +708,14 @@ tsc_calibrate(void)
if (tsc_disabled)
return;
+ /*
+ * Avoid using a low-quality timecounter to re-calibrate. In
+ * particular, old 32-bit platforms might only have the 8254 timer to
+ * calibrate against.
+ */
tc = atomic_load_ptr(&timecounter);
+ if (tc->tc_quality <= 0)
+ goto calibrated;
flags = intr_disable();
cpu = curcpu;