1 /* 2 * Generated by info2header.py 3 * Do not edit it. 4 */ 5 6 #define OTP_INFO_VER "1.0.1" 7 #define OTP_REG_RESERVED -1 8 #define OTP_REG_VALUE -2 9 #define OTP_REG_VALID_BIT -3 10 11 struct otpstrap_info { 12 signed char bit_offset; 13 signed char length; 14 signed char value; 15 char *information; 16 }; 17 18 struct otpconf_info { 19 signed char dw_offset; 20 signed char bit_offset; 21 signed char length; 22 signed char value; 23 char *information; 24 }; 25 26 static const struct otpstrap_info a0_strap_info[] = { 27 { 0, 1, 0, "Disable Secure Boot" }, 28 { 0, 1, 1, "Enable Secure Boot" }, 29 { 1, 1, 0, "Disable boot from eMMC" }, 30 { 1, 1, 1, "Enable boot from eMMC" }, 31 { 2, 1, 0, "Disable Boot from debug SPI" }, 32 { 2, 1, 1, "Enable Boot from debug SPI" }, 33 { 3, 1, 0, "Enable ARM CM3" }, 34 { 3, 1, 1, "Disable ARM CM3" }, 35 { 4, 1, 0, "No VGA BIOS ROM, VGA BIOS is merged in the system BIOS" }, 36 { 4, 1, 1, "Enable dedicated VGA BIOS ROM" }, 37 { 5, 1, 0, "MAC 1 : RMII/NCSI" }, 38 { 5, 1, 1, "MAC 1 : RGMII" }, 39 { 6, 1, 0, "MAC 2 : RMII/NCSI" }, 40 { 6, 1, 1, "MAC 2 : RGMII" }, 41 { 7, 2, 0, "CPU Frequency : 1GHz" }, 42 { 7, 2, 1, "CPU Frequency : 800MHz" }, 43 { 7, 2, 2, "CPU Frequency : 1.2GHz" }, 44 { 7, 2, 3, "CPU Frequency : 1.4GHz" }, 45 { 10, 2, 1, "HCLK ratio AXI:AHB = 2:1" }, 46 { 10, 2, 2, "HCLK ratio AXI:AHB = 3:1" }, 47 { 10, 2, 3, "HCLK ratio AXI:AHB = 4:1" }, 48 { 12, 2, 0, "VGA memory size : 8MB" }, 49 { 12, 2, 1, "VGA memory size : 16MB" }, 50 { 12, 2, 2, "VGA memory size : 32MB" }, 51 { 12, 2, 3, "VGA memory size : 64MB" }, 52 { 15, 1, 0, "CPU/AXI clock ratio : 2:1" }, 53 { 15, 1, 1, "CPU/AXI clock ratio : 1:1" }, 54 { 16, 1, 0, "Enable ARM JTAG debug" }, 55 { 16, 1, 1, "Disable ARM JTAG debug" }, 56 { 17, 1, 0, "VGA class code : video_device" }, 57 { 17, 1, 1, "VGA class code : vga_device" }, 58 { 18, 1, 0, "Enable debug interfaces 0" }, 59 { 18, 1, 1, "Disable debug interfaces 0" }, 60 { 19, 1, 0, "Boot from eMMC speed mode : normal" }, 61 { 19, 1, 1, "Boot from eMMC speed mode : high" }, 62 { 20, 1, 0, "Disable Pcie EHCI device" }, 63 { 20, 1, 1, "Enable Pcie EHCI device" }, 64 { 21, 1, 0, "Enable ARM JTAG trust world debug" }, 65 { 21, 1, 1, "Disable ARM JTAG trust world debug" }, 66 { 22, 1, 0, "Normal BMC mode" }, 67 { 22, 1, 1, "Disable dedicated BMC functions for non-BMC application" }, 68 { 23, 1, 0, "SSPRST# pin is for secondary processor dedicated reset pin" }, 69 { 23, 1, 1, "SSPRST# pin is for PCIE root complex dedicated reset pin" }, 70 { 24, 1, 0, "Enable watchdog to reset full chip" }, 71 { 24, 1, 1, "Disable watchdog to reset full chip" }, 72 { 25, 2, 0, "Internal bridge speed selection : 1x" }, 73 { 25, 2, 1, "Internal bridge speed selection : 1/2x" }, 74 { 25, 2, 2, "Internal bridge speed selection : 1/4x" }, 75 { 25, 2, 3, "Internal bridge speed selection : 1/8x" }, 76 { 29, 1, 0, "Enable RVAS function" }, 77 { 29, 1, 1, "Disable RVAS function" }, 78 { 32, 1, 0, "MAC 3 : RMII/NCSI" }, 79 { 32, 1, 1, "MAC 3 : RGMII" }, 80 { 33, 1, 0, "MAC 4 : RMII/NCSI" }, 81 { 33, 1, 1, "MAC 4 : RGMII" }, 82 { 34, 1, 0, "SuperIO configuration address : 0x2e" }, 83 { 34, 1, 1, "SuperIO configuration address : 0x4e" }, 84 { 35, 1, 0, "Enable LPC to decode SuperIO" }, 85 { 35, 1, 1, "Disable LPC to decode SuperIO" }, 86 { 36, 1, 0, "Enable debug interfaces 1" }, 87 { 36, 1, 1, "Disable debug interfaces 1" }, 88 { 37, 1, 0, "Disable ACPI function" }, 89 { 37, 1, 1, "Enable ACPI function" }, 90 { 38, 1, 0, "Select LPC/eSPI : eSPI" }, 91 { 38, 1, 1, "Select LPC/eSPI : LPC" }, 92 { 39, 1, 0, "Disable SAFS mode" }, 93 { 39, 1, 1, "Enable SAFS mode" }, 94 { 40, 1, 0, "Disable boot from uart5" }, 95 { 40, 1, 1, "Enable boot from uart5" }, 96 { 41, 1, 0, "Disable boot SPI 3B address mode auto-clear" }, 97 { 41, 1, 1, "Enable boot SPI 3B address mode auto-clear" }, 98 { 42, 1, 0, "Disable boot SPI 3B/4B address mode auto detection" }, 99 { 42, 1, 1, "Enable boot SPI 3B/4B address mode auto detection" }, 100 { 43, 1, 0, "Disable boot SPI or eMMC ABR" }, 101 { 43, 1, 1, "Enable boot SPI or eMMC ABR" }, 102 { 44, 1, 0, "Boot SPI ABR Mode : dual" }, 103 { 44, 1, 1, "Boot SPI ABR Mode : single" }, 104 { 45, 3, 0, "Boot SPI flash size : 0MB" }, 105 { 45, 3, 1, "Boot SPI flash size : 2MB" }, 106 { 45, 3, 2, "Boot SPI flash size : 4MB" }, 107 { 45, 3, 3, "Boot SPI flash size : 8MB" }, 108 { 45, 3, 4, "Boot SPI flash size : 16MB" }, 109 { 45, 3, 5, "Boot SPI flash size : 32MB" }, 110 { 45, 3, 6, "Boot SPI flash size : 64MB" }, 111 { 45, 3, 7, "Boot SPI flash size : 128MB" }, 112 { 48, 1, 0, "Disable host SPI ABR" }, 113 { 48, 1, 1, "Enable host SPI ABR" }, 114 { 49, 1, 0, "Disable host SPI ABR mode select pin" }, 115 { 49, 1, 1, "Enable host SPI ABR mode select pin" }, 116 { 50, 1, 0, "Host SPI ABR mode : dual" }, 117 { 50, 1, 1, "Host SPI ABR mode : single" }, 118 { 51, 3, 0, "Host SPI flash size : 0MB" }, 119 { 51, 3, 1, "Host SPI flash size : 2MB" }, 120 { 51, 3, 2, "Host SPI flash size : 4MB" }, 121 { 51, 3, 3, "Host SPI flash size : 8MB" }, 122 { 51, 3, 4, "Host SPI flash size : 16MB" }, 123 { 51, 3, 5, "Host SPI flash size : 32MB" }, 124 { 51, 3, 6, "Host SPI flash size : 64MB" }, 125 { 51, 3, 7, "Host SPI flash size : 128MB" }, 126 { 54, 1, 0, "Disable boot SPI auxiliary control pins" }, 127 { 54, 1, 1, "Enable boot SPI auxiliary control pins" }, 128 { 55, 2, 0, "Boot SPI CRTM size : 0KB" }, 129 { 55, 2, 1, "Boot SPI CRTM size : 256KB" }, 130 { 55, 2, 2, "Boot SPI CRTM size : 512KB" }, 131 { 55, 2, 3, "Boot SPI CRTM size : 1024KB" }, 132 { 57, 2, 0, "Host SPI CRTM size : 0KB" }, 133 { 57, 2, 1, "Host SPI CRTM size : 1024KB" }, 134 { 57, 2, 2, "Host SPI CRTM size : 2048KB" }, 135 { 57, 2, 3, "Host SPI CRTM size : 4096KB" }, 136 { 59, 1, 0, "Disable host SPI auxiliary control pins" }, 137 { 59, 1, 1, "Enable host SPI auxiliary control pins" }, 138 { 60, 1, 0, "Disable GPIO pass through" }, 139 { 60, 1, 1, "Enable GPIO pass through" }, 140 { 62, 1, 0, "Disable dedicate GPIO strap pins" }, 141 { 62, 1, 1, "Enable dedicate GPIO strap pins" } 142 }; 143 144 static const struct otpstrap_info a1_strap_info[] = { 145 { 0, 1, 0, "Disable Secure Boot" }, 146 { 0, 1, 1, "Enable Secure Boot" }, 147 { 1, 1, 0, "Disable boot from eMMC" }, 148 { 1, 1, 1, "Enable boot from eMMC" }, 149 { 2, 1, 0, "Disable Boot from debug SPI" }, 150 { 2, 1, 1, "Enable Boot from debug SPI" }, 151 { 3, 1, 0, "Enable ARM CM3" }, 152 { 3, 1, 1, "Disable ARM CM3" }, 153 { 4, 1, 0, "No VGA BIOS ROM, VGA BIOS is merged in the system BIOS" }, 154 { 4, 1, 1, "Enable dedicated VGA BIOS ROM" }, 155 { 5, 1, 0, "MAC 1 : RMII/NCSI" }, 156 { 5, 1, 1, "MAC 1 : RGMII" }, 157 { 6, 1, 0, "MAC 2 : RMII/NCSI" }, 158 { 6, 1, 1, "MAC 2 : RGMII" }, 159 { 7, 3, 0, "CPU Frequency : 1.2GHz" }, 160 { 7, 3, 1, "CPU Frequency : 1.6MHz" }, 161 { 7, 3, 2, "CPU Frequency : 1.2GHz" }, 162 { 7, 3, 3, "CPU Frequency : 1.6GHz" }, 163 { 7, 3, 4, "CPU Frequency : 800MHz" }, 164 { 7, 3, 5, "CPU Frequency : 800MHz" }, 165 { 7, 3, 6, "CPU Frequency : 800MHz" }, 166 { 7, 3, 7, "CPU Frequency : 800MHz" }, 167 { 10, 2, 1, "HCLK ratio AXI:AHB = 2:1" }, 168 { 10, 2, 2, "HCLK ratio AXI:AHB = 3:1" }, 169 { 10, 2, 3, "HCLK ratio AXI:AHB = 4:1" }, 170 { 12, 2, 0, "VGA memory size : 8MB" }, 171 { 12, 2, 1, "VGA memory size : 16MB" }, 172 { 12, 2, 2, "VGA memory size : 32MB" }, 173 { 12, 2, 3, "VGA memory size : 64MB" }, 174 { 15, 1, 0, "CPU/AXI clock ratio : 2:1" }, 175 { 15, 1, 1, "CPU/AXI clock ratio : 1:1" }, 176 { 16, 1, 0, "Enable ARM JTAG debug" }, 177 { 16, 1, 1, "Disable ARM JTAG debug" }, 178 { 17, 1, 0, "VGA class code : video_device" }, 179 { 17, 1, 1, "VGA class code : vga_device" }, 180 { 18, 1, 0, "Enable debug interfaces 0" }, 181 { 18, 1, 1, "Disable debug interfaces 0" }, 182 { 19, 1, 0, "Boot from eMMC speed mode : normal" }, 183 { 19, 1, 1, "Boot from eMMC speed mode : high" }, 184 { 20, 1, 0, "Disable Pcie EHCI device" }, 185 { 20, 1, 1, "Enable Pcie EHCI device" }, 186 { 21, 1, 0, "Enable ARM JTAG trust world debug" }, 187 { 21, 1, 1, "Disable ARM JTAG trust world debug" }, 188 { 22, 1, 0, "Normal BMC mode" }, 189 { 22, 1, 1, "Disable dedicated BMC functions for non-BMC application" }, 190 { 23, 1, 0, "SSPRST# pin is for secondary processor dedicated reset pin" }, 191 { 23, 1, 1, "SSPRST# pin is for PCIE root complex dedicated reset pin" }, 192 { 24, 1, 0, "Enable watchdog to reset full chip" }, 193 { 24, 1, 1, "Disable watchdog to reset full chip" }, 194 { 25, 2, 0, "Internal bridge speed selection : 1x" }, 195 { 25, 2, 1, "Internal bridge speed selection : 1/2x" }, 196 { 25, 2, 2, "Internal bridge speed selection : 1/4x" }, 197 { 25, 2, 3, "Internal bridge speed selection : 1/8x" }, 198 { 29, 1, 0, "Enable RVAS function" }, 199 { 29, 1, 1, "Disable RVAS function" }, 200 { 32, 1, 0, "MAC 3 : RMII/NCSI" }, 201 { 32, 1, 1, "MAC 3 : RGMII" }, 202 { 33, 1, 0, "MAC 4 : RMII/NCSI" }, 203 { 33, 1, 1, "MAC 4 : RGMII" }, 204 { 34, 1, 0, "SuperIO configuration address : 0x2e" }, 205 { 34, 1, 1, "SuperIO configuration address : 0x4e" }, 206 { 35, 1, 0, "Enable LPC to decode SuperIO" }, 207 { 35, 1, 1, "Disable LPC to decode SuperIO" }, 208 { 36, 1, 0, "Enable debug interfaces 1" }, 209 { 36, 1, 1, "Disable debug interfaces 1" }, 210 { 37, 1, 0, "Disable ACPI function" }, 211 { 37, 1, 1, "Enable ACPI function" }, 212 { 38, 1, 0, "Select LPC/eSPI : eSPI" }, 213 { 38, 1, 1, "Select LPC/eSPI : LPC" }, 214 { 39, 1, 0, "Disable SAFS mode" }, 215 { 39, 1, 1, "Enable SAFS mode" }, 216 { 40, 1, 0, "Disable boot from uart5" }, 217 { 40, 1, 1, "Enable boot from uart5" }, 218 { 41, 1, 0, "Disable boot SPI 3B address mode auto-clear" }, 219 { 41, 1, 1, "Enable boot SPI 3B address mode auto-clear" }, 220 { 42, 1, 0, "Disable boot SPI 3B/4B address mode auto detection" }, 221 { 42, 1, 1, "Enable boot SPI 3B/4B address mode auto detection" }, 222 { 43, 1, 0, "Disable boot SPI or eMMC ABR" }, 223 { 43, 1, 1, "Enable boot SPI or eMMC ABR" }, 224 { 44, 1, 0, "Boot SPI ABR Mode : dual" }, 225 { 44, 1, 1, "Boot SPI ABR Mode : single" }, 226 { 45, 3, 0, "Boot SPI flash size : 0MB" }, 227 { 45, 3, 1, "Boot SPI flash size : 2MB" }, 228 { 45, 3, 2, "Boot SPI flash size : 4MB" }, 229 { 45, 3, 3, "Boot SPI flash size : 8MB" }, 230 { 45, 3, 4, "Boot SPI flash size : 16MB" }, 231 { 45, 3, 5, "Boot SPI flash size : 32MB" }, 232 { 45, 3, 6, "Boot SPI flash size : 64MB" }, 233 { 45, 3, 7, "Boot SPI flash size : 128MB" }, 234 { 48, 1, 0, "Disable host SPI ABR" }, 235 { 48, 1, 1, "Enable host SPI ABR" }, 236 { 49, 1, 0, "Disable host SPI ABR mode select pin" }, 237 { 49, 1, 1, "Enable host SPI ABR mode select pin" }, 238 { 50, 1, 0, "Host SPI ABR mode : dual" }, 239 { 50, 1, 1, "Host SPI ABR mode : single" }, 240 { 51, 3, 0, "Host SPI flash size : 0MB" }, 241 { 51, 3, 1, "Host SPI flash size : 2MB" }, 242 { 51, 3, 2, "Host SPI flash size : 4MB" }, 243 { 51, 3, 3, "Host SPI flash size : 8MB" }, 244 { 51, 3, 4, "Host SPI flash size : 16MB" }, 245 { 51, 3, 5, "Host SPI flash size : 32MB" }, 246 { 51, 3, 6, "Host SPI flash size : 64MB" }, 247 { 51, 3, 7, "Host SPI flash size : 128MB" }, 248 { 54, 1, 0, "Disable boot SPI auxiliary control pins" }, 249 { 54, 1, 1, "Enable boot SPI auxiliary control pins" }, 250 { 55, 2, 0, "Boot SPI CRTM size : 0KB" }, 251 { 55, 2, 1, "Boot SPI CRTM size : 256KB" }, 252 { 55, 2, 2, "Boot SPI CRTM size : 512KB" }, 253 { 55, 2, 3, "Boot SPI CRTM size : 1024KB" }, 254 { 57, 2, 0, "Host SPI CRTM size : 0KB" }, 255 { 57, 2, 1, "Host SPI CRTM size : 1024KB" }, 256 { 57, 2, 2, "Host SPI CRTM size : 2048KB" }, 257 { 57, 2, 3, "Host SPI CRTM size : 4096KB" }, 258 { 59, 1, 0, "Disable host SPI auxiliary control pins" }, 259 { 59, 1, 1, "Enable host SPI auxiliary control pins" }, 260 { 60, 1, 0, "Disable GPIO pass through" }, 261 { 60, 1, 1, "Enable GPIO pass through" }, 262 { 62, 1, 0, "Disable dedicate GPIO strap pins" }, 263 { 62, 1, 1, "Enable dedicate GPIO strap pins" } 264 }; 265 266 static const struct otpstrap_info a2_strap_info[] = { 267 { 0, 1, 0, "Disable Secure Boot" }, 268 { 0, 1, 1, "Enable Secure Boot" }, 269 { 1, 1, 0, "Disable boot from eMMC" }, 270 { 1, 1, 1, "Enable boot from eMMC" }, 271 { 2, 1, 0, "Disable Boot from debug SPI" }, 272 { 2, 1, 1, "Enable Boot from debug SPI" }, 273 { 3, 1, 0, "Enable ARM CM3" }, 274 { 3, 1, 1, "Disable ARM CM3" }, 275 { 4, 1, 0, "No VGA BIOS ROM, VGA BIOS is merged in the system BIOS" }, 276 { 4, 1, 1, "Enable dedicated VGA BIOS ROM" }, 277 { 5, 1, 0, "MAC 1 : RMII/NCSI" }, 278 { 5, 1, 1, "MAC 1 : RGMII" }, 279 { 6, 1, 0, "MAC 2 : RMII/NCSI" }, 280 { 6, 1, 1, "MAC 2 : RGMII" }, 281 { 7, 3, 0, "CPU Frequency : 1.2GHz" }, 282 { 7, 3, 1, "CPU Frequency : 1.6MHz" }, 283 { 7, 3, 2, "CPU Frequency : 1.2GHz" }, 284 { 7, 3, 3, "CPU Frequency : 1.6GHz" }, 285 { 7, 3, 4, "CPU Frequency : 800MHz" }, 286 { 7, 3, 5, "CPU Frequency : 800MHz" }, 287 { 7, 3, 6, "CPU Frequency : 800MHz" }, 288 { 7, 3, 7, "CPU Frequency : 800MHz" }, 289 { 10, 2, 1, "HCLK ratio AXI:AHB = 2:1" }, 290 { 10, 2, 2, "HCLK ratio AXI:AHB = 3:1" }, 291 { 10, 2, 3, "HCLK ratio AXI:AHB = 4:1" }, 292 { 12, 2, 0, "VGA memory size : 8MB" }, 293 { 12, 2, 1, "VGA memory size : 16MB" }, 294 { 12, 2, 2, "VGA memory size : 32MB" }, 295 { 12, 2, 3, "VGA memory size : 64MB" }, 296 { 15, 1, 0, "CPU/AXI clock ratio : 2:1" }, 297 { 15, 1, 1, "CPU/AXI clock ratio : 1:1" }, 298 { 16, 1, 0, "Enable ARM JTAG debug" }, 299 { 16, 1, 1, "Disable ARM JTAG debug" }, 300 { 17, 1, 0, "VGA class code : video_device" }, 301 { 17, 1, 1, "VGA class code : vga_device" }, 302 { 18, 1, 0, "Enable debug interfaces 0" }, 303 { 18, 1, 1, "Disable debug interfaces 0" }, 304 { 19, 1, 0, "Boot from eMMC speed mode : normal" }, 305 { 19, 1, 1, "Boot from eMMC speed mode : high" }, 306 { 20, 1, 0, "Disable Pcie EHCI device" }, 307 { 20, 1, 1, "Enable Pcie EHCI device" }, 308 { 21, 1, 0, "Enable ARM JTAG trust world debug" }, 309 { 21, 1, 1, "Disable ARM JTAG trust world debug" }, 310 { 22, 1, 0, "Normal BMC mode" }, 311 { 22, 1, 1, "Disable dedicated BMC functions for non-BMC application" }, 312 { 23, 1, 0, "SSPRST# pin is for secondary processor dedicated reset pin" }, 313 { 23, 1, 1, "SSPRST# pin is for PCIE root complex dedicated reset pin" }, 314 { 24, 1, 0, "Enable watchdog to reset full chip" }, 315 { 24, 1, 1, "Disable watchdog to reset full chip" }, 316 { 25, 2, 0, "Internal bridge speed selection : 1x" }, 317 { 25, 2, 1, "Internal bridge speed selection : 1/2x" }, 318 { 25, 2, 2, "Internal bridge speed selection : 1/4x" }, 319 { 25, 2, 3, "Internal bridge speed selection : 1/8x" }, 320 { 29, 1, 0, "Enable RVAS function" }, 321 { 29, 1, 1, "Disable RVAS function" }, 322 { 32, 1, 0, "MAC 3 : RMII/NCSI" }, 323 { 32, 1, 1, "MAC 3 : RGMII" }, 324 { 33, 1, 0, "MAC 4 : RMII/NCSI" }, 325 { 33, 1, 1, "MAC 4 : RGMII" }, 326 { 34, 1, 0, "SuperIO configuration address : 0x2e" }, 327 { 34, 1, 1, "SuperIO configuration address : 0x4e" }, 328 { 35, 1, 0, "Enable LPC to decode SuperIO" }, 329 { 35, 1, 1, "Disable LPC to decode SuperIO" }, 330 { 36, 1, 0, "Enable debug interfaces 1" }, 331 { 36, 1, 1, "Disable debug interfaces 1" }, 332 { 37, 1, 0, "Disable ACPI function" }, 333 { 37, 1, 1, "Enable ACPI function" }, 334 { 38, 1, 0, "Select LPC/eSPI : eSPI" }, 335 { 38, 1, 1, "Select LPC/eSPI : LPC" }, 336 { 39, 1, 0, "Disable SAFS mode" }, 337 { 39, 1, 1, "Enable SAFS mode" }, 338 { 40, 1, 0, "Disable boot from uart5" }, 339 { 40, 1, 1, "Enable boot from uart5" }, 340 { 41, 1, 0, "Disable boot SPI 3B address mode auto-clear" }, 341 { 41, 1, 1, "Enable boot SPI 3B address mode auto-clear" }, 342 { 42, 1, 0, "Disable boot SPI 3B/4B address mode auto detection" }, 343 { 42, 1, 1, "Enable boot SPI 3B/4B address mode auto detection" }, 344 { 43, 1, 0, "Disable boot SPI or eMMC ABR" }, 345 { 43, 1, 1, "Enable boot SPI or eMMC ABR" }, 346 { 44, 1, 0, "Boot SPI ABR Mode : dual" }, 347 { 44, 1, 1, "Boot SPI ABR Mode : single" }, 348 { 45, 3, 0, "Boot SPI flash size : 0MB" }, 349 { 45, 3, 1, "Boot SPI flash size : 2MB" }, 350 { 45, 3, 2, "Boot SPI flash size : 4MB" }, 351 { 45, 3, 3, "Boot SPI flash size : 8MB" }, 352 { 45, 3, 4, "Boot SPI flash size : 16MB" }, 353 { 45, 3, 5, "Boot SPI flash size : 32MB" }, 354 { 45, 3, 6, "Boot SPI flash size : 64MB" }, 355 { 45, 3, 7, "Boot SPI flash size : 128MB" }, 356 { 48, 1, 0, "Disable host SPI ABR" }, 357 { 48, 1, 1, "Enable host SPI ABR" }, 358 { 49, 1, 0, "Disable host SPI ABR mode select pin" }, 359 { 49, 1, 1, "Enable host SPI ABR mode select pin" }, 360 { 50, 1, 0, "Host SPI ABR mode : dual" }, 361 { 50, 1, 1, "Host SPI ABR mode : single" }, 362 { 51, 3, 0, "Host SPI flash size : 0MB" }, 363 { 51, 3, 1, "Host SPI flash size : 2MB" }, 364 { 51, 3, 2, "Host SPI flash size : 4MB" }, 365 { 51, 3, 3, "Host SPI flash size : 8MB" }, 366 { 51, 3, 4, "Host SPI flash size : 16MB" }, 367 { 51, 3, 5, "Host SPI flash size : 32MB" }, 368 { 51, 3, 6, "Host SPI flash size : 64MB" }, 369 { 51, 3, 7, "Host SPI flash size : 128MB" }, 370 { 54, 1, 0, "Disable boot SPI auxiliary control pins" }, 371 { 54, 1, 1, "Enable boot SPI auxiliary control pins" }, 372 { 55, 2, 0, "Boot SPI CRTM size : 0KB" }, 373 { 55, 2, 1, "Boot SPI CRTM size : 256KB" }, 374 { 55, 2, 2, "Boot SPI CRTM size : 512KB" }, 375 { 55, 2, 3, "Boot SPI CRTM size : 1024KB" }, 376 { 57, 2, 0, "Host SPI CRTM size : 0KB" }, 377 { 57, 2, 1, "Host SPI CRTM size : 1024KB" }, 378 { 57, 2, 2, "Host SPI CRTM size : 2048KB" }, 379 { 57, 2, 3, "Host SPI CRTM size : 4096KB" }, 380 { 59, 1, 0, "Disable host SPI auxiliary control pins" }, 381 { 59, 1, 1, "Enable host SPI auxiliary control pins" }, 382 { 60, 1, 0, "Disable GPIO pass through" }, 383 { 60, 1, 1, "Enable GPIO pass through" }, 384 { 62, 1, 0, "Disable dedicate GPIO strap pins" }, 385 { 62, 1, 1, "Enable dedicate GPIO strap pins" } 386 }; 387 388 static const struct otpconf_info a0_conf_info[] = { 389 { 0, 1, 1, 0, "Disable Secure Boot" }, 390 { 0, 1, 1, 1, "Enable Secure Boot" }, 391 { 0, 3, 1, 0, "User region ECC disable" }, 392 { 0, 3, 1, 1, "User region ECC enable" }, 393 { 0, 4, 1, 0, "Secure Region ECC disable" }, 394 { 0, 4, 1, 1, "Secure Region ECC enable" }, 395 { 0, 5, 1, 0, "Enable low security key" }, 396 { 0, 5, 1, 1, "Disable low security key" }, 397 { 0, 6, 1, 0, "Do not ignore Secure Boot hardware strap" }, 398 { 0, 6, 1, 1, "Ignore Secure Boot hardware strap" }, 399 { 0, 7, 1, 0, "Secure Boot Mode: Mode_GCM" }, 400 { 0, 7, 1, 1, "Secure Boot Mode: Mode_2" }, 401 { 0, 10, 2, 0, "RSA mode : RSA1024" }, 402 { 0, 10, 2, 1, "RSA mode : RSA2048" }, 403 { 0, 10, 2, 2, "RSA mode : RSA3072" }, 404 { 0, 10, 2, 3, "RSA mode : RSA4096" }, 405 { 0, 12, 2, 0, "SHA mode : SHA224" }, 406 { 0, 12, 2, 1, "SHA mode : SHA256" }, 407 { 0, 12, 2, 2, "SHA mode : SHA384" }, 408 { 0, 12, 2, 3, "SHA mode : SHA512" }, 409 { 0, 14, 1, 0, "Disable patch code" }, 410 { 0, 14, 1, 1, "Enable patch code" }, 411 { 0, 15, 1, 0, "Enable Boot from Uart" }, 412 { 0, 15, 1, 1, "Disable Boot from Uart" }, 413 { 0, 16, 6, OTP_REG_VALUE, "Secure Region size (DW): 0x%x" }, 414 { 0, 22, 1, 0, "Secure Region : Writable" }, 415 { 0, 22, 1, 1, "Secure Region : Write Protect" }, 416 { 0, 23, 1, 0, "User Region : Writable" }, 417 { 0, 23, 1, 1, "User Region : Write Protect" }, 418 { 0, 24, 1, 0, "Configure Region : Writable" }, 419 { 0, 24, 1, 1, "Configure Region : Write Protect" }, 420 { 0, 25, 1, 0, "OTP strap Region : Writable" }, 421 { 0, 25, 1, 1, "OTP strap Region : Write Protect" }, 422 { 0, 26, 1, 0, "Disable Copy Boot Image to Internal SRAM" }, 423 { 0, 26, 1, 1, "Copy Boot Image to Internal SRAM" }, 424 { 0, 27, 1, 0, "Disable image encryption" }, 425 { 0, 27, 1, 1, "Enable image encryption" }, 426 { 0, 29, 1, 0, "OTP key retire Region : Writable" }, 427 { 0, 29, 1, 1, "OTP key retire Region : Write Protect" }, 428 { 0, 31, 1, 0, "OTP memory lock disable" }, 429 { 0, 31, 1, 1, "OTP memory lock enable" }, 430 { 2, 0, 16, OTP_REG_VALUE, "Vender ID : 0x%x" }, 431 { 2, 16, 16, OTP_REG_VALUE, "Key Revision : 0x%x" }, 432 { 3, 0, 16, OTP_REG_VALUE, "Secure boot header offset : 0x%x" }, 433 { 4, 0, 8, OTP_REG_VALID_BIT, "Keys retire : %s" }, 434 { 5, 0, 32, OTP_REG_VALUE, "User define data, random number low : 0x%x" }, 435 { 6, 0, 32, OTP_REG_VALUE, "User define data, random number high : 0x%x" }, 436 { 10, 0, 64, OTP_REG_VALUE, "Manifest ID : 0x%x" }, 437 { 14, 0, 11, OTP_REG_VALUE, "Patch code location (DW): 0x%x" }, 438 { 14, 11, 6, OTP_REG_VALUE, "Patch code size (DW): 0x%x" } 439 }; 440 441 static const struct otpconf_info a1_conf_info[] = { 442 { 0, 1, 1, 0, "Disable Secure Boot" }, 443 { 0, 1, 1, 1, "Enable Secure Boot" }, 444 { 0, 3, 1, 0, "User region ECC disable" }, 445 { 0, 3, 1, 1, "User region ECC enable" }, 446 { 0, 4, 1, 0, "Secure Region ECC disable" }, 447 { 0, 4, 1, 1, "Secure Region ECC enable" }, 448 { 0, 5, 1, 0, "Enable low security key" }, 449 { 0, 5, 1, 1, "Disable low security key" }, 450 { 0, 6, 1, 0, "Do not ignore Secure Boot hardware strap" }, 451 { 0, 6, 1, 1, "Ignore Secure Boot hardware strap" }, 452 { 0, 7, 1, 0, "Secure Boot Mode: Mode_GCM" }, 453 { 0, 7, 1, 1, "Secure Boot Mode: Mode_2" }, 454 { 0, 10, 2, 0, "RSA mode : RSA1024" }, 455 { 0, 10, 2, 1, "RSA mode : RSA2048" }, 456 { 0, 10, 2, 2, "RSA mode : RSA3072" }, 457 { 0, 10, 2, 3, "RSA mode : RSA4096" }, 458 { 0, 12, 2, 0, "SHA mode : SHA224" }, 459 { 0, 12, 2, 1, "SHA mode : SHA256" }, 460 { 0, 12, 2, 2, "SHA mode : SHA384" }, 461 { 0, 12, 2, 3, "SHA mode : SHA512" }, 462 { 0, 14, 1, 0, "Disable patch code" }, 463 { 0, 14, 1, 1, "Enable patch code" }, 464 { 0, 15, 1, 0, "Enable Boot from Uart" }, 465 { 0, 15, 1, 1, "Disable Boot from Uart" }, 466 { 0, 16, 6, OTP_REG_VALUE, "Secure Region size (DW): 0x%x" }, 467 { 0, 22, 1, 0, "Secure Region : Writable" }, 468 { 0, 22, 1, 1, "Secure Region : Write Protect" }, 469 { 0, 23, 1, 0, "User Region : Writable" }, 470 { 0, 23, 1, 1, "User Region : Write Protect" }, 471 { 0, 24, 1, 0, "Configure Region : Writable" }, 472 { 0, 24, 1, 1, "Configure Region : Write Protect" }, 473 { 0, 25, 1, 0, "OTP strap Region : Writable" }, 474 { 0, 25, 1, 1, "OTP strap Region : Write Protect" }, 475 { 0, 26, 1, 0, "Disable Copy Boot Image to Internal SRAM" }, 476 { 0, 26, 1, 1, "Copy Boot Image to Internal SRAM" }, 477 { 0, 27, 1, 0, "Disable image encryption" }, 478 { 0, 27, 1, 1, "Enable image encryption" }, 479 { 0, 29, 1, 0, "OTP key retire Region : Writable" }, 480 { 0, 29, 1, 1, "OTP key retire Region : Write Protect" }, 481 { 0, 31, 1, 0, "OTP memory lock disable" }, 482 { 0, 31, 1, 1, "OTP memory lock enable" }, 483 { 2, 0, 16, OTP_REG_VALUE, "Vender ID : 0x%x" }, 484 { 2, 16, 16, OTP_REG_VALUE, "Key Revision : 0x%x" }, 485 { 3, 0, 16, OTP_REG_VALUE, "Secure boot header offset : 0x%x" }, 486 { 4, 0, 8, OTP_REG_VALID_BIT, "Keys retire : %s" }, 487 { 5, 0, 32, OTP_REG_VALUE, "User define data, random number low : 0x%x" }, 488 { 6, 0, 32, OTP_REG_VALUE, "User define data, random number high : 0x%x" }, 489 { 10, 0, 64, OTP_REG_VALUE, "Manifest ID : 0x%x" }, 490 { 14, 0, 11, OTP_REG_VALUE, "Patch code location (DW): 0x%x" }, 491 { 14, 11, 6, OTP_REG_VALUE, "Patch code size (DW): 0x%x" } 492 }; 493 494 static const struct otpconf_info a2_conf_info[] = { 495 { 0, 1, 1, 0, "Enable OTP Memory BIST Mode" }, 496 { 0, 1, 1, 1, "Disable OTP Memory BIST Mode" }, 497 { 0, 1, 1, 0, "Disable Secure Boot" }, 498 { 0, 1, 1, 1, "Enable Secure Boot" }, 499 { 0, 3, 1, 0, "User region ECC disable" }, 500 { 0, 3, 1, 1, "User region ECC enable" }, 501 { 0, 4, 1, 0, "Secure Region ECC disable" }, 502 { 0, 4, 1, 1, "Secure Region ECC enable" }, 503 { 0, 5, 1, 0, "Enable low security key" }, 504 { 0, 5, 1, 1, "Disable low security key" }, 505 { 0, 6, 1, 0, "Do not ignore Secure Boot hardware strap" }, 506 { 0, 6, 1, 1, "Ignore Secure Boot hardware strap" }, 507 { 0, 7, 1, 0, "Secure Boot Mode: Mode_GCM" }, 508 { 0, 7, 1, 1, "Secure Boot Mode: Mode_2" }, 509 { 0, 9, 1, 0, "ROM code will dump boot messages" }, 510 { 0, 9, 1, 1, "ROM code message is disabled" }, 511 { 0, 10, 2, 0, "RSA mode : RSA1024" }, 512 { 0, 10, 2, 1, "RSA mode : RSA2048" }, 513 { 0, 10, 2, 2, "RSA mode : RSA3072" }, 514 { 0, 10, 2, 3, "RSA mode : RSA4096" }, 515 { 0, 12, 2, 0, "SHA mode : SHA224" }, 516 { 0, 12, 2, 1, "SHA mode : SHA256" }, 517 { 0, 12, 2, 2, "SHA mode : SHA384" }, 518 { 0, 12, 2, 3, "SHA mode : SHA512" }, 519 { 0, 14, 1, 0, "Disable patch code" }, 520 { 0, 14, 1, 1, "Enable patch code" }, 521 { 0, 15, 1, 0, "Enable Boot from Uart" }, 522 { 0, 15, 1, 1, "Disable Boot from Uart" }, 523 { 0, 16, 6, OTP_REG_VALUE, "Secure Region size (DW): 0x%x" }, 524 { 0, 22, 1, 0, "Secure Region : Writable" }, 525 { 0, 22, 1, 1, "Secure Region : Write Protect" }, 526 { 0, 23, 1, 0, "User Region : Writable" }, 527 { 0, 23, 1, 1, "User Region : Write Protect" }, 528 { 0, 24, 1, 0, "Configure Region : Writable" }, 529 { 0, 24, 1, 1, "Configure Region : Write Protect" }, 530 { 0, 25, 1, 0, "OTP strap Region : Writable" }, 531 { 0, 25, 1, 1, "OTP strap Region : Write Protect" }, 532 { 0, 26, 1, 0, "Disable Copy Boot Image to Internal SRAM" }, 533 { 0, 26, 1, 1, "Copy Boot Image to Internal SRAM" }, 534 { 0, 27, 1, 0, "Disable image encryption" }, 535 { 0, 27, 1, 1, "Enable image encryption" }, 536 { 0, 29, 1, 0, "OTP key retire Region : Writable" }, 537 { 0, 29, 1, 1, "OTP key retire Region : Write Protect" }, 538 { 0, 30, 1, 0, "Boot from UART/VUART when normal boot is fail" }, 539 { 0, 30, 1, 1, "Disable auto UART/VUART boot option" }, 540 { 0, 31, 1, 0, "OTP memory lock disable" }, 541 { 0, 31, 1, 1, "OTP memory lock enable" }, 542 { 2, 0, 16, OTP_REG_VALUE, "Vender ID : 0x%x" }, 543 { 2, 16, 16, OTP_REG_VALUE, "Key Revision : 0x%x" }, 544 { 3, 0, 16, OTP_REG_VALUE, "Secure boot header offset : 0x%x" }, 545 { 3, 16, 1, 0, "Boot from UART using: UART5" }, 546 { 3, 16, 1, 1, "Boot from UART using: UART1" }, 547 { 3, 17, 1, 0, "Enable Auto Boot from UART or VUART" }, 548 { 3, 17, 1, 1, "Disable Auto Boot from UART or VUART" }, 549 { 3, 18, 1, 0, "Enable Auto Boot from VUART2 over PCIE" }, 550 { 3, 18, 1, 1, "Disable Auto Boot from VUART2 over PCIE" }, 551 { 3, 19, 1, 0, "Enable Auto Boot from VUART2 over LPC" }, 552 { 3, 19, 1, 1, "Disable Auto Boot from VUART2 over LPC" }, 553 { 3, 20, 1, 0, "Enable ROM code based programming control" }, 554 { 3, 20, 1, 1, "Disable ROM code based programming control" }, 555 { 3, 21, 3, OTP_REG_VALUE, "Rollback prevention shift bit : 0x%x" }, 556 { 3, 24, 6, OTP_REG_VALUE, "Extra Data Write Protection Region size (DW): 0x%x" }, 557 { 3, 30, 1, 0, "Do not erase signature data after secure boot check" }, 558 { 3, 30, 1, 1, "Erase signature data after secure boot check" }, 559 { 3, 31, 1, 0, "Do not erase RSA public key after secure boot check" }, 560 { 3, 31, 1, 1, "Erase RSA public key after secure boot check" }, 561 { 4, 0, 8, OTP_REG_VALID_BIT, "Keys retire : %s" }, 562 { 5, 0, 32, OTP_REG_VALUE, "User define data, random number low : 0x%x" }, 563 { 6, 0, 32, OTP_REG_VALUE, "User define data, random number high : 0x%x" }, 564 { 10, 0, 64, OTP_REG_VALUE, "Manifest ID : 0x%x" }, 565 { 14, 0, 11, OTP_REG_VALUE, "Patch code location (DW): 0x%x" }, 566 { 14, 11, 6, OTP_REG_VALUE, "Patch code size (DW): 0x%x" } 567 }; 568 569