From 19226cb656c54d58fad98ce9a73f0aea2b5d5a92 Mon Sep 17 00:00:00 2001 From: Andrey G Date: Sun, 11 Sep 2022 12:46:55 +0300 Subject: [PATCH] efiWatchdog: avoid converting time to float (#4562) https://stackoverflow.com/questions/68690961/why-does-converting-int-to-float-lose-precision-in-c-programming-language --- firmware/controllers/algo/engine.cpp | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/firmware/controllers/algo/engine.cpp b/firmware/controllers/algo/engine.cpp index 055635d991..ac3006a5a5 100644 --- a/firmware/controllers/algo/engine.cpp +++ b/firmware/controllers/algo/engine.cpp @@ -454,13 +454,12 @@ void Engine::efiWatchdog() { if (engine->configBurnTimer.hasElapsedSec(5) && engineConfiguration->tempBooleanForVerySpecialLogic) { static efitimems_t mostRecentMs = 0; - float msNow = currentTimeMillis(); - if (msNow != 0) { - float gapInMs = msNow - mostRecentMs; + efitimems_t msNow = currentTimeMillis(); + if (mostRecentMs != 0) { + efitimems_t gapInMs = msNow - mostRecentMs; if (gapInMs > 500) { - // float has 24 bits in the mantissa, which should allow up to 8 significant figures - // we loose precision here after about 1,000,000 seconds which is 11 days - firmwareError(WATCH_DOG_SECONDS, "gap in time: now=%fms gap=%fms", msNow, gapInMs); + firmwareError(WATCH_DOG_SECONDS, "gap in time: now=%d mS, was %d mS, gap=%dmS", + msNow, mostRecentMs, gapInMs); } } mostRecentMs = msNow;