mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-26 09:38:14 +00:00 
			
		
		
		
	This reverts commit 1fdf53ace13f745fe8ad4d2d4e79eed98088d555, reversing changes made to e5aef1bbf11412eebd4c242b46adff5301353c30. I had missed that this caused too much size growth on rcar3_salvator-x. Signed-off-by: Tom Rini <trini@konsulko.com>
		
			
				
	
	
		
			1179 lines
		
	
	
		
			37 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			1179 lines
		
	
	
		
			37 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| menu "Library routines"
 | |
| 
 | |
| config ADDR_MAP
 | |
| 	bool "Enable support for non-identity virtual-physical mappings"
 | |
| 	help
 | |
| 	  Enables helper code for implementing non-identity virtual-physical
 | |
| 	  memory mappings for 32bit CPUs.
 | |
| 
 | |
| 	  This library only works in the post-relocation phase.
 | |
| 
 | |
| config SYS_NUM_ADDR_MAP
 | |
| 	int "Size of the address-map table"
 | |
| 	depends on ADDR_MAP
 | |
| 	default 16
 | |
| 	help
 | |
| 	  Sets the number of entries in the virtual-physical mapping table.
 | |
| 
 | |
| config SYS_TIMER_COUNTS_DOWN
 | |
| 	bool "System timer counts down rather than up"
 | |
| 
 | |
| config PHYSMEM
 | |
| 	bool "Access to physical memory region (> 4G)"
 | |
| 	help
 | |
| 	  Some basic support is provided for operations on memory not
 | |
| 	  normally accessible to 32-bit U-Boot - e.g. some architectures
 | |
| 	  support access to more than 4G of memory on 32-bit
 | |
| 	  machines using physical address extension or similar.
 | |
| 	  Enable this to access this basic support, which only supports clearing
 | |
| 	  the memory.
 | |
| 
 | |
| config BCH
 | |
| 	bool "Enable Software based BCH ECC"
 | |
| 	help
 | |
| 	  Enables software based BCH ECC algorithm present in lib/bch.c
 | |
| 	  This is used by SoC platforms which do not have built-in ELM
 | |
| 	  hardware engine required for BCH ECC correction.
 | |
| 
 | |
| config BINMAN_FDT
 | |
| 	bool "Allow access to binman information in the device tree"
 | |
| 	depends on BINMAN && DM && OF_CONTROL
 | |
| 	default y if OF_SEPARATE || OF_EMBED
 | |
| 	help
 | |
| 	  This enables U-Boot to access information about binman entries,
 | |
| 	  stored in the device tree in a binman node. Typical uses are to
 | |
| 	  locate entries in the firmware image. See binman.h for the available
 | |
| 	  functionality.
 | |
| 
 | |
| config BINMAN_DTB
 | |
| 	string "binman DTB description"
 | |
| 	depends on BINMAN
 | |
| 	help
 | |
| 	  This enables option to point to different DTB file with binman node which
 | |
| 	  is outside of DTB used by the firmware. Use this option if information
 | |
| 	  about generated images shouldn't be the part of target binary. Or on system
 | |
| 	  with limited storage.
 | |
| 
 | |
| config CC_OPTIMIZE_LIBS_FOR_SPEED
 | |
| 	bool "Optimize libraries for speed"
 | |
| 	help
 | |
| 	  Enabling this option will pass "-O2" to gcc when compiling
 | |
| 	  under "lib" directory.
 | |
| 
 | |
| 	  If unsure, say N.
 | |
| 
 | |
| config CHARSET
 | |
| 	bool
 | |
| 
 | |
| config DYNAMIC_CRC_TABLE
 | |
| 	bool "Enable Dynamic tables for CRC"
 | |
| 	help
 | |
| 	  Enable this option to calculate entries for CRC tables at runtime.
 | |
| 	  This can be helpful when reducing the size of the build image
 | |
| 
 | |
| config HAVE_ARCH_IOMAP
 | |
| 	bool
 | |
| 	help
 | |
| 	  Enable this option if architecture provides io{read,write}{8,16,32}
 | |
| 	  I/O accessor functions.
 | |
| 
 | |
| config HAVE_PRIVATE_LIBGCC
 | |
| 	bool
 | |
| 
 | |
| config LIB_UUID
 | |
| 	bool
 | |
| 	select SHA1
 | |
| 
 | |
| config RANDOM_UUID
 | |
| 	bool "GPT Random UUID generation"
 | |
| 	select LIB_UUID
 | |
| 	help
 | |
| 	  Enable the generation of partitions with random UUIDs if none
 | |
| 	  are provided.
 | |
| 
 | |
| config SPL_LIB_UUID
 | |
| 	depends on SPL
 | |
| 	bool
 | |
| 
 | |
| config SEMIHOSTING
 | |
| 	bool "Support semihosting"
 | |
| 	depends on ARM || RISCV
 | |
| 	help
 | |
| 	  Semihosting is a method for a target to communicate with a host
 | |
| 	  debugger. It uses special instructions which the debugger will trap
 | |
| 	  on and interpret. This allows U-Boot to read/write files, print to
 | |
| 	  the console, and execute arbitrary commands on the host system.
 | |
| 
 | |
| 	  Enabling this option will add support for reading and writing files
 | |
| 	  on the host system. If you don't have a debugger attached then trying
 | |
| 	  to do this will likely cause U-Boot to hang. Say 'n' if you are unsure.
 | |
| 
 | |
| config SEMIHOSTING_FALLBACK
 | |
| 	bool "Recover gracefully when semihosting fails"
 | |
| 	depends on SEMIHOSTING
 | |
| 	default y
 | |
| 	help
 | |
| 	  Normally, if U-Boot makes a semihosting call and no debugger is
 | |
| 	  attached, then it will panic due to a synchronous abort
 | |
| 	  exception. This config adds an exception handler which will allow
 | |
| 	  U-Boot to recover. Say 'y' if unsure.
 | |
| 
 | |
| config SPL_SEMIHOSTING
 | |
| 	bool "Support semihosting in SPL"
 | |
| 	depends on SPL && (ARM || RISCV)
 | |
| 	help
 | |
| 	  Semihosting is a method for a target to communicate with a host
 | |
| 	  debugger. It uses special instructions which the debugger will trap
 | |
| 	  on and interpret. This allows U-Boot to read/write files, print to
 | |
| 	  the console, and execute arbitrary commands on the host system.
 | |
| 
 | |
| 	  Enabling this option will add support for reading and writing files
 | |
| 	  on the host system. If you don't have a debugger attached then trying
 | |
| 	  to do this will likely cause U-Boot to hang. Say 'n' if you are unsure.
 | |
| 
 | |
| config SPL_SEMIHOSTING_FALLBACK
 | |
| 	bool "Recover gracefully when semihosting fails in SPL"
 | |
| 	depends on SPL_SEMIHOSTING
 | |
| 	select ARMV8_SPL_EXCEPTION_VECTORS if ARM64
 | |
| 	default y
 | |
| 	help
 | |
| 	  Normally, if U-Boot makes a semihosting call and no debugger is
 | |
| 	  attached, then it will panic due to a synchronous abort
 | |
| 	  exception. This config adds an exception handler which will allow
 | |
| 	  U-Boot to recover. Say 'y' if unsure.
 | |
| 
 | |
| config PRINTF
 | |
| 	bool
 | |
| 	default y
 | |
| 
 | |
| config SPL_PRINTF
 | |
| 	bool
 | |
| 	select SPL_SPRINTF
 | |
| 	select SPL_STRTO if !SPL_USE_TINY_PRINTF
 | |
| 
 | |
| config TPL_PRINTF
 | |
| 	bool
 | |
| 	select TPL_SPRINTF
 | |
| 	select TPL_STRTO if !TPL_USE_TINY_PRINTF
 | |
| 
 | |
| config VPL_PRINTF
 | |
| 	bool
 | |
| 	select VPL_SPRINTF
 | |
| 	select VPL_STRTO if !VPL_USE_TINY_PRINTF
 | |
| 
 | |
| config SPRINTF
 | |
| 	bool
 | |
| 	default y
 | |
| 
 | |
| config SPL_SPRINTF
 | |
| 	bool
 | |
| 
 | |
| config TPL_SPRINTF
 | |
| 	bool
 | |
| 
 | |
| config VPL_SPRINTF
 | |
| 	bool
 | |
| 
 | |
| config SSCANF
 | |
| 	bool
 | |
| 
 | |
| config STRTO
 | |
| 	bool
 | |
| 	default y
 | |
| 
 | |
| config SPL_STRTO
 | |
| 	bool
 | |
| 
 | |
| config TPL_STRTO
 | |
| 	bool
 | |
| 
 | |
| config VPL_STRTO
 | |
| 	bool
 | |
| 
 | |
| config IMAGE_SPARSE
 | |
| 	bool
 | |
| 
 | |
| config IMAGE_SPARSE_FILLBUF_SIZE
 | |
| 	hex "Android sparse image CHUNK_TYPE_FILL buffer size"
 | |
| 	default 0x80000
 | |
| 	depends on IMAGE_SPARSE
 | |
| 	help
 | |
| 	  Set the size of the fill buffer used when processing CHUNK_TYPE_FILL
 | |
| 	  chunks.
 | |
| 
 | |
| config USE_PRIVATE_LIBGCC
 | |
| 	bool "Use private libgcc"
 | |
| 	depends on HAVE_PRIVATE_LIBGCC
 | |
| 	default y if HAVE_PRIVATE_LIBGCC && ((ARM && !ARM64) || MIPS)
 | |
| 	help
 | |
| 	  This option allows you to use the built-in libgcc implementation
 | |
| 	  of U-Boot instead of the one provided by the compiler.
 | |
| 	  If unsure, say N.
 | |
| 
 | |
| config SYS_HZ
 | |
| 	int
 | |
| 	default 1000
 | |
| 	help
 | |
| 	  The frequency of the timer returned by get_timer().
 | |
| 	  get_timer() must operate in milliseconds and this option must be
 | |
| 	  set to 1000.
 | |
| 
 | |
| config SPL_USE_TINY_PRINTF
 | |
| 	bool "Enable tiny printf() version in SPL"
 | |
| 	depends on SPL
 | |
| 	default y
 | |
| 	help
 | |
| 	  This option enables a tiny, stripped down printf version.
 | |
| 	  This should only be used in space limited environments,
 | |
| 	  like SPL versions with hard memory limits. This version
 | |
| 	  reduces the code size by about 2.5KiB on armv7.
 | |
| 
 | |
| 	  The supported format specifiers are %c, %s, %u/%d and %x.
 | |
| 
 | |
| config TPL_USE_TINY_PRINTF
 | |
| 	bool "Enable tiny printf() version in TPL"
 | |
| 	depends on TPL
 | |
| 	default y if SPL_USE_TINY_PRINTF
 | |
| 	help
 | |
| 	  This option enables a tiny, stripped down printf version.
 | |
| 	  This should only be used in space limited environments,
 | |
| 	  like SPL versions with hard memory limits. This version
 | |
| 	  reduces the code size by about 2.5KiB on armv7.
 | |
| 
 | |
| 	  The supported format specifiers are %c, %s, %u/%d and %x.
 | |
| 
 | |
| config VPL_USE_TINY_PRINTF
 | |
| 	bool "Enable tiny printf() version for VPL"
 | |
| 	depends on VPL
 | |
| 	help
 | |
| 	  This option enables a tiny, stripped down printf version.
 | |
| 	  This should only be used in space limited environments,
 | |
| 	  like SPL versions with hard memory limits. This version
 | |
| 	  reduces the code size by about 2.5KiB on armv7.
 | |
| 
 | |
| 	  The supported format specifiers are %c, %s, %u/%d and %x.
 | |
| 
 | |
| config PANIC_HANG
 | |
| 	bool "Do not reset the system on fatal error"
 | |
| 	help
 | |
| 	  Define this option to stop the system in case of a fatal error,
 | |
| 	  so that you have to reset it manually. This is probably NOT a good
 | |
| 	  idea for an embedded system where you want the system to reboot
 | |
| 	  automatically as fast as possible, but it may be useful during
 | |
| 	  development since you can try to debug the conditions that lead to
 | |
| 	  the situation.
 | |
| 
 | |
| config REGEX
 | |
| 	bool "Enable regular expression support"
 | |
| 	default y if NET
 | |
| 	help
 | |
| 	  If this variable is defined, U-Boot is linked against the
 | |
| 	  SLRE (Super Light Regular Expression) library, which adds
 | |
| 	  regex support to some commands, for example "env grep" and
 | |
| 	  "setexpr".
 | |
| 
 | |
| choice
 | |
| 	prompt "Pseudo-random library support type"
 | |
| 	depends on NET_RANDOM_ETHADDR || RANDOM_UUID || CMD_UUID || \
 | |
| 		   RNG_SANDBOX || UT_LIB && AES || FAT_WRITE
 | |
| 	default LIB_RAND
 | |
| 	help
 | |
| 	  Select the library to provide pseudo-random number generator
 | |
| 	  functions.  LIB_HW_RAND supports certain hardware engines that
 | |
| 	  provide this functionality.  If in doubt, select LIB_RAND.
 | |
| 
 | |
| config LIB_RAND
 | |
| 	bool "Pseudo-random library support"
 | |
| 
 | |
| config LIB_HW_RAND
 | |
| 	bool "HW Engine for random library support"
 | |
| 
 | |
| endchoice
 | |
| 
 | |
| config SUPPORT_ACPI
 | |
| 	bool
 | |
| 	help
 | |
| 	  Enable this if your arch or board can support generating ACPI
 | |
| 	  (Advanced Configuration and Power Interface) tables. In this case
 | |
| 	  U-Boot can generate these tables and pass them to the Operating
 | |
| 	  System.
 | |
| 
 | |
| config ACPI
 | |
| 	bool "Enable support for ACPI libraries"
 | |
| 	depends on SUPPORT_ACPI
 | |
| 	help
 | |
| 	  Provides library functions for dealing with ACPI tables. This does
 | |
| 	  not necessarily include generation of tables
 | |
| 	  (see GENERATE_ACPI_TABLE), but allows for tables to be located.
 | |
| 
 | |
| config SPL_ACPI
 | |
| 	bool "Enable support for ACPI libraries in SPL"
 | |
| 	depends on SPL && SUPPORT_ACPI
 | |
| 	help
 | |
| 	  Provides library functions for dealing with ACPI tables in SPL. This
 | |
| 	  does not necessarily include generation of tables
 | |
| 	  (see GENERATE_ACPI_TABLE), but allows for tables to be located.
 | |
| 
 | |
| config GENERATE_ACPI_TABLE
 | |
| 	bool "Generate an ACPI (Advanced Configuration and Power Interface) table"
 | |
| 	depends on ACPI
 | |
| 	select QFW if QEMU
 | |
| 	help
 | |
| 	  The Advanced Configuration and Power Interface (ACPI) specification
 | |
| 	  provides an open standard for device configuration and management
 | |
| 	  by the operating system. It defines platform-independent interfaces
 | |
| 	  for configuration and power management monitoring.
 | |
| 
 | |
| config ACPI_PARKING_PROTOCOL
 | |
| 	bool "Support ACPI parking protocol method"
 | |
| 	depends on GENERATE_ACPI_TABLE
 | |
| 	depends on ARMV8_MULTIENTRY
 | |
| 	depends on BLOBLIST_TABLES
 | |
| 	default y if !SEC_FIRMWARE_ARMV8_PSCI && !ARMV8_PSCI
 | |
| 	help
 | |
| 	  Say Y here to support "ACPI parking protocol" enable method
 | |
| 	  for booting Linux.
 | |
| 
 | |
| 	  To use this feature, you must do:
 | |
| 	    - Bring secondary CPUs into U-Boot proper in a board-specific
 | |
| 	      manner.  This must be done *after* relocation.  Otherwise, the
 | |
| 	      secondary CPUs will spin in unprotected memory-area because the
 | |
| 	      master CPU protects the relocated spin code.
 | |
| 
 | |
| config SPL_TINY_MEMSET
 | |
| 	bool "Use a very small memset() in SPL"
 | |
| 	depends on SPL
 | |
| 	help
 | |
| 	  The faster memset() is the arch-specific one (if available) enabled
 | |
| 	  by CONFIG_USE_ARCH_MEMSET. If that is not enabled, we can still get
 | |
| 	  better performance by writing a word at a time. But in very
 | |
| 	  size-constrained environments even this may be too big. Enable this
 | |
| 	  option to reduce code size slightly at the cost of some speed.
 | |
| 
 | |
| config TPL_TINY_MEMSET
 | |
| 	bool "Use a very small memset() in TPL"
 | |
| 	depends on TPL
 | |
| 	help
 | |
| 	  The faster memset() is the arch-specific one (if available) enabled
 | |
| 	  by CONFIG_USE_ARCH_MEMSET. If that is not enabled, we can still get
 | |
| 	  better performance by writing a word at a time. But in very
 | |
| 	  size-constrained environments even this may be too big. Enable this
 | |
| 	  option to reduce code size slightly at the cost of some speed.
 | |
| 
 | |
| config RBTREE
 | |
| 	bool
 | |
| 
 | |
| config BITREVERSE
 | |
| 	bool "Bit reverse library from Linux"
 | |
| 
 | |
| config TRACE
 | |
| 	bool "Support for tracing of function calls and timing"
 | |
| 	imply CMD_TRACE
 | |
| 	imply TIMER_EARLY
 | |
| 	help
 | |
| 	  Enables function tracing within U-Boot. This allows recording of call
 | |
| 	  traces including timing information. The command can write data to
 | |
| 	  memory for exporting for analysis (e.g. using bootchart).
 | |
| 	  See doc/develop/trace.rst for full details.
 | |
| 
 | |
| config TRACE_BUFFER_SIZE
 | |
| 	hex "Size of trace buffer in U-Boot"
 | |
| 	depends on TRACE
 | |
| 	default 0x01000000
 | |
| 	help
 | |
| 	  Sets the size of the trace buffer in U-Boot. This is allocated from
 | |
| 	  memory during relocation. If this buffer is too small, the trace
 | |
| 	  history will be truncated, with later records omitted.
 | |
| 
 | |
| 	  If early trace is enabled (i.e. before relocation), this buffer must
 | |
| 	  be large enough to include all the data from the early trace buffer as
 | |
| 	  well, since this is copied over to the main buffer during relocation.
 | |
| 
 | |
| 	  A trace record is emitted for each function call and each record is
 | |
| 	  12 bytes (see struct trace_call). A suggested minimum size is 1MB. If
 | |
| 	  the size is too small then 'trace stats' will show a message saying
 | |
| 	  how many records were dropped due to buffer overflow.
 | |
| 
 | |
| config TRACE_CALL_DEPTH_LIMIT
 | |
| 	int "Trace call depth limit"
 | |
| 	depends on TRACE
 | |
| 	default 15
 | |
| 	help
 | |
| 	  Sets the maximum call depth up to which function calls are recorded.
 | |
| 
 | |
| config TRACE_EARLY
 | |
| 	bool "Enable tracing before relocation"
 | |
| 	depends on TRACE
 | |
| 	help
 | |
| 	  Sometimes it is helpful to trace execution of U-Boot before
 | |
| 	  relocation. This is possible by using a arch-specific, fixed buffer
 | |
| 	  position in memory. Enable this option to start tracing as early as
 | |
| 	  possible after U-Boot starts.
 | |
| 
 | |
| config TRACE_EARLY_SIZE
 | |
| 	hex "Size of early trace buffer in U-Boot"
 | |
| 	depends on TRACE_EARLY
 | |
| 	default 0x00100000
 | |
| 	help
 | |
| 	  Sets the size of the early trace buffer in bytes. This is used to hold
 | |
| 	  tracing information before relocation.
 | |
| 
 | |
| config TRACE_EARLY_CALL_DEPTH_LIMIT
 | |
| 	int "Early trace call depth limit"
 | |
| 	depends on TRACE_EARLY
 | |
| 	default 15
 | |
| 	help
 | |
| 	  Sets the maximum call depth up to which function calls are recorded
 | |
| 	  during early tracing.
 | |
| 
 | |
| config TRACE_EARLY_ADDR
 | |
| 	hex "Address of early trace buffer in U-Boot"
 | |
| 	depends on TRACE_EARLY
 | |
| 	default 0x00200000
 | |
| 	help
 | |
| 	  Sets the address of the early trace buffer in U-Boot. This memory
 | |
| 	  must be accessible before relocation.
 | |
| 
 | |
| 	  A trace record is emitted for each function call and each record is
 | |
| 	  12 bytes (see struct trace_call). A suggested minimum size is 1MB. If
 | |
| 	  the size is too small then the message which says the amount of early
 | |
| 	  data being coped will the the same as the
 | |
| 
 | |
| config CIRCBUF
 | |
| 	bool "Enable circular buffer support"
 | |
| 
 | |
| source "lib/dhry/Kconfig"
 | |
| 
 | |
| menu "Alternative crypto libraries"
 | |
| source lib/mbedtls/Kconfig
 | |
| endmenu
 | |
| 
 | |
| menu "Security support"
 | |
| 
 | |
| config AES
 | |
| 	bool "Support the AES algorithm"
 | |
| 	help
 | |
| 	  This provides a means to encrypt and decrypt data using the AES
 | |
| 	  (Advanced Encryption Standard). This algorithm uses a symetric key
 | |
| 	  and is widely used as a streaming cipher. Different key lengths are
 | |
| 	  supported by the algorithm but only a 128-bit key is supported at
 | |
| 	  present.
 | |
| 
 | |
| source "lib/ecdsa/Kconfig"
 | |
| source "lib/rsa/Kconfig"
 | |
| source "lib/crypto/Kconfig"
 | |
| source "lib/crypt/Kconfig"
 | |
| 
 | |
| config TPM
 | |
| 	bool "Trusted Platform Module (TPM) Support"
 | |
| 	depends on DM
 | |
| 	imply DM_RNG
 | |
| 	select SHA1
 | |
| 	help
 | |
| 	  This enables support for TPMs which can be used to provide security
 | |
| 	  features for your board. The TPM can be connected via LPC or I2C
 | |
| 	  and a sandbox TPM is provided for testing purposes. Use the 'tpm'
 | |
| 	  command to interactive the TPM. Driver model support is provided
 | |
| 	  for the low-level TPM interface, but only one TPM is supported at
 | |
| 	  a time by the TPM library.
 | |
| 	  For size reasons only SHA1 is selected which is supported on TPM1.2.
 | |
| 	  If you want a fully functional TPM enable all hashing algorithms.
 | |
| 	  If you enabled measured boot all hashing algorithms are selected.
 | |
| 
 | |
| config SPL_TPM
 | |
| 	bool "Trusted Platform Module (TPM) Support in SPL"
 | |
| 	depends on SPL_DM
 | |
| 	imply SPL_CRC8
 | |
| 	help
 | |
| 	  This enables support for TPMs which can be used to provide security
 | |
| 	  features for your board. The TPM can be connected via LPC or I2C
 | |
| 	  and a sandbox TPM is provided for testing purposes. Use the 'tpm'
 | |
| 	  command to interactive the TPM. Driver model support is provided
 | |
| 	  for the low-level TPM interface, but only one TPM is supported at
 | |
| 	  a time by the TPM library.
 | |
| 
 | |
| config TPL_TPM
 | |
| 	bool "Trusted Platform Module (TPM) Support in TPL"
 | |
| 	depends on TPL_DM
 | |
| 	help
 | |
| 	  This enables support for TPMs which can be used to provide security
 | |
| 	  features for your board. The TPM can be connected via LPC or I2C
 | |
| 	  and a sandbox TPM is provided for testing purposes. Use the 'tpm'
 | |
| 	  command to interactive the TPM. Driver model support is provided
 | |
| 	  for the low-level TPM interface, but only one TPM is supported at
 | |
| 	  a time by the TPM library.
 | |
| 
 | |
| config VPL_TPM
 | |
| 	bool "Trusted Platform Module (TPM) Support in VPL"
 | |
| 	depends on VPL_DM
 | |
| 	help
 | |
| 	  This enables support for TPMs which can be used to provide security
 | |
| 	  features for your board. The TPM can be connected via LPC or I2C
 | |
| 	  and a sandbox TPM is provided for testing purposes. Use the 'tpm'
 | |
| 	  command to interactive the TPM. Driver model support is provided
 | |
| 	  for the low-level TPM interface, but only one TPM is supported at
 | |
| 	  a time by the TPM library.
 | |
| 
 | |
| endmenu
 | |
| 
 | |
| menu "Android Verified Boot"
 | |
| 
 | |
| config LIBAVB
 | |
| 	bool "Android Verified Boot 2.0 support"
 | |
| 	depends on ANDROID_BOOT_IMAGE
 | |
| 	help
 | |
| 	  This enables support of Android Verified Boot 2.0 which can be used
 | |
| 	  to assure the end user of the integrity of the software running on a
 | |
| 	  device. Introduces such features as boot chain of trust, rollback
 | |
| 	  protection etc.
 | |
| 
 | |
| endmenu
 | |
| 
 | |
| menu "Hashing Support"
 | |
| 
 | |
| config BLAKE2
 | |
| 	bool "Enable BLAKE2 support"
 | |
| 	help
 | |
| 	  This option enables support of hashing using BLAKE2B algorithm.
 | |
| 	  The hash is calculated in software.
 | |
| 	  The BLAKE2 algorithm produces a hash value (digest) between 1 and
 | |
| 	  64 bytes.
 | |
| 
 | |
| config SHA1
 | |
| 	bool "Enable SHA1 support"
 | |
| 	help
 | |
| 	  This option enables support of hashing using SHA1 algorithm.
 | |
| 	  The hash is calculated in software.
 | |
| 	  The SHA1 algorithm produces a 160-bit (20-byte) hash value
 | |
| 	  (digest).
 | |
| 
 | |
| config SHA256
 | |
| 	bool "Enable SHA256 support"
 | |
| 	help
 | |
| 	  This option enables support of hashing using SHA256 algorithm.
 | |
| 	  The hash is calculated in software.
 | |
| 	  The SHA256 algorithm produces a 256-bit (32-byte) hash value
 | |
| 	  (digest).
 | |
| 
 | |
| config SHA512
 | |
| 	bool "Enable SHA512 support"
 | |
| 	default y if TI_SECURE_DEVICE && FIT_SIGNATURE
 | |
| 	help
 | |
| 	  This option enables support of hashing using SHA512 algorithm.
 | |
| 	  The hash is calculated in software.
 | |
| 	  The SHA512 algorithm produces a 512-bit (64-byte) hash value
 | |
| 	  (digest).
 | |
| 
 | |
| config SHA384
 | |
| 	bool "Enable SHA384 support"
 | |
| 	select SHA512
 | |
| 	help
 | |
| 	  This option enables support of hashing using SHA384 algorithm.
 | |
| 	  The hash is calculated in software. This is also selects SHA512,
 | |
| 	  because these implementations share the bulk of the code..
 | |
| 	  The SHA384 algorithm produces a 384-bit (48-byte) hash value
 | |
| 	  (digest).
 | |
| 
 | |
| config SHA_HW_ACCEL
 | |
| 	bool "Enable hardware acceleration for SHA hash functions"
 | |
| 	help
 | |
| 	  This option enables hardware acceleration for the SHA1 and SHA256
 | |
| 	  hashing algorithms. This affects the 'hash' command and also the
 | |
| 	  hash_lookup_algo() function.
 | |
| 
 | |
| if SPL
 | |
| 
 | |
| config SPL_CRC32
 | |
| 	bool "Enable CRC32 support in SPL"
 | |
| 	default y if SPL_LEGACY_IMAGE_SUPPORT || SPL_EFI_PARTITION
 | |
| 	default y if SPL_ENV_SUPPORT || TPL_BLOBLIST
 | |
| 	help
 | |
| 	  This option enables support of hashing using CRC32 algorithm.
 | |
| 	  The CRC32 algorithm produces 32-bit checksum value. For FIT
 | |
| 	  images, this is the least secure type of checksum, suitable for
 | |
| 	  detected accidental image corruption. For secure applications you
 | |
| 	  should consider SHA256 or SHA384.
 | |
| 
 | |
| config SPL_SHA1
 | |
| 	bool "Enable SHA1 support in SPL"
 | |
| 	default y if SHA1
 | |
| 	help
 | |
| 	  This option enables support of hashing using SHA1 algorithm.
 | |
| 	  The hash is calculated in software.
 | |
| 	  The SHA1 algorithm produces a 160-bit (20-byte) hash value
 | |
| 	  (digest).
 | |
| 
 | |
| config SPL_SHA256
 | |
| 	bool "Enable SHA256 support in SPL"
 | |
| 	default y if SHA256
 | |
| 	help
 | |
| 	  This option enables support of hashing using SHA256 algorithm.
 | |
| 	  The hash is calculated in software.
 | |
| 	  The SHA256 algorithm produces a 256-bit (32-byte) hash value
 | |
| 	  (digest).
 | |
| 
 | |
| config SPL_SHA512
 | |
| 	bool "Enable SHA512 support in SPL"
 | |
| 	default y if SHA512
 | |
| 	help
 | |
| 	  This option enables support of hashing using SHA512 algorithm.
 | |
| 	  The hash is calculated in software.
 | |
| 	  The SHA512 algorithm produces a 512-bit (64-byte) hash value
 | |
| 	  (digest).
 | |
| 
 | |
| config SPL_SHA384
 | |
| 	bool "Enable SHA384 support in SPL"
 | |
| 	default y if SHA384
 | |
| 	select SPL_SHA512
 | |
| 	help
 | |
| 	  This option enables support of hashing using SHA384 algorithm.
 | |
| 	  The hash is calculated in software. This is also selects SHA512,
 | |
| 	  because these implementations share the bulk of the code..
 | |
| 	  The SHA384 algorithm produces a 384-bit (48-byte) hash value
 | |
| 	  (digest).
 | |
| 
 | |
| config SPL_SHA_HW_ACCEL
 | |
| 	bool "Enable hardware acceleration for SHA hash functions"
 | |
| 	default y if SHA_HW_ACCEL
 | |
| 	help
 | |
| 	  This option enables hardware acceleration for the SHA1 and SHA256
 | |
| 	  hashing algorithms. This affects the 'hash' command and also the
 | |
| 	  hash_lookup_algo() function.
 | |
| 
 | |
| config SPL_SHA_PROG_HW_ACCEL
 | |
| 	bool "Enable Progressive hashing support using hardware in SPL"
 | |
| 	depends on SHA_PROG_HW_ACCEL
 | |
| 	default y
 | |
| 	help
 | |
| 	  This option enables hardware-acceleration for SHA progressive
 | |
| 	  hashing.
 | |
| 	  Data can be streamed in a block at a time and the hashing is
 | |
| 	  performed in hardware.
 | |
| 
 | |
| endif
 | |
| 
 | |
| config VPL_SHA1
 | |
| 	bool "Enable SHA1 support in VPL"
 | |
| 	depends on VPL
 | |
| 	default y if SHA1
 | |
| 	help
 | |
| 	  This option enables support of hashing using SHA1 algorithm.
 | |
| 	  The hash is calculated in software.
 | |
| 	  The SHA1 algorithm produces a 160-bit (20-byte) hash value
 | |
| 	  (digest).
 | |
| 
 | |
| config VPL_SHA256
 | |
| 	bool "Enable SHA256 support in VPL"
 | |
| 	depends on VPL
 | |
| 	default y if SHA256
 | |
| 	help
 | |
| 	  This option enables support of hashing using SHA256 algorithm.
 | |
| 	  The hash is calculated in software.
 | |
| 	  The SHA256 algorithm produces a 256-bit (32-byte) hash value
 | |
| 	  (digest).
 | |
| 
 | |
| if SHA_HW_ACCEL
 | |
| 
 | |
| config SHA512_HW_ACCEL
 | |
| 	bool "Enable hardware acceleration for SHA512"
 | |
| 	depends on SHA512
 | |
| 	help
 | |
| 	  This option enables hardware acceleration for the SHA384 and SHA512
 | |
| 	  hashing algorithms. This affects the 'hash' command and also the
 | |
| 	  hash_lookup_algo() function.
 | |
| 
 | |
| config SHA_PROG_HW_ACCEL
 | |
| 	bool "Enable Progressive hashing support using hardware"
 | |
| 	help
 | |
| 	  This option enables hardware-acceleration for SHA progressive
 | |
| 	  hashing.
 | |
| 	  Data can be streamed in a block at a time and the hashing is
 | |
| 	  performed in hardware.
 | |
| 
 | |
| endif
 | |
| 
 | |
| config MD5
 | |
| 	bool "Support MD5 algorithm"
 | |
| 	help
 | |
| 	  This option enables MD5 support. MD5 is an algorithm designed
 | |
| 	  in 1991 that produces a 16-byte digest (or checksum) from its input
 | |
| 	  data. It has a number of vulnerabilities which preclude its use in
 | |
| 	  security applications, but it can be useful for providing a quick
 | |
| 	  checksum of a block of data.
 | |
| 
 | |
| config SPL_MD5
 | |
| 	bool "Support MD5 algorithm in SPL"
 | |
| 	depends on SPL
 | |
| 	help
 | |
| 	  This option enables MD5 support in SPL. MD5 is an algorithm designed
 | |
| 	  in 1991 that produces a 16-byte digest (or checksum) from its input
 | |
| 	  data. It has a number of vulnerabilities which preclude its use in
 | |
| 	  security applications, but it can be useful for providing a quick
 | |
| 	  checksum of a block of data.
 | |
| 
 | |
| config CRC8
 | |
| 	def_bool y
 | |
| 	help
 | |
| 	  Enables CRC8 support in U-Boot. This is normally required. CRC8 is
 | |
| 	  a simple and fast checksumming algorithm which does a bytewise
 | |
| 	  checksum with feedback to produce an 8-bit result. The code is small
 | |
| 	  and it does not require a lookup table (unlike CRC32).
 | |
| 
 | |
| config SPL_CRC8
 | |
| 	bool "Support CRC8 in SPL"
 | |
| 	depends on SPL
 | |
| 	help
 | |
| 	  Enables CRC8 support in SPL. This is not normally required. CRC8 is
 | |
| 	  a simple and fast checksumming algorithm which does a bytewise
 | |
| 	  checksum with feedback to produce an 8-bit result. The code is small
 | |
| 	  and it does not require a lookup table (unlike CRC32).
 | |
| 
 | |
| config SPL_CRC16
 | |
| 	bool "Support CRC16 in SPL"
 | |
| 	depends on SPL
 | |
| 	help
 | |
| 	  Enables CRC16 support in SPL. This is not normally required.
 | |
| 
 | |
| config CRC32
 | |
| 	def_bool y
 | |
| 	help
 | |
| 	  Enables CRC32 support in U-Boot. This is normally required.
 | |
| 
 | |
| config CRC32C
 | |
| 	bool
 | |
| 
 | |
| config XXHASH
 | |
| 	bool
 | |
| 
 | |
| endmenu
 | |
| 
 | |
| menu "Compression Support"
 | |
| 
 | |
| config LZ4
 | |
| 	bool "Enable LZ4 decompression support"
 | |
| 	help
 | |
| 	  If this option is set, support for LZ4 compressed images
 | |
| 	  is included. The LZ4 algorithm can run in-place as long as the
 | |
| 	  compressed image is loaded to the end of the output buffer, and
 | |
| 	  trades lower compression ratios for much faster decompression.
 | |
| 
 | |
| 	  NOTE: This implements the release version of the LZ4 frame
 | |
| 	  format as generated by default by the 'lz4' command line tool.
 | |
| 	  This is not the same as the outdated, less efficient legacy
 | |
| 	  frame format currently (2015) implemented in the Linux kernel
 | |
| 	  (generated by 'lz4 -l'). The two formats are incompatible.
 | |
| 
 | |
| config LZMA
 | |
| 	bool "Enable LZMA decompression support"
 | |
| 	help
 | |
| 	  This enables support for LZMA (Lempel-Ziv-Markov chain algorithm),
 | |
| 	  a dictionary compression algorithm that provides a high compression
 | |
| 	  ratio and fairly fast decompression speed. See also
 | |
| 	  CONFIG_CMD_LZMADEC which provides a decode command.
 | |
| 
 | |
| config LZO
 | |
| 	bool "Enable LZO decompression support"
 | |
| 	help
 | |
| 	  This enables support for the LZO compression algorithm.
 | |
| 
 | |
| config GZIP
 | |
| 	bool "Enable gzip decompression support"
 | |
| 	select ZLIB
 | |
| 	default y
 | |
| 	help
 | |
| 	  This enables support for GZIP compression algorithm.
 | |
| 
 | |
| config ZLIB_UNCOMPRESS
 | |
| 	bool "Enables zlib's uncompress() functionality"
 | |
| 	help
 | |
| 	  This enables an extra zlib functionality: the uncompress() function,
 | |
| 	  which decompresses data from a buffer into another, knowing their
 | |
| 	  sizes. Unlike gunzip(), there is no header parsing.
 | |
| 
 | |
| config GZIP_COMPRESSED
 | |
| 	bool
 | |
| 	select ZLIB
 | |
| 
 | |
| config BZIP2
 | |
| 	bool "Enable bzip2 decompression support"
 | |
| 	help
 | |
| 	  This enables support for BZIP2 compression algorithm.
 | |
| 
 | |
| config ZLIB
 | |
| 	bool
 | |
| 	default y
 | |
| 	help
 | |
| 	  This enables ZLIB compression lib.
 | |
| 
 | |
| config ZSTD
 | |
| 	bool "Enable Zstandard decompression support"
 | |
| 	select XXHASH
 | |
| 	help
 | |
| 	  This enables Zstandard decompression library.
 | |
| 
 | |
| if ZSTD
 | |
| 
 | |
| config ZSTD_LIB_MINIFY
 | |
| 	bool "Minify Zstandard code"
 | |
| 	default y
 | |
| 	help
 | |
| 	  This disables various optional components and changes the
 | |
| 	  compilation flags to prioritize space-saving.
 | |
| 
 | |
| 	  For detailed info, see zstd's lib/README.md
 | |
| 
 | |
| 	  https://github.com/facebook/zstd/blob/dev/lib/README.md
 | |
| 
 | |
| endif
 | |
| 
 | |
| config SPL_BZIP2
 | |
| 	bool "Enable bzip2 decompression support for SPL build"
 | |
| 	depends on SPL
 | |
| 	help
 | |
| 	  This enables support for bzip2 compression algorithm for SPL boot.
 | |
| 
 | |
| config SPL_LZ4
 | |
| 	bool "Enable LZ4 decompression support in SPL"
 | |
| 	depends on SPL
 | |
| 	help
 | |
| 	  This enables support for the LZ4 decompression algorithm in SPL. LZ4
 | |
| 	  is a lossless data compression algorithm that is focused on
 | |
| 	  fast compression and decompression speed. It belongs to the LZ77
 | |
| 	  family of byte-oriented compression schemes.
 | |
| 
 | |
| config SPL_LZMA
 | |
| 	bool "Enable LZMA decompression support for SPL build"
 | |
| 	depends on SPL
 | |
| 	help
 | |
| 	  This enables support for LZMA compression algorithm for SPL boot.
 | |
| 
 | |
| config VPL_LZMA
 | |
| 	bool "Enable LZMA decompression support for VPL build"
 | |
| 	default y if LZMA
 | |
| 	help
 | |
| 	  This enables support for LZMA compression algorithm for VPL boot.
 | |
| 
 | |
| config SPL_LZO
 | |
| 	bool "Enable LZO decompression support in SPL"
 | |
| 	depends on SPL
 | |
| 	help
 | |
| 	  This enables support for LZO compression algorithm in the SPL.
 | |
| 
 | |
| config SPL_GZIP
 | |
| 	bool "Enable gzip decompression support for SPL build"
 | |
| 	select SPL_ZLIB
 | |
| 	help
 | |
| 	  This enables support for the GZIP compression algorithm for SPL boot.
 | |
| 
 | |
| config SPL_ZLIB
 | |
| 	bool
 | |
| 	help
 | |
| 	  This enables compression lib for SPL boot.
 | |
| 
 | |
| config SPL_ZSTD
 | |
| 	bool "Enable Zstandard decompression support in SPL"
 | |
| 	depends on SPL
 | |
| 	select XXHASH
 | |
| 	help
 | |
| 	  This enables Zstandard decompression library in the SPL.
 | |
| 
 | |
| endmenu
 | |
| 
 | |
| config ERRNO_STR
 | |
| 	bool "Enable function for getting errno-related string message"
 | |
| 	help
 | |
| 	  The function errno_str(int errno), returns a pointer to the errno
 | |
| 	  corresponding text message:
 | |
| 	  - if errno is null or positive number - a pointer to "Success" message
 | |
| 	  - if errno is negative - a pointer to errno related message
 | |
| 
 | |
| config HEXDUMP
 | |
| 	bool "Enable hexdump"
 | |
| 	help
 | |
| 	  This enables functions for printing dumps of binary data.
 | |
| 
 | |
| config SPL_HEXDUMP
 | |
| 	bool "Enable hexdump in SPL"
 | |
| 	depends on SPL && HEXDUMP
 | |
| 	help
 | |
| 	  This enables functions for printing dumps of binary data in
 | |
| 	  SPL.
 | |
| 
 | |
| config GETOPT
 | |
| 	bool "Enable getopt"
 | |
| 	help
 | |
| 	  This enables functions for parsing command-line options.
 | |
| 
 | |
| config OF_LIBFDT
 | |
| 	bool "Enable the FDT library"
 | |
| 	default y if OF_CONTROL
 | |
| 	help
 | |
| 	  This enables the FDT library (libfdt). It provides functions for
 | |
| 	  accessing binary device tree images in memory, such as adding and
 | |
| 	  removing nodes and properties, scanning through the tree and finding
 | |
| 	  particular compatible nodes. The library operates on a flattened
 | |
| 	  version of the device tree.
 | |
| 
 | |
| config OF_LIBFDT_ASSUME_MASK
 | |
| 	hex "Mask of conditions to assume for libfdt"
 | |
| 	depends on OF_LIBFDT || FIT
 | |
| 	default 0x0
 | |
| 	help
 | |
| 	  Use this to change the assumptions made by libfdt about the
 | |
| 	  device tree it is working with. A value of 0 means that no assumptions
 | |
| 	  are made, and libfdt is able to deal with malicious data. A value of
 | |
| 	  0xff means all assumptions are made and any invalid data may cause
 | |
| 	  unsafe execution. See FDT_ASSUME_PERFECT, etc. in libfdt_internal.h
 | |
| 
 | |
| config OF_LIBFDT_OVERLAY
 | |
| 	bool "Enable the FDT library overlay support"
 | |
| 	depends on OF_LIBFDT
 | |
| 	default y if ARCH_OMAP2PLUS || ARCH_KEYSTONE
 | |
| 	help
 | |
| 	  This enables the FDT library (libfdt) overlay support.
 | |
| 
 | |
| config SYS_FDT_PAD
 | |
| 	hex "Maximum size of the FDT memory area passeed to the OS"
 | |
| 	depends on OF_LIBFDT
 | |
| 	default 0x13000 if FMAN_ENET || QE || U_QE
 | |
| 	default 0x3000
 | |
| 	help
 | |
| 	  During OS boot, we allocate a region of memory within the bootmap
 | |
| 	  for the FDT. This is the size that we will expand the FDT that we
 | |
| 	  are using will be extended to be, in bytes.
 | |
| 
 | |
| config SPL_OF_LIBFDT
 | |
| 	bool "Enable the FDT library for SPL"
 | |
| 	depends on SPL_LIBGENERIC_SUPPORT
 | |
| 	default y if SPL_OF_CONTROL
 | |
| 	help
 | |
| 	  This enables the FDT library (libfdt). It provides functions for
 | |
| 	  accessing binary device tree images in memory, such as adding and
 | |
| 	  removing nodes and properties, scanning through the tree and finding
 | |
| 	  particular compatible nodes. The library operates on a flattened
 | |
| 	  version of the device tree.
 | |
| 
 | |
| config SPL_OF_LIBFDT_ASSUME_MASK
 | |
| 	hex "Mask of conditions to assume for libfdt"
 | |
| 	depends on SPL_OF_LIBFDT || (FIT && SPL)
 | |
| 	default 0xff
 | |
| 	help
 | |
| 	  Use this to change the assumptions made by libfdt in SPL about the
 | |
| 	  device tree it is working with. A value of 0 means that no assumptions
 | |
| 	  are made, and libfdt is able to deal with malicious data. A value of
 | |
| 	  0xff means all assumptions are made and any invalid data may cause
 | |
| 	  unsafe execution. See FDT_ASSUME_PERFECT, etc. in libfdt_internal.h
 | |
| 
 | |
| config TPL_OF_LIBFDT
 | |
| 	bool "Enable the FDT library for TPL"
 | |
| 	depends on TPL_LIBGENERIC_SUPPORT
 | |
| 	default y if TPL_OF_CONTROL
 | |
| 	help
 | |
| 	  This enables the FDT library (libfdt). It provides functions for
 | |
| 	  accessing binary device tree images in memory, such as adding and
 | |
| 	  removing nodes and properties, scanning through the tree and finding
 | |
| 	  particular compatible nodes. The library operates on a flattened
 | |
| 	  version of the device tree.
 | |
| 
 | |
| config TPL_OF_LIBFDT_ASSUME_MASK
 | |
| 	hex "Mask of conditions to assume for libfdt"
 | |
| 	depends on TPL_OF_LIBFDT || (FIT && TPL)
 | |
| 	default 0xff
 | |
| 	help
 | |
| 	  Use this to change the assumptions made by libfdt in TPL about the
 | |
| 	  device tree it is working with. A value of 0 means that no assumptions
 | |
| 	  are made, and libfdt is able to deal with malicious data. A value of
 | |
| 	  0xff means all assumptions are made and any invalid data may cause
 | |
| 	  unsafe execution. See FDT_ASSUME_PERFECT, etc. in libfdt_internal.h
 | |
| 
 | |
| config VPL_OF_LIBFDT
 | |
| 	bool "Enable the FDT library for VPL"
 | |
| 	depends on VPL
 | |
| 	default y if VPL_OF_CONTROL && !VPL_OF_PLATDATA
 | |
| 	help
 | |
| 	  This enables the FDT library (libfdt). It provides functions for
 | |
| 	  accessing binary device tree images in memory, such as adding and
 | |
| 	  removing nodes and properties, scanning through the tree and finding
 | |
| 	  particular compatible nodes. The library operates on a flattened
 | |
| 	  version of the device tree.
 | |
| 
 | |
| config VPL_OF_LIBFDT_ASSUME_MASK
 | |
| 	hex "Mask of conditions to assume for libfdt"
 | |
| 	depends on VPL_OF_LIBFDT || (FIT && VPL)
 | |
| 	default 0xff
 | |
| 	help
 | |
| 	  Use this to change the assumptions made by libfdt in SPL about the
 | |
| 	  device tree it is working with. A value of 0 means that no assumptions
 | |
| 	  are made, and libfdt is able to deal with malicious data. A value of
 | |
| 	  0xff means all assumptions are made and any invalid data may cause
 | |
| 	  unsafe execution. See FDT_ASSUME_PERFECT, etc. in libfdt_internal.h
 | |
| 
 | |
| menu "System tables"
 | |
| 	depends on (!EFI && !SYS_COREBOOT) || (ARM && EFI_LOADER)
 | |
| 
 | |
| config BLOBLIST_TABLES
 | |
| 	bool "Put tables in a bloblist"
 | |
| 	depends on BLOBLIST
 | |
| 	default y if (ARM && EFI_LOADER && GENERATE_ACPI_TABLE)
 | |
| 	default n
 | |
| 	help
 | |
| 	  On x86 normally tables are placed at address 0xf0000 and can be up
 | |
| 	  to 64KB long. With this option, tables are instead placed in the
 | |
| 	  bloblist with a pointer from 0xf0000. The size can then be larger
 | |
| 	  and the tables can be placed high in memory.
 | |
| 	  On other architectures the tables are always placed in high memory.
 | |
| 
 | |
| config GENERATE_SMBIOS_TABLE
 | |
| 	bool "Generate an SMBIOS (System Management BIOS) table"
 | |
| 	depends on SMBIOS
 | |
| 	default y
 | |
| 	help
 | |
| 	  The System Management BIOS (SMBIOS) specification addresses how
 | |
| 	  motherboard and system vendors present management information about
 | |
| 	  their products in a standard format by extending the BIOS interface
 | |
| 	  on Intel architecture systems.
 | |
| 
 | |
| 	  Check http://www.dmtf.org/standards/smbios for details.
 | |
| 
 | |
| 	  See also SYSINFO_SMBIOS which allows SMBIOS values to be provided in
 | |
| 	  the devicetree.
 | |
| 
 | |
| endmenu
 | |
| 
 | |
| config LIB_RATIONAL
 | |
| 	bool "enable continued fraction calculation routines"
 | |
| 
 | |
| config SPL_LIB_RATIONAL
 | |
| 	bool "enable continued fraction calculation routines for SPL"
 | |
| 	depends on SPL
 | |
| 
 | |
| config ASN1_COMPILER
 | |
| 	bool
 | |
| 	help
 | |
| 	  ASN.1 (Abstract Syntax Notation One) is a standard interface
 | |
| 	  description language for defining data structures that can be
 | |
| 	  serialized and deserialized in a cross-platform way. It is
 | |
| 	  broadly used in telecommunications and computer networking,
 | |
| 	  and especially in cryptography (https://en.wikipedia.org/wiki/ASN.1).
 | |
| 	  This option enables the support of the asn1 compiler.
 | |
| 
 | |
| config ASN1_DECODER
 | |
| 	bool
 | |
| 	help
 | |
| 	  ASN.1 (Abstract Syntax Notation One) is a standard interface
 | |
| 	  description language for defining data structures that can be
 | |
| 	  serialized and deserialized in a cross-platform way. It is
 | |
| 	  broadly used in telecommunications and computer networking,
 | |
| 	  and especially in cryptography (https://en.wikipedia.org/wiki/ASN.1).
 | |
| 	  This option enables the support of the asn1 decoder.
 | |
| 
 | |
| config SPL_ASN1_DECODER
 | |
| 	bool
 | |
| 	help
 | |
| 	  ASN.1 (Abstract Syntax Notation One) is a standard interface
 | |
| 	  description language for defining data structures that can be
 | |
| 	  serialized and deserialized in a cross-platform way. It is
 | |
| 	  broadly used in telecommunications and computer networking,
 | |
| 	  and especially in cryptography (https://en.wikipedia.org/wiki/ASN.1).
 | |
| 	  This option enables the support of the asn1 decoder in the SPL.
 | |
| 
 | |
| config OID_REGISTRY
 | |
| 	bool
 | |
| 	help
 | |
| 	  In computing, object identifiers or OIDs are an identifier mechanism
 | |
| 	  standardized by the International Telecommunication Union (ITU) and
 | |
| 	  ISO/IEC for naming any object, concept, or "thing" with a globally
 | |
| 	  unambiguous persistent name (https://en.wikipedia.org/wiki/Object_identifier).
 | |
| 	  Enable fast lookup object identifier registry.
 | |
| 
 | |
| config SPL_OID_REGISTRY
 | |
| 	bool
 | |
| 	help
 | |
| 	  In computing, object identifiers or OIDs are an identifier mechanism
 | |
| 	  standardized by the International Telecommunication Union (ITU) and
 | |
| 	  ISO/IEC for naming any object, concept, or "thing" with a globally
 | |
| 	  unambiguous persistent name (https://en.wikipedia.org/wiki/Object_identifier).
 | |
| 	  Enable fast lookup object identifier registry in the SPL.
 | |
| 
 | |
| config SMBIOS
 | |
| 	bool "SMBIOS support"
 | |
| 	depends on X86 || EFI_LOADER
 | |
| 	default y
 | |
| 	select LAST_STAGE_INIT
 | |
| 	help
 | |
| 	  Indicates that this platform can support System Management BIOS
 | |
| 	  (SMBIOS) tables. These provide various pieces of information about
 | |
| 	  the board, such as the manufacturer and the model name.
 | |
| 
 | |
| 	  See GENERATE_SMBIOS_TABLE which controls whether U-Boot actually
 | |
| 	  creates these tables, rather than them coming from a previous firmware
 | |
| 	  stage.
 | |
| 
 | |
| config SMBIOS_PARSER
 | |
| 	bool "SMBIOS parser"
 | |
| 	help
 | |
| 	  A simple parser for SMBIOS data.
 | |
| 
 | |
| source "lib/optee/Kconfig"
 | |
| 
 | |
| config TEST_FDTDEC
 | |
| 	bool "enable fdtdec test"
 | |
| 	depends on OF_LIBFDT
 | |
| 
 | |
| config LIB_DATE
 | |
| 	bool
 | |
| 
 | |
| config LIB_ELF
 | |
| 	bool
 | |
| 	help
 | |
| 	  Support basic elf loading/validating functions.
 | |
| 	  This supports for 32 bit and 64 bit versions.
 | |
| 
 | |
| config LMB
 | |
| 	bool "Enable the logical memory blocks library (lmb)"
 | |
| 	default y if ARC || ARM || M68K || MICROBLAZE || MIPS || \
 | |
| 		     NIOS2 || PPC || RISCV || SANDBOX || SH || X86 || XTENSA
 | |
| 	select ARCH_MISC_INIT if PPC
 | |
| 	help
 | |
| 	  Support the library logical memory blocks. This will require
 | |
| 	  a malloc() implementation for defining the data structures
 | |
| 	  needed for maintaining the LMB memory map.
 | |
| 
 | |
| config SPL_LMB
 | |
| 	bool "Enable LMB module for SPL"
 | |
| 	depends on SPL && SPL_FRAMEWORK && SPL_SYS_MALLOC
 | |
| 	help
 | |
| 	  Enable support for Logical Memory Block library routines in
 | |
| 	  SPL. This will require a malloc() implementation for defining
 | |
| 	  the data structures needed for maintaining the LMB memory map.
 | |
| 
 | |
| config LMB_ARCH_MEM_MAP
 | |
| 	bool "Add an architecture specific memory map"
 | |
| 	depends on LMB
 | |
| 	default y if FSL_LAYERSCAPE || X86
 | |
| 	help
 | |
| 	  Some architectures have special or unique aspects which need
 | |
| 	  consideration when adding memory ranges to the list of available
 | |
| 	  memory map. Enable this config in such scenarios which allow
 | |
| 	  architectures and boards to define their own memory map.
 | |
| 
 | |
| config SPL_LMB_ARCH_MEM_MAP
 | |
| 	bool "Add an architecture specific memory map"
 | |
| 	depends on SPL_LMB
 | |
| 	help
 | |
| 	  Some architectures have special or unique scenarios which need
 | |
| 	  consideration when adding memory ranges to the list of available
 | |
| 	  memory map. Enable this config in such scenarios which allow
 | |
| 	  architectures and boards to define their own memory map.
 | |
| 
 | |
| config PHANDLE_CHECK_SEQ
 | |
| 	bool "Enable phandle check while getting sequence number"
 | |
| 	help
 | |
| 	  When there are multiple device tree nodes with same name,
 | |
| 	  enable this config option to distinguish them using
 | |
| 	  phandles in fdtdec_get_alias_seq() function.
 | |
| 
 | |
| endmenu
 | |
| 
 | |
| source "lib/fwu_updates/Kconfig"
 |