blob: 80550fc44780d8d7f5e5af9a4948b00e2000cc15 [file] [log] [blame]
Simon Glassea754aa2021-10-21 21:08:45 -06001.. SPDX-License-Identifier: GPL-2.0+
2
3Environment Variables
4=====================
5
Simon Glass40b9e0d2021-10-21 21:08:50 -06006U-Boot supports user configuration using environment variables which
Simon Glass5ba9e012021-10-21 21:08:49 -06007can be made persistent by saving to persistent storage, for example flash
8memory.
Simon Glassea754aa2021-10-21 21:08:45 -06009
Simon Glass40b9e0d2021-10-21 21:08:50 -060010Environment variables are set using "env set" (alias "setenv"), printed using
Simon Glass5ba9e012021-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 Glassea754aa2021-10-21 21:08:45 -060013without a value can be used to delete a variable from the
Simon Glass5ba9e012021-10-21 21:08:49 -060014environment. As long as you don't save the environment, you are
Simon Glassea754aa2021-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
Simon Glass5ba9e012021-10-21 21:08:49 -060018Some configuration is controlled by Environment Variables, so that setting the
19variable can adjust the behaviour of U-Boot (e.g. autoboot delay, autoloading
20from tftp).
Simon Glassea754aa2021-10-21 21:08:45 -060021
Simon Glass86b9c3e2021-10-21 21:08:46 -060022Text-based Environment
23----------------------
24
25The default environment for a board is created using a `.env` environment file
26using a simple text format. The base filename for this is defined by
27`CONFIG_ENV_SOURCE_FILE`, or `CONFIG_SYS_BOARD` if that is empty.
28
29The file must be in the board directory and have a .env extension, so
30assuming that there is a board vendor, the resulting filename is therefore::
31
32 board/<vendor>/<board>/<CONFIG_ENV_SOURCE_FILE>.env
33
34or::
35
36 board/<vendor>/<board>/<CONFIG_SYS_BOARD>.env
37
38This is a plain text file where you can type your environment variables in
39the form `var=value`. Blank lines and multi-line variables are supported.
40The conversion script looks for a line that starts in column 1 with a string
41and has an equals sign immediately afterwards. Spaces before the = are not
42permitted. It is a good idea to indent your scripts so that only the 'var='
43appears at the start of a line.
44
45To add additional text to a variable you can use `var+=value`. This text is
46merged into the variable during the make process and made available as a
47single value to U-Boot. Variables can contain `+` characters but in the unlikely
48event that you want to have a variable name ending in plus, put a backslash
49before the `+` so that the script knows you are not adding to an existing
50variable but assigning to a new one::
51
52 maximum\+=value
53
54This file can include C-style comments. Blank lines and multi-line
55variables are supported, and you can use normal C preprocessor directives
56and CONFIG defines from your board config also.
57
58For example, for snapper9260 you would create a text file called
59`board/bluewater/snapper9260.env` containing the environment text.
60
61Example::
62
63 stdout=serial
64 #ifdef CONFIG_LCD
65 stdout+=,lcd
66 #endif
67 bootcmd=
68 /* U-Boot script for booting */
69
70 if [ -z ${tftpserverip} ]; then
71 echo "Use 'setenv tftpserverip a.b.c.d' to set IP address."
72 fi
73
74 usb start; setenv autoload n; bootp;
75 tftpboot ${tftpserverip}:
76 bootm
77 failed=
78 /* Print a message when boot fails */
79 echo CONFIG_SYS_BOARD boot failed - please check your image
80 echo Load address is CONFIG_SYS_LOAD_ADDR
81
82If CONFIG_ENV_SOURCE_FILE is empty and the default filename is not present, then
83the old-style C environment is used instead. See below.
84
85Old-style C environment
86-----------------------
87
88Traditionally, the default environment is created in `include/env_default.h`,
89and can be augmented by various `CONFIG` defines. See that file for details. In
90particular you can define `CONFIG_EXTRA_ENV_SETTINGS` in your board file
91to add environment variables.
92
93Board maintainers are encouraged to migrate to the text-based environment as it
94is easier to maintain. The distro-board script still requires the old-style
95environment but work is underway to address this.
96
97
98List of environment variables
99-----------------------------
100
Simon Glass40b9e0d2021-10-21 21:08:50 -0600101Some device configuration options can be set using environment variables. In
102many cases the value in the default environment comes from a CONFIG option - see
Simon Glass5ba9e012021-10-21 21:08:49 -0600103`include/env_default.h`) for this.
104
Simon Glass86b9c3e2021-10-21 21:08:46 -0600105This is most-likely not complete:
Simon Glassea754aa2021-10-21 21:08:45 -0600106
107baudrate
Simon Glass40b9e0d2021-10-21 21:08:50 -0600108 Used to set the baudrate of the UART - it defaults to CONFIG_BAUDRATE (which
109 defaults to 115200).
Simon Glassea754aa2021-10-21 21:08:45 -0600110
111bootdelay
Simon Glass40b9e0d2021-10-21 21:08:50 -0600112 Delay before automatically running bootcmd. During this time the user
113 can choose to enter the shell (or the boot menu if
114 CONFIG_AUTOBOOT_MENU_SHOW=y):
115
116 - 0 to autoboot with no delay, but you can stop it by key input.
117 - -1 to disable autoboot.
118 - -2 to autoboot with no delay and not check for abort
119
120 The default value is defined by CONFIG_BOOTDELAY.
121 The value of 'bootdelay' is overridden by the /config/bootdelay value in
122 the device-tree if CONFIG_OF_CONTROL=y.
Simon Glassea754aa2021-10-21 21:08:45 -0600123
124bootcmd
Simon Glass40b9e0d2021-10-21 21:08:50 -0600125 The command that is run if the user does not enter the shell during the
126 boot delay.
Simon Glassea754aa2021-10-21 21:08:45 -0600127
128bootargs
Simon Glass40b9e0d2021-10-21 21:08:50 -0600129 Command line arguments passed when booting an operating system or binary
130 image
Simon Glassea754aa2021-10-21 21:08:45 -0600131
132bootfile
133 Name of the image to load with TFTP
134
135bootm_low
136 Memory range available for image processing in the bootm
137 command can be restricted. This variable is given as
138 a hexadecimal number and defines lowest address allowed
139 for use by the bootm command. See also "bootm_size"
140 environment variable. Address defined by "bootm_low" is
141 also the base of the initial memory mapping for the Linux
142 kernel -- see the description of CONFIG_SYS_BOOTMAPSZ and
143 bootm_mapsize.
144
145bootm_mapsize
146 Size of the initial memory mapping for the Linux kernel.
147 This variable is given as a hexadecimal number and it
148 defines the size of the memory region starting at base
149 address bootm_low that is accessible by the Linux kernel
150 during early boot. If unset, CONFIG_SYS_BOOTMAPSZ is used
151 as the default value if it is defined, and bootm_size is
152 used otherwise.
153
154bootm_size
155 Memory range available for image processing in the bootm
156 command can be restricted. This variable is given as
157 a hexadecimal number and defines the size of the region
158 allowed for use by the bootm command. See also "bootm_low"
159 environment variable.
160
161bootstopkeysha256, bootdelaykey, bootstopkey
162 See README.autoboot
163
164updatefile
165 Location of the software update file on a TFTP server, used
166 by the automatic software update feature. Please refer to
167 documentation in doc/README.update for more details.
168
169autoload
170 if set to "no" (any string beginning with 'n'),
Simon Glass40b9e0d2021-10-21 21:08:50 -0600171 "bootp" and "dhcp" will just load perform a lookup of the
Simon Glassea754aa2021-10-21 21:08:45 -0600172 configuration from the BOOTP server, but not try to
Simon Glass754a7222022-03-11 16:22:39 -0700173 load any image.
Simon Glassea754aa2021-10-21 21:08:45 -0600174
175autostart
Simon Glass40b9e0d2021-10-21 21:08:50 -0600176 if set to "yes", an image loaded using the "bootp", "dhcp",
Simon Glassea754aa2021-10-21 21:08:45 -0600177 "rarpboot", "tftpboot" or "diskboot" commands will
178 be automatically started (by internally calling
179 "bootm")
180
Simon Glass78398652021-10-21 21:08:52 -0600181 If unset, or set to "1"/"yes"/"true" (case insensitive, just the first
182 character is enough), a standalone image
183 passed to the "bootm" command will be copied to the load address
Simon Glassea754aa2021-10-21 21:08:45 -0600184 (and eventually uncompressed), but NOT be started.
185 This can be used to load and uncompress arbitrary
186 data.
187
188fdt_high
189 if set this restricts the maximum address that the
190 flattened device tree will be copied into upon boot.
191 For example, if you have a system with 1 GB memory
192 at physical address 0x10000000, while Linux kernel
193 only recognizes the first 704 MB as low memory, you
194 may need to set fdt_high as 0x3C000000 to have the
195 device tree blob be copied to the maximum address
196 of the 704 MB low memory, so that Linux kernel can
197 access it during the boot procedure.
198
Simon Glass40b9e0d2021-10-21 21:08:50 -0600199 If this is set to the special value 0xffffffff (32-bit machines) or
200 0xffffffffffffffff (64-bit machines) then
Simon Glassea754aa2021-10-21 21:08:45 -0600201 the fdt will not be copied at all on boot. For this
202 to work it must reside in writable memory, have
203 sufficient padding on the end of it for u-boot to
204 add the information it needs into it, and the memory
205 must be accessible by the kernel.
206
207fdtcontroladdr
208 if set this is the address of the control flattened
209 device tree used by U-Boot when CONFIG_OF_CONTROL is
210 defined.
211
212initrd_high
213 restrict positioning of initrd images:
214 If this variable is not set, initrd images will be
215 copied to the highest possible address in RAM; this
216 is usually what you want since it allows for
217 maximum initrd size. If for some reason you want to
218 make sure that the initrd image is loaded below the
219 CONFIG_SYS_BOOTMAPSZ limit, you can set this environment
220 variable to a value of "no" or "off" or "0".
221 Alternatively, you can set it to a maximum upper
222 address to use (U-Boot will still check that it
223 does not overwrite the U-Boot stack and data).
224
225 For instance, when you have a system with 16 MB
226 RAM, and want to reserve 4 MB from use by Linux,
227 you can do this by adding "mem=12M" to the value of
228 the "bootargs" variable. However, now you must make
229 sure that the initrd image is placed in the first
230 12 MB as well - this can be done with::
231
232 setenv initrd_high 00c00000
233
Simon Glass40b9e0d2021-10-21 21:08:50 -0600234 If you set initrd_high to 0xffffffff (32-bit machines) or
235 0xffffffffffffffff (64-bit machines), this is an
Simon Glassea754aa2021-10-21 21:08:45 -0600236 indication to U-Boot that all addresses are legal
237 for the Linux kernel, including addresses in flash
238 memory. In this case U-Boot will NOT COPY the
239 ramdisk at all. This may be useful to reduce the
240 boot time on your system, but requires that this
241 feature is supported by your Linux kernel.
242
243ipaddr
244 IP address; needed for tftpboot command
245
246loadaddr
247 Default load address for commands like "bootp",
248 "rarpboot", "tftpboot", "loadb" or "diskboot"
249
250loads_echo
251 see CONFIG_LOADS_ECHO
252
253serverip
254 TFTP server IP address; needed for tftpboot command
255
256bootretry
257 see CONFIG_BOOT_RETRY_TIME
258
259bootdelaykey
260 see CONFIG_AUTOBOOT_DELAY_STR
261
262bootstopkey
263 see CONFIG_AUTOBOOT_STOP_STR
264
265ethprime
Simon Glass40b9e0d2021-10-21 21:08:50 -0600266 controls which network interface is used first.
Simon Glassea754aa2021-10-21 21:08:45 -0600267
268ethact
269 controls which interface is currently active.
270 For example you can do the following::
271
272 => setenv ethact FEC
273 => ping 192.168.0.1 # traffic sent on FEC
274 => setenv ethact SCC
275 => ping 10.0.0.1 # traffic sent on SCC
276
277ethrotate
278 When set to "no" U-Boot does not go through all
279 available network interfaces.
Simon Glass40b9e0d2021-10-21 21:08:50 -0600280 It just stays at the currently selected interface. When unset or set to
281 anything other than "no", U-Boot does go through all
282 available network interfaces.
Simon Glassea754aa2021-10-21 21:08:45 -0600283
284netretry
285 When set to "no" each network operation will
286 either succeed or fail without retrying.
287 When set to "once" the network operation will
288 fail when all the available network interfaces
289 are tried once without success.
290 Useful on scripts which control the retry operation
291 themselves.
292
Simon Glassea754aa2021-10-21 21:08:45 -0600293silent_linux
294 If set then Linux will be told to boot silently, by
Simon Glass40b9e0d2021-10-21 21:08:50 -0600295 adding 'console=' to its command line. If "yes" it will be
Simon Glassea754aa2021-10-21 21:08:45 -0600296 made silent. If "no" it will not be made silent. If
297 unset, then it will be made silent if the U-Boot console
298 is silent.
299
300tftpsrcp
301 If this is set, the value is used for TFTP's
302 UDP source port.
303
304tftpdstp
305 If this is set, the value is used for TFTP's UDP
Simon Glass40b9e0d2021-10-21 21:08:50 -0600306 destination port instead of the default port 69.
Simon Glassea754aa2021-10-21 21:08:45 -0600307
308tftpblocksize
309 Block size to use for TFTP transfers; if not set,
310 we use the TFTP server's default block size
311
312tftptimeout
313 Retransmission timeout for TFTP packets (in milli-
314 seconds, minimum value is 1000 = 1 second). Defines
315 when a packet is considered to be lost so it has to
316 be retransmitted. The default is 5000 = 5 seconds.
317 Lowering this value may make downloads succeed
318 faster in networks with high packet loss rates or
319 with unreliable TFTP servers.
320
321tftptimeoutcountmax
322 maximum count of TFTP timeouts (no
323 unit, minimum value = 0). Defines how many timeouts
324 can happen during a single file transfer before that
325 transfer is aborted. The default is 10, and 0 means
326 'no timeouts allowed'. Increasing this value may help
327 downloads succeed with high packet loss rates, or with
328 unreliable TFTP servers or client hardware.
329
330tftpwindowsize
331 if this is set, the value is used for TFTP's
332 window size as described by RFC 7440.
333 This means the count of blocks we can receive before
334 sending ack to server.
335
336vlan
337 When set to a value < 4095 the traffic over
338 Ethernet is encapsulated/received over 802.1q
339 VLAN tagged frames.
340
Simon Glass5ba9e012021-10-21 21:08:49 -0600341 Note: This appears not to be used in U-Boot. See `README.VLAN`.
342
Simon Glassea754aa2021-10-21 21:08:45 -0600343bootpretryperiod
344 Period during which BOOTP/DHCP sends retries.
345 Unsigned value, in milliseconds. If not set, the period will
346 be either the default (28000), or a value based on
347 CONFIG_NET_RETRY_COUNT, if defined. This value has
348 precedence over the valu based on CONFIG_NET_RETRY_COUNT.
349
350memmatches
351 Number of matches found by the last 'ms' command, in hex
352
353memaddr
354 Address of the last match found by the 'ms' command, in hex,
355 or 0 if none
356
357mempos
358 Index position of the last match found by the 'ms' command,
359 in units of the size (.b, .w, .l) of the search
360
361zbootbase
362 (x86 only) Base address of the bzImage 'setup' block
363
364zbootaddr
365 (x86 only) Address of the loaded bzImage, typically
366 BZIMAGE_LOAD_ADDR which is 0x100000
367
368
369Image locations
370---------------
371
372The following image location variables contain the location of images
373used in booting. The "Image" column gives the role of the image and is
374not an environment variable name. The other columns are environment
375variable names. "File Name" gives the name of the file on a TFTP
376server, "RAM Address" gives the location in RAM the image will be
377loaded to, and "Flash Location" gives the image's address in NOR
378flash or offset in NAND flash.
379
380*Note* - these variables don't have to be defined for all boards, some
381boards currently use other variables for these purposes, and some
382boards use these variables for other purposes.
383
Simon Glass5ba9e012021-10-21 21:08:49 -0600384Also note that most of these variables are just a commonly used set of variable
385names, used in some other variable definitions, but are not hard-coded anywhere
386in U-Boot code.
387
Simon Glassea754aa2021-10-21 21:08:45 -0600388================= ============== ================ ==============
389Image File Name RAM Address Flash Location
390================= ============== ================ ==============
391u-boot u-boot u-boot_addr_r u-boot_addr
392Linux kernel bootfile kernel_addr_r kernel_addr
393device tree blob fdtfile fdt_addr_r fdt_addr
394ramdisk ramdiskfile ramdisk_addr_r ramdisk_addr
395================= ============== ================ ==============
396
397
398Automatically updated variables
399-------------------------------
400
401The following environment variables may be used and automatically
402updated by the network boot commands ("bootp" and "rarpboot"),
403depending the information provided by your boot server:
404
405========= ===================================================
406Variable Notes
407========= ===================================================
408bootfile see above
409dnsip IP address of your Domain Name Server
410dnsip2 IP address of your secondary Domain Name Server
411gatewayip IP address of the Gateway (Router) to use
412hostname Target hostname
413ipaddr See above
414netmask Subnet Mask
415rootpath Pathname of the root filesystem on the NFS server
416serverip see above
417========= ===================================================
418
419
420Special environment variables
421-----------------------------
422
423There are two special Environment Variables:
424
425serial#
426 contains hardware identification information such as type string and/or
427 serial number
428ethaddr
Simon Glass40b9e0d2021-10-21 21:08:50 -0600429 Ethernet address. If CONFIG_REGEX=y, also eth*addr (where * is an integer).
Simon Glassea754aa2021-10-21 21:08:45 -0600430
431These variables can be set only once (usually during manufacturing of
432the board). U-Boot refuses to delete or overwrite these variables
Simon Glass40b9e0d2021-10-21 21:08:50 -0600433once they have been set, unless CONFIG_ENV_OVERWRITE is enabled in the board
434configuration.
Simon Glassea754aa2021-10-21 21:08:45 -0600435
436Also:
437
438ver
439 Contains the U-Boot version string as printed
440 with the "version" command. This variable is
441 readonly (see CONFIG_VERSION_VARIABLE).
442
443Please note that changes to some configuration parameters may take
Simon Glass40b9e0d2021-10-21 21:08:50 -0600444only effect after the next boot (yes, that's just like Windows).
Simon Glass1df02d12021-10-21 21:08:48 -0600445
446
447External environment file
448-------------------------
449
450The `CONFIG_USE_DEFAULT_ENV_FILE` option provides a way to bypass the
451environment generation in U-Boot. If enabled, then `CONFIG_DEFAULT_ENV_FILE`
452provides the name of a file which is converted into the environment,
453completely bypassing the standard environment variables in `env_default.h`.
454
455The format is the same as accepted by the mkenvimage tool, with lines containing
456key=value pairs. Blank lines and lines beginning with # are ignored.
457
458Future work may unify this feature with the text-based environment, perhaps
459moving the contents of `env_default.h` to a text file.
Simon Glass40b9e0d2021-10-21 21:08:50 -0600460
461Implementation
462--------------
463
464See :doc:`../develop/environment` for internal development details.