fix nasty bug in ISR handler, where interrupt was not properly acknowleged (write to CR instead of ISR, as intended). Also, minor, set the LSI prescaler values more appropriately (though not critical since LSI is so low precision anyway).
This commit is contained in:
parent
e0371de24d
commit
0d659de226
@ -525,13 +525,20 @@ static int rtc_setup(void)
|
|||||||
#ifdef CONFIG_STM32L4_RTC_HSECLOCK
|
#ifdef CONFIG_STM32L4_RTC_HSECLOCK
|
||||||
/* For a 1 MHz clock this yields 0.9999360041 Hz on the second
|
/* For a 1 MHz clock this yields 0.9999360041 Hz on the second
|
||||||
* timer - which is pretty close.
|
* timer - which is pretty close.
|
||||||
|
* NOTE: max HSE is 4 MHz if it is to be used with RTC
|
||||||
*/
|
*/
|
||||||
|
|
||||||
putreg32(((uint32_t)7812 << RTC_PRER_PREDIV_S_SHIFT) |
|
putreg32(((uint32_t)7812 << RTC_PRER_PREDIV_S_SHIFT) |
|
||||||
((uint32_t)0x7f << RTC_PRER_PREDIV_A_SHIFT),
|
((uint32_t)0x7f << RTC_PRER_PREDIV_A_SHIFT),
|
||||||
STM32L4_RTC_PRER);
|
STM32L4_RTC_PRER);
|
||||||
#else
|
#elif defined(CONFIG_STM32L4_RTC_LSICLOCK)
|
||||||
/* Correct values for 32.768 KHz LSE clock and inaccurate LSI clock */
|
/* Suitable values for 32.000 KHz LSI clock (29.5 - 34 KHz, though) */
|
||||||
|
|
||||||
|
putreg32(((uint32_t)0xf9 << RTC_PRER_PREDIV_S_SHIFT) |
|
||||||
|
((uint32_t)0x7f << RTC_PRER_PREDIV_A_SHIFT),
|
||||||
|
STM32L4_RTC_PRER);
|
||||||
|
#else /* defined(CONFIG_STM32L4_RTC_LSECLOCK) */
|
||||||
|
/* Correct values for 32.768 KHz LSE clock */
|
||||||
|
|
||||||
putreg32(((uint32_t)0xff << RTC_PRER_PREDIV_S_SHIFT) |
|
putreg32(((uint32_t)0xff << RTC_PRER_PREDIV_S_SHIFT) |
|
||||||
((uint32_t)0x7f << RTC_PRER_PREDIV_A_SHIFT),
|
((uint32_t)0x7f << RTC_PRER_PREDIV_A_SHIFT),
|
||||||
@ -631,7 +638,7 @@ static int stm32l4_rtc_alarm_handler(int irq, void *context)
|
|||||||
}
|
}
|
||||||
|
|
||||||
isr = getreg32(STM32L4_RTC_ISR) & ~RTC_ISR_ALRAF;
|
isr = getreg32(STM32L4_RTC_ISR) & ~RTC_ISR_ALRAF;
|
||||||
putreg32(isr, STM32L4_RTC_CR);
|
putreg32(isr, STM32L4_RTC_ISR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -655,7 +662,7 @@ static int stm32l4_rtc_alarm_handler(int irq, void *context)
|
|||||||
}
|
}
|
||||||
|
|
||||||
isr = getreg32(STM32L4_RTC_ISR) & ~RTC_ISR_ALRBF;
|
isr = getreg32(STM32L4_RTC_ISR) & ~RTC_ISR_ALRBF;
|
||||||
putreg32(isr, STM32L4_RTC_CR);
|
putreg32(isr, STM32L4_RTC_ISR);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1356,6 +1363,8 @@ int stm32l4_rtc_setalarm(FAR struct alm_setalarm_s *alminfo)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
rtc_dumpregs("After alarm setting");
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user