summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarshall Mohror <mohror64@gmail.com>2022-07-06 13:00:00 -0500
committerMarshall Mohror <mohror64@gmail.com>2022-07-06 13:00:00 -0500
commite71d457af923f373505729fe5a335e6768f6144a (patch)
tree535a7a3ddd28e3a98f5984e0730277cd74850cea
parentb2ad4dd189135be9a87af86619d6f5854525f7fa (diff)
guard against div-by-zero
-rw-r--r--src/common/x64/cpu_detect.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/src/common/x64/cpu_detect.cpp b/src/common/x64/cpu_detect.cpp
index 4230b2da6..1a27532d4 100644
--- a/src/common/x64/cpu_detect.cpp
+++ b/src/common/x64/cpu_detect.cpp
@@ -170,8 +170,11 @@ static CPUCaps Detect() {
// The CPU model can be detected to use the values from turbostat
// https://github.com/torvalds/linux/blob/master/tools/power/x86/turbostat/turbostat.c#L5569
// but it's easier to just estimate the TSC tick rate for these cases.
- caps.tsc_frequency = static_cast<u64>(caps.crystal_frequency) *
- caps.tsc_crystal_ratio_numerator / caps.tsc_crystal_ratio_denominator;
+ if (caps.tsc_crystal_ratio_denominator) {
+ caps.tsc_frequency = static_cast<u64>(caps.crystal_frequency) *
+ caps.tsc_crystal_ratio_numerator /
+ caps.tsc_crystal_ratio_denominator;
+ }
}
if (max_std_fn >= 0x16) {