summaryrefslogtreecommitdiff
path: root/firmware/drivers/rtc/rtc_e8564.c
diff options
context:
space:
mode:
Diffstat (limited to 'firmware/drivers/rtc/rtc_e8564.c')
-rw-r--r--firmware/drivers/rtc/rtc_e8564.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/firmware/drivers/rtc/rtc_e8564.c b/firmware/drivers/rtc/rtc_e8564.c
index c0209e9..c3ae934 100644
--- a/firmware/drivers/rtc/rtc_e8564.c
+++ b/firmware/drivers/rtc/rtc_e8564.c
@@ -24,8 +24,28 @@
#include "i2c-pp.h"
#include <stdbool.h>
+/* RTC registers */
+#define RTC_CTRL1 0x00
+#define RTC_CTRL2 0x01
+
+/* Control 2 register flags */
+#define RTC_TF 0x04
+#define RTC_AF 0x08
+
void rtc_init(void)
{
+ unsigned char tmp;
+ int rv;
+
+ /* initialize Control 1 register */
+ tmp = 0;
+ pp_i2c_send(0x51, RTC_CTRL1,tmp);
+
+ /* read value of the Control 2 register - we'll need it to preserve alarm and timer interrupt assertion flags */
+ rv = i2c_readbytes(0x51,RTC_CTRL2,1,&tmp);
+ /* clear alarm and timer interrupts */
+ tmp &= (RTC_TF | RTC_AF);
+ pp_i2c_send(0x51, RTC_CTRL2,tmp);
}
int rtc_read_datetime(unsigned char* buf)