blob: f0acfad8056c13fbd765e7003b90f859914902b3 [file] [log] [blame]
Stefan Roese0044c422012-08-16 17:55:41 +00001/*
2 * (C) Copyright 2011
3 * Heiko Schocher, DENX Software Engineering, hs@denx.de.
4 *
Wolfgang Denk1a459662013-07-08 09:37:19 +02005 * SPDX-License-Identifier: GPL-2.0+
Stefan Roese0044c422012-08-16 17:55:41 +00006 */
7
8#include <bootcount.h>
Tom Rini155d4242013-08-28 09:00:28 -04009#include <asm/davinci_rtc.h>
Stefan Roese0044c422012-08-16 17:55:41 +000010
11void bootcount_store(ulong a)
12{
13 struct davinci_rtc *reg =
14 (struct davinci_rtc *)CONFIG_SYS_BOOTCOUNT_ADDR;
15
16 /*
17 * write RTC kick register to enable write
18 * for RTC Scratch registers. Scratch0 and 1 are
19 * used for bootcount values.
20 */
21 writel(RTC_KICK0R_WE, &reg->kick0r);
22 writel(RTC_KICK1R_WE, &reg->kick1r);
Tom Rini22ee3972013-08-28 09:00:29 -040023 raw_bootcount_store(&reg->scratch2,
24 (BOOTCOUNT_MAGIC & 0xffff0000) | (a & 0x0000ffff));
Stefan Roese0044c422012-08-16 17:55:41 +000025}
26
27ulong bootcount_load(void)
28{
Tom Rini22ee3972013-08-28 09:00:29 -040029 unsigned long val;
Stefan Roese0044c422012-08-16 17:55:41 +000030 struct davinci_rtc *reg =
31 (struct davinci_rtc *)CONFIG_SYS_BOOTCOUNT_ADDR;
32
Tom Rini22ee3972013-08-28 09:00:29 -040033 val = raw_bootcount_load(&reg->scratch2);
34 if ((val & 0xffff0000) != (BOOTCOUNT_MAGIC & 0xffff0000))
Stefan Roese0044c422012-08-16 17:55:41 +000035 return 0;
36 else
Tom Rini22ee3972013-08-28 09:00:29 -040037 return val & 0x0000ffff;
Stefan Roese0044c422012-08-16 17:55:41 +000038}