rtc: pcf8523: refuse to write dates later than 2099
authorUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Fri, 6 Nov 2015 16:37:56 +0000 (17:37 +0100)
committerAlexandre Belloni <alexandre.belloni@free-electrons.com>
Mon, 11 Jan 2016 19:19:54 +0000 (20:19 +0100)
When the chip increments the YEAR register and it already holds
bin2bcd(99) it reads as 0 afterwards. With this behaviour the last valid
day (without trickery) that has a representation is 2099-12-31 23:59:59.
So refuse to write later dates.

Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: Alexandre Belloni <alexandre.belloni@free-electrons.com>
drivers/rtc/rtc-pcf8523.c

index e7ebcc0b7e59b55eecfc8daf7d2540a4b4282217..988566caaaa639c7854f3a78c1aecbf21c478139 100644 (file)
@@ -219,6 +219,17 @@ static int pcf8523_rtc_set_time(struct device *dev, struct rtc_time *tm)
        u8 regs[8];
        int err;
 
+       /*
+        * The hardware can only store values between 0 and 99 in it's YEAR
+        * register (with 99 overflowing to 0 on increment).
+        * After 2100-02-28 we could start interpreting the year to be in the
+        * interval [2100, 2199], but there is no path to switch in a smooth way
+        * because the chip handles YEAR=0x00 (and the out-of-spec
+        * YEAR=0xa0) as a leap year, but 2100 isn't.
+        */
+       if (tm->tm_year < 100 || tm->tm_year >= 200)
+               return -EINVAL;
+
        err = pcf8523_stop_rtc(client);
        if (err < 0)
                return err;