.. SPDX-License-Identifier: GPL-2.0+ Command-line Parsing ==================== The command line is available in U-Boot proper, enabled by CONFIG_CMDLINE which is on by default. It is not enabled in SPL. There are two different command-line parsers available with U-Boot: the old "simple" one, and the much more powerful "hush" shell: Simple command-line parser -------------------------- This takes very little code space and offers only basic features: - supports environment variables (through :doc:`cmd/env`) - several commands on one line, separated by ';' - variable substitution using "... ${name} ..." syntax - special characters ('$', ';') can be escaped by prefixing with '\', for example:: setenv bootcmd bootm \${address} - You can also escape text by enclosing in single apostrophes, for example:: setenv addip 'setenv bootargs $bootargs ip=$ipaddr:$serverip:$gatewayip:$netmask:$hostname::off' Hush shell ---------- This is similar to Bourne shell, with control structures like: - `if`... `then` ... `else`... `fi` - `for`... `do` ... `done` - `while` ... `do` ... `done` - `until` ... `do` ... `done` Hush supports environment ("global") variables (through setenv / saveenv commands) and local shell variables (through standard shell syntax `name=value`); only environment variables can be used with the "run" command The Hush shell is enabled with `CONFIG_HUSH_PARSER`. General rules ------------- #. If a command line (or an environment variable executed by a "run" command) contains several commands separated by semicolon, and one of these commands fails, then the remaining commands will be executed anyway. #. If you execute several variables with one call to run (i. e. calling run with a list of variables as arguments), any failing command will cause "run" to terminate, i. e. the remaining variables are not executed. Representing numbers -------------------- Most U-Boot commands use hexadecimal (hex) as the default base, for convenient use of addresses, for example:: => md 1000 6 00001000: 2c786f62 00697073 03000000 0c000000 box,spi......... 00001010: 67020000 00000000 ...g.... There is no need to add a `0x` prefix to the arguments and the output is shown in hex also, without any prefixes. This helps to avoid clutter. Some commands use decimal where it is more natural:: => i2c dev 0 Setting bus to 0 => i2c speed Current bus speed=400000 => i2c speed 100000 Setting bus speed to 100000 Hz In some cases the default is decimal but it is possible to use octal if that is useful:: pmic dev pmic@41 dev: 1 @ pmic@41 => pmic write 2 0177 => pmic read 2 0x02: 0x00007f It is possible to use a `0x` prefix to use a hex value if that is more convenient:: => i2c speed 0x30000 Setting bus speed to 196608 Hz