1ed36323fSMasahiro Yamadamenu "Library routines" 2ed36323fSMasahiro Yamada 36ef2f901SAdam Fordconfig BCH 46ef2f901SAdam Ford bool "Enable Software based BCH ECC" 56ef2f901SAdam Ford help 66ef2f901SAdam Ford Enables software based BCH ECC algorithm present in lib/bch.c 76ef2f901SAdam Ford This is used by SoC platforms which do not have built-in ELM 86ef2f901SAdam Ford hardware engine required for BCH ECC correction. 96ef2f901SAdam Ford 10b0928da6SMasahiro Yamadaconfig CC_OPTIMIZE_LIBS_FOR_SPEED 11b0928da6SMasahiro Yamada bool "Optimize libraries for speed" 12b0928da6SMasahiro Yamada help 13b0928da6SMasahiro Yamada Enabling this option will pass "-O2" to gcc when compiling 14b0928da6SMasahiro Yamada under "lib" directory. 15b0928da6SMasahiro Yamada 16b0928da6SMasahiro Yamada If unsure, say N. 17b0928da6SMasahiro Yamada 1845ccec8fSMasahiro Yamadaconfig HAVE_PRIVATE_LIBGCC 1945ccec8fSMasahiro Yamada bool 2045ccec8fSMasahiro Yamada 2145ccec8fSMasahiro Yamadaconfig USE_PRIVATE_LIBGCC 2245ccec8fSMasahiro Yamada bool "Use private libgcc" 2345ccec8fSMasahiro Yamada depends on HAVE_PRIVATE_LIBGCC 2491b86e21SMarek Vasut default y if HAVE_PRIVATE_LIBGCC && ((ARM && !ARM64) || MIPS) 2545ccec8fSMasahiro Yamada help 2645ccec8fSMasahiro Yamada This option allows you to use the built-in libgcc implementation 2767976306SMasahiro Yamada of U-Boot instead of the one provided by the compiler. 2845ccec8fSMasahiro Yamada If unsure, say N. 2945ccec8fSMasahiro Yamada 308c688bc4SMasahiro Yamadaconfig SYS_HZ 318c688bc4SMasahiro Yamada int 328c688bc4SMasahiro Yamada default 1000 338c688bc4SMasahiro Yamada help 348c688bc4SMasahiro Yamada The frequency of the timer returned by get_timer(). 358c688bc4SMasahiro Yamada get_timer() must operate in milliseconds and this option must be 368c688bc4SMasahiro Yamada set to 1000. 378c688bc4SMasahiro Yamada 38*7f28cbb6SJoseph Chenconfig SYS_STACK_SIZE 39*7f28cbb6SJoseph Chen hex 40*7f28cbb6SJoseph Chen default 0x20000 41*7f28cbb6SJoseph Chen help 42*7f28cbb6SJoseph Chen The system stack size. 43*7f28cbb6SJoseph Chen 447d9cde10SStefan Roeseconfig USE_TINY_PRINTF 457d9cde10SStefan Roese bool "Enable tiny printf() version" 467d9cde10SStefan Roese help 477d9cde10SStefan Roese This option enables a tiny, stripped down printf version. 487d9cde10SStefan Roese This should only be used in space limited environments, 497d9cde10SStefan Roese like SPL versions with hard memory limits. This version 507d9cde10SStefan Roese reduces the code size by about 2.5KiB on armv7. 517d9cde10SStefan Roese 527d9cde10SStefan Roese The supported format specifiers are %c, %s, %u/%d and %x. 537d9cde10SStefan Roese 540e13c182SMasahiro Yamadaconfig PANIC_HANG 550e13c182SMasahiro Yamada bool "Do not reset the system on fatal error" 560e13c182SMasahiro Yamada help 570e13c182SMasahiro Yamada Define this option to stop the system in case of a fatal error, 580e13c182SMasahiro Yamada so that you have to reset it manually. This is probably NOT a good 590e13c182SMasahiro Yamada idea for an embedded system where you want the system to reboot 600e13c182SMasahiro Yamada automatically as fast as possible, but it may be useful during 610e13c182SMasahiro Yamada development since you can try to debug the conditions that lead to 620e13c182SMasahiro Yamada the situation. 630e13c182SMasahiro Yamada 641a60650cSJoe Hershbergerconfig REGEX 651a60650cSJoe Hershberger bool "Enable regular expression support" 66f7848d90SJoe Hershberger default y if NET 671a60650cSJoe Hershberger help 681a60650cSJoe Hershberger If this variable is defined, U-Boot is linked against the 691a60650cSJoe Hershberger SLRE (Super Light Regular Expression) library, which adds 701a60650cSJoe Hershberger regex support to some commands, for example "env grep" and 711a60650cSJoe Hershberger "setexpr". 721a60650cSJoe Hershberger 739ba9e85fSMichal Simekconfig LIB_RAND 743850dbe8SMasahiro Yamada bool "Pseudo-random library support " 753850dbe8SMasahiro Yamada help 763850dbe8SMasahiro Yamada This library provides pseudo-random number generator functions. 779ba9e85fSMichal Simek 78ab4458bdSSimon Glassconfig SPL_TINY_MEMSET 79ab4458bdSSimon Glass bool "Use a very small memset() in SPL" 80ab4458bdSSimon Glass help 81ab4458bdSSimon Glass The faster memset() is the arch-specific one (if available) enabled 82ab4458bdSSimon Glass by CONFIG_USE_ARCH_MEMSET. If that is not enabled, we can still get 83ab4458bdSSimon Glass better performance by writing a word at a time. But in very 84ab4458bdSSimon Glass size-constrained envrionments even this may be too big. Enable this 85ab4458bdSSimon Glass option to reduce code size slightly at the cost of some speed. 86ab4458bdSSimon Glass 8796b9082cSPhilipp Tomsichconfig TPL_TINY_MEMSET 8896b9082cSPhilipp Tomsich bool "Use a very small memset() in TPL" 8996b9082cSPhilipp Tomsich help 9096b9082cSPhilipp Tomsich The faster memset() is the arch-specific one (if available) enabled 9196b9082cSPhilipp Tomsich by CONFIG_USE_ARCH_MEMSET. If that is not enabled, we can still get 9296b9082cSPhilipp Tomsich better performance by writing a word at a time. But in very 9396b9082cSPhilipp Tomsich size-constrained envrionments even this may be too big. Enable this 9496b9082cSPhilipp Tomsich option to reduce code size slightly at the cost of some speed. 9596b9082cSPhilipp Tomsich 96aa049152SBoris Brezillonconfig RBTREE 97aa049152SBoris Brezillon bool 98aa049152SBoris Brezillon 99c6348130SZhangbin Tongconfig BITREVERSE 100c6348130SZhangbin Tong bool 101c6348130SZhangbin Tong 102ffa8f8b7SJoseph Chenconfig SYSMEM 103ffa8f8b7SJoseph Chen bool "System memory management" 104ffa8f8b7SJoseph Chen default y 105ffa8f8b7SJoseph Chen help 106ffa8f8b7SJoseph Chen This enables support for system permanent memory management. 107ffa8f8b7SJoseph Chen 108d1389403SSimon Glasssource lib/dhry/Kconfig 109d1389403SSimon Glass 110b1a873dfSSimon Glassmenu "Security support" 111b1a873dfSSimon Glass 112b1a873dfSSimon Glassconfig AES 113b1a873dfSSimon Glass bool "Support the AES algorithm" 114b1a873dfSSimon Glass help 115b1a873dfSSimon Glass This provides a means to encrypt and decrypt data using the AES 116b1a873dfSSimon Glass (Advanced Encryption Standard). This algorithm uses a symetric key 117b1a873dfSSimon Glass and is widely used as a streaming cipher. Different key lengths are 118b1a873dfSSimon Glass supported by the algorithm but only a 128-bit key is supported at 119b1a873dfSSimon Glass present. 120b1a873dfSSimon Glass 121d9f23c7fSRuchika Guptasource lib/rsa/Kconfig 122c4beb22fSRuchika Gupta 123a7d660bcSSimon Glassconfig TPM 124a7d660bcSSimon Glass bool "Trusted Platform Module (TPM) Support" 1252419cd16SSimon Glass depends on DM 126a7d660bcSSimon Glass help 127a7d660bcSSimon Glass This enables support for TPMs which can be used to provide security 128a7d660bcSSimon Glass features for your board. The TPM can be connected via LPC or I2C 129a7d660bcSSimon Glass and a sandbox TPM is provided for testing purposes. Use the 'tpm' 130a7d660bcSSimon Glass command to interactive the TPM. Driver model support is provided 131a7d660bcSSimon Glass for the low-level TPM interface, but only one TPM is supported at 132a7d660bcSSimon Glass a time by the TPM library. 133a7d660bcSSimon Glass 134b1a873dfSSimon Glassendmenu 135b1a873dfSSimon Glass 13694e3c8c4Sgaurav ranamenu "Hashing Support" 13794e3c8c4Sgaurav rana 13894e3c8c4Sgaurav ranaconfig SHA1 13994e3c8c4Sgaurav rana bool "Enable SHA1 support" 14094e3c8c4Sgaurav rana help 14194e3c8c4Sgaurav rana This option enables support of hashing using SHA1 algorithm. 14294e3c8c4Sgaurav rana The hash is calculated in software. 14394e3c8c4Sgaurav rana The SHA1 algorithm produces a 160-bit (20-byte) hash value 14494e3c8c4Sgaurav rana (digest). 14594e3c8c4Sgaurav rana 14694e3c8c4Sgaurav ranaconfig SHA256 14794e3c8c4Sgaurav rana bool "Enable SHA256 support" 14894e3c8c4Sgaurav rana help 14994e3c8c4Sgaurav rana This option enables support of hashing using SHA256 algorithm. 15094e3c8c4Sgaurav rana The hash is calculated in software. 15194e3c8c4Sgaurav rana The SHA256 algorithm produces a 256-bit (32-byte) hash value 15294e3c8c4Sgaurav rana (digest). 15394e3c8c4Sgaurav rana 15494e3c8c4Sgaurav ranaconfig SHA_HW_ACCEL 15594e3c8c4Sgaurav rana bool "Enable hashing using hardware" 15694e3c8c4Sgaurav rana help 15794e3c8c4Sgaurav rana This option enables hardware acceleration 15894e3c8c4Sgaurav rana for SHA1/SHA256 hashing. 15994e3c8c4Sgaurav rana This affects the 'hash' command and also the 16094e3c8c4Sgaurav rana hash_lookup_algo() function. 16194e3c8c4Sgaurav rana 16294e3c8c4Sgaurav ranaconfig SHA_PROG_HW_ACCEL 16394e3c8c4Sgaurav rana bool "Enable Progressive hashing support using hardware" 16494e3c8c4Sgaurav rana depends on SHA_HW_ACCEL 16594e3c8c4Sgaurav rana help 16694e3c8c4Sgaurav rana This option enables hardware-acceleration for 16794e3c8c4Sgaurav rana SHA1/SHA256 progressive hashing. 16894e3c8c4Sgaurav rana Data can be streamed in a block at a time and the hashing 16994e3c8c4Sgaurav rana is performed in hardware. 170bea79d7dSAndre Przywara 171bea79d7dSAndre Przywaraconfig MD5 172bea79d7dSAndre Przywara bool 173bea79d7dSAndre Przywara 17492193ef7SMarek Behúnconfig CRC32C 17592193ef7SMarek Behún bool 17692193ef7SMarek Behún 17794e3c8c4Sgaurav ranaendmenu 17894e3c8c4Sgaurav rana 179027b728dSJulius Wernermenu "Compression Support" 180027b728dSJulius Werner 181027b728dSJulius Wernerconfig LZ4 182027b728dSJulius Werner bool "Enable LZ4 decompression support" 183027b728dSJulius Werner help 184027b728dSJulius Werner If this option is set, support for LZ4 compressed images 185027b728dSJulius Werner is included. The LZ4 algorithm can run in-place as long as the 186027b728dSJulius Werner compressed image is loaded to the end of the output buffer, and 187027b728dSJulius Werner trades lower compression ratios for much faster decompression. 188027b728dSJulius Werner 189027b728dSJulius Werner NOTE: This implements the release version of the LZ4 frame 190027b728dSJulius Werner format as generated by default by the 'lz4' command line tool. 191027b728dSJulius Werner This is not the same as the outdated, less efficient legacy 192027b728dSJulius Werner frame format currently (2015) implemented in the Linux kernel 193027b728dSJulius Werner (generated by 'lz4 -l'). The two formats are incompatible. 194027b728dSJulius Werner 195aed998aaSSimon Glassconfig LZMA 196aed998aaSSimon Glass bool "Enable LZMA decompression support" 197aed998aaSSimon Glass help 198aed998aaSSimon Glass This enables support for LZMA (Lempel-Ziv-Markov chain algorithm), 199aed998aaSSimon Glass a dictionary compression algorithm that provides a high compression 200aed998aaSSimon Glass ratio and fairly fast decompression speed. See also 201aed998aaSSimon Glass CONFIG_CMD_LZMADEC which provides a decode command. 202aed998aaSSimon Glass 203173aafbfSBoris Brezillonconfig LZO 204d56b4b19STom Rini bool "Enable LZO decompression support" 205d56b4b19STom Rini help 206d56b4b19STom Rini This enables support for LZO compression algorithm.r 207b81c4739SYork Sun 208205ac79eSJean-Jacques Hiblotconfig SPL_LZO 209205ac79eSJean-Jacques Hiblot bool "Enable LZO decompression support in SPL" 210205ac79eSJean-Jacques Hiblot help 211205ac79eSJean-Jacques Hiblot This enables support for LZO compression algorithm in the SPL. 212205ac79eSJean-Jacques Hiblot 213b81c4739SYork Sunconfig SPL_GZIP 214b81c4739SYork Sun bool "Enable gzip decompression support for SPL build" 215b81c4739SYork Sun select SPL_ZLIB 216b81c4739SYork Sun help 217b81c4739SYork Sun This enables support for GZIP compression altorithm for SPL boot. 218b81c4739SYork Sun 219b81c4739SYork Sunconfig SPL_ZLIB 220b81c4739SYork Sun bool 221b81c4739SYork Sun help 222b81c4739SYork Sun This enables compression lib for SPL boot. 223b81c4739SYork Sun 224027b728dSJulius Wernerendmenu 225027b728dSJulius Werner 2266501ff62SPrzemyslaw Marczakconfig ERRNO_STR 2276501ff62SPrzemyslaw Marczak bool "Enable function for getting errno-related string message" 2286501ff62SPrzemyslaw Marczak help 2296501ff62SPrzemyslaw Marczak The function errno_str(int errno), returns a pointer to the errno 2306501ff62SPrzemyslaw Marczak corresponding text message: 2316501ff62SPrzemyslaw Marczak - if errno is null or positive number - a pointer to "Success" message 2326501ff62SPrzemyslaw Marczak - if errno is negative - a pointer to errno related message 2336501ff62SPrzemyslaw Marczak 23469e173ebSSimon Glassconfig OF_LIBFDT 23569e173ebSSimon Glass bool "Enable the FDT library" 23669e173ebSSimon Glass default y if OF_CONTROL 23769e173ebSSimon Glass help 23869e173ebSSimon Glass This enables the FDT library (libfdt). It provides functions for 23969e173ebSSimon Glass accessing binary device tree images in memory, such as adding and 240f1a7ba1dSAnatolij Gustschin removing nodes and properties, scanning through the tree and finding 24169e173ebSSimon Glass particular compatible nodes. The library operates on a flattened 24269e173ebSSimon Glass version of the device tree. 24369e173ebSSimon Glass 244ddf67f71SMaxime Ripardconfig OF_LIBFDT_OVERLAY 245ddf67f71SMaxime Ripard bool "Enable the FDT library overlay support" 246ddf67f71SMaxime Ripard help 247ddf67f71SMaxime Ripard This enables the FDT library (libfdt) overlay support. 248ddf67f71SMaxime Ripard 249aa34fbc0SSimon Glassconfig SPL_OF_LIBFDT 250aa34fbc0SSimon Glass bool "Enable the FDT library for SPL" 251aa34fbc0SSimon Glass default y if SPL_OF_CONTROL 252aa34fbc0SSimon Glass help 253aa34fbc0SSimon Glass This enables the FDT library (libfdt). It provides functions for 254aa34fbc0SSimon Glass accessing binary device tree images in memory, such as adding and 255f1a7ba1dSAnatolij Gustschin removing nodes and properties, scanning through the tree and finding 256aa34fbc0SSimon Glass particular compatible nodes. The library operates on a flattened 257aa34fbc0SSimon Glass version of the device tree. 258aa34fbc0SSimon Glass 259e2f2fb23SKever Yangconfig TPL_OF_LIBFDT 260e2f2fb23SKever Yang bool "Enable the FDT library for TPL" 261e2f2fb23SKever Yang default y if TPL_OF_CONTROL 262e2f2fb23SKever Yang help 263e2f2fb23SKever Yang This enables the FDT library (libfdt). It provides functions for 264e2f2fb23SKever Yang accessing binary device tree images in memory, such as adding and 265e2f2fb23SKever Yang removing nodes and properties, scanning through the tree and finding 266e2f2fb23SKever Yang particular compatible nodes. The library operates on a flattened 267e2f2fb23SKever Yang version of the device tree. 268e2f2fb23SKever Yang 269ebf7fff2SHeiko Schocherconfig FDT_FIXUP_PARTITIONS 270ebf7fff2SHeiko Schocher bool "overwrite MTD partitions in DTS through defined in 'mtdparts'" 271ebf7fff2SHeiko Schocher depends on OF_LIBFDT 272ebf7fff2SHeiko Schocher default n 273ebf7fff2SHeiko Schocher help 274ebf7fff2SHeiko Schocher Allow overwriting defined partitions in the device tree blob 275ebf7fff2SHeiko Schocher using partition info defined in the 'mtdparts' environment 276ebf7fff2SHeiko Schocher variable. 277ebf7fff2SHeiko Schocher 2784b6dddc2SAlexander Grafmenu "System tables" 279e663b350SAlexander Graf depends on (!EFI && !SYS_COREBOOT) || (ARM && EFI_LOADER) 2804b6dddc2SAlexander Graf 2814b6dddc2SAlexander Grafconfig GENERATE_SMBIOS_TABLE 2824b6dddc2SAlexander Graf bool "Generate an SMBIOS (System Management BIOS) table" 2834b6dddc2SAlexander Graf default y 284e663b350SAlexander Graf depends on X86 || EFI_LOADER 2854b6dddc2SAlexander Graf help 2864b6dddc2SAlexander Graf The System Management BIOS (SMBIOS) specification addresses how 2874b6dddc2SAlexander Graf motherboard and system vendors present management information about 2884b6dddc2SAlexander Graf their products in a standard format by extending the BIOS interface 2894b6dddc2SAlexander Graf on Intel architecture systems. 2904b6dddc2SAlexander Graf 2914b6dddc2SAlexander Graf Check http://www.dmtf.org/standards/smbios for details. 2924b6dddc2SAlexander Graf 2934b6dddc2SAlexander Grafconfig SMBIOS_MANUFACTURER 2944b6dddc2SAlexander Graf string "SMBIOS Manufacturer" 2954b6dddc2SAlexander Graf depends on GENERATE_SMBIOS_TABLE 2964b6dddc2SAlexander Graf default SYS_VENDOR 2974b6dddc2SAlexander Graf help 2984b6dddc2SAlexander Graf The board manufacturer to store in SMBIOS structures. 2994b6dddc2SAlexander Graf Change this to override the default one (CONFIG_SYS_VENDOR). 3004b6dddc2SAlexander Graf 3014b6dddc2SAlexander Grafconfig SMBIOS_PRODUCT_NAME 3024b6dddc2SAlexander Graf string "SMBIOS Product Name" 3034b6dddc2SAlexander Graf depends on GENERATE_SMBIOS_TABLE 3044b6dddc2SAlexander Graf default SYS_BOARD 3054b6dddc2SAlexander Graf help 3064b6dddc2SAlexander Graf The product name to store in SMBIOS structures. 3074b6dddc2SAlexander Graf Change this to override the default one (CONFIG_SYS_BOARD). 3084b6dddc2SAlexander Graf 3094b6dddc2SAlexander Grafendmenu 3104b6dddc2SAlexander Graf 311867a6ac8SSimon Glasssource lib/efi/Kconfig 312ed980b8cSAlexander Grafsource lib/efi_loader/Kconfig 31337a7bc39SJason Zhusource lib/avb/libavb/Kconfig 31437a7bc39SJason Zhusource lib/avb/libavb_ab/Kconfig 31537a7bc39SJason Zhusource lib/avb/libavb_atx/Kconfig 31637a7bc39SJason Zhusource lib/avb/libavb_user/Kconfig 31737a7bc39SJason Zhusource lib/avb/rk_avb_user/Kconfig 318abdd2437Shispingsource lib/optee_clientApi/Kconfig 319867a6ac8SSimon Glass 320ed36323fSMasahiro Yamadaendmenu 321