blob: 0de2b7bd78c6068b6625b48ffad8683b4504e74e [file] [log] [blame]
Ian Ray542a48e2017-11-08 15:35:13 +00001#
2# Boot count configuration
3#
4
Alex Kiernanaa0abed2018-02-16 15:50:39 +00005menuconfig BOOTCOUNT_LIMIT
Lukasz Majewski6dd8c902018-02-09 23:50:57 +01006 bool "Enable support for checking boot count limit"
7 help
8 Enable checking for exceeding the boot count limit.
9 More information: http://www.denx.de/wiki/DULG/UBootBootCountLimit
10
Alex Kiernan4aa943f2018-02-16 15:50:38 +000011if BOOTCOUNT_LIMIT
Ian Ray542a48e2017-11-08 15:35:13 +000012
Alex Kiernanaa0abed2018-02-16 15:50:39 +000013choice
14 prompt "Boot count device"
Alex Kiernan88456352018-02-16 15:50:40 +000015 default BOOTCOUNT_AM33XX if AM33XX || SOC_DA8XX
Alex Kiernan48bfd652018-02-16 15:50:45 +000016 default BOOTCOUNT_AT91 if AT91SAM9XE
Alex Kiernan4a80f1d2018-02-16 15:50:46 +000017 default BOOTCOUNT_GENERIC
18
19config BOOTCOUNT_GENERIC
20 bool "Generic default boot counter"
21 help
22 Generic bootcount stored at SYS_BOOTCOUNT_ADDR.
23
24 SYS_BOOTCOUNT_ADDR:
25 Set to the address where the bootcount and bootcount magic
26 will be stored.
Alex Kiernanaa0abed2018-02-16 15:50:39 +000027
Ian Ray542a48e2017-11-08 15:35:13 +000028config BOOTCOUNT_EXT
29 bool "Boot counter on EXT filesystem"
Frédéric Danis884bc8a2020-05-20 09:13:26 +020030 depends on FS_EXT4
31 select EXT4_WRITE
Ian Ray542a48e2017-11-08 15:35:13 +000032 help
33 Add support for maintaining boot count in a file on an EXT
34 filesystem.
35
Alex Kiernan88456352018-02-16 15:50:40 +000036config BOOTCOUNT_AM33XX
37 bool "Boot counter in AM33XX RTC IP block"
38 depends on AM33XX || SOC_DA8XX
Alex Kiernan10238ef2018-03-15 22:11:46 +000039 select SPL_AM33XX_ENABLE_RTC32K_OSC if AM33XX
Alex Kiernan88456352018-02-16 15:50:40 +000040 help
41 A bootcount driver for the RTC IP block found on many TI platforms.
42 This requires the RTC clocks, etc, to be enabled prior to use and
43 not all boards with this IP block on it will have the RTC in use.
44
Gireesh Hiremathc900eb12021-06-11 16:13:48 +000045config BOOTCOUNT_AM33XX_NVMEM
46 bool "Boot counter in AM33XX RTC IP block with upgrade_available flag"
47 depends on AM33XX
48 select SPL_AM33XX_ENABLE_RTC32K_OSC if AM33XX
49 help
50 Add support for maintaining bootcount,upgrade_available,
51 version and BOOTMAGIC in a AM33xx RTC IP block
52 scratch register2.
53
54 A bootcount driver for the RTC IP block found on many TI platforms.
55 This requires the RTC clocks, etc, to be enabled prior to use and
56 not all boards with this IP block on it will have the RTC in use.
57
58 If there is upgrade in software then "upgrade_available" is 1,
59 "bootcount" is incremented otherwise "upgrade_available" and
60 "bootcount" is always 0. So the Userspace Application must set
61 the "upgrade_available" and "bootcount" variable to 0, if a boot
62 was successfully.
63
Alex Kiernanc5037a82018-02-16 15:50:41 +000064config BOOTCOUNT_ENV
65 bool "Boot counter in environment"
66 help
67 If no softreset save registers are found on the hardware
68 "bootcount" is stored in the environment. To prevent a
69 saveenv on all reboots, the environment variable
70 "upgrade_available" is used. If "upgrade_available" is
71 0, "bootcount" is always 0, if "upgrade_available" is
72 1 "bootcount" is incremented in the environment.
73 So the Userspace Application must set the "upgrade_available"
74 and "bootcount" variable to 0, if a boot was successfully.
75
Alex Kiernan2a694292018-02-16 15:50:42 +000076config BOOTCOUNT_RAM
77 bool "Boot counter in RAM"
78 help
79 Store the bootcount in DRAM protected against against bit errors
80 due to short power loss or holding a system in RESET.
81
Alex Kiernan3cbc810b2018-02-16 15:50:43 +000082config BOOTCOUNT_I2C
83 bool "Boot counter on I2C device"
84 help
85 Enable support for the bootcounter on an i2c (like RTC) device.
86 CONFIG_SYS_I2C_RTC_ADDR = i2c chip address
87 CONFIG_SYS_BOOTCOUNT_ADDR = i2c addr which is used for
88 the bootcounter.
Alex Kiernan3cbc810b2018-02-16 15:50:43 +000089
Alex Kiernan48bfd652018-02-16 15:50:45 +000090config BOOTCOUNT_AT91
91 bool "Boot counter for Atmel AT91SAM9XE"
92 depends on AT91SAM9XE
93
Philipp Tomsichce860312018-11-27 23:00:18 +010094config DM_BOOTCOUNT
95 bool "Boot counter in a device-model device"
96 help
97 Enables reading/writing the bootcount in a device-model based
98 backing store. If an entry in /chosen/u-boot,bootcount-device
99 exists, this will be the preferred bootcount device; otherwise
100 the first available bootcount device will be used.
101
Alex Kiernanaa0abed2018-02-16 15:50:39 +0000102endchoice
103
Philipp Tomsich57be8822018-11-27 23:00:19 +0100104if DM_BOOTCOUNT
105
106menu "Backing stores for device-model backed bootcount"
107config DM_BOOTCOUNT_RTC
108 bool "Support RTC devices as a backing store for bootcount"
109 depends on DM_RTC
110 help
111 Enabled reading/writing the bootcount in a DM RTC device.
112 The wrapper device is to be specified with the compatible string
113 'u-boot,bootcount-rtc' and the 'rtc'-property (a phandle pointing
114 to the underlying RTC device) and an optional 'offset' property
115 are supported.
116
117 Accesses to the backing store are performed using the write16
118 and read16 ops of DM RTC devices.
119
Robert Becketta8c32b52019-10-28 18:44:06 +0000120config DM_BOOTCOUNT_I2C_EEPROM
121 bool "Support i2c eeprom devices as a backing store for bootcount"
122 depends on I2C_EEPROM
123 help
124 Enabled reading/writing the bootcount in a DM i2c eeprom device.
125 The wrapper device is to be specified with the compatible string
126 'u-boot,bootcount-i2c-eeprom' and the 'i2c-eeprom'-property (a phandle
127 pointing to the underlying i2c eeprom device) and an optional 'offset'
128 property are supported.
129
Sebastian Reichel40e77512020-09-02 19:31:38 +0200130config DM_BOOTCOUNT_SPI_FLASH
131 bool "Support SPI flash devices as a backing store for bootcount"
132 depends on DM_SPI_FLASH
133 help
134 Enabled reading/writing the bootcount in a DM SPI flash device.
135 The wrapper device is to be specified with the compatible string
136 'u-boot,bootcount-spi-flash' and the 'spi-flash'-property (a phandle
137 pointing to the underlying SPI flash device) and an optional 'offset'
138 property are supported.
139
Heiko Schochere2981922020-03-02 15:43:59 +0100140config BOOTCOUNT_MEM
141 bool "Support memory based bootcounter"
142 help
143 Enabling Memory based bootcount, typically in a SoC register which
144 is not cleared on softreset.
145 compatible = "u-boot,bootcount";
146
Philipp Tomsich57be8822018-11-27 23:00:19 +0100147endmenu
148
149endif
150
Alex Kiernancf9888f2018-07-21 20:25:32 +0000151config BOOTCOUNT_BOOTLIMIT
152 int "Maximum number of reboot cycles allowed"
153 default 0
154 help
155 Set the Maximum number of reboot cycles allowed without the boot
156 counter being cleared.
157 If set to 0 do not set a boot limit in the environment.
158
Alex Kiernan74910a72018-02-16 15:50:47 +0000159config BOOTCOUNT_ALEN
160 int "I2C address length"
161 default 1
162 depends on BOOTCOUNT_I2C
163 help
164 Length of the the I2C address at SYS_BOOTCOUNT_ADDR for storing
165 the boot counter.
166
Alex Kiernanaa0abed2018-02-16 15:50:39 +0000167config SYS_BOOTCOUNT_SINGLEWORD
168 bool "Use single word to pack boot count and magic value"
Alex Kiernan4a80f1d2018-02-16 15:50:46 +0000169 depends on BOOTCOUNT_GENERIC
Alex Kiernanaa0abed2018-02-16 15:50:39 +0000170 help
171 This option enables packing boot count magic value and boot count
172 into single word (32 bits).
Ian Ray542a48e2017-11-08 15:35:13 +0000173
174config SYS_BOOTCOUNT_EXT_INTERFACE
175 string "Interface on which to find boot counter EXT filesystem"
176 default "mmc"
177 depends on BOOTCOUNT_EXT
178 help
179 Set the interface to use when locating the filesystem to use for the
180 boot counter.
181
182config SYS_BOOTCOUNT_EXT_DEVPART
183 string "Partition of the boot counter EXT filesystem"
184 default "0:1"
185 depends on BOOTCOUNT_EXT
186 help
187 Set the partition to use when locating the filesystem to use for the
188 boot counter.
189
190config SYS_BOOTCOUNT_EXT_NAME
191 string "Path and filename of the EXT filesystem based boot counter"
192 default "/boot/failures"
193 depends on BOOTCOUNT_EXT
194 help
195 Set the filename and path of the file used to store the boot counter.
196
197config SYS_BOOTCOUNT_ADDR
198 hex "RAM address used for reading and writing the boot counter"
Gireesh Hiremathc900eb12021-06-11 16:13:48 +0000199 default 0x44E3E000 if BOOTCOUNT_AM33XX || BOOTCOUNT_AM33XX_NVMEM
Tom Rinic98ed5f2018-02-24 16:50:41 -0500200 default 0xE0115FF8 if ARCH_LS1043A || ARCH_LS1021A
201 depends on BOOTCOUNT_AM33XX || BOOTCOUNT_GENERIC || BOOTCOUNT_EXT || \
Gireesh Hiremathc900eb12021-06-11 16:13:48 +0000202 BOOTCOUNT_I2C || BOOTCOUNT_AM33XX_NVMEM
Ian Ray542a48e2017-11-08 15:35:13 +0000203 help
204 Set the address used for reading and writing the boot counter.
205
Marek Vasut6ae0ded2018-10-11 00:13:54 +0200206config SYS_BOOTCOUNT_MAGIC
207 hex "Magic value for the boot counter"
Gireesh Hiremathc900eb12021-06-11 16:13:48 +0000208 default 0xB001C041 if BOOTCOUNT_GENERIC || BOOTCOUNT_EXT || \
209 BOOTCOUNT_AM33XX || BOOTCOUNT_ENV || \
210 BOOTCOUNT_RAM || BOOTCOUNT_I2C || \
211 BOOTCOUNT_AT91 || DM_BOOTCOUNT
212 default 0xB0 if BOOTCOUNT_AM33XX_NVMEM
213 depends on BOOTCOUNT_GENERIC || BOOTCOUNT_EXT || \
214 BOOTCOUNT_AM33XX || BOOTCOUNT_ENV || \
215 BOOTCOUNT_RAM || BOOTCOUNT_I2C || \
216 BOOTCOUNT_AT91 || DM_BOOTCOUNT || \
217 BOOTCOUNT_AM33XX_NVMEM
Marek Vasut6ae0ded2018-10-11 00:13:54 +0200218 help
219 Set the magic value used for the boot counter.
220
Ian Ray542a48e2017-11-08 15:35:13 +0000221endif