]> git.ipfire.org Git - people/ms/u-boot.git/blob - cmd/Kconfig
nvme: Add nvme commands
[people/ms/u-boot.git] / cmd / Kconfig
1 menu "Command line interface"
2
3 config 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
14 config HUSH_PARSER
15 bool "Use hush shell"
16 depends on CMDLINE
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
26 config SYS_PROMPT
27 string "Shell prompt"
28 default "=> "
29 help
30 This string is displayed in the command line to the left of the
31 cursor.
32
33 menu "Autoboot options"
34
35 config AUTOBOOT
36 bool "Autoboot"
37 default y
38 help
39 This enables the autoboot. See doc/README.autoboot for detail.
40
41 config AUTOBOOT_KEYED
42 bool "Stop autobooting via specific input key / string"
43 default n
44 help
45 This option enables stopping (aborting) of the automatic
46 boot feature only by issuing a specific input key or
47 string. If not enabled, any input key will abort the
48 U-Boot automatic booting process and bring the device
49 to the U-Boot prompt for user input.
50
51 config AUTOBOOT_PROMPT
52 string "Autoboot stop prompt"
53 depends on AUTOBOOT_KEYED
54 default "Autoboot in %d seconds\\n"
55 help
56 This string is displayed before the boot delay selected by
57 CONFIG_BOOTDELAY starts. If it is not defined there is no
58 output indicating that autoboot is in progress.
59
60 Note that this define is used as the (only) argument to a
61 printf() call, so it may contain '%' format specifications,
62 provided that it also includes, sepearated by commas exactly
63 like in a printf statement, the required arguments. It is
64 the responsibility of the user to select only such arguments
65 that are valid in the given context.
66
67 config AUTOBOOT_ENCRYPTION
68 bool "Enable encryption in autoboot stopping"
69 depends on AUTOBOOT_KEYED
70 default n
71
72 config AUTOBOOT_DELAY_STR
73 string "Delay autobooting via specific input key / string"
74 depends on AUTOBOOT_KEYED && !AUTOBOOT_ENCRYPTION
75 help
76 This option delays the automatic boot feature by issuing
77 a specific input key or string. If CONFIG_AUTOBOOT_DELAY_STR
78 or the environment variable "bootdelaykey" is specified
79 and this string is received from console input before
80 autoboot starts booting, U-Boot gives a command prompt. The
81 U-Boot prompt will time out if CONFIG_BOOT_RETRY_TIME is
82 used, otherwise it never times out.
83
84 config AUTOBOOT_STOP_STR
85 string "Stop autobooting via specific input key / string"
86 depends on AUTOBOOT_KEYED && !AUTOBOOT_ENCRYPTION
87 help
88 This option enables stopping (aborting) of the automatic
89 boot feature only by issuing a specific input key or
90 string. If CONFIG_AUTOBOOT_STOP_STR or the environment
91 variable "bootstopkey" is specified and this string is
92 received from console input before autoboot starts booting,
93 U-Boot gives a command prompt. The U-Boot prompt never
94 times out, even if CONFIG_BOOT_RETRY_TIME is used.
95
96 config AUTOBOOT_KEYED_CTRLC
97 bool "Enable Ctrl-C autoboot interruption"
98 depends on AUTOBOOT_KEYED && !AUTOBOOT_ENCRYPTION
99 default n
100 help
101 This option allows for the boot sequence to be interrupted
102 by ctrl-c, in addition to the "bootdelaykey" and "bootstopkey".
103 Setting this variable provides an escape sequence from the
104 limited "password" strings.
105
106 config AUTOBOOT_STOP_STR_SHA256
107 string "Stop autobooting via SHA256 encrypted password"
108 depends on AUTOBOOT_KEYED && AUTOBOOT_ENCRYPTION
109 help
110 This option adds the feature to only stop the autobooting,
111 and therefore boot into the U-Boot prompt, when the input
112 string / password matches a values that is encypted via
113 a SHA256 hash and saved in the environment.
114
115 endmenu
116
117 source "cmd/fastboot/Kconfig"
118
119 comment "Commands"
120
121 menu "Info commands"
122
123 config CMD_BDI
124 bool "bdinfo"
125 default y
126 help
127 Print board info
128
129 config CMD_CONFIG
130 bool "config"
131 select BUILD_BIN2C
132 default SANDBOX
133 help
134 Print ".config" contents.
135
136 If this option is enabled, the ".config" file contents are embedded
137 in the U-Boot image and can be printed on the console by the "config"
138 command. This provides information of which options are enabled on
139 the running U-Boot.
140
141 config CMD_CONSOLE
142 bool "coninfo"
143 default y
144 help
145 Print console devices and information.
146
147 config CMD_CPU
148 bool "cpu"
149 help
150 Print information about available CPUs. This normally shows the
151 number of CPUs, type (e.g. manufacturer, architecture, product or
152 internal name) and clock frequency. Other information may be
153 available depending on the CPU driver.
154
155 config CMD_LICENSE
156 bool "license"
157 select BUILD_BIN2C
158 help
159 Print GPL license text
160
161 config CMD_REGINFO
162 bool "reginfo"
163 depends on PPC
164 help
165 Register dump
166
167 endmenu
168
169 menu "Boot commands"
170
171 config CMD_BOOTD
172 bool "bootd"
173 default y
174 help
175 Run the command stored in the environment "bootcmd", i.e.
176 "bootd" does the same thing as "run bootcmd".
177
178 config CMD_BOOTM
179 bool "bootm"
180 default y
181 help
182 Boot an application image from the memory.
183
184 config CMD_BOOTZ
185 bool "bootz"
186 help
187 Boot the Linux zImage
188
189 config CMD_BOOTI
190 bool "booti"
191 depends on ARM64
192 default y
193 help
194 Boot an AArch64 Linux Kernel image from memory.
195
196 config CMD_BOOTEFI
197 bool "bootefi"
198 depends on EFI_LOADER
199 default y
200 help
201 Boot an EFI image from memory.
202
203 config CMD_BOOTEFI_HELLO_COMPILE
204 bool "Compile a standard EFI hello world binary for testing"
205 depends on CMD_BOOTEFI && (ARM || X86)
206 default y
207 help
208 This compiles a standard EFI hello world application with U-Boot so
209 that it can be used with the test/py testing framework. This is useful
210 for testing that EFI is working at a basic level, and for bringing
211 up EFI support on a new architecture.
212
213 No additional space will be required in the resulting U-Boot binary
214 when this option is enabled.
215
216 config CMD_BOOTEFI_HELLO
217 bool "Allow booting a standard EFI hello world for testing"
218 depends on CMD_BOOTEFI_HELLO_COMPILE
219 help
220 This adds a standard EFI hello world application to U-Boot so that
221 it can be used with the 'bootefi hello' command. This is useful
222 for testing that EFI is working at a basic level, and for bringing
223 up EFI support on a new architecture.
224
225 config CMD_BOOTMENU
226 bool "bootmenu"
227 select MENU
228 help
229 Add an ANSI terminal boot menu command.
230
231 config CMD_ELF
232 bool "bootelf, bootvx"
233 default y
234 help
235 Boot an ELF/vxWorks image from the memory.
236
237 config CMD_FDT
238 bool "Flattened Device Tree utility commands"
239 default y
240 depends on OF_LIBFDT
241 help
242 Do FDT related setup before booting into the Operating System.
243
244 config CMD_GO
245 bool "go"
246 default y
247 help
248 Start an application at a given address.
249
250 config CMD_RUN
251 bool "run"
252 default y
253 help
254 Run the command in the given environment variable.
255
256 config CMD_IMI
257 bool "iminfo"
258 default y
259 help
260 Print header information for application image.
261
262 config CMD_IMLS
263 bool "imls"
264 default y
265 help
266 List all images found in flash
267
268 config CMD_XIMG
269 bool "imxtract"
270 default y
271 help
272 Extract a part of a multi-image.
273
274 config CMD_POWEROFF
275 bool "poweroff"
276 help
277 Poweroff/Shutdown the system
278
279 config CMD_SPL
280 bool "spl export - Export boot information for Falcon boot"
281 depends on SPL
282 help
283 Falcon mode allows booting directly from SPL into an Operating
284 System such as Linux, thus skipping U-Boot proper. See
285 doc/README.falcon for full information about how to use this
286 command.
287
288 config CMD_SPL_NAND_OFS
289 hex "Offset of OS command line args for Falcon-mode NAND boot"
290 depends on CMD_SPL
291 default 0
292 help
293 This provides the offset of the command line arguments for Linux
294 when booting from NAND in Falcon mode. See doc/README.falcon
295 for full information about how to use this option (and also see
296 board/gateworks/gw_ventana/README for an example).
297
298 config CMD_SPL_WRITE_SIZE
299 hex "Size of argument area"
300 depends on CMD_SPL
301 default 0x2000
302 help
303 This provides the size of the command-line argument area in NAND
304 flash used by Falcon-mode boot. See the documentation until CMD_SPL
305 for detail.
306
307 config CMD_THOR_DOWNLOAD
308 bool "thor - TIZEN 'thor' download"
309 help
310 Implements the 'thor' download protocol. This is a way of
311 downloading a software update over USB from an attached host.
312 There is no documentation about this within the U-Boot source code
313 but you should be able to find something on the interwebs.
314
315 config CMD_ZBOOT
316 bool "zboot - x86 boot command"
317 help
318 With x86 machines it is common to boot a bzImage file which
319 contains both a kernel and a setup.bin file. The latter includes
320 configuration information from the dark ages which x86 boards still
321 need to pick things out of.
322
323 Consider using FIT in preference to this since it supports directly
324 booting both 32- and 64-bit kernels, as well as secure boot.
325 Documentation is available in doc/uImage.FIT/x86-fit-boot.txt
326
327 endmenu
328
329 menu "Environment commands"
330
331 config CMD_ASKENV
332 bool "ask for env variable"
333 help
334 Ask for environment variable
335
336 config CMD_EXPORTENV
337 bool "env export"
338 default y
339 help
340 Export environments.
341
342 config CMD_IMPORTENV
343 bool "env import"
344 default y
345 help
346 Import environments.
347
348 config CMD_EDITENV
349 bool "editenv"
350 default y
351 help
352 Edit environment variable.
353
354 config CMD_GREPENV
355 bool "search env"
356 help
357 Allow for searching environment variables
358
359 config CMD_SAVEENV
360 bool "saveenv"
361 default y
362 help
363 Save all environment variables into the compiled-in persistent
364 storage.
365
366 config CMD_ENV_EXISTS
367 bool "env exists"
368 default y
369 help
370 Check if a variable is defined in the environment for use in
371 shell scripting.
372
373 config CMD_ENV_CALLBACK
374 bool "env callbacks - print callbacks and their associated variables"
375 help
376 Some environment variable have callbacks defined by
377 U_BOOT_ENV_CALLBACK. These are called when the variable changes.
378 For example changing "baudrate" adjust the serial baud rate. This
379 command lists the currently defined callbacks.
380
381 config CMD_ENV_FLAGS
382 bool "env flags -print variables that have non-default flags"
383 help
384 Some environment variables have special flags that control their
385 behaviour. For example, serial# can only be written once and cannot
386 be deleted. This command shows the variables that have special
387 flags.
388
389 endmenu
390
391 menu "Memory commands"
392
393 config CMD_CRC32
394 bool "crc32"
395 select HASH
396 default y
397 help
398 Compute CRC32.
399
400 config CRC32_VERIFY
401 bool "crc32 -v"
402 depends on CMD_CRC32
403 help
404 Add -v option to verify data against a crc32 checksum.
405
406 config CMD_EEPROM
407 bool "eeprom - EEPROM subsystem"
408 help
409 (deprecated, needs conversion to driver model)
410 Provides commands to read and write EEPROM (Electrically Erasable
411 Programmable Read Only Memory) chips that are connected over an
412 I2C bus.
413
414 config CMD_EEPROM_LAYOUT
415 bool "Enable layout-aware eeprom commands"
416 depends on CMD_EEPROM
417 help
418 (deprecated, needs conversion to driver model)
419 When enabled, additional eeprom sub-commands become available.
420
421 eeprom print - prints the contents of the eeprom in a human-readable
422 way (eeprom layout fields, and data formatted to be fit for human
423 consumption).
424
425 eeprom update - allows user to update eeprom fields by specifying
426 the field name, and providing the new data in a human readable format
427 (same format as displayed by the eeprom print command).
428
429 Both commands can either auto detect the layout, or be told which
430 layout to use.
431
432 Feature API:
433 __weak int parse_layout_version(char *str)
434 - override to provide your own layout name parsing
435 __weak void __eeprom_layout_assign(struct eeprom_layout *layout,
436 int layout_version);
437 - override to setup the layout metadata based on the version
438 __weak int eeprom_layout_detect(unsigned char *data)
439 - override to provide your own algorithm for detecting layout
440 version
441 eeprom_field.c
442 - contains various printing and updating functions for common
443 types of eeprom fields. Can be used for defining
444 custom layouts.
445
446 config EEPROM_LAYOUT_HELP_STRING
447 string "Tells user what layout names are supported"
448 depends on CMD_EEPROM_LAYOUT
449 default "<not defined>"
450 help
451 Help printed with the LAYOUT VERSIONS part of the 'eeprom'
452 command's help.
453
454 config LOOPW
455 bool "loopw"
456 help
457 Infinite write loop on address range
458
459 config CMD_MD5SUM
460 bool "md5sum"
461 default n
462 select MD5
463 help
464 Compute MD5 checksum.
465
466 config MD5SUM_VERIFY
467 bool "md5sum -v"
468 default n
469 depends on CMD_MD5SUM
470 help
471 Add -v option to verify data against an MD5 checksum.
472
473 config CMD_MEMINFO
474 bool "meminfo"
475 help
476 Display memory information.
477
478 config CMD_MEMORY
479 bool "md, mm, nm, mw, cp, cmp, base, loop"
480 default y
481 help
482 Memory commands.
483 md - memory display
484 mm - memory modify (auto-incrementing address)
485 nm - memory modify (constant address)
486 mw - memory write (fill)
487 cp - memory copy
488 cmp - memory compare
489 base - print or set address offset
490 loop - initialize loop on address range
491
492 config CMD_MEMTEST
493 bool "memtest"
494 help
495 Simple RAM read/write test.
496
497 config CMD_MX_CYCLIC
498 bool "mdc, mwc"
499 help
500 mdc - memory display cyclic
501 mwc - memory write cyclic
502
503 config CMD_SHA1SUM
504 bool "sha1sum"
505 select SHA1
506 help
507 Compute SHA1 checksum.
508
509 config SHA1SUM_VERIFY
510 bool "sha1sum -v"
511 depends on CMD_SHA1SUM
512 help
513 Add -v option to verify data against a SHA1 checksum.
514
515 config CMD_STRINGS
516 bool "strings - display strings in memory"
517 help
518 This works similarly to the Unix 'strings' command except that it
519 works with a memory range. String of printable characters found
520 within the range are displayed. The minimum number of characters
521 for a sequence to be considered a string can be provided.
522
523 endmenu
524
525 menu "Compression commands"
526
527 config CMD_LZMADEC
528 bool "lzmadec"
529 select LZMA
530 help
531 Support decompressing an LZMA (Lempel-Ziv-Markov chain algorithm)
532 image from memory.
533
534 config CMD_UNZIP
535 bool "unzip"
536 help
537 Uncompress a zip-compressed memory region.
538
539 config CMD_ZIP
540 bool "zip"
541 help
542 Compress a memory region with zlib deflate method.
543
544 endmenu
545
546 menu "Device access commands"
547
548 config CMD_ARMFLASH
549 #depends on FLASH_CFI_DRIVER
550 bool "armflash"
551 help
552 ARM Ltd reference designs flash partition access
553
554 config CMD_CLK
555 bool "clk - Show clock frequencies"
556 help
557 (deprecated)
558 Shows clock frequences by calling a sock_clk_dump() hook function.
559 This is depreated in favour of using the CLK uclass and accessing
560 clock values from associated drivers. However currently no command
561 exists for this.
562
563 config CMD_DEMO
564 bool "demo - Demonstration commands for driver model"
565 depends on DM
566 help
567 Provides a 'demo' command which can be used to play around with
568 driver model. To use this properly you will need to enable one or
569 both of the demo devices (DM_DEMO_SHAPE and DM_DEMO_SIMPLE).
570 Otherwise you will always get an empty list of devices. The demo
571 devices are defined in the sandbox device tree, so the easiest
572 option is to use sandbox and pass the -d point to sandbox's
573 u-boot.dtb file.
574
575 config CMD_DFU
576 bool "dfu"
577 select USB_FUNCTION_DFU
578 help
579 Enables the command "dfu" which is used to have U-Boot create a DFU
580 class device via USB. This command requires that the "dfu_alt_info"
581 environment variable be set and define the alt settings to expose to
582 the host.
583
584 config CMD_DM
585 bool "dm - Access to driver model information"
586 depends on DM
587 default y
588 help
589 Provides access to driver model data structures and information,
590 such as a list of devices, list of uclasses and the state of each
591 device (e.g. activated). This is not required for operation, but
592 can be useful to see the state of driver model for debugging or
593 interest.
594
595 config CMD_FDC
596 bool "fdcboot - Boot from floppy device"
597 help
598 The 'fdtboot' command allows booting an image from a floppy disk.
599
600 config CMD_FLASH
601 bool "flinfo, erase, protect"
602 default y
603 help
604 NOR flash support.
605 flinfo - print FLASH memory information
606 erase - FLASH memory
607 protect - enable or disable FLASH write protection
608
609 config CMD_FPGA
610 bool "fpga"
611 default y
612 help
613 FPGA support.
614
615 config CMD_FPGA_LOADBP
616 bool "fpga loadbp - load partial bitstream (Xilinx only)"
617 depends on CMD_FPGA
618 help
619 Supports loading an FPGA device from a bitstream buffer containing
620 a partial bitstream.
621
622 config CMD_FPGA_LOADFS
623 bool "fpga loadfs - load bitstream from FAT filesystem (Xilinx only)"
624 depends on CMD_FPGA
625 help
626 Supports loading an FPGA device from a FAT filesystem.
627
628 config CMD_FPGA_LOADMK
629 bool "fpga loadmk - load bitstream from image"
630 depends on CMD_FPGA
631 help
632 Supports loading an FPGA device from a image generated by mkimage.
633
634 config CMD_FPGA_LOADP
635 bool "fpga loadp - load partial bitstream"
636 depends on CMD_FPGA
637 help
638 Supports loading an FPGA device from a bitstream buffer containing
639 a partial bitstream.
640
641 config CMD_FPGAD
642 bool "fpgad - dump FPGA registers"
643 help
644 (legacy, needs conversion to driver model)
645 Provides a way to dump FPGA registers by calling the board-specific
646 fpga_get_reg() function. This functions similarly to the 'md'
647 command.
648
649 config CMD_FUSE
650 bool "fuse - support for the fuse subssystem"
651 help
652 (deprecated - needs conversion to driver model)
653 This allows reading, sensing, programming or overriding fuses
654 which control the behaviour of the device. The command uses the
655 fuse_...() API.
656
657 config CMD_GPIO
658 bool "gpio"
659 help
660 GPIO support.
661
662 config CMD_GPT
663 bool "GPT (GUID Partition Table) command"
664 select PARTITION_UUIDS
665 select EFI_PARTITION
666 help
667 Enable the 'gpt' command to ready and write GPT style partition
668 tables.
669
670 config CMD_GPT_RENAME
671 bool "GPT partition renaming commands"
672 depends on CMD_GPT
673 help
674 Enables the 'gpt' command to interchange names on two GPT
675 partitions via the 'gpt swap' command or to rename single
676 partitions via the 'rename' command.
677
678 config CMD_IDE
679 bool "ide - Support for IDE drivers"
680 select IDE
681 help
682 Provides an 'ide' command which allows accessing the IDE drive,
683 reseting the IDE interface, printing the partition table and
684 geting device info. It also enables the 'diskboot' command which
685 permits booting from an IDE drive.
686
687 config CMD_IO
688 bool "io - Support for performing I/O accesses"
689 help
690 Provides an 'iod' command to display I/O space and an 'iow' command
691 to write values to the I/O space. This can be useful for manually
692 checking the state of devices during boot when debugging device
693 drivers, etc.
694
695 config CMD_IOTRACE
696 bool "iotrace - Support for tracing I/O activity"
697 help
698 Provides an 'iotrace' command which supports recording I/O reads and
699 writes in a trace buffer in memory . It also maintains a checksum
700 of the trace records (even if space is exhausted) so that the
701 sequence of I/O accesses can be verified.
702
703 When debugging drivers it is useful to see what I/O accesses were
704 done and in what order.
705
706 Even if the individual accesses are of little interest it can be
707 useful to verify that the access pattern is consistent each time
708 an operation is performed. In this case a checksum can be used to
709 characterise the operation of a driver. The checksum can be compared
710 across different runs of the operation to verify that the driver is
711 working properly.
712
713 In particular, when performing major refactoring of the driver, where
714 the access pattern should not change, the checksum provides assurance
715 that the refactoring work has not broken the driver.
716
717 This works by sneaking into the io.h heder for an architecture and
718 redirecting I/O accesses through iotrace's tracing mechanism.
719
720 For now no commands are provided to examine the trace buffer. The
721 format is fairly simple, so 'md' is a reasonable substitute.
722
723 Note: The checksum feature is only useful for I/O regions where the
724 contents do not change outside of software control. Where this is not
725 suitable you can fall back to manually comparing the addresses. It
726 might be useful to enhance tracing to only checksum the accesses and
727 not the data read/written.
728
729 config CMD_I2C
730 bool "i2c"
731 help
732 I2C support.
733
734 config CMD_LOADB
735 bool "loadb"
736 default y
737 help
738 Load a binary file over serial line.
739
740 config CMD_LOADS
741 bool "loads"
742 default y
743 help
744 Load an S-Record file over serial line
745
746 config CMD_MMC
747 bool "mmc"
748 help
749 MMC memory mapped support.
750
751 config CMD_NAND
752 bool "nand"
753 default y if NAND_SUNXI
754 help
755 NAND support.
756
757 if CMD_NAND
758 config CMD_NAND_TRIMFFS
759 bool "nand write.trimffs"
760 default y if ARCH_SUNXI
761 help
762 Allows one to skip empty pages when flashing something on a NAND.
763
764 config CMD_NAND_LOCK_UNLOCK
765 bool "nand lock/unlock"
766 help
767 NAND locking support.
768
769 config CMD_NAND_TORTURE
770 bool "nand torture"
771 help
772 NAND torture support.
773
774 endif # CMD_NAND
775
776 config CMD_NVME
777 bool "nvme"
778 depends on NVME
779 default y if NVME
780 help
781 NVM Express device support
782
783 config CMD_MMC_SPI
784 bool "mmc_spi - Set up MMC SPI device"
785 help
786 Provides a way to set up an MMC (Multimedia Card) SPI (Serial
787 Peripheral Interface) device. The device provides a means of
788 accessing an MMC device via SPI using a single data line, limited
789 to 20MHz. It is useful since it reduces the amount of protocol code
790 required.
791
792 config CMD_ONENAND
793 bool "onenand - access to onenand device"
794 help
795 OneNAND is a brand of NAND ('Not AND' gate) flash which provides
796 various useful features. This command allows reading, writing,
797 and erasing blocks. It allso provides a way to show and change
798 bad blocks, and test the device.
799
800 config CMD_PART
801 bool "part"
802 select PARTITION_UUIDS
803 help
804 Read and display information about the partition table on
805 various media.
806
807 config CMD_PCI
808 bool "pci - Access PCI devices"
809 help
810 Provide access to PCI (Peripheral Interconnect Bus), a type of bus
811 used on some devices to allow the CPU to communicate with its
812 peripherals. Sub-commands allow bus enumeration, displaying and
813 changing configuration space and a few other features.
814
815 config CMD_PCMCIA
816 bool "pinit - Set up PCMCIA device"
817 help
818 Provides a means to initialise a PCMCIA (Personal Computer Memory
819 Card International Association) device. This is an old standard from
820 about 1990. These devices are typically removable memory or network
821 cards using a standard 68-pin connector.
822
823 config CMD_READ
824 bool "read - Read binary data from a partition"
825 help
826 Provides low-level access to the data in a partition.
827
828 config CMD_REMOTEPROC
829 bool "remoteproc"
830 depends on REMOTEPROC
831 help
832 Support for Remote Processor control
833
834 config CMD_SATA
835 bool "sata - Access SATA subsystem"
836 select SATA
837 help
838 SATA (Serial Advanced Technology Attachment) is a serial bus
839 standard for connecting to hard drives and other storage devices.
840 This command provides information about attached devices and allows
841 reading, writing and other operations.
842
843 SATA replaces PATA (originally just ATA), which stands for Parallel AT
844 Attachment, where AT refers to an IBM AT (Advanced Technology)
845 computer released in 1984.
846
847 config CMD_SAVES
848 bool "saves - Save a file over serial in S-Record format"
849 help
850 Provides a way to save a binary file using the Motorola S-Record
851 format over the serial line.
852
853 config CMD_SDRAM
854 bool "sdram - Print SDRAM configuration information"
855 help
856 Provides information about attached SDRAM. This assumed that the
857 SDRAM has an EEPROM with information that can be read using the
858 I2C bus. This is only available on some boards.
859
860 config CMD_SF
861 bool "sf"
862 help
863 SPI Flash support
864
865 config CMD_SF_TEST
866 bool "sf test - Allow testing of SPI flash"
867 help
868 Provides a way to test that SPI flash is working correctly. The
869 test is destructive, in that an area of SPI flash must be provided
870 for the test to use. Performance information is also provided,
871 measuring the performance of reading, writing and erasing in
872 Mbps (Million Bits Per Second). This value should approximately
873 equal the SPI bus speed for a single-bit-wide SPI bus, assuming
874 everything is working properly.
875
876 config CMD_SPI
877 bool "sspi"
878 help
879 SPI utility command.
880
881 config CMD_TSI148
882 bool "tsi148 - Command to access tsi148 device"
883 help
884 This provides various sub-commands to initialise and configure the
885 Turndra tsi148 device. See the command help for full details.
886
887 config CMD_UNIVERSE
888 bool "universe - Command to set up the Turndra Universe controller"
889 help
890 This allows setting up the VMEbus provided by this controller.
891 See the command help for full details.
892
893 config CMD_USB
894 bool "usb"
895 help
896 USB support.
897
898 config CMD_USB_MASS_STORAGE
899 bool "UMS usb mass storage"
900 help
901 USB mass storage support
902
903 endmenu
904
905
906 menu "Shell scripting commands"
907
908 config CMD_ECHO
909 bool "echo"
910 default y
911 help
912 Echo args to console
913
914 config CMD_ITEST
915 bool "itest"
916 default y
917 help
918 Return true/false on integer compare.
919
920 config CMD_SOURCE
921 bool "source"
922 default y
923 help
924 Run script from memory
925
926 config CMD_SETEXPR
927 bool "setexpr"
928 default y
929 help
930 Evaluate boolean and math expressions and store the result in an env
931 variable.
932 Also supports loading the value at a memory location into a variable.
933 If CONFIG_REGEX is enabled, setexpr also supports a gsub function.
934
935 endmenu
936
937 menu "Network commands"
938
939 config CMD_NET
940 bool "bootp, tftpboot"
941 select NET
942 default y
943 help
944 Network commands.
945 bootp - boot image via network using BOOTP/TFTP protocol
946 tftpboot - boot image via network using TFTP protocol
947
948 config CMD_TFTPPUT
949 bool "tftp put"
950 help
951 TFTP put command, for uploading files to a server
952
953 config CMD_TFTPSRV
954 bool "tftpsrv"
955 help
956 Act as a TFTP server and boot the first received file
957
958 config CMD_RARP
959 bool "rarpboot"
960 help
961 Boot image via network using RARP/TFTP protocol
962
963 config CMD_DHCP
964 bool "dhcp"
965 help
966 Boot image via network using DHCP/TFTP protocol
967
968 config CMD_PXE
969 bool "pxe"
970 select MENU
971 help
972 Boot image via network using PXE protocol
973
974 config CMD_NFS
975 bool "nfs"
976 default y
977 help
978 Boot image via network using NFS protocol.
979
980 config CMD_MII
981 bool "mii"
982 help
983 Enable MII utility commands.
984
985 config CMD_PING
986 bool "ping"
987 help
988 Send ICMP ECHO_REQUEST to network host
989
990 config CMD_CDP
991 bool "cdp"
992 help
993 Perform CDP network configuration
994
995 config CMD_SNTP
996 bool "sntp"
997 help
998 Synchronize RTC via network
999
1000 config CMD_DNS
1001 bool "dns"
1002 help
1003 Lookup the IP of a hostname
1004
1005 config CMD_LINK_LOCAL
1006 bool "linklocal"
1007 help
1008 Acquire a network IP address using the link-local protocol
1009
1010 config CMD_ETHSW
1011 bool "ethsw"
1012 help
1013 Allow control of L2 Ethernet switch commands. These are supported
1014 by the vsc9953 Ethernet driver at present. Sub-commands allow
1015 operations such as enabling / disabling a port and
1016 viewing/maintaining the filtering database (FDB)
1017
1018 endmenu
1019
1020 menu "Misc commands"
1021
1022 config CMD_BMP
1023 bool "Enable 'bmp' command"
1024 depends on LCD || DM_VIDEO || VIDEO
1025 help
1026 This provides a way to obtain information about a BMP-format iamge
1027 and to display it. BMP (which presumably stands for BitMaP) is a
1028 file format defined by Microsoft which supports images of various
1029 depths, formats and compression methods. Headers on the file
1030 determine the formats used. This command can be used by first loading
1031 the image into RAM, then using this command to look at it or display
1032 it.
1033
1034 config CMD_BSP
1035 bool "Enable board-specific commands"
1036 help
1037 (deprecated: instead, please define a Kconfig option for each command)
1038
1039 Some boards have board-specific commands which are only enabled
1040 during developemnt and need to be turned off for production. This
1041 option provides a way to control this. The commands that are enabled
1042 vary depending on the board.
1043
1044 config CMD_BKOPS_ENABLE
1045 bool "mmc bkops enable"
1046 depends on CMD_MMC
1047 default n
1048 help
1049 Enable command for setting manual background operations handshake
1050 on a eMMC device. The feature is optionally available on eMMC devices
1051 conforming to standard >= 4.41.
1052
1053 config CMD_BLOCK_CACHE
1054 bool "blkcache - control and stats for block cache"
1055 depends on BLOCK_CACHE
1056 default y if BLOCK_CACHE
1057 help
1058 Enable the blkcache command, which can be used to control the
1059 operation of the cache functions.
1060 This is most useful when fine-tuning the operation of the cache
1061 during development, but also allows the cache to be disabled when
1062 it might hurt performance (e.g. when using the ums command).
1063
1064 config CMD_CACHE
1065 bool "icache or dcache"
1066 help
1067 Enable the "icache" and "dcache" commands
1068
1069 config CMD_DISPLAY
1070 bool "Enable the 'display' command, for character displays"
1071 help
1072 (this needs porting to driver model)
1073 This enables the 'display' command which allows a string to be
1074 displayed on a simple board-specific display. Implement
1075 display_putc() to use it.
1076
1077 config CMD_LED
1078 bool "led"
1079 default y if LED
1080 help
1081 Enable the 'led' command which allows for control of LEDs supported
1082 by the board. The LEDs can be listed with 'led list' and controlled
1083 with led on/off/togle/blink. Any LED drivers can be controlled with
1084 this command, e.g. led_gpio.
1085
1086 config CMD_DATE
1087 bool "date"
1088 default y if DM_RTC
1089 help
1090 Enable the 'date' command for getting/setting the time/date in RTC
1091 devices.
1092
1093 config CMD_TIME
1094 bool "time"
1095 help
1096 Run commands and summarize execution time.
1097
1098 config CMD_GETTIME
1099 bool "gettime - read elapsed time"
1100 help
1101 Enable the 'gettime' command which reads the elapsed time since
1102 U-Boot started running. This shows the time in seconds and
1103 milliseconds. See also the 'bootstage' command which provides more
1104 flexibility for boot timing.
1105
1106 # TODO: rename to CMD_SLEEP
1107 config CMD_MISC
1108 bool "sleep"
1109 default y
1110 help
1111 Delay execution for some time
1112
1113 config CMD_TIMER
1114 bool "timer"
1115 help
1116 Access the system timer.
1117
1118 config CMD_SOUND
1119 bool "sound"
1120 depends on SOUND
1121 help
1122 This provides basic access to the U-Boot's sound support. The main
1123 feature is to play a beep.
1124
1125 sound init - set up sound system
1126 sound play - play a sound
1127
1128 config CMD_QFW
1129 bool "qfw"
1130 select QFW
1131 help
1132 This provides access to the QEMU firmware interface. The main
1133 feature is to allow easy loading of files passed to qemu-system
1134 via -kernel / -initrd
1135
1136 source "cmd/mvebu/Kconfig"
1137
1138 config CMD_TERMINAL
1139 bool "terminal - provides a way to attach a serial terminal"
1140 help
1141 Provides a 'cu'-like serial terminal command. This can be used to
1142 access other serial ports from the system console. The terminal
1143 is very simple with no special processing of characters. As with
1144 cu, you can press ~. (tilde followed by period) to exit.
1145
1146 config CMD_UUID
1147 bool "uuid, guid - generation of unique IDs"
1148 help
1149 This enables two commands:
1150
1151 uuid - generate random Universally Unique Identifier
1152 guid - generate Globally Unique Identifier based on random UUID
1153
1154 The two commands are very similar except for the endianness of the
1155 output.
1156
1157 endmenu
1158
1159 config CMD_BOOTSTAGE
1160 bool "Enable the 'bootstage' command"
1161 depends on BOOTSTAGE
1162 help
1163 Add a 'bootstage' command which supports printing a report
1164 and un/stashing of bootstage data.
1165
1166 menu "Power commands"
1167 config CMD_PMIC
1168 bool "Enable Driver Model PMIC command"
1169 depends on DM_PMIC
1170 help
1171 This is the pmic command, based on a driver model pmic's API.
1172 Command features are unchanged:
1173 - list - list pmic devices
1174 - pmic dev <id> - show or [set] operating pmic device (NEW)
1175 - pmic dump - dump registers
1176 - pmic read address - read byte of register at address
1177 - pmic write address - write byte to register at address
1178 The only one change for this command is 'dev' subcommand.
1179
1180 config CMD_REGULATOR
1181 bool "Enable Driver Model REGULATOR command"
1182 depends on DM_REGULATOR
1183 help
1184 This command is based on driver model regulator's API.
1185 User interface features:
1186 - list - list regulator devices
1187 - regulator dev <id> - show or [set] operating regulator device
1188 - regulator info - print constraints info
1189 - regulator status - print operating status
1190 - regulator value <val] <-f> - print/[set] voltage value [uV]
1191 - regulator current <val> - print/[set] current value [uA]
1192 - regulator mode <id> - print/[set] operating mode id
1193 - regulator enable - enable the regulator output
1194 - regulator disable - disable the regulator output
1195
1196 The '-f' (force) option can be used for set the value which exceeds
1197 the limits, which are found in device-tree and are kept in regulator's
1198 uclass platdata structure.
1199
1200 endmenu
1201
1202 menu "Security commands"
1203 config CMD_AES
1204 bool "Enable the 'aes' command"
1205 select AES
1206 help
1207 This provides a means to encrypt and decrypt data using the AES
1208 (Advanced Encryption Standard). This algorithm uses a symetric key
1209 and is widely used as a streaming cipher. Different key lengths are
1210 supported by the algorithm but this command only supports 128 bits
1211 at present.
1212
1213 config CMD_BLOB
1214 bool "Enable the 'blob' command"
1215 help
1216 This is used with the Freescale secure boot mechanism.
1217
1218 Freescale's SEC block has built-in Blob Protocol which provides
1219 a method for protecting user-defined data across system power
1220 cycles. SEC block protects data in a data structure called a Blob,
1221 which provides both confidentiality and integrity protection.
1222
1223 Encapsulating data as a blob
1224 Each time that the Blob Protocol is used to protect data, a
1225 different randomly generated key is used to encrypt the data.
1226 This random key is itself encrypted using a key which is derived
1227 from SoC's non-volatile secret key and a 16 bit Key identifier.
1228 The resulting encrypted key along with encrypted data is called a
1229 blob. The non-volatile secure key is available for use only during
1230 secure boot.
1231
1232 During decapsulation, the reverse process is performed to get back
1233 the original data.
1234
1235 Sub-commands:
1236 blob enc - encapsulating data as a cryptgraphic blob
1237 blob dec - decapsulating cryptgraphic blob to get the data
1238
1239 Syntax:
1240
1241 blob enc src dst len km
1242
1243 Encapsulate and create blob of data $len bytes long
1244 at address $src and store the result at address $dst.
1245 $km is the 16 byte key modifier is also required for
1246 generation/use as key for cryptographic operation. Key
1247 modifier should be 16 byte long.
1248
1249 blob dec src dst len km
1250
1251 Decapsulate the blob of data at address $src and
1252 store result of $len byte at addr $dst.
1253 $km is the 16 byte key modifier is also required for
1254 generation/use as key for cryptographic operation. Key
1255 modifier should be 16 byte long.
1256
1257 config CMD_HASH
1258 bool "Support 'hash' command"
1259 select HASH
1260 help
1261 This provides a way to hash data in memory using various supported
1262 algorithms (such as SHA1, MD5, CRC32). The computed digest can be
1263 saved to memory or to an environment variable. It is also possible
1264 to verify a hash against data in memory.
1265
1266 config HASH_VERIFY
1267 bool "hash -v"
1268 depends on CMD_HASH
1269 help
1270 Add -v option to verify data against a hash.
1271
1272 config CMD_TPM
1273 bool "Enable the 'tpm' command"
1274 depends on TPM
1275 help
1276 This provides a means to talk to a TPM from the command line. A wide
1277 range of commands if provided - see 'tpm help' for details. The
1278 command requires a suitable TPM on your board and the correct driver
1279 must be enabled.
1280
1281 config CMD_TPM_TEST
1282 bool "Enable the 'tpm test' command"
1283 depends on CMD_TPM
1284 help
1285 This provides a a series of tests to confirm that the TPM is working
1286 correctly. The tests cover initialisation, non-volatile RAM, extend,
1287 global lock and checking that timing is within expectations. The
1288 tests pass correctly on Infineon TPMs but may need to be adjusted
1289 for other devices.
1290
1291 endmenu
1292
1293 menu "Firmware commands"
1294 config CMD_CROS_EC
1295 bool "Enable crosec command"
1296 depends on CROS_EC
1297 default y
1298 help
1299 Enable command-line access to the Chrome OS EC (Embedded
1300 Controller). This provides the 'crosec' command which has
1301 a number of sub-commands for performing EC tasks such as
1302 updating its flash, accessing a small saved context area
1303 and talking to the I2C bus behind the EC (if there is one).
1304 endmenu
1305
1306 menu "Filesystem commands"
1307 config CMD_CBFS
1308 bool "Enable the 'cbfs' command"
1309 depends on FS_CBFS
1310 help
1311 Define this to enable support for reading from a Coreboot
1312 filesystem. This is a ROM-based filesystem used for accessing files
1313 on systems that use coreboot as the first boot-loader and then load
1314 U-Boot to actually boot the Operating System. Available commands are
1315 cbfsinit, cbfsinfo, cbfsls and cbfsload.
1316
1317 config CMD_CRAMFS
1318 bool "Enable the 'cramfs' command"
1319 depends on FS_CRAMFS
1320 help
1321 This provides commands for dealing with CRAMFS (Compressed ROM
1322 filesystem). CRAMFS is useful when space is tight since files are
1323 compressed. Two commands are provided:
1324
1325 cramfsls - lists files in a cramfs image
1326 cramfsload - loads a file from a cramfs image
1327
1328 config CMD_EXT2
1329 bool "ext2 command support"
1330 help
1331 Enables EXT2 FS command
1332
1333 config CMD_EXT4
1334 bool "ext4 command support"
1335 help
1336 Enables EXT4 FS command
1337
1338 config CMD_EXT4_WRITE
1339 depends on CMD_EXT4
1340 bool "ext4 write command support"
1341 help
1342 Enables EXT4 FS write command
1343
1344 config CMD_FAT
1345 bool "FAT command support"
1346 select FS_FAT
1347 help
1348 Support for the FAT fs
1349
1350 config CMD_FS_GENERIC
1351 bool "filesystem commands"
1352 help
1353 Enables filesystem commands (e.g. load, ls) that work for multiple
1354 fs types.
1355
1356 config CMD_FS_UUID
1357 bool "fsuuid command"
1358 help
1359 Enables fsuuid command for filesystem UUID.
1360
1361 config CMD_JFFS2
1362 bool "jffs2 command"
1363 select FS_JFFS2
1364 help
1365 Enables commands to support the JFFS2 (Journalling Flash File System
1366 version 2) filesystem. This enables fsload, ls and fsinfo which
1367 provide the ability to load files, list directories and obtain
1368 filesystem information.
1369
1370 config CMD_MTDPARTS
1371 bool "MTD partition support"
1372 help
1373 MTD partition support
1374
1375 config MTDIDS_DEFAULT
1376 string "Default MTD IDs"
1377 depends on CMD_MTDPARTS
1378 help
1379 Defines a default MTD ID
1380
1381 config MTDPARTS_DEFAULT
1382 string "Default MTD partition scheme"
1383 depends on CMD_MTDPARTS
1384 help
1385 Defines a default MTD partitioning scheme in the Linux MTD command
1386 line partitions format
1387
1388 config CMD_MTDPARTS_SPREAD
1389 bool "Padd partition size to take account of bad blocks"
1390 depends on CMD_MTDPARTS
1391 help
1392 This enables the 'spread' sub-command of the mtdparts command.
1393 This command will modify the existing mtdparts variable by increasing
1394 the size of the partitions such that 1) each partition's net size is
1395 at least as large as the size specified in the mtdparts variable and
1396 2) each partition starts on a good block.
1397
1398 config CMD_REISER
1399 bool "reiser - Access to reiserfs filesystems"
1400 help
1401 This provides two commands which operate on a resierfs filesystem,
1402 commonly used some years ago:
1403
1404 reiserls - list files
1405 reiserload - load a file
1406
1407 config CMD_SCSI
1408 bool "scsi - Access to SCSI devices"
1409 default y if SCSI
1410 help
1411 This provides a 'scsi' command which provides access to SCSI (Small
1412 Computer System Interface) devices. The command provides a way to
1413 scan the bus, reset the bus, read and write data and get information
1414 about devices.
1415
1416 config CMD_YAFFS2
1417 bool "yaffs2 - Access of YAFFS2 filesystem"
1418 depends on YAFFS2
1419 default y
1420 help
1421 This provides commands for accessing a YAFFS2 filesystem. Yet
1422 Another Flash Filesystem 2 is a filesystem designed specifically
1423 for NAND flash. It incorporates bad-block management and ensures
1424 that device writes are sequential regardless of filesystem
1425 activity.
1426
1427 config CMD_ZFS
1428 bool "zfs - Access of ZFS filesystem"
1429 help
1430 This provides commands to accessing a ZFS filesystem, commonly used
1431 on Solaris systems. Two sub-commands are provided:
1432
1433 zfsls - list files in a directory
1434 zfsload - load a file
1435
1436 See doc/README.zfs for more details.
1437
1438 endmenu
1439
1440 menu "Debug commands"
1441
1442 config CMD_BEDBUG
1443 bool "bedbug"
1444 help
1445 The bedbug (emBEDded deBUGger) command provides debugging features
1446 for some PowerPC processors. For details please see the
1447 docuemntation in doc/README.beddbug
1448
1449 config CMD_DIAG
1450 bool "diag - Board diagnostics"
1451 help
1452 This command provides access to board diagnostic tests. These are
1453 called Power-on Self Tests (POST). The command allows listing of
1454 available tests and running either all the tests, or specific tests
1455 identified by name.
1456
1457 config CMD_IRQ
1458 bool "irq - Show information about interrupts"
1459 depends on !ARM && !MIPS && !SH
1460 help
1461 This enables two commands:
1462
1463 interrupts - enable or disable interrupts
1464 irqinfo - print device-specific interrupt information
1465
1466 config CMD_KGDB
1467 bool "kgdb - Allow debugging of U-Boot with gdb"
1468 help
1469 This enables a 'kgdb' command which allows gdb to connect to U-Boot
1470 over a serial link for debugging purposes. This allows
1471 single-stepping, inspecting variables, etc. This is supported only
1472 on PowerPC at present.
1473
1474 config CMD_TRACE
1475 bool "trace - Support tracing of function calls and timing"
1476 help
1477 Enables a command to control using of function tracing within
1478 U-Boot. This allows recording of call traces including timing
1479 information. The command can write data to memory for exporting
1480 for analsys (e.g. using bootchart). See doc/README.trace for full
1481 details.
1482
1483 endmenu
1484
1485 config CMD_UBI
1486 tristate "Enable UBI - Unsorted block images commands"
1487 select CRC32
1488 select MTD_UBI
1489 select CMD_MTDPARTS
1490 default y if NAND_SUNXI
1491 help
1492 UBI is a software layer above MTD layer which admits use of LVM-like
1493 logical volumes on top of MTD devices, hides some complexities of
1494 flash chips like wear and bad blocks and provides some other useful
1495 capabilities. Please, consult the MTD web site for more details
1496 (www.linux-mtd.infradead.org). Activate this option if you want
1497 to use U-Boot UBI commands.
1498
1499 config CMD_UBIFS
1500 tristate "Enable UBIFS - Unsorted block images filesystem commands"
1501 depends on CMD_UBI
1502 select CRC32
1503 select LZO
1504 default y if CMD_UBI
1505 help
1506 UBIFS is a file system for flash devices which works on top of UBI.
1507
1508 endmenu