blob: 90d93379c31adfc7b1ef423d53fe22ebf7591965 [file] [log] [blame]
Simon Glass72a8cf82016-01-17 20:53:51 -07001menu "Command line interface"
2
Simon Glass302a6482016-03-13 19:07:28 -06003config 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
Simon Glass72a8cf82016-01-17 20:53:51 -070014config HUSH_PARSER
15 bool "Use hush shell"
Simon Glass302a6482016-03-13 19:07:28 -060016 depends on CMDLINE
Simon Glass72a8cf82016-01-17 20:53:51 -070017 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
Simon Glass72a8cf82016-01-17 20:53:51 -070026config 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
33menu "Autoboot options"
34
Masahiro Yamada41598c82016-06-20 17:33:39 +090035config AUTOBOOT
36 bool "Autoboot"
37 default y
38 help
39 This enables the autoboot. See doc/README.autoboot for detail.
40
Simon Glass72a8cf82016-01-17 20:53:51 -070041config 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
51config 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
67config AUTOBOOT_ENCRYPTION
68 bool "Enable encryption in autoboot stopping"
69 depends on AUTOBOOT_KEYED
70 default n
71
72config 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
84config 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
96config 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
106config 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
115endmenu
116
Steve Raee016f0b2016-08-15 17:26:26 -0700117source "cmd/fastboot/Kconfig"
118
Simon Glass72a8cf82016-01-17 20:53:51 -0700119comment "Commands"
120
121menu "Info commands"
122
123config CMD_BDI
124 bool "bdinfo"
125 default y
126 help
127 Print board info
128
Masahiro Yamada61304db2017-01-30 11:12:07 +0900129config 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
Simon Glass72a8cf82016-01-17 20:53:51 -0700141config CMD_CONSOLE
142 bool "coninfo"
143 default y
144 help
145 Print console devices and information.
146
147config 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
155config CMD_LICENSE
156 bool "license"
Masahiro Yamadad726f222017-01-30 11:12:08 +0900157 select BUILD_BIN2C
Simon Glass72a8cf82016-01-17 20:53:51 -0700158 help
159 Print GPL license text
160
161endmenu
162
163menu "Boot commands"
164
165config CMD_BOOTD
166 bool "bootd"
167 default y
168 help
169 Run the command stored in the environment "bootcmd", i.e.
170 "bootd" does the same thing as "run bootcmd".
171
172config CMD_BOOTM
173 bool "bootm"
174 default y
175 help
176 Boot an application image from the memory.
177
Dinh Nguyenab8243e2016-04-21 09:05:23 -0500178config CMD_BOOTZ
179 bool "bootz"
180 help
181 Boot the Linux zImage
182
Masahiro Yamada26959272016-08-12 08:31:16 -0400183config CMD_BOOTI
184 bool "booti"
185 depends on ARM64
186 default y
187 help
188 Boot an AArch64 Linux Kernel image from memory.
189
Alexander Grafb9939332016-03-10 00:27:20 +0100190config CMD_BOOTEFI
191 bool "bootefi"
192 depends on EFI_LOADER
193 default y
194 help
195 Boot an EFI image from memory.
196
Alexander Graf95b62b22016-11-17 22:40:10 +0100197config CMD_BOOTEFI_HELLO_COMPILE
198 bool "Compile a standard EFI hello world binary for testing"
199 depends on CMD_BOOTEFI && (ARM || X86)
200 default y
201 help
202 This compiles a standard EFI hello world application with U-Boot so
203 that it can be used with the test/py testing framework. This is useful
204 for testing that EFI is working at a basic level, and for bringing
205 up EFI support on a new architecture.
206
207 No additional space will be required in the resulting U-Boot binary
208 when this option is enabled.
209
Simon Glassc7ae3df2016-11-07 08:47:08 -0700210config CMD_BOOTEFI_HELLO
211 bool "Allow booting a standard EFI hello world for testing"
Alexander Graf95b62b22016-11-17 22:40:10 +0100212 depends on CMD_BOOTEFI_HELLO_COMPILE
Simon Glassc7ae3df2016-11-07 08:47:08 -0700213 help
214 This adds a standard EFI hello world application to U-Boot so that
215 it can be used with the 'bootefi hello' command. This is useful
216 for testing that EFI is working at a basic level, and for bringing
217 up EFI support on a new architecture.
218
Tom Rini4880b022016-11-29 09:14:56 -0500219config CMD_BOOTMENU
220 bool "bootmenu"
221 select MENU
222 help
223 Add an ANSI terminal boot menu command.
224
Simon Glass72a8cf82016-01-17 20:53:51 -0700225config CMD_ELF
226 bool "bootelf, bootvx"
227 default y
228 help
229 Boot an ELF/vxWorks image from the memory.
230
Michal Simek23922e22016-04-06 20:28:04 +0200231config CMD_FDT
232 bool "Flattened Device Tree utility commands"
233 default y
234 depends on OF_LIBFDT
235 help
236 Do FDT related setup before booting into the Operating System.
237
Simon Glass72a8cf82016-01-17 20:53:51 -0700238config CMD_GO
239 bool "go"
240 default y
241 help
242 Start an application at a given address.
243
244config CMD_RUN
245 bool "run"
246 default y
247 help
248 Run the command in the given environment variable.
249
250config CMD_IMI
251 bool "iminfo"
252 default y
253 help
254 Print header information for application image.
255
256config CMD_IMLS
257 bool "imls"
258 default y
259 help
260 List all images found in flash
261
262config CMD_XIMG
263 bool "imxtract"
264 default y
265 help
266 Extract a part of a multi-image.
267
268config CMD_POWEROFF
Michal Simeke05d5052017-06-05 08:28:17 +0200269 bool "poweroff"
270 help
271 Poweroff/Shutdown the system
Simon Glass72a8cf82016-01-17 20:53:51 -0700272
273endmenu
274
275menu "Environment commands"
276
Dinh Nguyenab8243e2016-04-21 09:05:23 -0500277config CMD_ASKENV
278 bool "ask for env variable"
279 help
280 Ask for environment variable
281
Simon Glass72a8cf82016-01-17 20:53:51 -0700282config CMD_EXPORTENV
283 bool "env export"
284 default y
285 help
286 Export environments.
287
288config CMD_IMPORTENV
289 bool "env import"
290 default y
291 help
292 Import environments.
293
294config CMD_EDITENV
295 bool "editenv"
296 default y
297 help
298 Edit environment variable.
299
Dinh Nguyenab8243e2016-04-21 09:05:23 -0500300config CMD_GREPENV
301 bool "search env"
302 help
303 Allow for searching environment variables
304
Simon Glass72a8cf82016-01-17 20:53:51 -0700305config CMD_SAVEENV
306 bool "saveenv"
307 default y
308 help
309 Save all environment variables into the compiled-in persistent
310 storage.
311
312config CMD_ENV_EXISTS
313 bool "env exists"
314 default y
315 help
316 Check if a variable is defined in the environment for use in
317 shell scripting.
318
Simon Glassa55d29d2017-05-17 03:25:13 -0600319config CMD_ENV_CALLBACK
320 bool "env callbacks - print callbacks and their associated variables"
321 help
322 Some environment variable have callbacks defined by
323 U_BOOT_ENV_CALLBACK. These are called when the variable changes.
324 For example changing "baudrate" adjust the serial baud rate. This
325 command lists the currently defined callbacks.
326
Simon Glassffc76582017-05-17 03:25:14 -0600327config CMD_ENV_FLAGS
328 bool "env flags -print variables that have non-default flags"
329 help
330 Some environment variables have special flags that control their
331 behaviour. For example, serial# can only be written once and cannot
332 be deleted. This command shows the variables that have special
333 flags.
334
Simon Glass72a8cf82016-01-17 20:53:51 -0700335endmenu
336
337menu "Memory commands"
338
339config CMD_MEMORY
340 bool "md, mm, nm, mw, cp, cmp, base, loop"
341 default y
342 help
Fabio Estevamc99d1b32016-12-15 20:02:19 -0200343 Memory commands.
Simon Glass72a8cf82016-01-17 20:53:51 -0700344 md - memory display
345 mm - memory modify (auto-incrementing address)
346 nm - memory modify (constant address)
347 mw - memory write (fill)
348 cp - memory copy
349 cmp - memory compare
350 base - print or set address offset
Fabio Estevamc99d1b32016-12-15 20:02:19 -0200351 loop - initialize loop on address range
Simon Glass72a8cf82016-01-17 20:53:51 -0700352
353config CMD_CRC32
354 bool "crc32"
Simon Glassd70f9192017-05-17 09:05:34 -0600355 select HASH
Simon Glass72a8cf82016-01-17 20:53:51 -0700356 default y
357 help
358 Compute CRC32.
359
Daniel Thompson221a9492017-05-19 17:26:58 +0100360config CRC32_VERIFY
361 bool "crc32 -v"
362 depends on CMD_CRC32
363 help
364 Add -v option to verify data against a crc32 checksum.
365
Simon Glassa1dc9802017-05-17 03:25:10 -0600366config CMD_EEPROM
367 bool "eeprom - EEPROM subsystem"
368 help
369 (deprecated, needs conversion to driver model)
370 Provides commands to read and write EEPROM (Electrically Erasable
371 Programmable Read Only Memory) chips that are connected over an
372 I2C bus.
373
374config CMD_EEPROM_LAYOUT
375 bool "Enable layout-aware eeprom commands"
376 depends on CMD_EEPROM
377 help
378 (deprecated, needs conversion to driver model)
379 When enabled, additional eeprom sub-commands become available.
380
381 eeprom print - prints the contents of the eeprom in a human-readable
382 way (eeprom layout fields, and data formatted to be fit for human
383 consumption).
384
385 eeprom update - allows user to update eeprom fields by specifying
386 the field name, and providing the new data in a human readable format
387 (same format as displayed by the eeprom print command).
388
389 Both commands can either auto detect the layout, or be told which
390 layout to use.
391
392 Feature API:
393 __weak int parse_layout_version(char *str)
394 - override to provide your own layout name parsing
395 __weak void __eeprom_layout_assign(struct eeprom_layout *layout,
396 int layout_version);
397 - override to setup the layout metadata based on the version
398 __weak int eeprom_layout_detect(unsigned char *data)
399 - override to provide your own algorithm for detecting layout
400 version
401 eeprom_field.c
402 - contains various printing and updating functions for common
403 types of eeprom fields. Can be used for defining
404 custom layouts.
405
406config EEPROM_LAYOUT_HELP_STRING
407 string "Tells user what layout names are supported"
408 depends on CMD_EEPROM_LAYOUT
409 default "<not defined>"
410 help
411 Help printed with the LAYOUT VERSIONS part of the 'eeprom'
412 command's help.
413
Andre Przywarabea79d72017-03-15 01:19:05 +0000414config CMD_MD5SUM
415 bool "md5sum"
416 default n
417 select MD5
418 help
419 Compute MD5 checksum.
420
Daniel Thompson221a9492017-05-19 17:26:58 +0100421config MD5SUM_VERIFY
Andre Przywarabea79d72017-03-15 01:19:05 +0000422 bool "md5sum -v"
423 default n
424 depends on CMD_MD5SUM
425 help
426 Add -v option to verify data against an MD5 checksum.
427
Daniel Thompson221a9492017-05-19 17:26:58 +0100428config CMD_SHA1SUM
429 bool "sha1sum"
430 select SHA1
431 help
432 Compute SHA1 checksum.
433
434config SHA1SUM_VERIFY
435 bool "sha1sum -v"
436 depends on CMD_SHA1SUM
437 help
438 Add -v option to verify data against a SHA1 checksum.
439
Simon Glass72a8cf82016-01-17 20:53:51 -0700440config LOOPW
441 bool "loopw"
442 help
443 Infinite write loop on address range
444
445config CMD_MEMTEST
446 bool "memtest"
447 help
448 Simple RAM read/write test.
449
450config CMD_MX_CYCLIC
451 bool "mdc, mwc"
452 help
453 mdc - memory display cyclic
454 mwc - memory write cyclic
455
456config CMD_MEMINFO
457 bool "meminfo"
458 help
459 Display memory information.
460
Simon Glassee7c0e72017-05-17 03:25:43 -0600461endmenu
462
463menu "Compression commands"
464
465config CMD_LZMADEC
466 bool "lzmadec"
467 select LZMA
468 help
469 Support decompressing an LZMA (Lempel-Ziv-Markov chain algorithm)
470 image from memory.
471
Masahiro Yamadae9d33e72017-02-05 10:42:56 +0900472config CMD_UNZIP
473 bool "unzip"
474 help
475 Uncompress a zip-compressed memory region.
476
477config CMD_ZIP
478 bool "zip"
479 help
480 Compress a memory region with zlib deflate method.
481
Simon Glass72a8cf82016-01-17 20:53:51 -0700482endmenu
483
484menu "Device access commands"
485
Simon Glassd3156282017-04-26 22:28:02 -0600486config CMD_CLK
487 bool "clk - Show clock frequencies"
488 help
489 (deprecated)
490 Shows clock frequences by calling a sock_clk_dump() hook function.
491 This is depreated in favour of using the CLK uclass and accessing
492 clock values from associated drivers. However currently no command
493 exists for this.
494
Simon Glass72a8cf82016-01-17 20:53:51 -0700495config CMD_DM
496 bool "dm - Access to driver model information"
497 depends on DM
498 default y
499 help
500 Provides access to driver model data structures and information,
501 such as a list of devices, list of uclasses and the state of each
502 device (e.g. activated). This is not required for operation, but
503 can be useful to see the state of driver model for debugging or
504 interest.
505
506config CMD_DEMO
507 bool "demo - Demonstration commands for driver model"
508 depends on DM
509 help
510 Provides a 'demo' command which can be used to play around with
511 driver model. To use this properly you will need to enable one or
512 both of the demo devices (DM_DEMO_SHAPE and DM_DEMO_SIMPLE).
513 Otherwise you will always get an empty list of devices. The demo
514 devices are defined in the sandbox device tree, so the easiest
515 option is to use sandbox and pass the -d point to sandbox's
516 u-boot.dtb file.
517
Simon Glass75eb9972017-05-17 03:25:29 -0600518config CMD_IDE
519 bool "ide - Support for IDE drivers"
Simon Glassfc843a02017-05-17 03:25:30 -0600520 select IDE
Simon Glass75eb9972017-05-17 03:25:29 -0600521 help
522 Provides an 'ide' command which allows accessing the IDE drive,
523 reseting the IDE interface, printing the partition table and
524 geting device info. It also enables the 'diskboot' command which
525 permits booting from an IDE drive.
526
Simon Glass594e8d12017-05-17 03:25:34 -0600527config CMD_IO
528 bool "io - Support for performing I/O accesses"
529 help
530 Provides an 'iod' command to display I/O space and an 'iow' command
531 to write values to the I/O space. This can be useful for manually
532 checking the state of devices during boot when debugging device
533 drivers, etc.
534
Simon Glass7d0f5c12017-05-17 03:25:36 -0600535config CMD_IOTRACE
536 bool "iotrace - Support for tracing I/O activity"
537 help
538 Provides an 'iotrace' command which supports recording I/O reads and
539 writes in a trace buffer in memory . It also maintains a checksum
540 of the trace records (even if space is exhausted) so that the
541 sequence of I/O accesses can be verified.
542
543 When debugging drivers it is useful to see what I/O accesses were
544 done and in what order.
545
546 Even if the individual accesses are of little interest it can be
547 useful to verify that the access pattern is consistent each time
548 an operation is performed. In this case a checksum can be used to
549 characterise the operation of a driver. The checksum can be compared
550 across different runs of the operation to verify that the driver is
551 working properly.
552
553 In particular, when performing major refactoring of the driver, where
554 the access pattern should not change, the checksum provides assurance
555 that the refactoring work has not broken the driver.
556
557 This works by sneaking into the io.h heder for an architecture and
558 redirecting I/O accesses through iotrace's tracing mechanism.
559
560 For now no commands are provided to examine the trace buffer. The
561 format is fairly simple, so 'md' is a reasonable substitute.
562
563 Note: The checksum feature is only useful for I/O regions where the
564 contents do not change outside of software control. Where this is not
565 suitable you can fall back to manually comparing the addresses. It
566 might be useful to enhance tracing to only checksum the accesses and
567 not the data read/written.
568
Simon Glass72a8cf82016-01-17 20:53:51 -0700569config CMD_LOADB
570 bool "loadb"
571 default y
572 help
573 Load a binary file over serial line.
574
575config CMD_LOADS
576 bool "loads"
577 default y
578 help
579 Load an S-Record file over serial line
580
581config CMD_FLASH
582 bool "flinfo, erase, protect"
583 default y
584 help
585 NOR flash support.
586 flinfo - print FLASH memory information
587 erase - FLASH memory
588 protect - enable or disable FLASH write protection
589
Patrick Delaunayb331cd62017-01-27 11:00:42 +0100590config CMD_GPT
591 bool "GPT (GUID Partition Table) command"
592 select PARTITION_UUIDS
593 select EFI_PARTITION
594 help
595 Enable the 'gpt' command to ready and write GPT style partition
596 tables.
597
Simon Glass72a8cf82016-01-17 20:53:51 -0700598config CMD_ARMFLASH
Tom Rini78d1e1d2016-04-22 16:41:25 -0400599 #depends on FLASH_CFI_DRIVER
Simon Glass72a8cf82016-01-17 20:53:51 -0700600 bool "armflash"
601 help
602 ARM Ltd reference designs flash partition access
603
Dinh Nguyenab8243e2016-04-21 09:05:23 -0500604config CMD_MMC
605 bool "mmc"
606 help
607 MMC memory mapped support.
608
Simon Glass72a8cf82016-01-17 20:53:51 -0700609config CMD_NAND
610 bool "nand"
Maxime Ripard522c2822017-03-03 15:13:30 +0100611 default y if NAND_SUNXI
Simon Glass72a8cf82016-01-17 20:53:51 -0700612 help
613 NAND support.
614
Boris Brezillone915d202017-02-27 18:22:07 +0100615if CMD_NAND
616config CMD_NAND_TRIMFFS
617 bool "nand write.trimffs"
Hans de Goeded482a8d2017-02-27 18:22:10 +0100618 default y if ARCH_SUNXI
Boris Brezillone915d202017-02-27 18:22:07 +0100619 help
620 Allows one to skip empty pages when flashing something on a NAND.
621
622config CMD_NAND_LOCK_UNLOCK
623 bool "nand lock/unlock"
624 help
625 NAND locking support.
626
627config CMD_NAND_TORTURE
628 bool "nand torture"
629 help
630 NAND torture support.
631
632endif # CMD_NAND
633
Patrick Delaunayb331cd62017-01-27 11:00:42 +0100634config CMD_PART
635 bool "part"
636 select PARTITION_UUIDS
637 help
638 Read and display information about the partition table on
639 various media.
640
Simon Glass72a8cf82016-01-17 20:53:51 -0700641config CMD_SF
642 bool "sf"
643 help
644 SPI Flash support
645
646config CMD_SPI
647 bool "sspi"
648 help
649 SPI utility command.
650
651config CMD_I2C
652 bool "i2c"
653 help
654 I2C support.
655
656config CMD_USB
657 bool "usb"
658 help
659 USB support.
660
Dinh Nguyenab8243e2016-04-21 09:05:23 -0500661config CMD_DFU
662 bool "dfu"
Tom Rini6828e602016-09-19 13:31:30 -0400663 select USB_FUNCTION_DFU
Dinh Nguyenab8243e2016-04-21 09:05:23 -0500664 help
665 Enables the command "dfu" which is used to have U-Boot create a DFU
666 class device via USB.
667
668config CMD_USB_MASS_STORAGE
669 bool "UMS usb mass storage"
670 help
671 USB mass storage support
672
Simon Glass72a8cf82016-01-17 20:53:51 -0700673config CMD_FPGA
674 bool "fpga"
675 default y
676 help
677 FPGA support.
678
Simon Glassfe7604a2017-05-17 03:25:21 -0600679config CMD_FPGA_LOADBP
680 bool "fpga loadbp - load partial bitstream (Xilinx only)"
681 depends on CMD_FPGA
682 help
683 Supports loading an FPGA device from a bitstream buffer containing
684 a partial bitstream.
685
686config CMD_FPGA_LOADFS
687 bool "fpga loadfs - load bitstream from FAT filesystem (Xilinx only)"
688 depends on CMD_FPGA
689 help
690 Supports loading an FPGA device from a FAT filesystem.
691
692config CMD_FPGA_LOADMK
693 bool "fpga loadmk - load bitstream from image"
694 depends on CMD_FPGA
695 help
696 Supports loading an FPGA device from a image generated by mkimage.
697
698config CMD_FPGA_LOADP
699 bool "fpga loadp - load partial bitstream"
700 depends on CMD_FPGA
701 help
702 Supports loading an FPGA device from a bitstream buffer containing
703 a partial bitstream.
704
Simon Glassdf1c4892017-05-17 03:25:20 -0600705config CMD_FPGAD
706 bool "fpgad - dump FPGA registers"
707 help
708 (legacy, needs conversion to driver model)
709 Provides a way to dump FPGA registers by calling the board-specific
710 fpga_get_reg() function. This functions similarly to the 'md'
711 command.
712
Simon Glass51f29372017-05-17 03:25:22 -0600713config CMD_FUSE
714 bool "fuse - support for the fuse subssystem"
715 help
716 (deprecated - needs conversion to driver model)
717 This allows reading, sensing, programming or overriding fuses
718 which control the behaviour of the device. The command uses the
719 fuse_...() API.
720
Simon Glass72a8cf82016-01-17 20:53:51 -0700721config CMD_REMOTEPROC
722 bool "remoteproc"
723 depends on REMOTEPROC
724 help
725 Support for Remote Processor control
726
727config CMD_GPIO
728 bool "gpio"
729 help
730 GPIO support.
731
Simon Glassb0e7a702017-05-17 03:25:18 -0600732config CMD_FDC
733 bool "fdcboot - Boot from floppy device"
734 help
735 The 'fdtboot' command allows booting an image from a floppy disk.
736
Simon Glass3bf926c2017-06-14 21:28:24 -0600737config CMD_SATA
738 bool "sata - Access SATA subsystem"
739 help
740 SATA (Serial Advanced Technology Attachment) is a serial bus
741 standard for connecting to hard drives and other storage devices.
742 This command provides information about attached devices and allows
743 reading, writing and other operations.
744
745 SATA replaces PATA (originally just ATA), which stands for Parallel AT
746 Attachment, where AT refers to an IBM AT (Advanced Technology)
747 computer released in 1984.
748
Simon Glass72a8cf82016-01-17 20:53:51 -0700749endmenu
750
751
752menu "Shell scripting commands"
753
754config CMD_ECHO
755 bool "echo"
756 default y
757 help
758 Echo args to console
759
760config CMD_ITEST
761 bool "itest"
762 default y
763 help
764 Return true/false on integer compare.
765
766config CMD_SOURCE
767 bool "source"
768 default y
769 help
770 Run script from memory
771
772config CMD_SETEXPR
773 bool "setexpr"
774 default y
775 help
776 Evaluate boolean and math expressions and store the result in an env
777 variable.
778 Also supports loading the value at a memory location into a variable.
779 If CONFIG_REGEX is enabled, setexpr also supports a gsub function.
780
781endmenu
782
783menu "Network commands"
784
785config CMD_NET
786 bool "bootp, tftpboot"
787 select NET
788 default y
789 help
790 Network commands.
791 bootp - boot image via network using BOOTP/TFTP protocol
792 tftpboot - boot image via network using TFTP protocol
793
794config CMD_TFTPPUT
795 bool "tftp put"
796 help
797 TFTP put command, for uploading files to a server
798
799config CMD_TFTPSRV
800 bool "tftpsrv"
801 help
802 Act as a TFTP server and boot the first received file
803
804config CMD_RARP
805 bool "rarpboot"
806 help
807 Boot image via network using RARP/TFTP protocol
808
809config CMD_DHCP
810 bool "dhcp"
811 help
812 Boot image via network using DHCP/TFTP protocol
813
Yann E. MORINbfb380b2016-11-13 21:59:52 +0100814config CMD_PXE
815 bool "pxe"
816 select MENU
817 help
818 Boot image via network using PXE protocol
819
Simon Glass72a8cf82016-01-17 20:53:51 -0700820config CMD_NFS
821 bool "nfs"
822 default y
823 help
824 Boot image via network using NFS protocol.
825
Dinh Nguyenab8243e2016-04-21 09:05:23 -0500826config CMD_MII
827 bool "mii"
828 help
829 Enable MII utility commands.
830
Simon Glass72a8cf82016-01-17 20:53:51 -0700831config CMD_PING
832 bool "ping"
833 help
834 Send ICMP ECHO_REQUEST to network host
835
836config CMD_CDP
837 bool "cdp"
838 help
839 Perform CDP network configuration
840
841config CMD_SNTP
842 bool "sntp"
843 help
844 Synchronize RTC via network
845
846config CMD_DNS
847 bool "dns"
848 help
849 Lookup the IP of a hostname
850
851config CMD_LINK_LOCAL
852 bool "linklocal"
853 help
854 Acquire a network IP address using the link-local protocol
855
Simon Glassef072202017-05-17 03:25:17 -0600856config CMD_ETHSW
857 bool "ethsw"
858 help
859 Allow control of L2 Ethernet switch commands. These are supported
860 by the vsc9953 Ethernet driver at present. Sub-commands allow
861 operations such as enabling / disabling a port and
862 viewing/maintaining the filtering database (FDB)
863
Simon Glass72a8cf82016-01-17 20:53:51 -0700864endmenu
865
866menu "Misc commands"
867
Simon Glass0f710252017-04-26 22:27:55 -0600868config CMD_BMP
869 bool "Enable 'bmp' command"
870 depends on LCD || DM_VIDEO || VIDEO
871 help
872 This provides a way to obtain information about a BMP-format iamge
873 and to display it. BMP (which presumably stands for BitMaP) is a
874 file format defined by Microsoft which supports images of various
875 depths, formats and compression methods. Headers on the file
876 determine the formats used. This command can be used by first loading
877 the image into RAM, then using this command to look at it or display
878 it.
879
Simon Glass4893e342017-04-26 22:27:56 -0600880config CMD_BSP
881 bool "Enable board-specific commands"
882 help
883 (deprecated: instead, please define a Kconfig option for each command)
884
885 Some boards have board-specific commands which are only enabled
886 during developemnt and need to be turned off for production. This
887 option provides a way to control this. The commands that are enabled
888 vary depending on the board.
889
Tomas Melincd3d4882016-11-25 11:01:03 +0200890config CMD_BKOPS_ENABLE
891 bool "mmc bkops enable"
892 depends on CMD_MMC
893 default n
894 help
895 Enable command for setting manual background operations handshake
896 on a eMMC device. The feature is optionally available on eMMC devices
897 conforming to standard >= 4.41.
898
Eric Nelsone40cf342016-03-28 10:05:44 -0700899config CMD_BLOCK_CACHE
900 bool "blkcache - control and stats for block cache"
901 depends on BLOCK_CACHE
902 default y if BLOCK_CACHE
903 help
904 Enable the blkcache command, which can be used to control the
905 operation of the cache functions.
906 This is most useful when fine-tuning the operation of the cache
907 during development, but also allows the cache to be disabled when
908 it might hurt performance (e.g. when using the ums command).
909
Dinh Nguyenab8243e2016-04-21 09:05:23 -0500910config CMD_CACHE
911 bool "icache or dcache"
912 help
913 Enable the "icache" and "dcache" commands
914
Simon Glass93d66ee2017-04-26 22:28:09 -0600915config CMD_DISPLAY
916 bool "Enable the 'display' command, for character displays"
917 help
918 (this needs porting to driver model)
919 This enables the 'display' command which allows a string to be
920 displayed on a simple board-specific display. Implement
921 display_putc() to use it.
922
Simon Glassffe20522017-04-10 11:34:59 -0600923config CMD_LED
924 bool "led"
925 default y if LED
926 help
927 Enable the 'led' command which allows for control of LEDs supported
928 by the board. The LEDs can be listed with 'led list' and controlled
929 with led on/off/togle/blink. Any LED drivers can be controlled with
930 this command, e.g. led_gpio.
931
Chris Packhamc9032ce2017-04-29 15:20:28 +1200932config CMD_DATE
933 bool "date"
934 default y if DM_RTC
935 help
936 Enable the 'date' command for getting/setting the time/date in RTC
937 devices.
938
Simon Glass72a8cf82016-01-17 20:53:51 -0700939config CMD_TIME
940 bool "time"
941 help
942 Run commands and summarize execution time.
943
Simon Glassd91a9d72017-05-17 03:25:23 -0600944config CMD_GETTIME
945 bool "gettime - read elapsed time"
946 help
947 Enable the 'gettime' command which reads the elapsed time since
948 U-Boot started running. This shows the time in seconds and
949 milliseconds. See also the 'bootstage' command which provides more
950 flexibility for boot timing.
951
Simon Glass72a8cf82016-01-17 20:53:51 -0700952# TODO: rename to CMD_SLEEP
953config CMD_MISC
954 bool "sleep"
955 default y
956 help
957 Delay execution for some time
958
959config CMD_TIMER
960 bool "timer"
961 help
962 Access the system timer.
963
Simon Glass72a8cf82016-01-17 20:53:51 -0700964config CMD_SOUND
965 bool "sound"
966 depends on SOUND
967 help
968 This provides basic access to the U-Boot's sound support. The main
969 feature is to play a beep.
970
971 sound init - set up sound system
972 sound play - play a sound
973
Miao Yan18686592016-05-22 19:37:17 -0700974config CMD_QFW
Tom Rinidd6f3ab2016-05-06 10:40:22 -0400975 bool "qfw"
Miao Yanfcf5c042016-05-22 19:37:14 -0700976 select QFW
Tom Rinidd6f3ab2016-05-06 10:40:22 -0400977 help
978 This provides access to the QEMU firmware interface. The main
979 feature is to allow easy loading of files passed to qemu-system
980 via -kernel / -initrd
Konstantin Porotchkinfa61ef62016-12-08 12:22:28 +0200981
982source "cmd/mvebu/Kconfig"
983
Simon Glass72a8cf82016-01-17 20:53:51 -0700984endmenu
985
986config CMD_BOOTSTAGE
987 bool "Enable the 'bootstage' command"
988 depends on BOOTSTAGE
989 help
990 Add a 'bootstage' command which supports printing a report
991 and un/stashing of bootstage data.
992
993menu "Power commands"
994config CMD_PMIC
995 bool "Enable Driver Model PMIC command"
996 depends on DM_PMIC
997 help
998 This is the pmic command, based on a driver model pmic's API.
999 Command features are unchanged:
1000 - list - list pmic devices
1001 - pmic dev <id> - show or [set] operating pmic device (NEW)
1002 - pmic dump - dump registers
1003 - pmic read address - read byte of register at address
1004 - pmic write address - write byte to register at address
1005 The only one change for this command is 'dev' subcommand.
1006
1007config CMD_REGULATOR
1008 bool "Enable Driver Model REGULATOR command"
1009 depends on DM_REGULATOR
1010 help
1011 This command is based on driver model regulator's API.
1012 User interface features:
1013 - list - list regulator devices
1014 - regulator dev <id> - show or [set] operating regulator device
1015 - regulator info - print constraints info
1016 - regulator status - print operating status
1017 - regulator value <val] <-f> - print/[set] voltage value [uV]
1018 - regulator current <val> - print/[set] current value [uA]
1019 - regulator mode <id> - print/[set] operating mode id
1020 - regulator enable - enable the regulator output
1021 - regulator disable - disable the regulator output
1022
1023 The '-f' (force) option can be used for set the value which exceeds
1024 the limits, which are found in device-tree and are kept in regulator's
1025 uclass platdata structure.
1026
1027endmenu
1028
1029menu "Security commands"
Simon Glassb1a873d2017-04-26 22:27:49 -06001030config CMD_AES
1031 bool "Enable the 'aes' command"
1032 select AES
1033 help
1034 This provides a means to encrypt and decrypt data using the AES
1035 (Advanced Encryption Standard). This algorithm uses a symetric key
1036 and is widely used as a streaming cipher. Different key lengths are
1037 supported by the algorithm but this command only supports 128 bits
1038 at present.
1039
Simon Glassc04b9b32017-04-26 22:27:53 -06001040config CMD_BLOB
1041 bool "Enable the 'blob' command"
1042 help
1043 This is used with the Freescale secure boot mechanism.
1044
1045 Freescale's SEC block has built-in Blob Protocol which provides
1046 a method for protecting user-defined data across system power
1047 cycles. SEC block protects data in a data structure called a Blob,
1048 which provides both confidentiality and integrity protection.
1049
1050 Encapsulating data as a blob
1051 Each time that the Blob Protocol is used to protect data, a
1052 different randomly generated key is used to encrypt the data.
1053 This random key is itself encrypted using a key which is derived
1054 from SoC's non-volatile secret key and a 16 bit Key identifier.
1055 The resulting encrypted key along with encrypted data is called a
1056 blob. The non-volatile secure key is available for use only during
1057 secure boot.
1058
1059 During decapsulation, the reverse process is performed to get back
1060 the original data.
1061
1062 Sub-commands:
1063 blob enc - encapsulating data as a cryptgraphic blob
1064 blob dec - decapsulating cryptgraphic blob to get the data
1065
1066 Syntax:
1067
1068 blob enc src dst len km
1069
1070 Encapsulate and create blob of data $len bytes long
1071 at address $src and store the result at address $dst.
1072 $km is the 16 byte key modifier is also required for
1073 generation/use as key for cryptographic operation. Key
1074 modifier should be 16 byte long.
1075
1076 blob dec src dst len km
1077
1078 Decapsulate the blob of data at address $src and
1079 store result of $len byte at addr $dst.
1080 $km is the 16 byte key modifier is also required for
1081 generation/use as key for cryptographic operation. Key
1082 modifier should be 16 byte long.
1083
Simon Glass551c3932017-05-17 03:25:25 -06001084config CMD_HASH
1085 bool "Support 'hash' command"
Simon Glassd70f9192017-05-17 09:05:34 -06001086 select HASH
Simon Glass551c3932017-05-17 03:25:25 -06001087 help
1088 This provides a way to hash data in memory using various supported
1089 algorithms (such as SHA1, MD5, CRC32). The computed digest can be
1090 saved to memory or to an environment variable. It is also possible
1091 to verify a hash against data in memory.
1092
Daniel Thompson221a9492017-05-19 17:26:58 +01001093config HASH_VERIFY
1094 bool "hash -v"
1095 depends on CMD_HASH
1096 help
1097 Add -v option to verify data against a hash.
1098
Simon Glass72a8cf82016-01-17 20:53:51 -07001099config CMD_TPM
1100 bool "Enable the 'tpm' command"
1101 depends on TPM
1102 help
1103 This provides a means to talk to a TPM from the command line. A wide
1104 range of commands if provided - see 'tpm help' for details. The
1105 command requires a suitable TPM on your board and the correct driver
1106 must be enabled.
1107
1108config CMD_TPM_TEST
1109 bool "Enable the 'tpm test' command"
1110 depends on CMD_TPM
1111 help
1112 This provides a a series of tests to confirm that the TPM is working
1113 correctly. The tests cover initialisation, non-volatile RAM, extend,
1114 global lock and checking that timing is within expectations. The
1115 tests pass correctly on Infineon TPMs but may need to be adjusted
1116 for other devices.
1117
1118endmenu
1119
Moritz Fischerbfeba012016-10-04 17:08:08 -07001120menu "Firmware commands"
1121config CMD_CROS_EC
1122 bool "Enable crosec command"
1123 depends on CROS_EC
1124 default y
1125 help
1126 Enable command-line access to the Chrome OS EC (Embedded
1127 Controller). This provides the 'crosec' command which has
1128 a number of sub-commands for performing EC tasks such as
1129 updating its flash, accessing a small saved context area
1130 and talking to the I2C bus behind the EC (if there is one).
1131endmenu
1132
Dinh Nguyenab8243e2016-04-21 09:05:23 -05001133menu "Filesystem commands"
Simon Glassd66a10f2017-04-26 22:27:58 -06001134config CMD_CBFS
1135 bool "Enable the 'cbfs' command"
Simon Glassdeb959992017-04-26 22:27:59 -06001136 depends on FS_CBFS
Simon Glassd66a10f2017-04-26 22:27:58 -06001137 help
1138 Define this to enable support for reading from a Coreboot
1139 filesystem. This is a ROM-based filesystem used for accessing files
1140 on systems that use coreboot as the first boot-loader and then load
1141 U-Boot to actually boot the Operating System. Available commands are
1142 cbfsinit, cbfsinfo, cbfsls and cbfsload.
1143
Simon Glass97072742017-04-26 22:28:03 -06001144config CMD_CRAMFS
1145 bool "Enable the 'cramfs' command"
Simon Glass80e44cf2017-04-26 22:28:04 -06001146 depends on FS_CRAMFS
Simon Glass97072742017-04-26 22:28:03 -06001147 help
1148 This provides commands for dealing with CRAMFS (Compressed ROM
1149 filesystem). CRAMFS is useful when space is tight since files are
1150 compressed. Two commands are provided:
1151
1152 cramfsls - lists files in a cramfs image
1153 cramfsload - loads a file from a cramfs image
1154
Dinh Nguyenab8243e2016-04-21 09:05:23 -05001155config CMD_EXT2
1156 bool "ext2 command support"
1157 help
1158 Enables EXT2 FS command
1159
1160config CMD_EXT4
1161 bool "ext4 command support"
1162 help
1163 Enables EXT4 FS command
1164
1165config CMD_EXT4_WRITE
1166 depends on CMD_EXT4
1167 bool "ext4 write command support"
1168 help
1169 Enables EXT4 FS write command
1170
1171config CMD_FAT
1172 bool "FAT command support"
Sekhar Norieedfb892017-06-02 17:53:59 +05301173 select FS_FAT
Dinh Nguyenab8243e2016-04-21 09:05:23 -05001174 help
1175 Support for the FAT fs
1176
1177config CMD_FS_GENERIC
1178 bool "filesystem commands"
1179 help
1180 Enables filesystem commands (e.g. load, ls) that work for multiple
1181 fs types.
Maxime Ripard0269dfa2017-02-27 18:22:04 +01001182
Josua Mayerefbe99c2017-04-24 10:10:45 +02001183config CMD_FS_UUID
1184 bool "fsuuid command"
1185 help
1186 Enables fsuuid command for filesystem UUID.
1187
Simon Glassb8682a72017-05-17 03:25:37 -06001188config CMD_JFFS2
1189 bool "jffs2 command"
Simon Glass59e12a42017-05-17 03:25:38 -06001190 select FS_JFFS2
Simon Glassb8682a72017-05-17 03:25:37 -06001191 help
1192 Enables commands to support the JFFS2 (Journalling Flash File System
1193 version 2) filesystem. This enables fsload, ls and fsinfo which
1194 provide the ability to load files, list directories and obtain
1195 filesystem information.
1196
Maxime Ripard0269dfa2017-02-27 18:22:04 +01001197config CMD_MTDPARTS
1198 depends on ARCH_SUNXI
1199 bool "MTD partition support"
1200 help
1201 MTD partition support
1202
1203config MTDIDS_DEFAULT
1204 string "Default MTD IDs"
1205 depends on CMD_MTDPARTS
1206 help
1207 Defines a default MTD ID
1208
1209config MTDPARTS_DEFAULT
1210 string "Default MTD partition scheme"
1211 depends on CMD_MTDPARTS
1212 help
1213 Defines a default MTD partitioning scheme in the Linux MTD command
1214 line partitions format
1215
Dinh Nguyenab8243e2016-04-21 09:05:23 -05001216endmenu
1217
Simon Glassac20a1b2017-04-26 22:27:52 -06001218menu "Debug commands"
1219
1220config CMD_BEDBUG
1221 bool "bedbug"
1222 help
1223 The bedbug (emBEDded deBUGger) command provides debugging features
1224 for some PowerPC processors. For details please see the
1225 docuemntation in doc/README.beddbug
1226
Simon Glass3bd25cb2017-04-26 22:28:08 -06001227config CMD_DIAG
1228 bool "diag - Board diagnostics"
1229 help
1230 This command provides access to board diagnostic tests. These are
1231 called Power-on Self Tests (POST). The command allows listing of
1232 available tests and running either all the tests, or specific tests
1233 identified by name.
1234
Simon Glass1b330892017-05-17 03:25:39 -06001235config CMD_IRQ
1236 bool "irq - Show information about interrupts"
Heiko Schocher064b55c2017-06-14 05:49:40 +02001237 depends on !ARM && !MIPS && !SH
Simon Glass1b330892017-05-17 03:25:39 -06001238 help
1239 This enables two commands:
1240
1241 interrupts - enable or disable interrupts
1242 irqinfo - print device-specific interrupt information
Simon Glass6bac2272017-05-17 03:25:40 -06001243
1244config CMD_KGDB
1245 bool "kgdb - Allow debugging of U-Boot with gdb"
1246 help
1247 This enables a 'kgdb' command which allows gdb to connect to U-Boot
1248 over a serial link for debugging purposes. This allows
1249 single-stepping, inspecting variables, etc. This is supported only
1250 on PowerPC at present.
1251
Simon Glassac20a1b2017-04-26 22:27:52 -06001252endmenu
1253
Heiko Schocher8f2fe0c2016-09-21 07:58:19 +02001254config CMD_UBI
1255 tristate "Enable UBI - Unsorted block images commands"
1256 select CRC32
1257 select MTD_UBI
Maxime Ripard522c2822017-03-03 15:13:30 +01001258 default y if NAND_SUNXI
Heiko Schocher8f2fe0c2016-09-21 07:58:19 +02001259 help
1260 UBI is a software layer above MTD layer which admits use of LVM-like
1261 logical volumes on top of MTD devices, hides some complexities of
1262 flash chips like wear and bad blocks and provides some other useful
1263 capabilities. Please, consult the MTD web site for more details
1264 (www.linux-mtd.infradead.org). Activate this option if you want
1265 to use U-Boot UBI commands.
1266
Boris Brezillon173aafb2017-02-27 18:22:06 +01001267config CMD_UBIFS
1268 tristate "Enable UBIFS - Unsorted block images filesystem commands"
Maxime Ripard2bc734b2017-03-03 14:53:22 +01001269 depends on CMD_UBI
Boris Brezillon173aafb2017-02-27 18:22:06 +01001270 select CRC32
1271 select RBTREE if ARCH_SUNXI
1272 select LZO if ARCH_SUNXI
Maxime Ripard522c2822017-03-03 15:13:30 +01001273 default y if NAND_SUNXI
Boris Brezillon173aafb2017-02-27 18:22:06 +01001274 help
1275 UBIFS is a file system for flash devices which works on top of UBI.
1276
Simon Glass72a8cf82016-01-17 20:53:51 -07001277endmenu