]> git.ipfire.org Git - thirdparty/u-boot.git/blame - cmd/Kconfig
common: Fix autocompletion with CONFIG_CMDLINE_PS_SUPPORT
[thirdparty/u-boot.git] / cmd / Kconfig
CommitLineData
72a8cf8d
SG
1menu "Command line interface"
2
302a6487
SG
3config CMDLINE
4 bool "Support U-Boot commands"
5 default y
6 help
7 Enable U-Boot's command-line functions. This provides a means
8 to enter commands into U-Boot for a wide variety of purposes. It
9 also allows scripts (containing commands) to be executed.
10 Various commands and command categorys can be indivdually enabled.
11 Depending on the number of commands enabled, this can add
12 substantially to the size of U-Boot.
13
72a8cf8d
SG
14config HUSH_PARSER
15 bool "Use hush shell"
302a6487 16 depends on CMDLINE
72a8cf8d
SG
17 help
18 This option enables the "hush" shell (from Busybox) as command line
19 interpreter, thus enabling powerful command line syntax like
20 if...then...else...fi conditionals or `&&' and '||'
21 constructs ("shell scripts").
22
23 If disabled, you get the old, much simpler behaviour with a somewhat
24 smaller memory footprint.
25
d021e942
AF
26config CMDLINE_EDITING
27 bool "Enable command line editing"
28 depends on CMDLINE
29 default y
30 help
31 Enable editing and History functions for interactive command line
32 input operations
33
34config AUTO_COMPLETE
35 bool "Enable auto complete using TAB"
36 depends on CMDLINE
37 default y
38 help
39 Enable auto completion of commands using TAB.
40
41config SYS_LONGHELP
42 bool "Enable long help messages"
43 depends on CMDLINE
44 default y if CMDLINE
45 help
46 Defined when you want long help messages included
47 Do not set this option when short of memory.
48
72a8cf8d
SG
49config SYS_PROMPT
50 string "Shell prompt"
51 default "=> "
52 help
53 This string is displayed in the command line to the left of the
54 cursor.
55
7ae31fcc
CM
56config SYS_XTRACE
57 string "Command execution tracer"
58 depends on CMDLINE
59 default y if CMDLINE
60 help
61 This option enables the possiblity to print all commands before
62 executing them and after all variables are evaluated (similar
63 to Bash's xtrace/'set -x' feature).
64 To enable the tracer a variable "xtrace" needs to be defined in
65 the environment.
66
72a8cf8d
SG
67menu "Autoboot options"
68
41598c82
MY
69config AUTOBOOT
70 bool "Autoboot"
71 default y
72 help
73 This enables the autoboot. See doc/README.autoboot for detail.
74
72a8cf8d
SG
75config AUTOBOOT_KEYED
76 bool "Stop autobooting via specific input key / string"
77 default n
78 help
79 This option enables stopping (aborting) of the automatic
80 boot feature only by issuing a specific input key or
81 string. If not enabled, any input key will abort the
82 U-Boot automatic booting process and bring the device
83 to the U-Boot prompt for user input.
84
85config AUTOBOOT_PROMPT
86 string "Autoboot stop prompt"
87 depends on AUTOBOOT_KEYED
88 default "Autoboot in %d seconds\\n"
89 help
90 This string is displayed before the boot delay selected by
91 CONFIG_BOOTDELAY starts. If it is not defined there is no
92 output indicating that autoboot is in progress.
93
94 Note that this define is used as the (only) argument to a
95 printf() call, so it may contain '%' format specifications,
96 provided that it also includes, sepearated by commas exactly
97 like in a printf statement, the required arguments. It is
98 the responsibility of the user to select only such arguments
99 that are valid in the given context.
100
101config AUTOBOOT_ENCRYPTION
102 bool "Enable encryption in autoboot stopping"
103 depends on AUTOBOOT_KEYED
104 default n
105
106config AUTOBOOT_DELAY_STR
107 string "Delay autobooting via specific input key / string"
108 depends on AUTOBOOT_KEYED && !AUTOBOOT_ENCRYPTION
109 help
110 This option delays the automatic boot feature by issuing
111 a specific input key or string. If CONFIG_AUTOBOOT_DELAY_STR
112 or the environment variable "bootdelaykey" is specified
113 and this string is received from console input before
114 autoboot starts booting, U-Boot gives a command prompt. The
115 U-Boot prompt will time out if CONFIG_BOOT_RETRY_TIME is
116 used, otherwise it never times out.
117
118config AUTOBOOT_STOP_STR
119 string "Stop autobooting via specific input key / string"
120 depends on AUTOBOOT_KEYED && !AUTOBOOT_ENCRYPTION
121 help
122 This option enables stopping (aborting) of the automatic
123 boot feature only by issuing a specific input key or
124 string. If CONFIG_AUTOBOOT_STOP_STR or the environment
125 variable "bootstopkey" is specified and this string is
126 received from console input before autoboot starts booting,
127 U-Boot gives a command prompt. The U-Boot prompt never
128 times out, even if CONFIG_BOOT_RETRY_TIME is used.
129
130config AUTOBOOT_KEYED_CTRLC
131 bool "Enable Ctrl-C autoboot interruption"
132 depends on AUTOBOOT_KEYED && !AUTOBOOT_ENCRYPTION
133 default n
134 help
135 This option allows for the boot sequence to be interrupted
136 by ctrl-c, in addition to the "bootdelaykey" and "bootstopkey".
137 Setting this variable provides an escape sequence from the
138 limited "password" strings.
139
140config AUTOBOOT_STOP_STR_SHA256
141 string "Stop autobooting via SHA256 encrypted password"
142 depends on AUTOBOOT_KEYED && AUTOBOOT_ENCRYPTION
143 help
144 This option adds the feature to only stop the autobooting,
145 and therefore boot into the U-Boot prompt, when the input
146 string / password matches a values that is encypted via
147 a SHA256 hash and saved in the environment.
148
149endmenu
150
610eec7f
SP
151config BUILD_BIN2C
152 bool
153
72a8cf8d
SG
154comment "Commands"
155
156menu "Info commands"
157
158config CMD_BDI
159 bool "bdinfo"
160 default y
161 help
162 Print board info
163
61304dbe
MY
164config CMD_CONFIG
165 bool "config"
61304dbe 166 default SANDBOX
5ed063d1 167 select BUILD_BIN2C
61304dbe
MY
168 help
169 Print ".config" contents.
170
171 If this option is enabled, the ".config" file contents are embedded
172 in the U-Boot image and can be printed on the console by the "config"
173 command. This provides information of which options are enabled on
174 the running U-Boot.
175
72a8cf8d
SG
176config CMD_CONSOLE
177 bool "coninfo"
178 default y
179 help
180 Print console devices and information.
181
182config CMD_CPU
183 bool "cpu"
184 help
185 Print information about available CPUs. This normally shows the
186 number of CPUs, type (e.g. manufacturer, architecture, product or
187 internal name) and clock frequency. Other information may be
188 available depending on the CPU driver.
189
190config CMD_LICENSE
191 bool "license"
d726f225 192 select BUILD_BIN2C
72a8cf8d
SG
193 help
194 Print GPL license text
195
fa379223
CL
196config CMD_REGINFO
197 bool "reginfo"
198 depends on PPC
199 help
200 Register dump
201
72a8cf8d
SG
202endmenu
203
204menu "Boot commands"
205
206config CMD_BOOTD
207 bool "bootd"
208 default y
209 help
210 Run the command stored in the environment "bootcmd", i.e.
211 "bootd" does the same thing as "run bootcmd".
212
213config CMD_BOOTM
214 bool "bootm"
215 default y
216 help
217 Boot an application image from the memory.
218
ab8243e4
DN
219config CMD_BOOTZ
220 bool "bootz"
221 help
222 Boot the Linux zImage
223
26959271
MY
224config CMD_BOOTI
225 bool "booti"
3cedc974 226 depends on ARM64 || RISCV
26959271
MY
227 default y
228 help
229 Boot an AArch64 Linux Kernel image from memory.
230
b9939336
AG
231config CMD_BOOTEFI
232 bool "bootefi"
233 depends on EFI_LOADER
234 default y
235 help
236 Boot an EFI image from memory.
237
95b62b2e
AG
238config CMD_BOOTEFI_HELLO_COMPILE
239 bool "Compile a standard EFI hello world binary for testing"
0ea8741f 240 depends on CMD_BOOTEFI && !CPU_V7M && !SANDBOX
95b62b2e
AG
241 default y
242 help
243 This compiles a standard EFI hello world application with U-Boot so
244 that it can be used with the test/py testing framework. This is useful
245 for testing that EFI is working at a basic level, and for bringing
246 up EFI support on a new architecture.
247
248 No additional space will be required in the resulting U-Boot binary
249 when this option is enabled.
250
c7ae3dfd
SG
251config CMD_BOOTEFI_HELLO
252 bool "Allow booting a standard EFI hello world for testing"
95b62b2e 253 depends on CMD_BOOTEFI_HELLO_COMPILE
c7ae3dfd
SG
254 help
255 This adds a standard EFI hello world application to U-Boot so that
256 it can be used with the 'bootefi hello' command. This is useful
257 for testing that EFI is working at a basic level, and for bringing
258 up EFI support on a new architecture.
259
623b3a57
HS
260source lib/efi_selftest/Kconfig
261
4880b026
TR
262config CMD_BOOTMENU
263 bool "bootmenu"
264 select MENU
265 help
266 Add an ANSI terminal boot menu command.
267
d03e76af
SP
268config CMD_DTIMG
269 bool "dtimg"
270 help
271 Android DTB/DTBO image manipulation commands. Read dtb/dtbo files from
272 image into RAM, dump image structure information, etc. Those dtb/dtbo
273 files should be merged in one dtb further, which needs to be passed to
274 the kernel, as part of a boot process.
275
72a8cf8d
SG
276config CMD_ELF
277 bool "bootelf, bootvx"
278 default y
279 help
280 Boot an ELF/vxWorks image from the memory.
281
23922e26
MS
282config CMD_FDT
283 bool "Flattened Device Tree utility commands"
284 default y
285 depends on OF_LIBFDT
286 help
287 Do FDT related setup before booting into the Operating System.
288
72a8cf8d
SG
289config CMD_GO
290 bool "go"
291 default y
292 help
293 Start an application at a given address.
294
295config CMD_RUN
296 bool "run"
297 default y
298 help
299 Run the command in the given environment variable.
300
301config CMD_IMI
302 bool "iminfo"
303 default y
304 help
305 Print header information for application image.
306
307config CMD_IMLS
308 bool "imls"
72a8cf8d
SG
309 help
310 List all images found in flash
311
312config CMD_XIMG
313 bool "imxtract"
314 default y
315 help
316 Extract a part of a multi-image.
317
72c3033f
SG
318config CMD_SPL
319 bool "spl export - Export boot information for Falcon boot"
320 depends on SPL
321 help
322 Falcon mode allows booting directly from SPL into an Operating
323 System such as Linux, thus skipping U-Boot proper. See
324 doc/README.falcon for full information about how to use this
325 command.
326
203dc1b3
SG
327config CMD_SPL_NAND_OFS
328 hex "Offset of OS command line args for Falcon-mode NAND boot"
329 depends on CMD_SPL
330 default 0
331 help
332 This provides the offset of the command line arguments for Linux
333 when booting from NAND in Falcon mode. See doc/README.falcon
334 for full information about how to use this option (and also see
335 board/gateworks/gw_ventana/README for an example).
336
3a91a253
SG
337config CMD_SPL_WRITE_SIZE
338 hex "Size of argument area"
339 depends on CMD_SPL
340 default 0x2000
341 help
342 This provides the size of the command-line argument area in NAND
343 flash used by Falcon-mode boot. See the documentation until CMD_SPL
344 for detail.
345
ac08432a
MV
346config CMD_FITUPD
347 bool "fitImage update command"
348 help
349 Implements the 'fitupd' command, which allows to automatically
350 store software updates present on a TFTP server in NOR Flash
351
9b92a8d7
SG
352config CMD_THOR_DOWNLOAD
353 bool "thor - TIZEN 'thor' download"
354 help
355 Implements the 'thor' download protocol. This is a way of
356 downloading a software update over USB from an attached host.
357 There is no documentation about this within the U-Boot source code
358 but you should be able to find something on the interwebs.
359
e7a815f3
SG
360config CMD_ZBOOT
361 bool "zboot - x86 boot command"
362 help
363 With x86 machines it is common to boot a bzImage file which
364 contains both a kernel and a setup.bin file. The latter includes
365 configuration information from the dark ages which x86 boards still
366 need to pick things out of.
367
368 Consider using FIT in preference to this since it supports directly
369 booting both 32- and 64-bit kernels, as well as secure boot.
370 Documentation is available in doc/uImage.FIT/x86-fit-boot.txt
371
72a8cf8d
SG
372endmenu
373
374menu "Environment commands"
375
ab8243e4
DN
376config CMD_ASKENV
377 bool "ask for env variable"
378 help
379 Ask for environment variable
380
72a8cf8d
SG
381config CMD_EXPORTENV
382 bool "env export"
383 default y
384 help
385 Export environments.
386
387config CMD_IMPORTENV
388 bool "env import"
389 default y
390 help
391 Import environments.
392
393config CMD_EDITENV
394 bool "editenv"
395 default y
396 help
397 Edit environment variable.
398
ab8243e4
DN
399config CMD_GREPENV
400 bool "search env"
401 help
402 Allow for searching environment variables
403
72a8cf8d
SG
404config CMD_SAVEENV
405 bool "saveenv"
406 default y
407 help
408 Save all environment variables into the compiled-in persistent
409 storage.
410
411config CMD_ENV_EXISTS
412 bool "env exists"
413 default y
414 help
415 Check if a variable is defined in the environment for use in
416 shell scripting.
417
a55d29d2
SG
418config CMD_ENV_CALLBACK
419 bool "env callbacks - print callbacks and their associated variables"
420 help
421 Some environment variable have callbacks defined by
422 U_BOOT_ENV_CALLBACK. These are called when the variable changes.
423 For example changing "baudrate" adjust the serial baud rate. This
424 command lists the currently defined callbacks.
425
ffc76589
SG
426config CMD_ENV_FLAGS
427 bool "env flags -print variables that have non-default flags"
428 help
429 Some environment variables have special flags that control their
430 behaviour. For example, serial# can only be written once and cannot
431 be deleted. This command shows the variables that have special
432 flags.
433
49d81fdf
AT
434config CMD_NVEDIT_EFI
435 bool "env [set|print] -e - set/print UEFI variables"
436 depends on EFI_LOADER
437 default y
438 imply HEXDUMP
439 help
440 UEFI variables are encoded as some form of U-Boot variables.
441 If enabled, we are allowed to set/print UEFI variables using
442 "env" command with "-e" option without knowing details.
443
8e92120b
LR
444config CMD_NVEDIT_INFO
445 bool "env info - print or evaluate environment information"
446 help
447 Print environment information:
448 - env_valid : is environment valid
449 - env_ready : is environment imported into hash table
450 - env_use_default : is default environment used
451
452 This command can be optionally used for evaluation in scripts:
453 [-d] : evaluate whether default environment is used
454 [-p] : evaluate whether environment can be persisted
455 The result of multiple evaluations will be combined with AND.
456
72a8cf8d
SG
457endmenu
458
459menu "Memory commands"
460
55b25561
MS
461config CMD_BINOP
462 bool "binop"
463 help
464 Compute binary operations (xor, or, and) of byte arrays of arbitrary
465 size from memory and store the result in memory or the environment.
466
72a8cf8d
SG
467config CMD_CRC32
468 bool "crc32"
469 default y
5ed063d1 470 select HASH
72a8cf8d
SG
471 help
472 Compute CRC32.
473
221a949e
DT
474config CRC32_VERIFY
475 bool "crc32 -v"
476 depends on CMD_CRC32
477 help
478 Add -v option to verify data against a crc32 checksum.
479
a1dc980d
SG
480config CMD_EEPROM
481 bool "eeprom - EEPROM subsystem"
482 help
483 (deprecated, needs conversion to driver model)
484 Provides commands to read and write EEPROM (Electrically Erasable
485 Programmable Read Only Memory) chips that are connected over an
486 I2C bus.
487
488config CMD_EEPROM_LAYOUT
489 bool "Enable layout-aware eeprom commands"
490 depends on CMD_EEPROM
491 help
492 (deprecated, needs conversion to driver model)
493 When enabled, additional eeprom sub-commands become available.
494
495 eeprom print - prints the contents of the eeprom in a human-readable
496 way (eeprom layout fields, and data formatted to be fit for human
497 consumption).
498
499 eeprom update - allows user to update eeprom fields by specifying
500 the field name, and providing the new data in a human readable format
501 (same format as displayed by the eeprom print command).
502
503 Both commands can either auto detect the layout, or be told which
504 layout to use.
505
506 Feature API:
507 __weak int parse_layout_version(char *str)
508 - override to provide your own layout name parsing
509 __weak void __eeprom_layout_assign(struct eeprom_layout *layout,
510 int layout_version);
511 - override to setup the layout metadata based on the version
512 __weak int eeprom_layout_detect(unsigned char *data)
513 - override to provide your own algorithm for detecting layout
514 version
515 eeprom_field.c
516 - contains various printing and updating functions for common
517 types of eeprom fields. Can be used for defining
518 custom layouts.
519
520config EEPROM_LAYOUT_HELP_STRING
521 string "Tells user what layout names are supported"
522 depends on CMD_EEPROM_LAYOUT
523 default "<not defined>"
524 help
525 Help printed with the LAYOUT VERSIONS part of the 'eeprom'
526 command's help.
527
ba71be54
SG
528config LOOPW
529 bool "loopw"
530 help
531 Infinite write loop on address range
532
bea79d7d
AP
533config CMD_MD5SUM
534 bool "md5sum"
535 default n
536 select MD5
537 help
538 Compute MD5 checksum.
539
221a949e 540config MD5SUM_VERIFY
bea79d7d
AP
541 bool "md5sum -v"
542 default n
543 depends on CMD_MD5SUM
544 help
545 Add -v option to verify data against an MD5 checksum.
546
ba71be54
SG
547config CMD_MEMINFO
548 bool "meminfo"
221a949e 549 help
ba71be54 550 Display memory information.
221a949e 551
ba71be54
SG
552config CMD_MEMORY
553 bool "md, mm, nm, mw, cp, cmp, base, loop"
554 default y
72a8cf8d 555 help
ba71be54
SG
556 Memory commands.
557 md - memory display
558 mm - memory modify (auto-incrementing address)
559 nm - memory modify (constant address)
560 mw - memory write (fill)
561 cp - memory copy
562 cmp - memory compare
563 base - print or set address offset
564 loop - initialize loop on address range
72a8cf8d
SG
565
566config CMD_MEMTEST
567 bool "memtest"
568 help
569 Simple RAM read/write test.
570
e89f8aae
MS
571if CMD_MEMTEST
572
573config SYS_ALT_MEMTEST
574 bool "Alternative test"
575 help
576 Use a more complete alternative memory test.
577
578endif
579
72a8cf8d
SG
580config CMD_MX_CYCLIC
581 bool "mdc, mwc"
582 help
583 mdc - memory display cyclic
584 mwc - memory write cyclic
585
ba71be54
SG
586config CMD_SHA1SUM
587 bool "sha1sum"
588 select SHA1
72a8cf8d 589 help
ba71be54
SG
590 Compute SHA1 checksum.
591
592config SHA1SUM_VERIFY
593 bool "sha1sum -v"
594 depends on CMD_SHA1SUM
595 help
596 Add -v option to verify data against a SHA1 checksum.
72a8cf8d 597
00805d7a
SG
598config CMD_STRINGS
599 bool "strings - display strings in memory"
600 help
601 This works similarly to the Unix 'strings' command except that it
602 works with a memory range. String of printable characters found
603 within the range are displayed. The minimum number of characters
604 for a sequence to be considered a string can be provided.
605
ee7c0e71
SG
606endmenu
607
608menu "Compression commands"
609
610config CMD_LZMADEC
611 bool "lzmadec"
99e46dfc 612 default y if CMD_BOOTI
ee7c0e71
SG
613 select LZMA
614 help
615 Support decompressing an LZMA (Lempel-Ziv-Markov chain algorithm)
616 image from memory.
617
e9d33e73
MY
618config CMD_UNZIP
619 bool "unzip"
99e46dfc 620 default y if CMD_BOOTI
e9d33e73
MY
621 help
622 Uncompress a zip-compressed memory region.
623
624config CMD_ZIP
625 bool "zip"
626 help
627 Compress a memory region with zlib deflate method.
628
72a8cf8d
SG
629endmenu
630
631menu "Device access commands"
632
0c19b4d1
SG
633config CMD_ARMFLASH
634 #depends on FLASH_CFI_DRIVER
635 bool "armflash"
636 help
637 ARM Ltd reference designs flash partition access
638
051ebe32
NA
639config CMD_ADC
640 bool "adc - Access Analog to Digital Converters info and data"
641 select ADC
642 select DM_REGULATOR
643 help
644 Shows ADC device info and permit printing one-shot analog converted
645 data from a named Analog to Digital Converter.
646
db7b7a05
ER
647config CMD_BCB
648 bool "bcb"
649 depends on MMC
650 depends on PARTITIONS
651 help
652 Read/modify/write the fields of Bootloader Control Block, usually
653 stored on the flash "misc" partition with its structure defined in:
654 https://android.googlesource.com/platform/bootable/recovery/+/master/
655 bootloader_message/include/bootloader_message/bootloader_message.h
656
657 Some real-life use-cases include (but are not limited to):
658 - Determine the "boot reason" (and act accordingly):
659 https://source.android.com/devices/bootloader/boot-reason
660 - Get/pass a list of commands from/to recovery:
661 https://android.googlesource.com/platform/bootable/recovery
662 - Inspect/dump the contents of the BCB fields
663
49c752c9
JJH
664config CMD_BIND
665 bool "bind/unbind - Bind or unbind a device to/from a driver"
666 depends on DM
667 help
668 Bind or unbind a device to/from a driver from the command line.
669 This is useful in situations where a device may be handled by several
670 drivers. For example, this can be used to bind a UDC to the usb ether
671 gadget driver from the command line.
672
d315628e
SG
673config CMD_CLK
674 bool "clk - Show clock frequencies"
675 help
676 (deprecated)
677 Shows clock frequences by calling a sock_clk_dump() hook function.
678 This is depreated in favour of using the CLK uclass and accessing
679 clock values from associated drivers. However currently no command
680 exists for this.
681
0c19b4d1
SG
682config CMD_DEMO
683 bool "demo - Demonstration commands for driver model"
684 depends on DM
685 help
686 Provides a 'demo' command which can be used to play around with
687 driver model. To use this properly you will need to enable one or
688 both of the demo devices (DM_DEMO_SHAPE and DM_DEMO_SIMPLE).
689 Otherwise you will always get an empty list of devices. The demo
690 devices are defined in the sandbox device tree, so the easiest
691 option is to use sandbox and pass the -d point to sandbox's
692 u-boot.dtb file.
693
694config CMD_DFU
695 bool "dfu"
0f44d335 696 select DFU
0c19b4d1
SG
697 help
698 Enables the command "dfu" which is used to have U-Boot create a DFU
00fd59dd
SG
699 class device via USB. This command requires that the "dfu_alt_info"
700 environment variable be set and define the alt settings to expose to
701 the host.
0c19b4d1 702
72a8cf8d
SG
703config CMD_DM
704 bool "dm - Access to driver model information"
705 depends on DM
72a8cf8d
SG
706 help
707 Provides access to driver model data structures and information,
708 such as a list of devices, list of uclasses and the state of each
709 device (e.g. activated). This is not required for operation, but
710 can be useful to see the state of driver model for debugging or
711 interest.
712
312a10f1
AK
713config CMD_FASTBOOT
714 bool "fastboot - Android fastboot support"
715 depends on FASTBOOT
716 help
717 This enables the command "fastboot" which enables the Android
718 fastboot mode for the platform. Fastboot is a protocol for
719 downloading images, flashing and device control used on
f73a7df9
AK
720 Android devices. Fastboot requires either the network stack
721 enabled or support for acting as a USB device.
312a10f1
AK
722
723 See doc/README.android-fastboot for more information.
724
0c19b4d1
SG
725config CMD_FDC
726 bool "fdcboot - Boot from floppy device"
72a8cf8d 727 help
0c19b4d1
SG
728 The 'fdtboot' command allows booting an image from a floppy disk.
729
730config CMD_FLASH
731 bool "flinfo, erase, protect"
732 default y
733 help
734 NOR flash support.
735 flinfo - print FLASH memory information
736 erase - FLASH memory
737 protect - enable or disable FLASH write protection
738
739config CMD_FPGA
740 bool "fpga"
a4fa8114 741 depends on FPGA
0c19b4d1
SG
742 default y
743 help
744 FPGA support.
745
746config CMD_FPGA_LOADBP
747 bool "fpga loadbp - load partial bitstream (Xilinx only)"
748 depends on CMD_FPGA
749 help
750 Supports loading an FPGA device from a bitstream buffer containing
751 a partial bitstream.
752
753config CMD_FPGA_LOADFS
754 bool "fpga loadfs - load bitstream from FAT filesystem (Xilinx only)"
755 depends on CMD_FPGA
756 help
757 Supports loading an FPGA device from a FAT filesystem.
758
759config CMD_FPGA_LOADMK
760 bool "fpga loadmk - load bitstream from image"
761 depends on CMD_FPGA
762 help
763 Supports loading an FPGA device from a image generated by mkimage.
764
765config CMD_FPGA_LOADP
766 bool "fpga loadp - load partial bitstream"
767 depends on CMD_FPGA
768 help
769 Supports loading an FPGA device from a bitstream buffer containing
770 a partial bitstream.
771
cedd48e2
SDPP
772config CMD_FPGA_LOAD_SECURE
773 bool "fpga loads - loads secure bitstreams (Xilinx only)"
774 depends on CMD_FPGA
775 help
776 Enables the fpga loads command which is used to load secure
777 (authenticated or encrypted or both) bitstreams on to FPGA.
778
0c19b4d1
SG
779config CMD_FPGAD
780 bool "fpgad - dump FPGA registers"
781 help
782 (legacy, needs conversion to driver model)
783 Provides a way to dump FPGA registers by calling the board-specific
784 fpga_get_reg() function. This functions similarly to the 'md'
785 command.
786
787config CMD_FUSE
788 bool "fuse - support for the fuse subssystem"
789 help
790 (deprecated - needs conversion to driver model)
791 This allows reading, sensing, programming or overriding fuses
792 which control the behaviour of the device. The command uses the
793 fuse_...() API.
794
795config CMD_GPIO
796 bool "gpio"
797 help
798 GPIO support.
799
800config CMD_GPT
801 bool "GPT (GUID Partition Table) command"
0c19b4d1 802 select EFI_PARTITION
1811a928 803 select HAVE_BLOCK_DEVICE
5ed063d1 804 select PARTITION_UUIDS
47738acc 805 imply RANDOM_UUID
0c19b4d1
SG
806 help
807 Enable the 'gpt' command to ready and write GPT style partition
808 tables.
809
47738acc
MR
810config RANDOM_UUID
811 bool "GPT Random UUID generation"
a451bc27 812 select LIB_UUID
47738acc
MR
813 help
814 Enable the generation of partitions with random UUIDs if none
815 are provided.
816
0c19b4d1
SG
817config CMD_GPT_RENAME
818 bool "GPT partition renaming commands"
819 depends on CMD_GPT
820 help
821 Enables the 'gpt' command to interchange names on two GPT
822 partitions via the 'gpt swap' command or to rename single
823 partitions via the 'rename' command.
72a8cf8d 824
75eb9976
SG
825config CMD_IDE
826 bool "ide - Support for IDE drivers"
fc843a02 827 select IDE
75eb9976
SG
828 help
829 Provides an 'ide' command which allows accessing the IDE drive,
830 reseting the IDE interface, printing the partition table and
831 geting device info. It also enables the 'diskboot' command which
832 permits booting from an IDE drive.
833
594e8d1c
SG
834config CMD_IO
835 bool "io - Support for performing I/O accesses"
836 help
837 Provides an 'iod' command to display I/O space and an 'iow' command
838 to write values to the I/O space. This can be useful for manually
839 checking the state of devices during boot when debugging device
840 drivers, etc.
841
7d0f5c13
SG
842config CMD_IOTRACE
843 bool "iotrace - Support for tracing I/O activity"
844 help
845 Provides an 'iotrace' command which supports recording I/O reads and
846 writes in a trace buffer in memory . It also maintains a checksum
847 of the trace records (even if space is exhausted) so that the
848 sequence of I/O accesses can be verified.
849
850 When debugging drivers it is useful to see what I/O accesses were
851 done and in what order.
852
853 Even if the individual accesses are of little interest it can be
854 useful to verify that the access pattern is consistent each time
855 an operation is performed. In this case a checksum can be used to
856 characterise the operation of a driver. The checksum can be compared
857 across different runs of the operation to verify that the driver is
858 working properly.
859
860 In particular, when performing major refactoring of the driver, where
861 the access pattern should not change, the checksum provides assurance
862 that the refactoring work has not broken the driver.
863
864 This works by sneaking into the io.h heder for an architecture and
865 redirecting I/O accesses through iotrace's tracing mechanism.
866
867 For now no commands are provided to examine the trace buffer. The
868 format is fairly simple, so 'md' is a reasonable substitute.
869
870 Note: The checksum feature is only useful for I/O regions where the
871 contents do not change outside of software control. Where this is not
872 suitable you can fall back to manually comparing the addresses. It
873 might be useful to enhance tracing to only checksum the accesses and
874 not the data read/written.
875
0c19b4d1
SG
876config CMD_I2C
877 bool "i2c"
878 help
879 I2C support.
880
d05266f7
EH
881config CMD_W1
882 depends on W1
883 default y if W1
884 bool "w1 - Support for Dallas 1-Wire protocol"
885 help
886 Dallas 1-wire protocol support
887
72a8cf8d
SG
888config CMD_LOADB
889 bool "loadb"
890 default y
891 help
892 Load a binary file over serial line.
893
894config CMD_LOADS
895 bool "loads"
896 default y
897 help
898 Load an S-Record file over serial line
899
ab8243e4
DN
900config CMD_MMC
901 bool "mmc"
902 help
903 MMC memory mapped support.
904
5a7b11e6
AK
905config CMD_MMC_RPMB
906 bool "Enable support for RPMB in the mmc command"
907 depends on CMD_MMC
908 help
909 Enable the commands for reading, writing and programming the
910 key for the Replay Protection Memory Block partition in eMMC.
911
c232d14d
AK
912config CMD_MMC_SWRITE
913 bool "mmc swrite"
914 depends on CMD_MMC && MMC_WRITE
915 select IMAGE_SPARSE
916 help
917 Enable support for the "mmc swrite" command to write Android sparse
918 images to eMMC.
919
5db66b3a
MR
920config CMD_MTD
921 bool "mtd"
922 select MTD_PARTITIONS
923 help
924 MTD commands support.
925
72a8cf8d
SG
926config CMD_NAND
927 bool "nand"
522c282f 928 default y if NAND_SUNXI
72a8cf8d
SG
929 help
930 NAND support.
931
e915d201
BB
932if CMD_NAND
933config CMD_NAND_TRIMFFS
934 bool "nand write.trimffs"
d482a8df 935 default y if ARCH_SUNXI
e915d201
BB
936 help
937 Allows one to skip empty pages when flashing something on a NAND.
938
939config CMD_NAND_LOCK_UNLOCK
940 bool "nand lock/unlock"
941 help
942 NAND locking support.
943
944config CMD_NAND_TORTURE
945 bool "nand torture"
946 help
947 NAND torture support.
948
949endif # CMD_NAND
950
0adc38be
ZZ
951config CMD_NVME
952 bool "nvme"
953 depends on NVME
954 default y if NVME
955 help
956 NVM Express device support
957
978f0854
SG
958config CMD_ONENAND
959 bool "onenand - access to onenand device"
960 help
961 OneNAND is a brand of NAND ('Not AND' gate) flash which provides
962 various useful features. This command allows reading, writing,
963 and erasing blocks. It allso provides a way to show and change
964 bad blocks, and test the device.
965
3bf65cb5
MS
966config CMD_OSD
967 bool "osd"
968 help
969 Enable the 'osd' command which allows to query information from and
970 write text data to a on-screen display (OSD) device; a virtual device
971 associated with a display capable of displaying a text overlay on the
972 display it's associated with..
973
b331cd62
PD
974config CMD_PART
975 bool "part"
1811a928 976 select HAVE_BLOCK_DEVICE
5ed063d1 977 select PARTITION_UUIDS
b331cd62
PD
978 help
979 Read and display information about the partition table on
980 various media.
981
6500ec7a
SG
982config CMD_PCI
983 bool "pci - Access PCI devices"
984 help
985 Provide access to PCI (Peripheral Interconnect Bus), a type of bus
986 used on some devices to allow the CPU to communicate with its
987 peripherals. Sub-commands allow bus enumeration, displaying and
988 changing configuration space and a few other features.
989
7f666555
SG
990config CMD_PCMCIA
991 bool "pinit - Set up PCMCIA device"
992 help
993 Provides a means to initialise a PCMCIA (Personal Computer Memory
994 Card International Association) device. This is an old standard from
995 about 1990. These devices are typically removable memory or network
996 cards using a standard 68-pin connector.
997
d5a83139
PC
998config CMD_PINMUX
999 bool "pinmux - show pins muxing"
1000 default y if PINCTRL
1001 help
1002 Parse all available pin-controllers and show pins muxing. This
1003 is useful for debug purpoer to check the pin muxing and to know if
1004 a pin is configured as a GPIO or as an alternate function.
1005
577c40ae
AF
1006config CMD_POWEROFF
1007 bool "poweroff"
1008 help
1009 Poweroff/Shutdown the system
1010
b75dfd2d
SG
1011config CMD_READ
1012 bool "read - Read binary data from a partition"
1013 help
1014 Provides low-level access to the data in a partition.
1015
0c19b4d1
SG
1016config CMD_REMOTEPROC
1017 bool "remoteproc"
1018 depends on REMOTEPROC
1019 help
1020 Support for Remote Processor control
1021
1022config CMD_SATA
1023 bool "sata - Access SATA subsystem"
1024 select SATA
1025 help
1026 SATA (Serial Advanced Technology Attachment) is a serial bus
1027 standard for connecting to hard drives and other storage devices.
1028 This command provides information about attached devices and allows
1029 reading, writing and other operations.
1030
1031 SATA replaces PATA (originally just ATA), which stands for Parallel AT
1032 Attachment, where AT refers to an IBM AT (Advanced Technology)
1033 computer released in 1984.
1034
15dc63d6
SG
1035config CMD_SAVES
1036 bool "saves - Save a file over serial in S-Record format"
1037 help
1038 Provides a way to save a binary file using the Motorola S-Record
1039 format over the serial line.
1040
0c3fecd0
HS
1041config CMD_SCSI
1042 bool "scsi - Access to SCSI devices"
1043 default y if SCSI
1044 help
1045 This provides a 'scsi' command which provides access to SCSI (Small
1046 Computer System Interface) devices. The command provides a way to
1047 scan the bus, reset the bus, read and write data and get information
1048 about devices.
1049
efce2442
SG
1050config CMD_SDRAM
1051 bool "sdram - Print SDRAM configuration information"
1052 help
1053 Provides information about attached SDRAM. This assumed that the
1054 SDRAM has an EEPROM with information that can be read using the
1055 I2C bus. This is only available on some boards.
1056
72a8cf8d
SG
1057config CMD_SF
1058 bool "sf"
a4298dda 1059 depends on DM_SPI_FLASH || SPI_FLASH
72a8cf8d
SG
1060 help
1061 SPI Flash support
1062
719d36ee
SG
1063config CMD_SF_TEST
1064 bool "sf test - Allow testing of SPI flash"
a4298dda 1065 depends on CMD_SF
719d36ee
SG
1066 help
1067 Provides a way to test that SPI flash is working correctly. The
1068 test is destructive, in that an area of SPI flash must be provided
1069 for the test to use. Performance information is also provided,
1070 measuring the performance of reading, writing and erasing in
1071 Mbps (Million Bits Per Second). This value should approximately
1072 equal the SPI bus speed for a single-bit-wide SPI bus, assuming
1073 everything is working properly.
1074
72a8cf8d 1075config CMD_SPI
c95e632d 1076 bool "sspi - Command to access spi device"
a4298dda 1077 depends on SPI
72a8cf8d
SG
1078 help
1079 SPI utility command.
1080
c95e632d
PD
1081config DEFAULT_SPI_BUS
1082 int "default spi bus used by sspi command"
1083 depends on CMD_SPI
1084 default 0
1085
1086config DEFAULT_SPI_MODE
1087 hex "default spi mode used by sspi command (see include/spi.h)"
1088 depends on CMD_SPI
1089 default 0
1090
5605aa8a
SG
1091config CMD_TSI148
1092 bool "tsi148 - Command to access tsi148 device"
1093 help
1094 This provides various sub-commands to initialise and configure the
1095 Turndra tsi148 device. See the command help for full details.
1096
2a242e3e
SG
1097config CMD_UNIVERSE
1098 bool "universe - Command to set up the Turndra Universe controller"
1099 help
1100 This allows setting up the VMEbus provided by this controller.
1101 See the command help for full details.
1102
72a8cf8d
SG
1103config CMD_USB
1104 bool "usb"
1811a928 1105 select HAVE_BLOCK_DEVICE
72a8cf8d
SG
1106 help
1107 USB support.
1108
2f005695
SA
1109config CMD_USB_SDP
1110 bool "sdp"
1111 select USB_FUNCTION_SDP
1112 help
1113 Enables the command "sdp" which is used to have U-Boot emulating the
1114 Serial Download Protocol (SDP) via USB.
6e7bdde4 1115
453c95e0
EC
1116config CMD_ROCKUSB
1117 bool "rockusb"
1118 depends on USB_FUNCTION_ROCKUSB
1119 help
6e7bdde4 1120 Rockusb protocol is widely used by Rockchip SoC based devices. It can
453c95e0
EC
1121 read/write info, image to/from devices. This enable rockusb command
1122 support to communication with rockusb device. for more detail about
1123 this command, please read doc/README.rockusb.
2f005695 1124
ab8243e4
DN
1125config CMD_USB_MASS_STORAGE
1126 bool "UMS usb mass storage"
e4d4604a 1127 select USB_FUNCTION_MASS_STORAGE
ab8243e4
DN
1128 help
1129 USB mass storage support
1130
78e12901
TT
1131config CMD_VIRTIO
1132 bool "virtio"
1133 depends on VIRTIO
1134 default y if VIRTIO
1135 help
1136 VirtIO block device support
1137
82a00be3
MW
1138config CMD_WDT
1139 bool "wdt"
1140 depends on WDT
1141 help
1142 This provides commands to control the watchdog timer devices.
1143
37c4a5f6
MS
1144config CMD_AXI
1145 bool "axi"
1146 depends on AXI
1147 help
1148 Enable the command "axi" for accessing AXI (Advanced eXtensible
1149 Interface) busses, a on-chip interconnect specification for managing
1150 functional blocks in SoC designs, which is also often used in designs
1151 involving FPGAs (e.g. communication with IP cores in Xilinx FPGAs).
72a8cf8d
SG
1152endmenu
1153
1154
1155menu "Shell scripting commands"
1156
1157config CMD_ECHO
1158 bool "echo"
1159 default y
1160 help
1161 Echo args to console
1162
1163config CMD_ITEST
1164 bool "itest"
1165 default y
1166 help
1167 Return true/false on integer compare.
1168
1169config CMD_SOURCE
1170 bool "source"
1171 default y
1172 help
1173 Run script from memory
1174
1175config CMD_SETEXPR
1176 bool "setexpr"
1177 default y
1178 help
1179 Evaluate boolean and math expressions and store the result in an env
1180 variable.
1181 Also supports loading the value at a memory location into a variable.
1182 If CONFIG_REGEX is enabled, setexpr also supports a gsub function.
1183
1184endmenu
1185
3b3ea2c5
MS
1186if NET
1187
d7a45eaf
JH
1188menuconfig CMD_NET
1189 bool "Network commands"
1190 default y
d7869b21 1191 imply NETDEVICES
d7a45eaf
JH
1192
1193if CMD_NET
1194
1195config CMD_BOOTP
1196 bool "bootp"
72a8cf8d
SG
1197 default y
1198 help
72a8cf8d 1199 bootp - boot image via network using BOOTP/TFTP protocol
d7a45eaf 1200
e88b2563
JH
1201config CMD_DHCP
1202 bool "dhcp"
1203 depends on CMD_BOOTP
1204 help
1205 Boot image via network using DHCP/TFTP protocol
1206
92fa44d5 1207config BOOTP_BOOTPATH
8df69d90 1208 bool "Request & store 'rootpath' from BOOTP/DHCP server"
3dfbc53b 1209 default y
92fa44d5 1210 depends on CMD_BOOTP
8df69d90
JH
1211 help
1212 Even though the config is called BOOTP_BOOTPATH, it stores the
1213 path in the variable 'rootpath'.
92fa44d5
JH
1214
1215config BOOTP_DNS
8df69d90 1216 bool "Request & store 'dnsip' from BOOTP/DHCP server"
3dfbc53b 1217 default y
92fa44d5 1218 depends on CMD_BOOTP
8df69d90
JH
1219 help
1220 The primary DNS server is stored as 'dnsip'. If two servers are
1221 returned, you must set BOOTP_DNS2 to store that second server IP
1222 also.
92fa44d5 1223
80449c03
JH
1224config BOOTP_DNS2
1225 bool "Store 'dnsip2' from BOOTP/DHCP server"
1226 depends on BOOTP_DNS
1227 help
1228 If a DHCP client requests the DNS server IP from a DHCP server,
1229 it is possible that more than one DNS serverip is offered to the
1230 client. If CONFIG_BOOTP_DNS2 is enabled, the secondary DNS
1231 server IP will be stored in the additional environment
1232 variable "dnsip2". The first DNS serverip is always
1233 stored in the variable "dnsip", when BOOTP_DNS is defined.
1234
92fa44d5 1235config BOOTP_GATEWAY
8df69d90 1236 bool "Request & store 'gatewayip' from BOOTP/DHCP server"
3dfbc53b 1237 default y
92fa44d5
JH
1238 depends on CMD_BOOTP
1239
1240config BOOTP_HOSTNAME
8df69d90 1241 bool "Request & store 'hostname' from BOOTP/DHCP server"
3dfbc53b 1242 default y
92fa44d5 1243 depends on CMD_BOOTP
8df69d90
JH
1244 help
1245 The name may or may not be qualified with the local domain name.
92fa44d5 1246
bdce340c
AG
1247config BOOTP_PREFER_SERVERIP
1248 bool "serverip variable takes precedent over DHCP server IP."
1249 depends on CMD_BOOTP
1250 help
1251 By default a BOOTP/DHCP reply will overwrite the 'serverip' variable.
1252
1253 With this option enabled, the 'serverip' variable in the environment
1254 takes precedence over DHCP server IP and will only be set by the DHCP
1255 server if not already set in the environment.
1256
92fa44d5 1257config BOOTP_SUBNETMASK
8df69d90 1258 bool "Request & store 'netmask' from BOOTP/DHCP server"
3dfbc53b 1259 default y
92fa44d5
JH
1260 depends on CMD_BOOTP
1261
9b23c73d
CP
1262config BOOTP_NTPSERVER
1263 bool "Request & store 'ntpserverip' from BOOTP/DHCP server"
1264 depends on CMD_BOOTP
1265
92fa44d5 1266config BOOTP_PXE
2b9f486b 1267 bool "Send PXE client arch to BOOTP/DHCP server"
3dfbc53b 1268 default y
2b9f486b
JH
1269 depends on CMD_BOOTP && CMD_PXE
1270 help
1271 Supported for ARM, ARM64, and x86 for now.
92fa44d5
JH
1272
1273config BOOTP_PXE_CLIENTARCH
1274 hex
2b9f486b 1275 depends on BOOTP_PXE
92fa44d5
JH
1276 default 0x16 if ARM64
1277 default 0x15 if ARM
1278 default 0 if X86
1279
1280config BOOTP_VCI_STRING
1281 string
1282 depends on CMD_BOOTP
4bbd6b1d 1283 default "U-Boot.armv7" if CPU_V7A || CPU_V7M || CPU_V7R
92fa44d5
JH
1284 default "U-Boot.armv8" if ARM64
1285 default "U-Boot.arm" if ARM
1286 default "U-Boot"
1287
d7a45eaf
JH
1288config CMD_TFTPBOOT
1289 bool "tftpboot"
1290 default y
1291 help
72a8cf8d
SG
1292 tftpboot - boot image via network using TFTP protocol
1293
1294config CMD_TFTPPUT
1295 bool "tftp put"
d7a45eaf 1296 depends on CMD_TFTPBOOT
72a8cf8d
SG
1297 help
1298 TFTP put command, for uploading files to a server
1299
1300config CMD_TFTPSRV
1301 bool "tftpsrv"
d7a45eaf 1302 depends on CMD_TFTPBOOT
72a8cf8d
SG
1303 help
1304 Act as a TFTP server and boot the first received file
1305
92fa44d5
JH
1306config NET_TFTP_VARS
1307 bool "Control TFTP timeout and count through environment"
1308 depends on CMD_TFTPBOOT
1309 default y
1310 help
1311 If set, allows controlling the TFTP timeout through the
1312 environment variable tftptimeout, and the TFTP maximum
1313 timeout count through the variable tftptimeoutcountmax.
1314 If unset, timeout and maximum are hard-defined as 1 second
1315 and 10 timouts per TFTP transfer.
1316
72a8cf8d
SG
1317config CMD_RARP
1318 bool "rarpboot"
1319 help
1320 Boot image via network using RARP/TFTP protocol
1321
72a8cf8d
SG
1322config CMD_NFS
1323 bool "nfs"
1324 default y
1325 help
1326 Boot image via network using NFS protocol.
1327
ab8243e4
DN
1328config CMD_MII
1329 bool "mii"
1330 help
1331 Enable MII utility commands.
1332
72a8cf8d
SG
1333config CMD_PING
1334 bool "ping"
1335 help
1336 Send ICMP ECHO_REQUEST to network host
1337
1338config CMD_CDP
1339 bool "cdp"
1340 help
1341 Perform CDP network configuration
1342
1343config CMD_SNTP
1344 bool "sntp"
1345 help
1346 Synchronize RTC via network
1347
1348config CMD_DNS
1349 bool "dns"
1350 help
1351 Lookup the IP of a hostname
1352
1353config CMD_LINK_LOCAL
1354 bool "linklocal"
6f0dc0ca 1355 select LIB_RAND
72a8cf8d
SG
1356 help
1357 Acquire a network IP address using the link-local protocol
1358
92fa44d5
JH
1359endif
1360
ef072200
SG
1361config CMD_ETHSW
1362 bool "ethsw"
1363 help
1364 Allow control of L2 Ethernet switch commands. These are supported
1365 by the vsc9953 Ethernet driver at present. Sub-commands allow
1366 operations such as enabling / disabling a port and
1367 viewing/maintaining the filtering database (FDB)
1368
92fa44d5
JH
1369config CMD_PXE
1370 bool "pxe"
1371 select MENU
1372 help
1373 Boot image via network using PXE protocol
3b3ea2c5 1374
d8970dae
LF
1375config CMD_WOL
1376 bool "wol"
1377 help
1378 Wait for wake-on-lan Magic Packet
1379
d7a45eaf 1380endif
72a8cf8d
SG
1381
1382menu "Misc commands"
1383
0f710258
SG
1384config CMD_BMP
1385 bool "Enable 'bmp' command"
1386 depends on LCD || DM_VIDEO || VIDEO
1387 help
1388 This provides a way to obtain information about a BMP-format iamge
1389 and to display it. BMP (which presumably stands for BitMaP) is a
1390 file format defined by Microsoft which supports images of various
1391 depths, formats and compression methods. Headers on the file
1392 determine the formats used. This command can be used by first loading
1393 the image into RAM, then using this command to look at it or display
1394 it.
1395
b11ed7d6
AK
1396config CMD_BOOTCOUNT
1397 bool "bootcount"
1398 depends on BOOTCOUNT_LIMIT
1399 help
1400 Enable the bootcount command, which allows interrogation and
1401 reset of the bootcounter.
1402
4893e34b
SG
1403config CMD_BSP
1404 bool "Enable board-specific commands"
1405 help
1406 (deprecated: instead, please define a Kconfig option for each command)
1407
1408 Some boards have board-specific commands which are only enabled
1409 during developemnt and need to be turned off for production. This
1410 option provides a way to control this. The commands that are enabled
1411 vary depending on the board.
1412
cd3d4880
TM
1413config CMD_BKOPS_ENABLE
1414 bool "mmc bkops enable"
1415 depends on CMD_MMC
1416 default n
1417 help
1418 Enable command for setting manual background operations handshake
1419 on a eMMC device. The feature is optionally available on eMMC devices
1420 conforming to standard >= 4.41.
1421
e40cf34a
EN
1422config CMD_BLOCK_CACHE
1423 bool "blkcache - control and stats for block cache"
1424 depends on BLOCK_CACHE
1425 default y if BLOCK_CACHE
1426 help
1427 Enable the blkcache command, which can be used to control the
1428 operation of the cache functions.
1429 This is most useful when fine-tuning the operation of the cache
1430 during development, but also allows the cache to be disabled when
1431 it might hurt performance (e.g. when using the ums command).
1432
ab8243e4
DN
1433config CMD_CACHE
1434 bool "icache or dcache"
1435 help
1436 Enable the "icache" and "dcache" commands
1437
29cfc096
HS
1438config CMD_CONITRACE
1439 bool "conitrace - trace console input codes"
1440 help
1441 Enable the 'conitrace' command which displays the codes received
1442 from the console input as hexadecimal numbers.
1443
4e92e60d
AG
1444config CMD_CLS
1445 bool "Enable clear screen command 'cls'"
1446 depends on CFB_CONSOLE || DM_VIDEO || LCD || VIDEO
1447 default y if LCD
1448 help
1449 Enable the 'cls' command which clears the screen contents
1450 on video frame buffer.
1451
59df7e7e
AT
1452config CMD_EFIDEBUG
1453 bool "efidebug - display/configure UEFI environment"
1454 depends on EFI_LOADER
64b5ba4d 1455 select EFI_DEVICE_PATH_TO_TEXT
59df7e7e
AT
1456 default n
1457 help
1458 Enable the 'efidebug' command which provides a subset of UEFI
1459 shell utility with simplified functionality. It will be useful
1460 particularly for managing boot parameters as well as examining
1461 various EFI status for debugging.
1462
dab8788a
HS
1463config CMD_EXCEPTION
1464 bool "exception - raise exception"
1465 depends on ARM || RISCV || X86
1466 help
1467 Enable the 'exception' command which allows to raise an exception.
1468
ffe2052d
SG
1469config CMD_LED
1470 bool "led"
2ab6e74d 1471 depends on LED
ffe2052d
SG
1472 default y if LED
1473 help
1474 Enable the 'led' command which allows for control of LEDs supported
1475 by the board. The LEDs can be listed with 'led list' and controlled
1476 with led on/off/togle/blink. Any LED drivers can be controlled with
1477 this command, e.g. led_gpio.
1478
c9032ce1
CP
1479config CMD_DATE
1480 bool "date"
1481 default y if DM_RTC
1482 help
1483 Enable the 'date' command for getting/setting the time/date in RTC
1484 devices.
1485
72a8cf8d
SG
1486config CMD_TIME
1487 bool "time"
1488 help
1489 Run commands and summarize execution time.
1490
d91a9d7f
SG
1491config CMD_GETTIME
1492 bool "gettime - read elapsed time"
1493 help
1494 Enable the 'gettime' command which reads the elapsed time since
1495 U-Boot started running. This shows the time in seconds and
1496 milliseconds. See also the 'bootstage' command which provides more
1497 flexibility for boot timing.
1498
72a8cf8d
SG
1499# TODO: rename to CMD_SLEEP
1500config CMD_MISC
1501 bool "sleep"
1502 default y
1503 help
1504 Delay execution for some time
1505
0fd2290c
SDPP
1506config MP
1507 bool "support for multiprocessor"
1508 help
1509 This provides an option to brinup
1510 different processors in multiprocessor
1511 cases.
1512
72a8cf8d
SG
1513config CMD_TIMER
1514 bool "timer"
1515 help
1516 Access the system timer.
1517
72a8cf8d
SG
1518config CMD_SOUND
1519 bool "sound"
1520 depends on SOUND
1521 help
1522 This provides basic access to the U-Boot's sound support. The main
1523 feature is to play a beep.
1524
1525 sound init - set up sound system
1526 sound play - play a sound
1527
18686590 1528config CMD_QFW
dd6f3abb 1529 bool "qfw"
fcf5c041 1530 select QFW
dd6f3abb
TR
1531 help
1532 This provides access to the QEMU firmware interface. The main
1533 feature is to allow easy loading of files passed to qemu-system
1534 via -kernel / -initrd
fa61ef6b
KP
1535
1536source "cmd/mvebu/Kconfig"
1537
3cef3b31
SG
1538config CMD_TERMINAL
1539 bool "terminal - provides a way to attach a serial terminal"
1540 help
1541 Provides a 'cu'-like serial terminal command. This can be used to
1542 access other serial ports from the system console. The terminal
1543 is very simple with no special processing of characters. As with
1544 cu, you can press ~. (tilde followed by period) to exit.
1545
1aa4e8d0
SG
1546config CMD_UUID
1547 bool "uuid, guid - generation of unique IDs"
a451bc27 1548 select LIB_UUID
1aa4e8d0
SG
1549 help
1550 This enables two commands:
1551
1552 uuid - generate random Universally Unique Identifier
1553 guid - generate Globally Unique Identifier based on random UUID
1554
1555 The two commands are very similar except for the endianness of the
1556 output.
1557
72a8cf8d
SG
1558endmenu
1559
5cd9661d
LV
1560source "cmd/ti/Kconfig"
1561
72a8cf8d
SG
1562config CMD_BOOTSTAGE
1563 bool "Enable the 'bootstage' command"
1564 depends on BOOTSTAGE
1565 help
1566 Add a 'bootstage' command which supports printing a report
1567 and un/stashing of bootstage data.
1568
1569menu "Power commands"
1570config CMD_PMIC
1571 bool "Enable Driver Model PMIC command"
1572 depends on DM_PMIC
1573 help
1574 This is the pmic command, based on a driver model pmic's API.
1575 Command features are unchanged:
1576 - list - list pmic devices
1577 - pmic dev <id> - show or [set] operating pmic device (NEW)
1578 - pmic dump - dump registers
1579 - pmic read address - read byte of register at address
1580 - pmic write address - write byte to register at address
1581 The only one change for this command is 'dev' subcommand.
1582
1583config CMD_REGULATOR
1584 bool "Enable Driver Model REGULATOR command"
1585 depends on DM_REGULATOR
1586 help
1587 This command is based on driver model regulator's API.
1588 User interface features:
1589 - list - list regulator devices
1590 - regulator dev <id> - show or [set] operating regulator device
1591 - regulator info - print constraints info
1592 - regulator status - print operating status
1593 - regulator value <val] <-f> - print/[set] voltage value [uV]
1594 - regulator current <val> - print/[set] current value [uA]
1595 - regulator mode <id> - print/[set] operating mode id
1596 - regulator enable - enable the regulator output
1597 - regulator disable - disable the regulator output
1598
1599 The '-f' (force) option can be used for set the value which exceeds
1600 the limits, which are found in device-tree and are kept in regulator's
1601 uclass platdata structure.
1602
1603endmenu
1604
1605menu "Security commands"
b1a873df
SG
1606config CMD_AES
1607 bool "Enable the 'aes' command"
1608 select AES
1609 help
1610 This provides a means to encrypt and decrypt data using the AES
1611 (Advanced Encryption Standard). This algorithm uses a symetric key
1612 and is widely used as a streaming cipher. Different key lengths are
1613 supported by the algorithm but this command only supports 128 bits
1614 at present.
1615
c04b9b34
SG
1616config CMD_BLOB
1617 bool "Enable the 'blob' command"
1618 help
1619 This is used with the Freescale secure boot mechanism.
1620
1621 Freescale's SEC block has built-in Blob Protocol which provides
1622 a method for protecting user-defined data across system power
1623 cycles. SEC block protects data in a data structure called a Blob,
1624 which provides both confidentiality and integrity protection.
1625
1626 Encapsulating data as a blob
1627 Each time that the Blob Protocol is used to protect data, a
1628 different randomly generated key is used to encrypt the data.
1629 This random key is itself encrypted using a key which is derived
1630 from SoC's non-volatile secret key and a 16 bit Key identifier.
1631 The resulting encrypted key along with encrypted data is called a
1632 blob. The non-volatile secure key is available for use only during
1633 secure boot.
1634
1635 During decapsulation, the reverse process is performed to get back
1636 the original data.
1637
1638 Sub-commands:
6e7bdde4 1639 blob enc - encapsulating data as a cryptgraphic blob
c04b9b34
SG
1640 blob dec - decapsulating cryptgraphic blob to get the data
1641
1642 Syntax:
1643
1644 blob enc src dst len km
1645
1646 Encapsulate and create blob of data $len bytes long
1647 at address $src and store the result at address $dst.
1648 $km is the 16 byte key modifier is also required for
1649 generation/use as key for cryptographic operation. Key
1650 modifier should be 16 byte long.
1651
1652 blob dec src dst len km
1653
1654 Decapsulate the blob of data at address $src and
1655 store result of $len byte at addr $dst.
1656 $km is the 16 byte key modifier is also required for
1657 generation/use as key for cryptographic operation. Key
1658 modifier should be 16 byte long.
1659
551c3934
SG
1660config CMD_HASH
1661 bool "Support 'hash' command"
d70f919e 1662 select HASH
551c3934
SG
1663 help
1664 This provides a way to hash data in memory using various supported
1665 algorithms (such as SHA1, MD5, CRC32). The computed digest can be
1666 saved to memory or to an environment variable. It is also possible
1667 to verify a hash against data in memory.
1668
666028fc
MP
1669config CMD_HVC
1670 bool "Support the 'hvc' command"
1671 depends on ARM_SMCCC
1672 help
1673 Allows issuing Hypervisor Calls (HVCs). Mostly useful for
1674 development and testing.
1675
1676config CMD_SMC
1677 bool "Support the 'smc' command"
1678 depends on ARM_SMCCC
1679 help
1680 Allows issuing Secure Monitor Calls (SMCs). Mostly useful for
1681 development and testing.
1682
221a949e
DT
1683config HASH_VERIFY
1684 bool "hash -v"
1685 depends on CMD_HASH
1686 help
1687 Add -v option to verify data against a hash.
1688
9f9ce3c3
MR
1689config CMD_TPM_V1
1690 bool
1691
1692config CMD_TPM_V2
1693 bool
3a8c8bff 1694 select CMD_LOG
9f9ce3c3 1695
72a8cf8d
SG
1696config CMD_TPM
1697 bool "Enable the 'tpm' command"
9f9ce3c3
MR
1698 depends on TPM_V1 || TPM_V2
1699 select CMD_TPM_V1 if TPM_V1
1700 select CMD_TPM_V2 if TPM_V2
72a8cf8d
SG
1701 help
1702 This provides a means to talk to a TPM from the command line. A wide
1703 range of commands if provided - see 'tpm help' for details. The
1704 command requires a suitable TPM on your board and the correct driver
1705 must be enabled.
1706
9f9ce3c3
MR
1707if CMD_TPM
1708
72a8cf8d
SG
1709config CMD_TPM_TEST
1710 bool "Enable the 'tpm test' command"
9f9ce3c3 1711 depends on TPM_V1
72a8cf8d 1712 help
9f9ce3c3
MR
1713 This provides a a series of tests to confirm that the TPMv1.x is
1714 working correctly. The tests cover initialisation, non-volatile RAM,
1715 extend, global lock and checking that timing is within expectations.
1716 The tests pass correctly on Infineon TPMs but may need to be adjusted
72a8cf8d
SG
1717 for other devices.
1718
9f9ce3c3
MR
1719endif
1720
72a8cf8d 1721endmenu
bfeba017
MF
1722
1723menu "Firmware commands"
1724config CMD_CROS_EC
1725 bool "Enable crosec command"
1726 depends on CROS_EC
1727 default y
1728 help
1729 Enable command-line access to the Chrome OS EC (Embedded
1730 Controller). This provides the 'crosec' command which has
1731 a number of sub-commands for performing EC tasks such as
1732 updating its flash, accessing a small saved context area
1733 and talking to the I2C bus behind the EC (if there is one).
1734endmenu
72a8cf8d 1735
ab8243e4 1736menu "Filesystem commands"
9d845509
MB
1737config CMD_BTRFS
1738 bool "Enable the 'btrsubvol' command"
1739 select FS_BTRFS
1740 help
1741 This enables the 'btrsubvol' command to list subvolumes
1742 of a BTRFS filesystem. There are no special commands for
1743 listing BTRFS directories or loading BTRFS files - this
1744 can be done by the generic 'fs' commands (see CMD_FS_GENERIC)
1745 when BTRFS is enabled (see FS_BTRFS).
1746
d66a10fc
SG
1747config CMD_CBFS
1748 bool "Enable the 'cbfs' command"
deb95999 1749 depends on FS_CBFS
d66a10fc
SG
1750 help
1751 Define this to enable support for reading from a Coreboot
1752 filesystem. This is a ROM-based filesystem used for accessing files
1753 on systems that use coreboot as the first boot-loader and then load
1754 U-Boot to actually boot the Operating System. Available commands are
1755 cbfsinit, cbfsinfo, cbfsls and cbfsload.
1756
97072747
SG
1757config CMD_CRAMFS
1758 bool "Enable the 'cramfs' command"
80e44cfe 1759 depends on FS_CRAMFS
97072747
SG
1760 help
1761 This provides commands for dealing with CRAMFS (Compressed ROM
1762 filesystem). CRAMFS is useful when space is tight since files are
1763 compressed. Two commands are provided:
1764
1765 cramfsls - lists files in a cramfs image
1766 cramfsload - loads a file from a cramfs image
1767
ab8243e4
DN
1768config CMD_EXT2
1769 bool "ext2 command support"
3d22bae5 1770 select FS_EXT4
ab8243e4
DN
1771 help
1772 Enables EXT2 FS command
1773
1774config CMD_EXT4
1775 bool "ext4 command support"
3d22bae5 1776 select FS_EXT4
ab8243e4
DN
1777 help
1778 Enables EXT4 FS command
1779
1780config CMD_EXT4_WRITE
1781 depends on CMD_EXT4
1782 bool "ext4 write command support"
3d22bae5 1783 select EXT4_WRITE
ab8243e4
DN
1784 help
1785 Enables EXT4 FS write command
1786
1787config CMD_FAT
1788 bool "FAT command support"
eedfb89e 1789 select FS_FAT
ab8243e4
DN
1790 help
1791 Support for the FAT fs
1792
1793config CMD_FS_GENERIC
1794 bool "filesystem commands"
1795 help
1796 Enables filesystem commands (e.g. load, ls) that work for multiple
1797 fs types.
0269dfae 1798
efbe99ce
JM
1799config CMD_FS_UUID
1800 bool "fsuuid command"
1801 help
1802 Enables fsuuid command for filesystem UUID.
1803
b8682a7f
SG
1804config CMD_JFFS2
1805 bool "jffs2 command"
59e12a4a 1806 select FS_JFFS2
b8682a7f
SG
1807 help
1808 Enables commands to support the JFFS2 (Journalling Flash File System
1809 version 2) filesystem. This enables fsload, ls and fsinfo which
1810 provide the ability to load files, list directories and obtain
1811 filesystem information.
1812
0269dfae 1813config CMD_MTDPARTS
0269dfae 1814 bool "MTD partition support"
9c5b0097 1815 select MTD_DEVICE if (CMD_NAND || NAND)
0269dfae 1816 help
938db6fe
MR
1817 MTD partitioning tool support.
1818 It is strongly encouraged to avoid using this command
1819 anymore along with 'sf', 'nand', 'onenand'. One can still
1820 declare the partitions in the mtdparts environment variable
1821 but better use the MTD stack and the 'mtd' command instead.
0269dfae
MR
1822
1823config MTDIDS_DEFAULT
1824 string "Default MTD IDs"
03303fb7 1825 depends on MTD_PARTITIONS || CMD_MTDPARTS || CMD_NAND || CMD_FLASH
0269dfae 1826 help
43ede0bc
TR
1827 Defines a default MTD IDs list for use with MTD partitions in the
1828 Linux MTD command line partitions format.
0269dfae
MR
1829
1830config MTDPARTS_DEFAULT
1831 string "Default MTD partition scheme"
03303fb7 1832 depends on MTD_PARTITIONS || CMD_MTDPARTS || CMD_NAND || CMD_FLASH
0269dfae
MR
1833 help
1834 Defines a default MTD partitioning scheme in the Linux MTD command
1835 line partitions format
1836
cb70e6cb
SG
1837config CMD_MTDPARTS_SPREAD
1838 bool "Padd partition size to take account of bad blocks"
1839 depends on CMD_MTDPARTS
1840 help
1841 This enables the 'spread' sub-command of the mtdparts command.
1842 This command will modify the existing mtdparts variable by increasing
1843 the size of the partitions such that 1) each partition's net size is
1844 at least as large as the size specified in the mtdparts variable and
1845 2) each partition starts on a good block.
1846
f8803a99
SG
1847config CMD_REISER
1848 bool "reiser - Access to reiserfs filesystems"
1849 help
1850 This provides two commands which operate on a resierfs filesystem,
1851 commonly used some years ago:
1852
1853 reiserls - list files
1854 reiserload - load a file
1855
7a764318
SG
1856config CMD_YAFFS2
1857 bool "yaffs2 - Access of YAFFS2 filesystem"
1858 depends on YAFFS2
1859 default y
1860 help
1861 This provides commands for accessing a YAFFS2 filesystem. Yet
1862 Another Flash Filesystem 2 is a filesystem designed specifically
1863 for NAND flash. It incorporates bad-block management and ensures
1864 that device writes are sequential regardless of filesystem
1865 activity.
1866
54feea17
SG
1867config CMD_ZFS
1868 bool "zfs - Access of ZFS filesystem"
1869 help
1870 This provides commands to accessing a ZFS filesystem, commonly used
1871 on Solaris systems. Two sub-commands are provided:
1872
1873 zfsls - list files in a directory
1874 zfsload - load a file
1875
1876 See doc/README.zfs for more details.
1877
ab8243e4
DN
1878endmenu
1879
ac20a1b2
SG
1880menu "Debug commands"
1881
1882config CMD_BEDBUG
1883 bool "bedbug"
1884 help
1885 The bedbug (emBEDded deBUGger) command provides debugging features
1886 for some PowerPC processors. For details please see the
1887 docuemntation in doc/README.beddbug
1888
3bd25cb5
SG
1889config CMD_DIAG
1890 bool "diag - Board diagnostics"
1891 help
1892 This command provides access to board diagnostic tests. These are
1893 called Power-on Self Tests (POST). The command allows listing of
1894 available tests and running either all the tests, or specific tests
1895 identified by name.
1896
1b330894
SG
1897config CMD_IRQ
1898 bool "irq - Show information about interrupts"
064b55cf 1899 depends on !ARM && !MIPS && !SH
1b330894
SG
1900 help
1901 This enables two commands:
1902
1903 interrupts - enable or disable interrupts
1904 irqinfo - print device-specific interrupt information
6bac227a
SG
1905
1906config CMD_KGDB
1907 bool "kgdb - Allow debugging of U-Boot with gdb"
b9205506 1908 depends on PPC
6bac227a
SG
1909 help
1910 This enables a 'kgdb' command which allows gdb to connect to U-Boot
1911 over a serial link for debugging purposes. This allows
1912 single-stepping, inspecting variables, etc. This is supported only
1913 on PowerPC at present.
1914
d5f61f27
SG
1915config CMD_LOG
1916 bool "log - Generation, control and access to logging"
83a1f933 1917 select LOG
d5f61f27
SG
1918 help
1919 This provides access to logging features. It allows the output of
1920 log data to be controlled to a limited extent (setting up the default
ef11ed82
SG
1921 maximum log level for emitting of records). It also provides access
1922 to a command used for testing the log system.
d5f61f27 1923
ce058ae5
SG
1924config CMD_TRACE
1925 bool "trace - Support tracing of function calls and timing"
1926 help
1927 Enables a command to control using of function tracing within
1928 U-Boot. This allows recording of call traces including timing
1929 information. The command can write data to memory for exporting
a24a78d7 1930 for analysis (e.g. using bootchart). See doc/README.trace for full
ce058ae5
SG
1931 details.
1932
60b2f9e7
IO
1933config CMD_AVB
1934 bool "avb - Android Verified Boot 2.0 operations"
b0aa74a2 1935 depends on AVB_VERIFY
60b2f9e7
IO
1936 default n
1937 help
1938 Enables a "avb" command to perform verification of partitions using
1939 Android Verified Boot 2.0 functionality. It includes such subcommands:
1940 avb init - initialize avb2 subsystem
1941 avb read_rb - read rollback index
1942 avb write_rb - write rollback index
1943 avb is_unlocked - check device lock state
1944 avb get_uuid - read and print uuid of a partition
1945 avb read_part - read data from partition
1946 avb read_part_hex - read data from partition and output to stdout
1947 avb write_part - write data to partition
1948 avb verify - run full verification chain
ac20a1b2
SG
1949endmenu
1950
8f2fe0c8
HS
1951config CMD_UBI
1952 tristate "Enable UBI - Unsorted block images commands"
8f2fe0c8
HS
1953 select MTD_UBI
1954 help
1955 UBI is a software layer above MTD layer which admits use of LVM-like
1956 logical volumes on top of MTD devices, hides some complexities of
1957 flash chips like wear and bad blocks and provides some other useful
1958 capabilities. Please, consult the MTD web site for more details
1959 (www.linux-mtd.infradead.org). Activate this option if you want
1960 to use U-Boot UBI commands.
c58fb2cd
MR
1961 It is also strongly encouraged to also enable CONFIG_MTD to get full
1962 partition support.
8f2fe0c8 1963
173aafbf
BB
1964config CMD_UBIFS
1965 tristate "Enable UBIFS - Unsorted block images filesystem commands"
2bc734b1 1966 depends on CMD_UBI
5ed063d1 1967 default y if CMD_UBI
24fc9531 1968 select LZO
173aafbf
BB
1969 help
1970 UBIFS is a file system for flash devices which works on top of UBI.
1971
72a8cf8d 1972endmenu