summaryrefslogtreecommitdiff
path: root/firmware/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'firmware/drivers')
-rw-r--r--firmware/drivers/rtc/rtc_mc13783.c16
1 files changed, 9 insertions, 7 deletions
diff --git a/firmware/drivers/rtc/rtc_mc13783.c b/firmware/drivers/rtc/rtc_mc13783.c
index 9d2c50cf11..325a496646 100644
--- a/firmware/drivers/rtc/rtc_mc13783.c
+++ b/firmware/drivers/rtc/rtc_mc13783.c
@@ -67,11 +67,6 @@ enum rtc_registers_indexes
/* was it an alarm that triggered power on ? */
static bool alarm_start = false;
-void mc13783_alarm_start(void)
-{
- alarm_start = true;
-}
-
static const unsigned char rtc_registers[RTC_NUM_REGS] =
{
[RTC_REG_TIME] = MC13783_RTC_TIME,
@@ -122,7 +117,12 @@ static int is_leap_year(int y)
/** Public APIs **/
void rtc_init(void)
{
- /* Nothing to do */
+ /* only needs to be polled on startup */
+ if (mc13783_read(MC13783_INTERRUPT_STATUS1) & MC13783_TODAI)
+ {
+ alarm_start = true;
+ mc13783_write(MC13783_INTERRUPT_STATUS1, MC13783_TODAI);
+ }
}
int rtc_read_datetime(unsigned char* buf)
@@ -264,7 +264,9 @@ bool rtc_enable_alarm(bool enable)
bool rtc_check_alarm_started(bool release_alarm)
{
bool rc = alarm_start;
- alarm_start &= ~release_alarm;
+
+ if (release_alarm)
+ alarm_start = false;
return rc;
}