summaryrefslogtreecommitdiffstats
path: root/sys/mips/cavium
diff options
context:
space:
mode:
authorkan <kan@FreeBSD.org>2014-09-14 00:02:40 +0000
committerkan <kan@FreeBSD.org>2014-09-14 00:02:40 +0000
commit36b9d96b9212d462aaadce44fe978d69389dbba7 (patch)
tree6717befdca0b67c3b012375a042b6fec72dd4234 /sys/mips/cavium
parentfff5c2c5e1d83d5cb78d9e3f743cf2587785ae95 (diff)
downloadFreeBSD-src-36b9d96b9212d462aaadce44fe978d69389dbba7.zip
FreeBSD-src-36b9d96b9212d462aaadce44fe978d69389dbba7.tar.gz
Fix RTC clock writes on many Octeon boards.
The struct clocktime uses 0-based week day number, so back out part of r229161 by gonzo, which actually broke the RTC clock writes on Sundays.
Diffstat (limited to 'sys/mips/cavium')
-rw-r--r--sys/mips/cavium/octeon_ds1337.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/sys/mips/cavium/octeon_ds1337.c b/sys/mips/cavium/octeon_ds1337.c
index a5cba94..73405a9 100644
--- a/sys/mips/cavium/octeon_ds1337.c
+++ b/sys/mips/cavium/octeon_ds1337.c
@@ -81,7 +81,7 @@ static int validate_ct_struct(struct clocktime *ct)
CT_CHECK(ct->min < 0 || ct->min > 59, "minute");
CT_CHECK(ct->hour < 0 || ct->hour > 23, "hour");
CT_CHECK(ct->day < 1 || ct->day > 31, "day");
- CT_CHECK(ct->dow < 1 || ct->dow > 7, "day of week");
+ CT_CHECK(ct->dow < 0 || ct->dow > 6, "day of week");
CT_CHECK(ct->mon < 1 || ct->mon > 12, "month");
CT_CHECK(ct->year > 2037,"year");
@@ -124,7 +124,7 @@ uint32_t cvmx_rtc_ds1337_read(void)
{
ct.hour = (ct.hour + 12) % 24;
}
- ct.dow = (reg[3] & 0x7); /* Day of week field is 1..7 */
+ ct.dow = (reg[3] & 0x7) - 1; /* Day of week field is 0..6 */
ct.day = bcd2bin(reg[4] & 0x3f);
ct.mon = bcd2bin(reg[5] & 0x1f); /* Month field is 1..12 */
#if defined(OCTEON_BOARD_CAPK_0100ND)
@@ -136,7 +136,6 @@ uint32_t cvmx_rtc_ds1337_read(void)
ct.year = ((reg[5] & 0x80) ? 2000 : 1900) + bcd2bin(reg[6]);
#endif
-
if (validate_ct_struct(&ct))
cvmx_dprintf("Warning: RTC calendar is not configured properly\n");
@@ -174,13 +173,15 @@ int cvmx_rtc_ds1337_write(uint32_t time)
reg[0] = bin2bcd(ct.sec);
reg[1] = bin2bcd(ct.min);
reg[2] = bin2bcd(ct.hour); /* Force 0..23 format even if using AM/PM */
- reg[3] = bin2bcd(ct.dow);
+ reg[3] = bin2bcd(ct.dow + 1);
reg[4] = bin2bcd(ct.day);
reg[5] = bin2bcd(ct.mon);
+#if !defined(OCTEON_BOARD_CAPK_0100ND)
if (ct.year >= 2000) /* Set century bit*/
{
reg[5] |= 0x80;
}
+#endif
reg[6] = bin2bcd(ct.year % 100);
/* Lockless write: detects the infrequent roll-over and retries */
OpenPOWER on IntegriCloud