Ian Ray | f31dac4 | 2017-11-08 15:35:13 +0000 | [diff] [blame] | 1 | # |
| 2 | # Boot count configuration |
| 3 | # |
| 4 | |
Alex Kiernan | c1e1c1e | 2018-02-16 15:50:39 +0000 | [diff] [blame] | 5 | menuconfig BOOTCOUNT_LIMIT |
Lukasz Majewski | d1ec946 | 2018-02-09 23:50:57 +0100 | [diff] [blame] | 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 | |
Alex Kiernan | 3dccc10 | 2018-02-16 15:50:38 +0000 | [diff] [blame] | 11 | if BOOTCOUNT_LIMIT |
Ian Ray | f31dac4 | 2017-11-08 15:35:13 +0000 | [diff] [blame] | 12 | |
Alex Kiernan | c1e1c1e | 2018-02-16 15:50:39 +0000 | [diff] [blame] | 13 | choice |
| 14 | prompt "Boot count device" |
Alex Kiernan | c35e2d9 | 2018-02-16 15:50:40 +0000 | [diff] [blame] | 15 | default BOOTCOUNT_AM33XX if AM33XX || SOC_DA8XX |
Alex Kiernan | bec8c64 | 2018-02-16 15:50:45 +0000 | [diff] [blame] | 16 | default BOOTCOUNT_AT91 if AT91SAM9XE |
Alex Kiernan | aa5a863 | 2018-02-16 15:50:46 +0000 | [diff] [blame] | 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. |
Alex Kiernan | c1e1c1e | 2018-02-16 15:50:39 +0000 | [diff] [blame] | 27 | |
Ian Ray | f31dac4 | 2017-11-08 15:35:13 +0000 | [diff] [blame] | 28 | config BOOTCOUNT_EXT |
| 29 | bool "Boot counter on EXT filesystem" |
| 30 | help |
| 31 | Add support for maintaining boot count in a file on an EXT |
| 32 | filesystem. |
| 33 | |
Alex Kiernan | c35e2d9 | 2018-02-16 15:50:40 +0000 | [diff] [blame] | 34 | config BOOTCOUNT_AM33XX |
| 35 | bool "Boot counter in AM33XX RTC IP block" |
| 36 | depends on AM33XX || SOC_DA8XX |
Alex Kiernan | 3bf5f13 | 2018-03-15 22:11:46 +0000 | [diff] [blame] | 37 | select SPL_AM33XX_ENABLE_RTC32K_OSC if AM33XX |
Alex Kiernan | c35e2d9 | 2018-02-16 15:50:40 +0000 | [diff] [blame] | 38 | help |
| 39 | A bootcount driver for the RTC IP block found on many TI platforms. |
| 40 | This requires the RTC clocks, etc, to be enabled prior to use and |
| 41 | not all boards with this IP block on it will have the RTC in use. |
| 42 | |
Alex Kiernan | 04c96ed | 2018-02-16 15:50:41 +0000 | [diff] [blame] | 43 | config BOOTCOUNT_ENV |
| 44 | bool "Boot counter in environment" |
| 45 | help |
| 46 | If no softreset save registers are found on the hardware |
| 47 | "bootcount" is stored in the environment. To prevent a |
| 48 | saveenv on all reboots, the environment variable |
| 49 | "upgrade_available" is used. If "upgrade_available" is |
| 50 | 0, "bootcount" is always 0, if "upgrade_available" is |
| 51 | 1 "bootcount" is incremented in the environment. |
| 52 | So the Userspace Application must set the "upgrade_available" |
| 53 | and "bootcount" variable to 0, if a boot was successfully. |
| 54 | |
Alex Kiernan | ff5410d | 2018-02-16 15:50:42 +0000 | [diff] [blame] | 55 | config BOOTCOUNT_RAM |
| 56 | bool "Boot counter in RAM" |
| 57 | help |
| 58 | Store the bootcount in DRAM protected against against bit errors |
| 59 | due to short power loss or holding a system in RESET. |
| 60 | |
Alex Kiernan | 6cdd70e | 2018-02-16 15:50:43 +0000 | [diff] [blame] | 61 | config BOOTCOUNT_I2C |
| 62 | bool "Boot counter on I2C device" |
| 63 | help |
| 64 | Enable support for the bootcounter on an i2c (like RTC) device. |
| 65 | CONFIG_SYS_I2C_RTC_ADDR = i2c chip address |
| 66 | CONFIG_SYS_BOOTCOUNT_ADDR = i2c addr which is used for |
| 67 | the bootcounter. |
Alex Kiernan | 6cdd70e | 2018-02-16 15:50:43 +0000 | [diff] [blame] | 68 | |
Alex Kiernan | bec8c64 | 2018-02-16 15:50:45 +0000 | [diff] [blame] | 69 | config BOOTCOUNT_AT91 |
| 70 | bool "Boot counter for Atmel AT91SAM9XE" |
| 71 | depends on AT91SAM9XE |
| 72 | |
Philipp Tomsich | ebb73de | 2018-11-27 23:00:18 +0100 | [diff] [blame] | 73 | config DM_BOOTCOUNT |
| 74 | bool "Boot counter in a device-model device" |
| 75 | help |
| 76 | Enables reading/writing the bootcount in a device-model based |
| 77 | backing store. If an entry in /chosen/u-boot,bootcount-device |
| 78 | exists, this will be the preferred bootcount device; otherwise |
| 79 | the first available bootcount device will be used. |
| 80 | |
Alex Kiernan | c1e1c1e | 2018-02-16 15:50:39 +0000 | [diff] [blame] | 81 | endchoice |
| 82 | |
Philipp Tomsich | 482734a | 2018-11-27 23:00:19 +0100 | [diff] [blame] | 83 | if DM_BOOTCOUNT |
| 84 | |
| 85 | menu "Backing stores for device-model backed bootcount" |
| 86 | config DM_BOOTCOUNT_RTC |
| 87 | bool "Support RTC devices as a backing store for bootcount" |
| 88 | depends on DM_RTC |
| 89 | help |
| 90 | Enabled reading/writing the bootcount in a DM RTC device. |
| 91 | The wrapper device is to be specified with the compatible string |
| 92 | 'u-boot,bootcount-rtc' and the 'rtc'-property (a phandle pointing |
| 93 | to the underlying RTC device) and an optional 'offset' property |
| 94 | are supported. |
| 95 | |
| 96 | Accesses to the backing store are performed using the write16 |
| 97 | and read16 ops of DM RTC devices. |
| 98 | |
Robert Beckett | ae3d38f | 2019-10-28 18:44:06 +0000 | [diff] [blame] | 99 | config DM_BOOTCOUNT_I2C_EEPROM |
| 100 | bool "Support i2c eeprom devices as a backing store for bootcount" |
| 101 | depends on I2C_EEPROM |
| 102 | help |
| 103 | Enabled reading/writing the bootcount in a DM i2c eeprom device. |
| 104 | The wrapper device is to be specified with the compatible string |
| 105 | 'u-boot,bootcount-i2c-eeprom' and the 'i2c-eeprom'-property (a phandle |
| 106 | pointing to the underlying i2c eeprom device) and an optional 'offset' |
| 107 | property are supported. |
| 108 | |
Heiko Schocher | 80e8b8a | 2020-03-02 15:43:59 +0100 | [diff] [blame] | 109 | config BOOTCOUNT_MEM |
| 110 | bool "Support memory based bootcounter" |
| 111 | help |
| 112 | Enabling Memory based bootcount, typically in a SoC register which |
| 113 | is not cleared on softreset. |
| 114 | compatible = "u-boot,bootcount"; |
| 115 | |
Philipp Tomsich | 482734a | 2018-11-27 23:00:19 +0100 | [diff] [blame] | 116 | endmenu |
| 117 | |
| 118 | endif |
| 119 | |
Alex Kiernan | c9ad6bc | 2018-07-21 20:25:32 +0000 | [diff] [blame] | 120 | config BOOTCOUNT_BOOTLIMIT |
| 121 | int "Maximum number of reboot cycles allowed" |
| 122 | default 0 |
| 123 | help |
| 124 | Set the Maximum number of reboot cycles allowed without the boot |
| 125 | counter being cleared. |
| 126 | If set to 0 do not set a boot limit in the environment. |
| 127 | |
Alex Kiernan | 4bc4f8a | 2018-02-16 15:50:47 +0000 | [diff] [blame] | 128 | config BOOTCOUNT_ALEN |
| 129 | int "I2C address length" |
| 130 | default 1 |
| 131 | depends on BOOTCOUNT_I2C |
| 132 | help |
| 133 | Length of the the I2C address at SYS_BOOTCOUNT_ADDR for storing |
| 134 | the boot counter. |
| 135 | |
Alex Kiernan | c1e1c1e | 2018-02-16 15:50:39 +0000 | [diff] [blame] | 136 | config SYS_BOOTCOUNT_SINGLEWORD |
| 137 | bool "Use single word to pack boot count and magic value" |
Alex Kiernan | aa5a863 | 2018-02-16 15:50:46 +0000 | [diff] [blame] | 138 | depends on BOOTCOUNT_GENERIC |
Alex Kiernan | c1e1c1e | 2018-02-16 15:50:39 +0000 | [diff] [blame] | 139 | help |
| 140 | This option enables packing boot count magic value and boot count |
| 141 | into single word (32 bits). |
Ian Ray | f31dac4 | 2017-11-08 15:35:13 +0000 | [diff] [blame] | 142 | |
| 143 | config SYS_BOOTCOUNT_EXT_INTERFACE |
| 144 | string "Interface on which to find boot counter EXT filesystem" |
| 145 | default "mmc" |
| 146 | depends on BOOTCOUNT_EXT |
| 147 | help |
| 148 | Set the interface to use when locating the filesystem to use for the |
| 149 | boot counter. |
| 150 | |
| 151 | config SYS_BOOTCOUNT_EXT_DEVPART |
| 152 | string "Partition of the boot counter EXT filesystem" |
| 153 | default "0:1" |
| 154 | depends on BOOTCOUNT_EXT |
| 155 | help |
| 156 | Set the partition to use when locating the filesystem to use for the |
| 157 | boot counter. |
| 158 | |
| 159 | config SYS_BOOTCOUNT_EXT_NAME |
| 160 | string "Path and filename of the EXT filesystem based boot counter" |
| 161 | default "/boot/failures" |
| 162 | depends on BOOTCOUNT_EXT |
| 163 | help |
| 164 | Set the filename and path of the file used to store the boot counter. |
| 165 | |
| 166 | config SYS_BOOTCOUNT_ADDR |
| 167 | hex "RAM address used for reading and writing the boot counter" |
Tom Rini | 39bcbb7 | 2018-02-24 16:50:41 -0500 | [diff] [blame] | 168 | default 0x44E3E000 if BOOTCOUNT_AM33XX |
| 169 | default 0xE0115FF8 if ARCH_LS1043A || ARCH_LS1021A |
| 170 | depends on BOOTCOUNT_AM33XX || BOOTCOUNT_GENERIC || BOOTCOUNT_EXT || \ |
| 171 | BOOTCOUNT_I2C |
Ian Ray | f31dac4 | 2017-11-08 15:35:13 +0000 | [diff] [blame] | 172 | help |
| 173 | Set the address used for reading and writing the boot counter. |
| 174 | |
Marek Vasut | 758694f | 2018-10-11 00:13:54 +0200 | [diff] [blame] | 175 | config SYS_BOOTCOUNT_MAGIC |
| 176 | hex "Magic value for the boot counter" |
| 177 | default 0xB001C041 |
| 178 | help |
| 179 | Set the magic value used for the boot counter. |
| 180 | |
Ian Ray | f31dac4 | 2017-11-08 15:35:13 +0000 | [diff] [blame] | 181 | endif |