blob: ebf75fa948ad1a544ba28a14673bb592b620fd80 [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
Patrick Delaunayfe869e12022-04-14 19:07:05 +020018See :doc:`cmd/env` for details.
19
Simon Glass5ba9e012021-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 Glassea754aa2021-10-21 21:08:45 -060023
Simon Glass86b9c3e2021-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
Simon Glassb86986c2022-10-18 07:46:31 -060066 #ifdef CONFIG_VIDEO
Simon Glass0f9b86f2022-10-16 15:59:22 -060067 stdout+=,vidconsole
Simon Glass86b9c3e2021-10-21 21:08:46 -060068 #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
Simon Glass63af90e2023-07-30 21:01:46 -060084Settings which are common to a group of boards can use #include to bring in
85a common file in the `include/env` directory, containing environment
86settings. For example::
87
88 #include <env/ti/mmc.env>
89
Simon Glass86b9c3e2021-10-21 21:08:46 -060090If CONFIG_ENV_SOURCE_FILE is empty and the default filename is not present, then
91the old-style C environment is used instead. See below.
92
93Old-style C environment
94-----------------------
95
96Traditionally, the default environment is created in `include/env_default.h`,
97and can be augmented by various `CONFIG` defines. See that file for details. In
Tom Rini0613c362022-12-04 10:03:50 -050098particular you can define `CFG_EXTRA_ENV_SETTINGS` in your board file
Simon Glass86b9c3e2021-10-21 21:08:46 -060099to add environment variables.
100
101Board maintainers are encouraged to migrate to the text-based environment as it
102is easier to maintain. The distro-board script still requires the old-style
Simon Glassf26a9662023-07-30 21:01:44 -0600103environments, so use :doc:`../develop/bootstd` instead.
Simon Glass86b9c3e2021-10-21 21:08:46 -0600104
105
106List of environment variables
107-----------------------------
108
Simon Glass40b9e0d2021-10-21 21:08:50 -0600109Some device configuration options can be set using environment variables. In
110many cases the value in the default environment comes from a CONFIG option - see
Simon Glass5ba9e012021-10-21 21:08:49 -0600111`include/env_default.h`) for this.
112
Simon Glass86b9c3e2021-10-21 21:08:46 -0600113This is most-likely not complete:
Simon Glassea754aa2021-10-21 21:08:45 -0600114
Heinrich Schuchardt0e219432022-09-10 09:16:37 +0200115autostart
116 If set to "yes" (actually any string starting with 1, y, Y, t, or T) an
117 image loaded with one of the commands listed below will be automatically
118 started by internally invoking the bootm command.
119
120 * bootelf - Boot from an ELF image in memory
121 * bootp - boot image via network using BOOTP/TFTP protocol
122 * dhcp - boot image via network using DHCP/TFTP protocol
123 * diskboot - boot from ide device
124 * nboot - boot from NAND device
125 * nfs - boot image via network using NFS protocol
126 * rarpboot - boot image via network using RARP/TFTP protocol
127 * scsiboot - boot from SCSI device
128 * tftpboot - boot image via network using TFTP protocol
129 * usbboot - boot from USB device
130
131 If the environment variable autostart is not set to a value starting with
132 1, y, Y, t, or T, an image passed to the "bootm" command will be copied to
133 the load address (and eventually uncompressed), but NOT be started.
134 This can be used to load and uncompress arbitrary data.
135
Simon Glassea754aa2021-10-21 21:08:45 -0600136baudrate
Simon Glass40b9e0d2021-10-21 21:08:50 -0600137 Used to set the baudrate of the UART - it defaults to CONFIG_BAUDRATE (which
138 defaults to 115200).
Simon Glassea754aa2021-10-21 21:08:45 -0600139
140bootdelay
Simon Glass40b9e0d2021-10-21 21:08:50 -0600141 Delay before automatically running bootcmd. During this time the user
142 can choose to enter the shell (or the boot menu if
143 CONFIG_AUTOBOOT_MENU_SHOW=y):
144
145 - 0 to autoboot with no delay, but you can stop it by key input.
146 - -1 to disable autoboot.
147 - -2 to autoboot with no delay and not check for abort
148
149 The default value is defined by CONFIG_BOOTDELAY.
150 The value of 'bootdelay' is overridden by the /config/bootdelay value in
151 the device-tree if CONFIG_OF_CONTROL=y.
Simon Glassea754aa2021-10-21 21:08:45 -0600152
153bootcmd
Simon Glass40b9e0d2021-10-21 21:08:50 -0600154 The command that is run if the user does not enter the shell during the
155 boot delay.
Simon Glassea754aa2021-10-21 21:08:45 -0600156
157bootargs
Simon Glass40b9e0d2021-10-21 21:08:50 -0600158 Command line arguments passed when booting an operating system or binary
159 image
Simon Glassea754aa2021-10-21 21:08:45 -0600160
161bootfile
162 Name of the image to load with TFTP
163
164bootm_low
165 Memory range available for image processing in the bootm
166 command can be restricted. This variable is given as
167 a hexadecimal number and defines lowest address allowed
168 for use by the bootm command. See also "bootm_size"
169 environment variable. Address defined by "bootm_low" is
170 also the base of the initial memory mapping for the Linux
Tom Rini65cc0e22022-11-16 13:10:41 -0500171 kernel -- see the description of CFG_SYS_BOOTMAPSZ and
Simon Glassea754aa2021-10-21 21:08:45 -0600172 bootm_mapsize.
173
174bootm_mapsize
175 Size of the initial memory mapping for the Linux kernel.
176 This variable is given as a hexadecimal number and it
177 defines the size of the memory region starting at base
178 address bootm_low that is accessible by the Linux kernel
Tom Rini65cc0e22022-11-16 13:10:41 -0500179 during early boot. If unset, CFG_SYS_BOOTMAPSZ is used
Simon Glassea754aa2021-10-21 21:08:45 -0600180 as the default value if it is defined, and bootm_size is
181 used otherwise.
182
183bootm_size
184 Memory range available for image processing in the bootm
185 command can be restricted. This variable is given as
186 a hexadecimal number and defines the size of the region
187 allowed for use by the bootm command. See also "bootm_low"
188 environment variable.
189
190bootstopkeysha256, bootdelaykey, bootstopkey
191 See README.autoboot
192
Caleb Connollye7610352024-01-09 11:51:09 +0000193button_cmd_0, button_cmd_0_name ... button_cmd_N, button_cmd_N_name
194 Used to map commands to run when a button is held during boot.
195 See CONFIG_BUTTON_CMD.
196
Simon Glassea754aa2021-10-21 21:08:45 -0600197updatefile
198 Location of the software update file on a TFTP server, used
199 by the automatic software update feature. Please refer to
200 documentation in doc/README.update for more details.
201
202autoload
203 if set to "no" (any string beginning with 'n'),
Simon Glass40b9e0d2021-10-21 21:08:50 -0600204 "bootp" and "dhcp" will just load perform a lookup of the
Simon Glassea754aa2021-10-21 21:08:45 -0600205 configuration from the BOOTP server, but not try to
Simon Glass754a7222022-03-11 16:22:39 -0700206 load any image.
Simon Glassea754aa2021-10-21 21:08:45 -0600207
Simon Glassea754aa2021-10-21 21:08:45 -0600208fdt_high
209 if set this restricts the maximum address that the
210 flattened device tree will be copied into upon boot.
211 For example, if you have a system with 1 GB memory
212 at physical address 0x10000000, while Linux kernel
213 only recognizes the first 704 MB as low memory, you
214 may need to set fdt_high as 0x3C000000 to have the
215 device tree blob be copied to the maximum address
216 of the 704 MB low memory, so that Linux kernel can
217 access it during the boot procedure.
218
Simon Glass40b9e0d2021-10-21 21:08:50 -0600219 If this is set to the special value 0xffffffff (32-bit machines) or
220 0xffffffffffffffff (64-bit machines) then
Simon Glassea754aa2021-10-21 21:08:45 -0600221 the fdt will not be copied at all on boot. For this
222 to work it must reside in writable memory, have
Michal Simeke6ff9982023-09-08 09:11:31 +0200223 sufficient padding on the end of it for U-Boot to
Simon Glassea754aa2021-10-21 21:08:45 -0600224 add the information it needs into it, and the memory
Tom Rini556af512022-06-20 10:31:28 -0400225 must be accessible by the kernel. This usage is strongly discouraged
226 however as it also stops U-Boot from ensuring the device tree starting
227 address is properly aligned and a misaligned tree will cause OS failures.
Simon Glassea754aa2021-10-21 21:08:45 -0600228
229fdtcontroladdr
230 if set this is the address of the control flattened
231 device tree used by U-Boot when CONFIG_OF_CONTROL is
232 defined.
233
234initrd_high
235 restrict positioning of initrd images:
236 If this variable is not set, initrd images will be
237 copied to the highest possible address in RAM; this
238 is usually what you want since it allows for
239 maximum initrd size. If for some reason you want to
240 make sure that the initrd image is loaded below the
Tom Rini65cc0e22022-11-16 13:10:41 -0500241 CFG_SYS_BOOTMAPSZ limit, you can set this environment
Simon Glassea754aa2021-10-21 21:08:45 -0600242 variable to a value of "no" or "off" or "0".
243 Alternatively, you can set it to a maximum upper
244 address to use (U-Boot will still check that it
245 does not overwrite the U-Boot stack and data).
246
247 For instance, when you have a system with 16 MB
248 RAM, and want to reserve 4 MB from use by Linux,
249 you can do this by adding "mem=12M" to the value of
250 the "bootargs" variable. However, now you must make
251 sure that the initrd image is placed in the first
252 12 MB as well - this can be done with::
253
254 setenv initrd_high 00c00000
255
Simon Glass40b9e0d2021-10-21 21:08:50 -0600256 If you set initrd_high to 0xffffffff (32-bit machines) or
257 0xffffffffffffffff (64-bit machines), this is an
Simon Glassea754aa2021-10-21 21:08:45 -0600258 indication to U-Boot that all addresses are legal
259 for the Linux kernel, including addresses in flash
260 memory. In this case U-Boot will NOT COPY the
261 ramdisk at all. This may be useful to reduce the
262 boot time on your system, but requires that this
Tom Rini556af512022-06-20 10:31:28 -0400263 feature is supported by your Linux kernel. This usage however requires
264 that the user ensure that there will be no overlap with other parts of the
265 image such as the Linux kernel BSS. It should not be enabled by default
266 and only done as part of optimizing a deployment.
Simon Glassea754aa2021-10-21 21:08:45 -0600267
268ipaddr
269 IP address; needed for tftpboot command
270
271loadaddr
272 Default load address for commands like "bootp",
Tom Rini556af512022-06-20 10:31:28 -0400273 "rarpboot", "tftpboot", "loadb" or "diskboot". Note that the optimal
274 default values here will vary between architectures. On 32bit ARM for
275 example, some offset from start of memory is used as the Linux kernel
276 zImage has a self decompressor and it's best if we stay out of where that
277 will be working.
Simon Glassea754aa2021-10-21 21:08:45 -0600278
279loads_echo
280 see CONFIG_LOADS_ECHO
281
282serverip
283 TFTP server IP address; needed for tftpboot command
284
285bootretry
286 see CONFIG_BOOT_RETRY_TIME
287
288bootdelaykey
289 see CONFIG_AUTOBOOT_DELAY_STR
290
291bootstopkey
292 see CONFIG_AUTOBOOT_STOP_STR
293
294ethprime
Simon Glass40b9e0d2021-10-21 21:08:50 -0600295 controls which network interface is used first.
Simon Glassea754aa2021-10-21 21:08:45 -0600296
297ethact
298 controls which interface is currently active.
299 For example you can do the following::
300
301 => setenv ethact FEC
302 => ping 192.168.0.1 # traffic sent on FEC
303 => setenv ethact SCC
304 => ping 10.0.0.1 # traffic sent on SCC
305
306ethrotate
307 When set to "no" U-Boot does not go through all
308 available network interfaces.
Simon Glass40b9e0d2021-10-21 21:08:50 -0600309 It just stays at the currently selected interface. When unset or set to
310 anything other than "no", U-Boot does go through all
311 available network interfaces.
Simon Glassea754aa2021-10-21 21:08:45 -0600312
Marek Vasut4caacb22023-12-13 22:11:13 +0100313httpdstp
314 If this is set, the value is used for HTTP's TCP
315 destination port instead of the default port 80.
316
Simon Glassea754aa2021-10-21 21:08:45 -0600317netretry
318 When set to "no" each network operation will
319 either succeed or fail without retrying.
320 When set to "once" the network operation will
321 fail when all the available network interfaces
322 are tried once without success.
323 Useful on scripts which control the retry operation
324 themselves.
325
Simon Glassea754aa2021-10-21 21:08:45 -0600326silent_linux
327 If set then Linux will be told to boot silently, by
Simon Glass40b9e0d2021-10-21 21:08:50 -0600328 adding 'console=' to its command line. If "yes" it will be
Simon Glassea754aa2021-10-21 21:08:45 -0600329 made silent. If "no" it will not be made silent. If
330 unset, then it will be made silent if the U-Boot console
331 is silent.
332
333tftpsrcp
334 If this is set, the value is used for TFTP's
335 UDP source port.
336
337tftpdstp
338 If this is set, the value is used for TFTP's UDP
Simon Glass40b9e0d2021-10-21 21:08:50 -0600339 destination port instead of the default port 69.
Simon Glassea754aa2021-10-21 21:08:45 -0600340
341tftpblocksize
342 Block size to use for TFTP transfers; if not set,
343 we use the TFTP server's default block size
344
345tftptimeout
346 Retransmission timeout for TFTP packets (in milli-
347 seconds, minimum value is 1000 = 1 second). Defines
348 when a packet is considered to be lost so it has to
349 be retransmitted. The default is 5000 = 5 seconds.
350 Lowering this value may make downloads succeed
351 faster in networks with high packet loss rates or
352 with unreliable TFTP servers.
353
354tftptimeoutcountmax
355 maximum count of TFTP timeouts (no
356 unit, minimum value = 0). Defines how many timeouts
357 can happen during a single file transfer before that
358 transfer is aborted. The default is 10, and 0 means
359 'no timeouts allowed'. Increasing this value may help
360 downloads succeed with high packet loss rates, or with
361 unreliable TFTP servers or client hardware.
362
363tftpwindowsize
364 if this is set, the value is used for TFTP's
365 window size as described by RFC 7440.
366 This means the count of blocks we can receive before
367 sending ack to server.
368
369vlan
370 When set to a value < 4095 the traffic over
371 Ethernet is encapsulated/received over 802.1q
372 VLAN tagged frames.
373
Simon Glass5ba9e012021-10-21 21:08:49 -0600374 Note: This appears not to be used in U-Boot. See `README.VLAN`.
375
Simon Glassea754aa2021-10-21 21:08:45 -0600376bootpretryperiod
377 Period during which BOOTP/DHCP sends retries.
378 Unsigned value, in milliseconds. If not set, the period will
379 be either the default (28000), or a value based on
380 CONFIG_NET_RETRY_COUNT, if defined. This value has
Chris Packhamf1533c42022-05-25 13:08:51 +1200381 precedence over the value based on CONFIG_NET_RETRY_COUNT.
Simon Glassea754aa2021-10-21 21:08:45 -0600382
383memmatches
384 Number of matches found by the last 'ms' command, in hex
385
386memaddr
387 Address of the last match found by the 'ms' command, in hex,
388 or 0 if none
389
390mempos
391 Index position of the last match found by the 'ms' command,
392 in units of the size (.b, .w, .l) of the search
393
394zbootbase
395 (x86 only) Base address of the bzImage 'setup' block
396
397zbootaddr
398 (x86 only) Address of the loaded bzImage, typically
399 BZIMAGE_LOAD_ADDR which is 0x100000
400
401
402Image locations
403---------------
404
405The following image location variables contain the location of images
406used in booting. The "Image" column gives the role of the image and is
407not an environment variable name. The other columns are environment
408variable names. "File Name" gives the name of the file on a TFTP
409server, "RAM Address" gives the location in RAM the image will be
410loaded to, and "Flash Location" gives the image's address in NOR
411flash or offset in NAND flash.
412
413*Note* - these variables don't have to be defined for all boards, some
414boards currently use other variables for these purposes, and some
415boards use these variables for other purposes.
416
Simon Glass5ba9e012021-10-21 21:08:49 -0600417Also note that most of these variables are just a commonly used set of variable
418names, used in some other variable definitions, but are not hard-coded anywhere
419in U-Boot code.
420
Simon Glassea754aa2021-10-21 21:08:45 -0600421================= ============== ================ ==============
422Image File Name RAM Address Flash Location
423================= ============== ================ ==============
Simon Glassea754aa2021-10-21 21:08:45 -0600424Linux kernel bootfile kernel_addr_r kernel_addr
425device tree blob fdtfile fdt_addr_r fdt_addr
426ramdisk ramdiskfile ramdisk_addr_r ramdisk_addr
427================= ============== ================ ==============
428
Tom Rinibf893582022-07-11 14:32:13 -0400429When setting the RAM addresses for `kernel_addr_r`, `fdt_addr_r` and
430`ramdisk_addr_r` there are several types of constraints to keep in mind. The
431one type of constraint is payload requirement. For example, a device tree MUST
432be loaded at an 8-byte aligned address as that is what the specification
433requires. In a similar manner, the operating system may define restrictions on
434where in memory space payloads can be. This is documented for example in Linux,
435with both the `Booting ARM Linux`_ and `Booting AArch64 Linux`_ documents.
436Finally, there are practical constraints. We do not know the size of a given
437payload a user will use but each payload must not overlap or it will corrupt
438the other payload. A similar problem can happen when a payload ends up being in
439the OS BSS area. For these reasons we need to ensure our default values here
440are both unlikely to lead to failure to boot and sufficiently explained so that
441they can be optimized for boot time or adjusted for smaller memory
442configurations.
443
444On different architectures we will have different constraints. It is important
445that we follow whatever documented requirements are available to best ensure
446forward compatibility. What follows are examples to highlight how to provide
447reasonable default values in different cases.
448
449Texas Instruments OMAP2PLUS (ARMv7) example
450^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
451
452On these families of processors we are on a 32bit ARMv7 core. As booting some
453form of Linux is our most common payload we will also keep in mind the
454documented requirements for booting that Linux provides. These values are also
455known to be fine for booting a number of other operating systems (or their
456loaders). In this example we define the following variables and values::
457
458 loadaddr=0x82000000
459 kernel_addr_r=${loadaddr}
460 fdt_addr_r=0x88000000
461 ramdisk_addr_r=0x88080000
462 bootm_size=0x10000000
463
464The first thing to keep in mind is that DRAM starts at 0x80000000. We set a
46532MiB buffer from the start of memory as our default load address and set
466``kernel_addr_r`` to that. This is because the Linux ``zImage`` decompressor
467will typically then be able to avoid doing a relocation itself. It also MUST be
468within the first 128MiB of memory. The next value is we set ``fdt_addr_r`` to
469be at 128MiB offset from the start of memory. This location is suggested by the
470kernel documentation and is exceedingly unlikely to be overwritten by the
471kernel itself given other architectural constraints. We then allow for the
472device tree to be up to 512KiB in size before placing the ramdisk in memory. We
473then say that everything should be within the first 256MiB of memory so that
474U-Boot can relocate things as needed to ensure proper alignment. We pick 256MiB
475as our value here because we know there are very few platforms on in this
476family with less memory. It could be as high as 768MiB and still ensure that
477everything would be visible to the kernel, but again we go with what we assume
478is the safest assumption.
Simon Glassea754aa2021-10-21 21:08:45 -0600479
480Automatically updated variables
481-------------------------------
482
483The following environment variables may be used and automatically
484updated by the network boot commands ("bootp" and "rarpboot"),
485depending the information provided by your boot server:
486
487========= ===================================================
488Variable Notes
489========= ===================================================
490bootfile see above
491dnsip IP address of your Domain Name Server
492dnsip2 IP address of your secondary Domain Name Server
493gatewayip IP address of the Gateway (Router) to use
494hostname Target hostname
495ipaddr See above
496netmask Subnet Mask
497rootpath Pathname of the root filesystem on the NFS server
498serverip see above
499========= ===================================================
500
501
502Special environment variables
503-----------------------------
504
505There are two special Environment Variables:
506
507serial#
508 contains hardware identification information such as type string and/or
509 serial number
510ethaddr
Simon Glass40b9e0d2021-10-21 21:08:50 -0600511 Ethernet address. If CONFIG_REGEX=y, also eth*addr (where * is an integer).
Simon Glassea754aa2021-10-21 21:08:45 -0600512
513These variables can be set only once (usually during manufacturing of
514the board). U-Boot refuses to delete or overwrite these variables
Simon Glass40b9e0d2021-10-21 21:08:50 -0600515once they have been set, unless CONFIG_ENV_OVERWRITE is enabled in the board
516configuration.
Simon Glassea754aa2021-10-21 21:08:45 -0600517
518Also:
519
520ver
521 Contains the U-Boot version string as printed
522 with the "version" command. This variable is
523 readonly (see CONFIG_VERSION_VARIABLE).
524
525Please note that changes to some configuration parameters may take
Simon Glass40b9e0d2021-10-21 21:08:50 -0600526only effect after the next boot (yes, that's just like Windows).
Simon Glass1df02d12021-10-21 21:08:48 -0600527
528
529External environment file
530-------------------------
531
532The `CONFIG_USE_DEFAULT_ENV_FILE` option provides a way to bypass the
533environment generation in U-Boot. If enabled, then `CONFIG_DEFAULT_ENV_FILE`
534provides the name of a file which is converted into the environment,
535completely bypassing the standard environment variables in `env_default.h`.
536
537The format is the same as accepted by the mkenvimage tool, with lines containing
538key=value pairs. Blank lines and lines beginning with # are ignored.
539
540Future work may unify this feature with the text-based environment, perhaps
541moving the contents of `env_default.h` to a text file.
Simon Glass40b9e0d2021-10-21 21:08:50 -0600542
543Implementation
544--------------
545
546See :doc:`../develop/environment` for internal development details.
Tom Rinibf893582022-07-11 14:32:13 -0400547
548.. _`Booting ARM Linux`: https://www.kernel.org/doc/html/latest/arm/booting.html
549.. _`Booting AArch64 Linux`: https://www.kernel.org/doc/html/latest/arm64/booting.html