Merge https://gitlab.denx.de/u-boot/custodians/u-boot-x86
[platform/kernel/u-boot.git] / drivers / bootcount / Kconfig
1 #
2 # Boot count configuration
3 #
4
5 menuconfig BOOTCOUNT_LIMIT
6         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
11 if BOOTCOUNT_LIMIT
12
13 choice
14         prompt "Boot count device"
15         default BOOTCOUNT_AM33XX if AM33XX || SOC_DA8XX
16         default BOOTCOUNT_AT91 if AT91SAM9XE
17         default BOOTCOUNT_GENERIC
18
19 config 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.
27
28 config BOOTCOUNT_EXT
29         bool "Boot counter on EXT filesystem"
30         depends on FS_EXT4
31         select EXT4_WRITE
32         help
33           Add support for maintaining boot count in a file on an EXT
34           filesystem.
35
36 config BOOTCOUNT_AM33XX
37         bool "Boot counter in AM33XX RTC IP block"
38         depends on AM33XX || SOC_DA8XX
39         select SPL_AM33XX_ENABLE_RTC32K_OSC if AM33XX
40         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
45 config BOOTCOUNT_ENV
46         bool "Boot counter in environment"
47         help
48           If no softreset save registers are found on the hardware
49           "bootcount" is stored in the environment. To prevent a
50           saveenv on all reboots, the environment variable
51           "upgrade_available" is used. If "upgrade_available" is
52           0, "bootcount" is always 0, if "upgrade_available" is
53           1 "bootcount" is incremented in the environment.
54           So the Userspace Application must set the "upgrade_available"
55           and "bootcount" variable to 0, if a boot was successfully.
56
57 config BOOTCOUNT_RAM
58         bool "Boot counter in RAM"
59         help
60           Store the bootcount in DRAM protected against against bit errors
61           due to short power loss or holding a system in RESET.
62
63 config BOOTCOUNT_I2C
64         bool "Boot counter on I2C device"
65         help
66           Enable support for the bootcounter on an i2c (like RTC) device.
67           CONFIG_SYS_I2C_RTC_ADDR = i2c chip address
68           CONFIG_SYS_BOOTCOUNT_ADDR = i2c addr which is used for
69                                       the bootcounter.
70
71 config BOOTCOUNT_AT91
72         bool "Boot counter for Atmel AT91SAM9XE"
73         depends on AT91SAM9XE
74
75 config DM_BOOTCOUNT
76         bool "Boot counter in a device-model device"
77         help
78           Enables reading/writing the bootcount in a device-model based
79           backing store.  If an entry in /chosen/u-boot,bootcount-device
80           exists, this will be the preferred bootcount device; otherwise
81           the first available bootcount device will be used.
82
83 endchoice
84
85 if DM_BOOTCOUNT
86
87 menu "Backing stores for device-model backed bootcount"
88 config DM_BOOTCOUNT_RTC
89         bool "Support RTC devices as a backing store for bootcount"
90         depends on DM_RTC
91         help
92           Enabled reading/writing the bootcount in a DM RTC device.
93           The wrapper device is to be specified with the compatible string
94           'u-boot,bootcount-rtc' and the 'rtc'-property (a phandle pointing
95           to the underlying RTC device) and an optional 'offset' property
96           are supported.
97
98           Accesses to the backing store are performed using the write16
99           and read16 ops of DM RTC devices.
100
101 config DM_BOOTCOUNT_I2C_EEPROM
102         bool "Support i2c eeprom devices as a backing store for bootcount"
103         depends on I2C_EEPROM
104         help
105           Enabled reading/writing the bootcount in a DM i2c eeprom device.
106           The wrapper device is to be specified with the compatible string
107           'u-boot,bootcount-i2c-eeprom' and the 'i2c-eeprom'-property (a phandle
108           pointing to the underlying i2c eeprom device) and an optional 'offset'
109           property are supported.
110
111 config DM_BOOTCOUNT_SPI_FLASH
112         bool "Support SPI flash devices as a backing store for bootcount"
113         depends on DM_SPI_FLASH
114         help
115           Enabled reading/writing the bootcount in a DM SPI flash device.
116           The wrapper device is to be specified with the compatible string
117           'u-boot,bootcount-spi-flash' and the 'spi-flash'-property (a phandle
118           pointing to the underlying SPI flash device) and an optional 'offset'
119           property are supported.
120
121 config BOOTCOUNT_MEM
122         bool "Support memory based bootcounter"
123         help
124           Enabling Memory based bootcount, typically in a SoC register which
125           is not cleared on softreset.
126           compatible = "u-boot,bootcount";
127
128 endmenu
129
130 endif
131
132 config BOOTCOUNT_BOOTLIMIT
133         int "Maximum number of reboot cycles allowed"
134         default 0
135         help
136           Set the Maximum number of reboot cycles allowed without the boot
137           counter being cleared.
138           If set to 0 do not set a boot limit in the environment.
139
140 config BOOTCOUNT_ALEN
141         int "I2C address length"
142         default 1
143         depends on BOOTCOUNT_I2C
144         help
145           Length of the the I2C address at SYS_BOOTCOUNT_ADDR for storing
146           the boot counter.
147
148 config SYS_BOOTCOUNT_SINGLEWORD
149         bool "Use single word to pack boot count and magic value"
150         depends on BOOTCOUNT_GENERIC
151         help
152           This option enables packing boot count magic value and boot count
153           into single word (32 bits).
154
155 config SYS_BOOTCOUNT_EXT_INTERFACE
156         string "Interface on which to find boot counter EXT filesystem"
157         default "mmc"
158         depends on BOOTCOUNT_EXT
159         help
160           Set the interface to use when locating the filesystem to use for the
161           boot counter.
162
163 config SYS_BOOTCOUNT_EXT_DEVPART
164         string "Partition of the boot counter EXT filesystem"
165         default "0:1"
166         depends on BOOTCOUNT_EXT
167         help
168           Set the partition to use when locating the filesystem to use for the
169           boot counter.
170
171 config SYS_BOOTCOUNT_EXT_NAME
172         string "Path and filename of the EXT filesystem based boot counter"
173         default "/boot/failures"
174         depends on BOOTCOUNT_EXT
175         help
176           Set the filename and path of the file used to store the boot counter.
177
178 config SYS_BOOTCOUNT_ADDR
179         hex "RAM address used for reading and writing the boot counter"
180         default 0x44E3E000 if BOOTCOUNT_AM33XX
181         default 0xE0115FF8 if ARCH_LS1043A || ARCH_LS1021A
182         depends on BOOTCOUNT_AM33XX || BOOTCOUNT_GENERIC || BOOTCOUNT_EXT || \
183                    BOOTCOUNT_I2C
184         help
185           Set the address used for reading and writing the boot counter.
186
187 config SYS_BOOTCOUNT_MAGIC
188         hex "Magic value for the boot counter"
189         default 0xB001C041
190         help
191           Set the magic value used for the boot counter.
192
193 endif