summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRob Purchase <shotofadds@rockbox.org>2009-10-11 17:46:00 +0000
committerRob Purchase <shotofadds@rockbox.org>2009-10-11 17:46:00 +0000
commit6170f01642caa5fbb9633989e7b9d9392e7cbae6 (patch)
treeded84c3425190ba92b283bf0f643d1c031c83158
parentb4097dd0e4b85f817ab51099e7c78de2ce78b382 (diff)
downloadrockbox-6170f01642caa5fbb9633989e7b9d9392e7cbae6.zip
rockbox-6170f01642caa5fbb9633989e7b9d9392e7cbae6.tar.gz
rockbox-6170f01642caa5fbb9633989e7b9d9392e7cbae6.tar.bz2
rockbox-6170f01642caa5fbb9633989e7b9d9392e7cbae6.tar.xz
D2: The RTC chip needs to be runtime detected.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@23112 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--firmware/drivers/rtc/rtc_d2.c87
-rw-r--r--firmware/export/config-cowond2.h4
-rw-r--r--firmware/export/config.h4
3 files changed, 91 insertions, 4 deletions
diff --git a/firmware/drivers/rtc/rtc_d2.c b/firmware/drivers/rtc/rtc_d2.c
new file mode 100644
index 0000000..8f60bc2
--- /dev/null
+++ b/firmware/drivers/rtc/rtc_d2.c
@@ -0,0 +1,87 @@
+/***************************************************************************
+ * __________ __ ___.
+ * Open \______ \ ____ ____ | | _\_ |__ _______ ___
+ * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
+ * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
+ * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
+ * \/ \/ \/ \/ \/
+ * $Id$
+ *
+ * Copyright (C) 2009 by Rob Purchase
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
+ * KIND, either express or implied.
+ *
+ ****************************************************************************/
+#include "rtc.h"
+#include "system.h"
+#include "pcf50606.h"
+#include "pcf50635.h"
+#include "power-target.h"
+
+void rtc_init(void)
+{
+}
+
+int rtc_read_datetime(struct tm *tm)
+{
+ unsigned int i;
+ int rc, oldlevel;
+ unsigned char buf[7];
+
+ oldlevel = disable_irq_save();
+
+ if (get_pmu_type() == PCF50606)
+ rc = pcf50606_read_multiple(0x0a, buf, sizeof(buf));
+ else
+ rc = pcf50635_read_multiple(0x59, buf, sizeof(buf));
+
+ restore_irq(oldlevel);
+
+ for (i = 0; i < sizeof(buf); i++)
+ buf[i] = BCD2DEC(buf[i]);
+
+ tm->tm_sec = buf[0];
+ tm->tm_min = buf[1];
+ tm->tm_hour = buf[2];
+ tm->tm_wday = buf[3];
+ tm->tm_mday = buf[4];
+ tm->tm_mon = buf[5] - 1;
+ tm->tm_year = buf[6] + 100;
+
+ return rc;
+}
+
+int rtc_write_datetime(const struct tm *tm)
+{
+ unsigned int i;
+ int rc, oldlevel;
+ unsigned char buf[7];
+
+ buf[0] = tm->tm_sec;
+ buf[1] = tm->tm_min;
+ buf[2] = tm->tm_hour;
+ buf[3] = tm->tm_wday;
+ buf[4] = tm->tm_mday;
+ buf[5] = tm->tm_mon + 1;
+ buf[6] = tm->tm_year - 100;
+
+ for (i = 0; i < sizeof(buf); i++)
+ buf[i] = DEC2BCD(buf[i]);
+
+ oldlevel = disable_irq_save();
+
+ if (get_pmu_type() == PCF50606)
+ rc = pcf50606_write_multiple(0x0a, buf, sizeof(buf));
+ else
+ rc = pcf50635_write_multiple(0x59, buf, sizeof(buf));
+
+ restore_irq(oldlevel);
+
+ return rc;
+}
diff --git a/firmware/export/config-cowond2.h b/firmware/export/config-cowond2.h
index 453fa0d..4341575 100644
--- a/firmware/export/config-cowond2.h
+++ b/firmware/export/config-cowond2.h
@@ -90,8 +90,8 @@
#define HAVE_TOUCHSCREEN
#define HAVE_BUTTON_DATA
-/* define this if you have a real-time clock */
-#define CONFIG_RTC RTC_PCF50606
+/* The D2 has either a PCF50606 or PCF50635, RTC_D2 handles both */
+#define CONFIG_RTC RTC_D2
/* define this if you have RTC RAM available for settings */
//#define HAVE_RTC_RAM
diff --git a/firmware/export/config.h b/firmware/export/config.h
index 4245a2d..70e2c79 100644
--- a/firmware/export/config.h
+++ b/firmware/export/config.h
@@ -261,8 +261,8 @@ Lyre prototype 1*/
#define RTC_S5L8700 14
#define RTC_S35390A 15
#define RTC_JZ47XX 16 /* Ingenic Jz47XX */
-#define RTC_NANO2G 17 /* This seems to be a PCFxxxxx,
- but we don't know which one */
+#define RTC_NANO2G 17 /* This seems to be a PCF5063x */
+#define RTC_D2 18 /* Either PCF50606 or PCF50635 */
/* USB On-the-go */
#define USBOTG_M66591 6591 /* M:Robe 500 */