mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-09-13 22:25:03 +00:00
rtc: mpc5121: set range
The datasheet states that 4052 is the maximum value for year. However, the mpc5121 read_time and set_time function abuse the target time register instead of using the broken down time so it is limited to 2106. Link: https://lore.kernel.org/r/20200306074404.58909-3-alexandre.belloni@bootlin.com Signed-off-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
This commit is contained in:
parent
fffbe10e2f
commit
3905d1c02d
1 changed files with 9 additions and 0 deletions
|
@ -352,6 +352,8 @@ static int mpc5121_rtc_probe(struct platform_device *op)
|
||||||
|
|
||||||
rtc->rtc->ops = &mpc5200_rtc_ops;
|
rtc->rtc->ops = &mpc5200_rtc_ops;
|
||||||
rtc->rtc->uie_unsupported = 1;
|
rtc->rtc->uie_unsupported = 1;
|
||||||
|
rtc->rtc->range_min = RTC_TIMESTAMP_BEGIN_0000;
|
||||||
|
rtc->rtc->range_max = 65733206399ULL; /* 4052-12-31 23:59:59 */
|
||||||
|
|
||||||
if (of_device_is_compatible(op->dev.of_node, "fsl,mpc5121-rtc")) {
|
if (of_device_is_compatible(op->dev.of_node, "fsl,mpc5121-rtc")) {
|
||||||
u32 ka;
|
u32 ka;
|
||||||
|
@ -362,6 +364,13 @@ static int mpc5121_rtc_probe(struct platform_device *op)
|
||||||
out_be32(&rtc->regs->keep_alive, ka);
|
out_be32(&rtc->regs->keep_alive, ka);
|
||||||
}
|
}
|
||||||
rtc->rtc->ops = &mpc5121_rtc_ops;
|
rtc->rtc->ops = &mpc5121_rtc_ops;
|
||||||
|
/*
|
||||||
|
* This is a limitation of the driver that abuses the target
|
||||||
|
* time register, the actual maximum year for the mpc5121 is
|
||||||
|
* also 4052.
|
||||||
|
*/
|
||||||
|
rtc->rtc->range_min = 0;
|
||||||
|
rtc->rtc->range_max = U32_MAX;
|
||||||
}
|
}
|
||||||
|
|
||||||
err = rtc_register_device(rtc->rtc);
|
err = rtc_register_device(rtc->rtc);
|
||||||
|
|
Loading…
Reference in a new issue