From 4159906291cbc5373c2e385386e75c3f5f1337bd Mon Sep 17 00:00:00 2001 From: Martin Schuster Date: Mon, 25 Nov 2024 22:53:38 +0100 Subject: [PATCH] fix: function TIMER_IF_Convert_Tick2ms() returned wrong value The order of the computation is important: first multiply by 1000, then divide, then add 1. It was: compute (1000/256+1) as int, which is 4, and then use the 4 as factor. Hence, the conversion of ms was quite off the real value. Also rename MS_TO_TICK, since it does not do that. Fixes #40. --- src/BSP/timer_if.c | 15 ++++++--------- 1 file changed, 6 insertions(+), 9 deletions(-) diff --git a/src/BSP/timer_if.c b/src/BSP/timer_if.c index 813303c..16d96aa 100644 --- a/src/BSP/timer_if.c +++ b/src/BSP/timer_if.c @@ -114,12 +114,9 @@ const UTIL_SYSTIM_Driver_s UTIL_SYSTIMDriver = * (1 tick is 3.9ms (when APREDIV = 0x7F) * for other RTC clock freq, the formula is ck_apre = RTC_clock / (prediv_A +1) */ -#define MS_TO_TICK \ +#define CK_APRE \ (uint32_t)(LL_RCC_GetRTCClockFreq() / (LL_RTC_GetAsynchPrescaler(hrtc->Instance) + 1)) -/* Give one more (to adjust to x3.9 factor) */ -#define TICK_TO_MS ((1000/MS_TO_TICK) + 1) - /* USER CODE BEGIN PD */ /* USER CODE END PD */ @@ -237,7 +234,7 @@ UTIL_TIMER_Status_t TIMER_IF_StartTimer(uint32_t timeout) TIMER_IF_DBG_PRINTF("Start timer: time=%d, alarm=%d\n\r", GetTimerTicks(), timeout); /* Program ALARM B on timeout ticks converted in ms (one more for uncertainty, mask is 31 */ - uint64_t subSeconds64 = ((uint64_t)((uint64_t)timeout * (uint64_t)(1000))) / MS_TO_TICK + 1; + uint64_t subSeconds64 = ((uint64_t)((uint64_t)timeout * (uint64_t)(1000))) / CK_APRE + 1; RTC_StartAlarm64(RTC_ALARM_B, 0, 0, 0, 0, subSeconds64, RTC_HOURFORMAT12_PM, 31UL); /* USER CODE BEGIN TIMER_IF_StartTimer_Last */ @@ -335,7 +332,7 @@ uint32_t TIMER_IF_Convert_ms2Tick(uint32_t timeMilliSec) /* USER CODE BEGIN TIMER_IF_Convert_ms2Tick */ /* USER CODE END TIMER_IF_Convert_ms2Tick */ - ret = ((uint32_t)(((uint64_t)timeMilliSec * MS_TO_TICK) / 1000)); + ret = ((uint32_t)(((uint64_t)timeMilliSec * CK_APRE) / 1000)); /* USER CODE BEGIN TIMER_IF_Convert_ms2Tick_Last */ /* USER CODE END TIMER_IF_Convert_ms2Tick_Last */ @@ -348,7 +345,7 @@ uint32_t TIMER_IF_Convert_Tick2ms(uint32_t tick) /* USER CODE BEGIN TIMER_IF_Convert_Tick2ms */ /* USER CODE END TIMER_IF_Convert_Tick2ms */ - ret = tick * TICK_TO_MS; + ret = (uint32_t)((uint64_t)tick * 1000 / CK_APRE + 1); /* USER CODE BEGIN TIMER_IF_Convert_Tick2ms_Last */ /* USER CODE END TIMER_IF_Convert_Tick2ms_Last */ @@ -395,8 +392,8 @@ uint32_t TIMER_IF_GetTime(uint32_t *mSeconds) ticks = (((uint64_t) timerValueMSB) << 32) + timerValueLsb; - seconds = ticks / MS_TO_TICK; - *mSeconds = (ticks * 1000) / MS_TO_TICK; + seconds = ticks / CK_APRE; + *mSeconds = (ticks * 1000) / CK_APRE; /* USER CODE BEGIN TIMER_IF_GetTime_Last */ /* USER CODE END TIMER_IF_GetTime_Last */