Start alarm by subSeconds: Avoid overflow during conversion from ms to ticks. #113
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
The issue stm32duino/STM32LoRaWAN#38 describes a bug that occus on LoRaWAN after 4 hours 40 minutes. This PR is the fix for that.
The bug occurs, when an alarm shall be put in place using subseconds for RTC_StartAlarm64(). If the subSeconds value is large enough, a computation in RTC_StartAlarm64() overflows.
E.g. when having predivSync=255, a value of subSeconds=2^24 (still well below UINT32_MAX and thus using the 32bit computation branch) would be multiplied by 256 and result in an overflow during computation. The overflow leads to not putting the right alarm in place.
In fact, 2^24 ms is about 4 hours 40 minutes.