aboutsummaryrefslogtreecommitdiffstats
path: root/os
diff options
context:
space:
mode:
authorbarthess <barthess@35acf78f-673a-0410-8e92-d51de3d6d3f4>2011-12-11 20:03:50 +0000
committerbarthess <barthess@35acf78f-673a-0410-8e92-d51de3d6d3f4>2011-12-11 20:03:50 +0000
commit4a5c4e2ae0098949ed614e22ae749620c730622f (patch)
treee88412776729127bf26199e0308a83cb8160c48a /os
parent7a783452728d82c395a6273022ea239375db0c64 (diff)
parentea9053eb9e09263bc16ba26efd7bce99f36b7c6b (diff)
downloadChibiOS-4a5c4e2ae0098949ed614e22ae749620c730622f.tar.gz
ChibiOS-4a5c4e2ae0098949ed614e22ae749620c730622f.tar.bz2
ChibiOS-4a5c4e2ae0098949ed614e22ae749620c730622f.zip
RTC. Merge RTC code from trunk.
git-svn-id: svn://svn.code.sf.net/p/chibios/svn/branches/rtc_dev@3595 35acf78f-673a-0410-8e92-d51de3d6d3f4
Diffstat (limited to 'os')
-rw-r--r--os/hal/platforms/STM32/RTCv1/rtc_lld.c31
1 files changed, 21 insertions, 10 deletions
diff --git a/os/hal/platforms/STM32/RTCv1/rtc_lld.c b/os/hal/platforms/STM32/RTCv1/rtc_lld.c
index cae23525f..1a6c85d8b 100644
--- a/os/hal/platforms/STM32/RTCv1/rtc_lld.c
+++ b/os/hal/platforms/STM32/RTCv1/rtc_lld.c
@@ -132,13 +132,14 @@ void rtc_lld_init(void){
}
#if STM32_RTC == STM32_RTC_LSE
+#define RTC_CLK STM32_LSECLK
if (!(RCC->BDCR & RCC_BDCR_LSEON)) {
RCC->BDCR |= RCC_BDCR_LSEON;
while (!(RCC->BDCR & RCC_BDCR_LSERDY))
;
}
- preload = STM32_LSECLK - 1;
#elif STM32_RTC == STM32_RTC_LSI
+#define RTC_CLK STM32_LSICLK
/* TODO: Move the LSI clock initialization in the HAL low level driver.*/
RCC->CSR |= RCC_CSR_LSION;
while (!(RCC->CSR & RCC_CSR_LSIRDY))
@@ -146,14 +147,15 @@ void rtc_lld_init(void){
/* According to errata sheet we must wait additional 100 uS for
stabilization.
TODO: Change this code, software loops are not reliable.*/
- uint32_t tmo = (STM32_SYSCLK / 1000000) * 100;
+ volatile uint32_t tmo = (STM32_SYSCLK / 1000000) * 100;
while (tmo--)
;
- preload = STM32_LSICLK - 1;
#elif STM32_RTC == STM32_RTC_HSE
- preload = (STM32_HSICLK / 128) - 1;
+#define RTC_CLK (STM32_HSECLK / 128)
#endif
+ preload = RTC_CLK - 1;
+
/* Selects clock source (previously enabled and stabilized).*/
RCC->BDCR = (RCC->BDCR & ~RCC_BDCR_RTCSEL) | STM32_RTC;
@@ -213,19 +215,28 @@ void rtc_lld_set_time(RTCDriver *rtcp, const RTCTime *timespec) {
* @brief Get current time.
*
* @param[in] rtcp pointer to RTC driver structure
- * @param[out] timespec pointer to a @p RTCTime structure
+ * @param[in] timespec pointer to a @p RTCTime structure
*
* @notapi
*/
void rtc_lld_get_time(RTCDriver *rtcp, RTCTime *timespec) {
- uint32_t time_frac;
-
(void)rtcp;
+ uint32_t time_frac;
+
+READ_REGISTERS:
+ chSysLock();
+ timespec->tv_sec = ((uint32_t)(RTC->CNTH) << 16) + RTC->CNTL;
time_frac = (((uint32_t)RTC->DIVH) << 16) + (uint32_t)RTC->DIVL;
- timespec->tv_msec = (uint16_t)(((STM32_LSECLK - time_frac) * 1000) /
- STM32_LSECLK);
- timespec->tv_sec = (RTC->CNTH << 16) + RTC->CNTL;
+ chSysUnlock();
+
+ /* If second counter updated between reading of integer and fractional parts
+ * we must reread both values. */
+ if((timespec->tv_sec) != (((uint32_t)(RTC->CNTH) << 16) + RTC->CNTL)){
+ goto READ_REGISTERS;
+ }
+
+ timespec->tv_msec = (uint16_t)(((RTC_CLK - 1 - time_frac) * 1000) / RTC_CLK);
}
/**