blob: 561076bac9482e747cd971b28abcbf686bf0b7b5 [file] [log] [blame]
Simon Glassaef523a2021-10-21 21:08:45 -06001.. SPDX-License-Identifier: GPL-2.0+
2
3Environment Variables
4=====================
5
Simon Glass420febd2021-10-21 21:08:50 -06006U-Boot supports user configuration using environment variables which
Simon Glass341c7ea2021-10-21 21:08:49 -06007can be made persistent by saving to persistent storage, for example flash
8memory.
Simon Glassaef523a2021-10-21 21:08:45 -06009
Simon Glass420febd2021-10-21 21:08:50 -060010Environment variables are set using "env set" (alias "setenv"), printed using
Simon Glass341c7ea2021-10-21 21:08:49 -060011"env print" (alias "printenv"), and saved to persistent storage using
12"env save" (alias "saveenv"). Using "env set"
Simon Glassaef523a2021-10-21 21:08:45 -060013without a value can be used to delete a variable from the
Simon Glass341c7ea2021-10-21 21:08:49 -060014environment. As long as you don't save the environment, you are
Simon Glassaef523a2021-10-21 21:08:45 -060015working with an in-memory copy. In case the Flash area containing the
16environment is erased by accident, a default environment is provided.
17
Patrick Delaunayaa5f43a2022-04-14 19:07:05 +020018See :doc:`cmd/env` for details.
19
Simon Glass341c7ea2021-10-21 21:08:49 -060020Some configuration is controlled by Environment Variables, so that setting the
21variable can adjust the behaviour of U-Boot (e.g. autoboot delay, autoloading
22from tftp).
Simon Glassaef523a2021-10-21 21:08:45 -060023
Simon Glass7327fe72021-10-21 21:08:46 -060024Text-based Environment
25----------------------
26
27The default environment for a board is created using a `.env` environment file
28using a simple text format. The base filename for this is defined by
29`CONFIG_ENV_SOURCE_FILE`, or `CONFIG_SYS_BOARD` if that is empty.
30
31The file must be in the board directory and have a .env extension, so
32assuming that there is a board vendor, the resulting filename is therefore::
33
34 board/<vendor>/<board>/<CONFIG_ENV_SOURCE_FILE>.env
35
36or::
37
38 board/<vendor>/<board>/<CONFIG_SYS_BOARD>.env
39
40This is a plain text file where you can type your environment variables in
41the form `var=value`. Blank lines and multi-line variables are supported.
42The conversion script looks for a line that starts in column 1 with a string
43and has an equals sign immediately afterwards. Spaces before the = are not
44permitted. It is a good idea to indent your scripts so that only the 'var='
45appears at the start of a line.
46
47To add additional text to a variable you can use `var+=value`. This text is
48merged into the variable during the make process and made available as a
49single value to U-Boot. Variables can contain `+` characters but in the unlikely
50event that you want to have a variable name ending in plus, put a backslash
51before the `+` so that the script knows you are not adding to an existing
52variable but assigning to a new one::
53
54 maximum\+=value
55
56This file can include C-style comments. Blank lines and multi-line
57variables are supported, and you can use normal C preprocessor directives
58and CONFIG defines from your board config also.
59
60For example, for snapper9260 you would create a text file called
61`board/bluewater/snapper9260.env` containing the environment text.
62
63Example::
64
65 stdout=serial
66 #ifdef CONFIG_LCD
67 stdout+=,lcd
68 #endif
69 bootcmd=
70 /* U-Boot script for booting */
71
72 if [ -z ${tftpserverip} ]; then
73 echo "Use 'setenv tftpserverip a.b.c.d' to set IP address."
74 fi
75
76 usb start; setenv autoload n; bootp;
77 tftpboot ${tftpserverip}:
78 bootm
79 failed=
80 /* Print a message when boot fails */
81 echo CONFIG_SYS_BOARD boot failed - please check your image
82 echo Load address is CONFIG_SYS_LOAD_ADDR
83
84If CONFIG_ENV_SOURCE_FILE is empty and the default filename is not present, then
85the old-style C environment is used instead. See below.
86
87Old-style C environment
88-----------------------
89
90Traditionally, the default environment is created in `include/env_default.h`,
91and can be augmented by various `CONFIG` defines. See that file for details. In
92particular you can define `CONFIG_EXTRA_ENV_SETTINGS` in your board file
93to add environment variables.
94
95Board maintainers are encouraged to migrate to the text-based environment as it
96is easier to maintain. The distro-board script still requires the old-style
97environment but work is underway to address this.
98
99
100List of environment variables
101-----------------------------
102
Simon Glass420febd2021-10-21 21:08:50 -0600103Some device configuration options can be set using environment variables. In
104many cases the value in the default environment comes from a CONFIG option - see
Simon Glass341c7ea2021-10-21 21:08:49 -0600105`include/env_default.h`) for this.
106
Simon Glass7327fe72021-10-21 21:08:46 -0600107This is most-likely not complete:
Simon Glassaef523a2021-10-21 21:08:45 -0600108
109baudrate
Simon Glass420febd2021-10-21 21:08:50 -0600110 Used to set the baudrate of the UART - it defaults to CONFIG_BAUDRATE (which
111 defaults to 115200).
Simon Glassaef523a2021-10-21 21:08:45 -0600112
113bootdelay
Simon Glass420febd2021-10-21 21:08:50 -0600114 Delay before automatically running bootcmd. During this time the user
115 can choose to enter the shell (or the boot menu if
116 CONFIG_AUTOBOOT_MENU_SHOW=y):
117
118 - 0 to autoboot with no delay, but you can stop it by key input.
119 - -1 to disable autoboot.
120 - -2 to autoboot with no delay and not check for abort
121
122 The default value is defined by CONFIG_BOOTDELAY.
123 The value of 'bootdelay' is overridden by the /config/bootdelay value in
124 the device-tree if CONFIG_OF_CONTROL=y.
Simon Glassaef523a2021-10-21 21:08:45 -0600125
126bootcmd
Simon Glass420febd2021-10-21 21:08:50 -0600127 The command that is run if the user does not enter the shell during the
128 boot delay.
Simon Glassaef523a2021-10-21 21:08:45 -0600129
130bootargs
Simon Glass420febd2021-10-21 21:08:50 -0600131 Command line arguments passed when booting an operating system or binary
132 image
Simon Glassaef523a2021-10-21 21:08:45 -0600133
134bootfile
135 Name of the image to load with TFTP
136
137bootm_low
138 Memory range available for image processing in the bootm
139 command can be restricted. This variable is given as
140 a hexadecimal number and defines lowest address allowed
141 for use by the bootm command. See also "bootm_size"
142 environment variable. Address defined by "bootm_low" is
143 also the base of the initial memory mapping for the Linux
144 kernel -- see the description of CONFIG_SYS_BOOTMAPSZ and
145 bootm_mapsize.
146
147bootm_mapsize
148 Size of the initial memory mapping for the Linux kernel.
149 This variable is given as a hexadecimal number and it
150 defines the size of the memory region starting at base
151 address bootm_low that is accessible by the Linux kernel
152 during early boot. If unset, CONFIG_SYS_BOOTMAPSZ is used
153 as the default value if it is defined, and bootm_size is
154 used otherwise.
155
156bootm_size
157 Memory range available for image processing in the bootm
158 command can be restricted. This variable is given as
159 a hexadecimal number and defines the size of the region
160 allowed for use by the bootm command. See also "bootm_low"
161 environment variable.
162
163bootstopkeysha256, bootdelaykey, bootstopkey
164 See README.autoboot
165
166updatefile
167 Location of the software update file on a TFTP server, used
168 by the automatic software update feature. Please refer to
169 documentation in doc/README.update for more details.
170
171autoload
172 if set to "no" (any string beginning with 'n'),
Simon Glass420febd2021-10-21 21:08:50 -0600173 "bootp" and "dhcp" will just load perform a lookup of the
Simon Glassaef523a2021-10-21 21:08:45 -0600174 configuration from the BOOTP server, but not try to
Simon Glassd68e1652022-03-11 16:22:39 -0700175 load any image.
Simon Glassaef523a2021-10-21 21:08:45 -0600176
177autostart
Simon Glass420febd2021-10-21 21:08:50 -0600178 if set to "yes", an image loaded using the "bootp", "dhcp",
Simon Glassaef523a2021-10-21 21:08:45 -0600179 "rarpboot", "tftpboot" or "diskboot" commands will
180 be automatically started (by internally calling
181 "bootm")
182
Simon Glass46b530a2021-10-21 21:08:52 -0600183 If unset, or set to "1"/"yes"/"true" (case insensitive, just the first
184 character is enough), a standalone image
185 passed to the "bootm" command will be copied to the load address
Simon Glassaef523a2021-10-21 21:08:45 -0600186 (and eventually uncompressed), but NOT be started.
187 This can be used to load and uncompress arbitrary
188 data.
189
190fdt_high
191 if set this restricts the maximum address that the
192 flattened device tree will be copied into upon boot.
193 For example, if you have a system with 1 GB memory
194 at physical address 0x10000000, while Linux kernel
195 only recognizes the first 704 MB as low memory, you
196 may need to set fdt_high as 0x3C000000 to have the
197 device tree blob be copied to the maximum address
198 of the 704 MB low memory, so that Linux kernel can
199 access it during the boot procedure.
200
Simon Glass420febd2021-10-21 21:08:50 -0600201 If this is set to the special value 0xffffffff (32-bit machines) or
202 0xffffffffffffffff (64-bit machines) then
Simon Glassaef523a2021-10-21 21:08:45 -0600203 the fdt will not be copied at all on boot. For this
204 to work it must reside in writable memory, have
205 sufficient padding on the end of it for u-boot to
206 add the information it needs into it, and the memory
Tom Rini3c860b52022-06-20 10:31:28 -0400207 must be accessible by the kernel. This usage is strongly discouraged
208 however as it also stops U-Boot from ensuring the device tree starting
209 address is properly aligned and a misaligned tree will cause OS failures.
Simon Glassaef523a2021-10-21 21:08:45 -0600210
211fdtcontroladdr
212 if set this is the address of the control flattened
213 device tree used by U-Boot when CONFIG_OF_CONTROL is
214 defined.
215
216initrd_high
217 restrict positioning of initrd images:
218 If this variable is not set, initrd images will be
219 copied to the highest possible address in RAM; this
220 is usually what you want since it allows for
221 maximum initrd size. If for some reason you want to
222 make sure that the initrd image is loaded below the
223 CONFIG_SYS_BOOTMAPSZ limit, you can set this environment
224 variable to a value of "no" or "off" or "0".
225 Alternatively, you can set it to a maximum upper
226 address to use (U-Boot will still check that it
227 does not overwrite the U-Boot stack and data).
228
229 For instance, when you have a system with 16 MB
230 RAM, and want to reserve 4 MB from use by Linux,
231 you can do this by adding "mem=12M" to the value of
232 the "bootargs" variable. However, now you must make
233 sure that the initrd image is placed in the first
234 12 MB as well - this can be done with::
235
236 setenv initrd_high 00c00000
237
Simon Glass420febd2021-10-21 21:08:50 -0600238 If you set initrd_high to 0xffffffff (32-bit machines) or
239 0xffffffffffffffff (64-bit machines), this is an
Simon Glassaef523a2021-10-21 21:08:45 -0600240 indication to U-Boot that all addresses are legal
241 for the Linux kernel, including addresses in flash
242 memory. In this case U-Boot will NOT COPY the
243 ramdisk at all. This may be useful to reduce the
244 boot time on your system, but requires that this
Tom Rini3c860b52022-06-20 10:31:28 -0400245 feature is supported by your Linux kernel. This usage however requires
246 that the user ensure that there will be no overlap with other parts of the
247 image such as the Linux kernel BSS. It should not be enabled by default
248 and only done as part of optimizing a deployment.
Simon Glassaef523a2021-10-21 21:08:45 -0600249
250ipaddr
251 IP address; needed for tftpboot command
252
253loadaddr
254 Default load address for commands like "bootp",
Tom Rini3c860b52022-06-20 10:31:28 -0400255 "rarpboot", "tftpboot", "loadb" or "diskboot". Note that the optimal
256 default values here will vary between architectures. On 32bit ARM for
257 example, some offset from start of memory is used as the Linux kernel
258 zImage has a self decompressor and it's best if we stay out of where that
259 will be working.
Simon Glassaef523a2021-10-21 21:08:45 -0600260
261loads_echo
262 see CONFIG_LOADS_ECHO
263
264serverip
265 TFTP server IP address; needed for tftpboot command
266
267bootretry
268 see CONFIG_BOOT_RETRY_TIME
269
270bootdelaykey
271 see CONFIG_AUTOBOOT_DELAY_STR
272
273bootstopkey
274 see CONFIG_AUTOBOOT_STOP_STR
275
276ethprime
Simon Glass420febd2021-10-21 21:08:50 -0600277 controls which network interface is used first.
Simon Glassaef523a2021-10-21 21:08:45 -0600278
279ethact
280 controls which interface is currently active.
281 For example you can do the following::
282
283 => setenv ethact FEC
284 => ping 192.168.0.1 # traffic sent on FEC
285 => setenv ethact SCC
286 => ping 10.0.0.1 # traffic sent on SCC
287
288ethrotate
289 When set to "no" U-Boot does not go through all
290 available network interfaces.
Simon Glass420febd2021-10-21 21:08:50 -0600291 It just stays at the currently selected interface. When unset or set to
292 anything other than "no", U-Boot does go through all
293 available network interfaces.
Simon Glassaef523a2021-10-21 21:08:45 -0600294
295netretry
296 When set to "no" each network operation will
297 either succeed or fail without retrying.
298 When set to "once" the network operation will
299 fail when all the available network interfaces
300 are tried once without success.
301 Useful on scripts which control the retry operation
302 themselves.
303
Simon Glassaef523a2021-10-21 21:08:45 -0600304silent_linux
305 If set then Linux will be told to boot silently, by
Simon Glass420febd2021-10-21 21:08:50 -0600306 adding 'console=' to its command line. If "yes" it will be
Simon Glassaef523a2021-10-21 21:08:45 -0600307 made silent. If "no" it will not be made silent. If
308 unset, then it will be made silent if the U-Boot console
309 is silent.
310
311tftpsrcp
312 If this is set, the value is used for TFTP's
313 UDP source port.
314
315tftpdstp
316 If this is set, the value is used for TFTP's UDP
Simon Glass420febd2021-10-21 21:08:50 -0600317 destination port instead of the default port 69.
Simon Glassaef523a2021-10-21 21:08:45 -0600318
319tftpblocksize
320 Block size to use for TFTP transfers; if not set,
321 we use the TFTP server's default block size
322
323tftptimeout
324 Retransmission timeout for TFTP packets (in milli-
325 seconds, minimum value is 1000 = 1 second). Defines
326 when a packet is considered to be lost so it has to
327 be retransmitted. The default is 5000 = 5 seconds.
328 Lowering this value may make downloads succeed
329 faster in networks with high packet loss rates or
330 with unreliable TFTP servers.
331
332tftptimeoutcountmax
333 maximum count of TFTP timeouts (no
334 unit, minimum value = 0). Defines how many timeouts
335 can happen during a single file transfer before that
336 transfer is aborted. The default is 10, and 0 means
337 'no timeouts allowed'. Increasing this value may help
338 downloads succeed with high packet loss rates, or with
339 unreliable TFTP servers or client hardware.
340
341tftpwindowsize
342 if this is set, the value is used for TFTP's
343 window size as described by RFC 7440.
344 This means the count of blocks we can receive before
345 sending ack to server.
346
347vlan
348 When set to a value < 4095 the traffic over
349 Ethernet is encapsulated/received over 802.1q
350 VLAN tagged frames.
351
Simon Glass341c7ea2021-10-21 21:08:49 -0600352 Note: This appears not to be used in U-Boot. See `README.VLAN`.
353
Simon Glassaef523a2021-10-21 21:08:45 -0600354bootpretryperiod
355 Period during which BOOTP/DHCP sends retries.
356 Unsigned value, in milliseconds. If not set, the period will
357 be either the default (28000), or a value based on
358 CONFIG_NET_RETRY_COUNT, if defined. This value has
Chris Packham291f7312022-05-25 13:08:51 +1200359 precedence over the value based on CONFIG_NET_RETRY_COUNT.
Simon Glassaef523a2021-10-21 21:08:45 -0600360
361memmatches
362 Number of matches found by the last 'ms' command, in hex
363
364memaddr
365 Address of the last match found by the 'ms' command, in hex,
366 or 0 if none
367
368mempos
369 Index position of the last match found by the 'ms' command,
370 in units of the size (.b, .w, .l) of the search
371
372zbootbase
373 (x86 only) Base address of the bzImage 'setup' block
374
375zbootaddr
376 (x86 only) Address of the loaded bzImage, typically
377 BZIMAGE_LOAD_ADDR which is 0x100000
378
379
380Image locations
381---------------
382
383The following image location variables contain the location of images
384used in booting. The "Image" column gives the role of the image and is
385not an environment variable name. The other columns are environment
386variable names. "File Name" gives the name of the file on a TFTP
387server, "RAM Address" gives the location in RAM the image will be
388loaded to, and "Flash Location" gives the image's address in NOR
389flash or offset in NAND flash.
390
391*Note* - these variables don't have to be defined for all boards, some
392boards currently use other variables for these purposes, and some
393boards use these variables for other purposes.
394
Simon Glass341c7ea2021-10-21 21:08:49 -0600395Also note that most of these variables are just a commonly used set of variable
396names, used in some other variable definitions, but are not hard-coded anywhere
397in U-Boot code.
398
Simon Glassaef523a2021-10-21 21:08:45 -0600399================= ============== ================ ==============
400Image File Name RAM Address Flash Location
401================= ============== ================ ==============
Simon Glassaef523a2021-10-21 21:08:45 -0600402Linux kernel bootfile kernel_addr_r kernel_addr
403device tree blob fdtfile fdt_addr_r fdt_addr
404ramdisk ramdiskfile ramdisk_addr_r ramdisk_addr
405================= ============== ================ ==============
406
Tom Rini4e2630e2022-07-11 14:32:13 -0400407When setting the RAM addresses for `kernel_addr_r`, `fdt_addr_r` and
408`ramdisk_addr_r` there are several types of constraints to keep in mind. The
409one type of constraint is payload requirement. For example, a device tree MUST
410be loaded at an 8-byte aligned address as that is what the specification
411requires. In a similar manner, the operating system may define restrictions on
412where in memory space payloads can be. This is documented for example in Linux,
413with both the `Booting ARM Linux`_ and `Booting AArch64 Linux`_ documents.
414Finally, there are practical constraints. We do not know the size of a given
415payload a user will use but each payload must not overlap or it will corrupt
416the other payload. A similar problem can happen when a payload ends up being in
417the OS BSS area. For these reasons we need to ensure our default values here
418are both unlikely to lead to failure to boot and sufficiently explained so that
419they can be optimized for boot time or adjusted for smaller memory
420configurations.
421
422On different architectures we will have different constraints. It is important
423that we follow whatever documented requirements are available to best ensure
424forward compatibility. What follows are examples to highlight how to provide
425reasonable default values in different cases.
426
427Texas Instruments OMAP2PLUS (ARMv7) example
428^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
429
430On these families of processors we are on a 32bit ARMv7 core. As booting some
431form of Linux is our most common payload we will also keep in mind the
432documented requirements for booting that Linux provides. These values are also
433known to be fine for booting a number of other operating systems (or their
434loaders). In this example we define the following variables and values::
435
436 loadaddr=0x82000000
437 kernel_addr_r=${loadaddr}
438 fdt_addr_r=0x88000000
439 ramdisk_addr_r=0x88080000
440 bootm_size=0x10000000
441
442The first thing to keep in mind is that DRAM starts at 0x80000000. We set a
44332MiB buffer from the start of memory as our default load address and set
444``kernel_addr_r`` to that. This is because the Linux ``zImage`` decompressor
445will typically then be able to avoid doing a relocation itself. It also MUST be
446within the first 128MiB of memory. The next value is we set ``fdt_addr_r`` to
447be at 128MiB offset from the start of memory. This location is suggested by the
448kernel documentation and is exceedingly unlikely to be overwritten by the
449kernel itself given other architectural constraints. We then allow for the
450device tree to be up to 512KiB in size before placing the ramdisk in memory. We
451then say that everything should be within the first 256MiB of memory so that
452U-Boot can relocate things as needed to ensure proper alignment. We pick 256MiB
453as our value here because we know there are very few platforms on in this
454family with less memory. It could be as high as 768MiB and still ensure that
455everything would be visible to the kernel, but again we go with what we assume
456is the safest assumption.
Simon Glassaef523a2021-10-21 21:08:45 -0600457
458Automatically updated variables
459-------------------------------
460
461The following environment variables may be used and automatically
462updated by the network boot commands ("bootp" and "rarpboot"),
463depending the information provided by your boot server:
464
465========= ===================================================
466Variable Notes
467========= ===================================================
468bootfile see above
469dnsip IP address of your Domain Name Server
470dnsip2 IP address of your secondary Domain Name Server
471gatewayip IP address of the Gateway (Router) to use
472hostname Target hostname
473ipaddr See above
474netmask Subnet Mask
475rootpath Pathname of the root filesystem on the NFS server
476serverip see above
477========= ===================================================
478
479
480Special environment variables
481-----------------------------
482
483There are two special Environment Variables:
484
485serial#
486 contains hardware identification information such as type string and/or
487 serial number
488ethaddr
Simon Glass420febd2021-10-21 21:08:50 -0600489 Ethernet address. If CONFIG_REGEX=y, also eth*addr (where * is an integer).
Simon Glassaef523a2021-10-21 21:08:45 -0600490
491These variables can be set only once (usually during manufacturing of
492the board). U-Boot refuses to delete or overwrite these variables
Simon Glass420febd2021-10-21 21:08:50 -0600493once they have been set, unless CONFIG_ENV_OVERWRITE is enabled in the board
494configuration.
Simon Glassaef523a2021-10-21 21:08:45 -0600495
496Also:
497
498ver
499 Contains the U-Boot version string as printed
500 with the "version" command. This variable is
501 readonly (see CONFIG_VERSION_VARIABLE).
502
503Please note that changes to some configuration parameters may take
Simon Glass420febd2021-10-21 21:08:50 -0600504only effect after the next boot (yes, that's just like Windows).
Simon Glassaef523a2021-10-21 21:08:45 -0600505
Simon Glass9f3a7bf2021-10-21 21:08:48 -0600506
507External environment file
508-------------------------
509
510The `CONFIG_USE_DEFAULT_ENV_FILE` option provides a way to bypass the
511environment generation in U-Boot. If enabled, then `CONFIG_DEFAULT_ENV_FILE`
512provides the name of a file which is converted into the environment,
513completely bypassing the standard environment variables in `env_default.h`.
514
515The format is the same as accepted by the mkenvimage tool, with lines containing
516key=value pairs. Blank lines and lines beginning with # are ignored.
517
518Future work may unify this feature with the text-based environment, perhaps
519moving the contents of `env_default.h` to a text file.
Simon Glass420febd2021-10-21 21:08:50 -0600520
521Implementation
522--------------
523
524See :doc:`../develop/environment` for internal development details.
Tom Rini4e2630e2022-07-11 14:32:13 -0400525
526.. _`Booting ARM Linux`: https://www.kernel.org/doc/html/latest/arm/booting.html
527.. _`Booting AArch64 Linux`: https://www.kernel.org/doc/html/latest/arm64/booting.html