Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 1 | .. SPDX-License-Identifier: GPL-2.0+ |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 2 | |
| 3 | Generic Distro Configuration Concept |
| 4 | ==================================== |
| 5 | |
| 6 | Linux distributions are faced with supporting a variety of boot mechanisms, |
| 7 | environments or bootloaders (PC BIOS, EFI, U-Boot, Barebox, ...). This makes |
| 8 | life complicated. Worse, bootloaders such as U-Boot have a configurable set |
| 9 | of features, and each board chooses to enable a different set of features. |
| 10 | Hence, distros typically need to have board-specific knowledge in order to |
| 11 | set up a bootable system. |
| 12 | |
| 13 | This document defines a common set of U-Boot features that are required for |
| 14 | a distro to support the board in a generic fashion. Any board wishing to |
| 15 | allow distros to install and boot in an out-of-the-box fashion should enable |
| 16 | all these features. Linux distros can then create a single set of boot |
| 17 | support/install logic that targets these features. This will allow distros |
| 18 | to install on many boards without the need for board-specific logic. |
| 19 | |
| 20 | In fact, some of these features can be implemented by any bootloader, thus |
| 21 | decoupling distro install/boot logic from any knowledge of the bootloader. |
| 22 | |
| 23 | This model assumes that boards will load boot configuration files from a |
| 24 | regular storage mechanism (eMMC, SD card, USB Disk, SATA disk, etc.) with |
Masahiro Yamada | 7790de7 | 2015-07-07 18:47:17 +0900 | [diff] [blame] | 25 | a standard partitioning scheme (MBR, GPT). Boards that cannot support this |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 26 | storage model are outside the scope of this document, and may still need |
| 27 | board-specific installer/boot-configuration support in a distro. |
| 28 | |
| 29 | To some extent, this model assumes that a board has a separate boot flash |
| 30 | that contains U-Boot, and that the user has somehow installed U-Boot to this |
| 31 | flash before running the distro installer. Even on boards that do not conform |
| 32 | to this aspect of the model, the extent of the board-specific support in the |
| 33 | distro installer logic would be to install a board-specific U-Boot package to |
Masahiro Yamada | 7790de7 | 2015-07-07 18:47:17 +0900 | [diff] [blame] | 34 | the boot partition during installation. This distro-supplied U-Boot can still |
| 35 | implement the same features as on any other board, and hence the distro's boot |
| 36 | configuration file generation logic can still be board-agnostic. |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 37 | |
| 38 | Locating Bootable Disks |
| 39 | ----------------------- |
| 40 | |
| 41 | Typical desktop/server PCs search all (or a user-defined subset of) attached |
| 42 | storage devices for a bootable partition, then load the bootloader or boot |
| 43 | configuration files from there. A U-Boot board port that enables the features |
| 44 | mentioned in this document will search for boot configuration files in the |
| 45 | same way. |
| 46 | |
| 47 | Thus, distros do not need to manipulate any kind of bootloader-specific |
| 48 | configuration data to indicate which storage device the system should boot |
| 49 | from. |
| 50 | |
| 51 | Distros simply need to install the boot configuration files (see next |
| 52 | section) in an ext2/3/4 or FAT partition, mark the partition bootable (via |
| 53 | the MBR bootable flag, or GPT legacy_bios_bootable attribute), and U-Boot (or |
| 54 | any other bootloader) will find those boot files and execute them. This is |
| 55 | conceptually identical to creating a grub2 configuration file on a desktop |
| 56 | PC. |
| 57 | |
Masahiro Yamada | 7790de7 | 2015-07-07 18:47:17 +0900 | [diff] [blame] | 58 | Note that in the absence of any partition that is explicitly marked bootable, |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 59 | U-Boot falls back to searching the first valid partition of a disk for boot |
| 60 | configuration files. Other bootloaders are recommended to do the same, since |
| 61 | I believe that partition table bootable flags aren't so commonly used outside |
| 62 | the realm of x86 PCs. |
| 63 | |
| 64 | U-Boot can also search for boot configuration files from a TFTP server. |
| 65 | |
| 66 | Boot Configuration Files |
| 67 | ------------------------ |
| 68 | |
| 69 | The standard format for boot configuration files is that of extlinux.conf, as |
| 70 | handled by U-Boot's "syslinux" (disk) or "pxe boot" (network). This is roughly |
Edoardo Tomelleri | 6acf1b9 | 2022-09-21 15:26:33 +0200 | [diff] [blame] | 71 | as specified at `Boot Loader Specification`_: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 72 | |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 73 | |
Edoardo Tomelleri | 6acf1b9 | 2022-09-21 15:26:33 +0200 | [diff] [blame] | 74 | ... with the exceptions that the Boot Loader Specification document: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 75 | |
| 76 | * Prescribes a separate configuration per boot menu option, whereas U-Boot |
| 77 | lumps all options into a single extlinux.conf file. Hence, U-Boot searches |
| 78 | for /extlinux/extlinux.conf then /boot/extlinux/extlinux.conf on disk, or |
| 79 | pxelinux.cfg/default over the network. |
| 80 | |
| 81 | * Does not document the fdtdir option, which automatically selects the DTB to |
| 82 | pass to the kernel. |
| 83 | |
Svyatoslav Ryhel | 08b7849e | 2024-01-25 22:16:54 +0200 | [diff] [blame] | 84 | * If no fdt/fdtdir is provided, the U-Boot will pass its own currently used |
| 85 | device tree. |
| 86 | |
| 87 | * If ``-`` is passed as fdt argument and ``CONFIG_SUPPORT_PASSING_ATAGS`` is |
| 88 | enabled, then no device tree will be used (legacy booting / pre-dtb kernel). |
| 89 | |
Edoardo Tomelleri | 6acf1b9 | 2022-09-21 15:26:33 +0200 | [diff] [blame] | 90 | See also doc/README.pxe under 'pxe file format'. |
| 91 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 92 | One example extlinux.conf generated by the Fedora installer is:: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 93 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 94 | # extlinux.conf generated by anaconda |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 95 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 96 | ui menu.c32 |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 97 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 98 | menu autoboot Welcome to Fedora. Automatic boot in # second{,s}. Press a key for options. |
| 99 | menu title Fedora Boot Options. |
| 100 | menu hidden |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 101 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 102 | timeout 50 |
| 103 | #totaltimeout 9000 |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 104 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 105 | default Fedora (3.17.0-0.rc4.git2.1.fc22.armv7hl+lpae) 22 (Rawhide) |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 106 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 107 | label Fedora (3.17.0-0.rc4.git2.1.fc22.armv7hl) 22 (Rawhide) |
| 108 | kernel /boot/vmlinuz-3.17.0-0.rc4.git2.1.fc22.armv7hl |
| 109 | append ro root=UUID=8eac677f-8ea8-4270-8479-d5ddbb797450 console=ttyS0,115200n8 LANG=en_US.UTF-8 drm.debug=0xf |
| 110 | fdtdir /boot/dtb-3.17.0-0.rc4.git2.1.fc22.armv7hl |
| 111 | initrd /boot/initramfs-3.17.0-0.rc4.git2.1.fc22.armv7hl.img |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 112 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 113 | label Fedora (3.17.0-0.rc4.git2.1.fc22.armv7hl+lpae) 22 (Rawhide) |
| 114 | kernel /boot/vmlinuz-3.17.0-0.rc4.git2.1.fc22.armv7hl+lpae |
| 115 | append ro root=UUID=8eac677f-8ea8-4270-8479-d5ddbb797450 console=ttyS0,115200n8 LANG=en_US.UTF-8 drm.debug=0xf |
| 116 | fdtdir /boot/dtb-3.17.0-0.rc4.git2.1.fc22.armv7hl+lpae |
| 117 | initrd /boot/initramfs-3.17.0-0.rc4.git2.1.fc22.armv7hl+lpae.img |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 118 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 119 | label Fedora-0-rescue-8f6ba7b039524e0eb957d2c9203f04bc (0-rescue-8f6ba7b039524e0eb957d2c9203f04bc) |
| 120 | kernel /boot/vmlinuz-0-rescue-8f6ba7b039524e0eb957d2c9203f04bc |
| 121 | initrd /boot/initramfs-0-rescue-8f6ba7b039524e0eb957d2c9203f04bc.img |
| 122 | append ro root=UUID=8eac677f-8ea8-4270-8479-d5ddbb797450 console=ttyS0,115200n8 |
| 123 | fdtdir /boot/dtb-3.16.0-0.rc6.git1.1.fc22.armv7hl+lpae |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 124 | |
Edoardo Tomelleri | 6acf1b9 | 2022-09-21 15:26:33 +0200 | [diff] [blame] | 125 | |
| 126 | One example of hand-crafted extlinux.conf:: |
| 127 | |
| 128 | menu title Select kernel |
| 129 | timeout 100 |
| 130 | |
| 131 | label Arch with uart devicetree overlay |
| 132 | kernel /arch/Image.gz |
| 133 | initrd /arch/initramfs-linux.img |
| 134 | fdt /dtbs/arch/board.dtb |
| 135 | fdtoverlays /dtbs/arch/overlay/uart0-gpio0-1.dtbo |
| 136 | append console=ttyS0,115200 console=tty1 rw root=UUID=fc0d0284-ca84-4194-bf8a-4b9da8d66908 |
| 137 | |
| 138 | label Arch with uart devicetree overlay but with Boot Loader Specification keys |
| 139 | kernel /arch/Image.gz |
| 140 | initrd /arch/initramfs-linux.img |
| 141 | devicetree /dtbs/arch/board.dtb |
| 142 | devicetree-overlay /dtbs/arch/overlay/uart0-gpio0-1.dtbo |
| 143 | append console=ttyS0,115200 console=tty1 rw root=UUID=fc0d0284-ca84-4194-bf8a-4b9da8d66908 |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 144 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 145 | Another hand-crafted network boot configuration file is:: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 146 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 147 | TIMEOUT 100 |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 148 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 149 | MENU TITLE TFTP boot options |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 150 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 151 | LABEL jetson-tk1-emmc |
| 152 | MENU LABEL ../zImage root on Jetson TK1 eMMC |
| 153 | LINUX ../zImage |
| 154 | FDTDIR ../ |
| 155 | APPEND console=ttyS0,115200n8 console=tty1 loglevel=8 rootwait rw earlyprintk root=PARTUUID=80a5a8e9-c744-491a-93c1-4f4194fd690b |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 156 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 157 | LABEL venice2-emmc |
| 158 | MENU LABEL ../zImage root on Venice2 eMMC |
| 159 | LINUX ../zImage |
| 160 | FDTDIR ../ |
| 161 | APPEND console=ttyS0,115200n8 console=tty1 loglevel=8 rootwait rw earlyprintk root=PARTUUID=5f71e06f-be08-48ed-b1ef-ee4800cc860f |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 162 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 163 | LABEL sdcard |
| 164 | MENU LABEL ../zImage, root on 2GB sdcard |
| 165 | LINUX ../zImage |
| 166 | FDTDIR ../ |
| 167 | APPEND console=ttyS0,115200n8 console=tty1 loglevel=8 rootwait rw earlyprintk root=PARTUUID=b2f82cda-2535-4779-b467-094a210fbae7 |
| 168 | |
| 169 | LABEL fedora-installer-fk |
| 170 | MENU LABEL Fedora installer w/ Fedora kernel |
| 171 | LINUX fedora-installer/vmlinuz |
| 172 | INITRD fedora-installer/initrd.img.orig |
| 173 | FDTDIR fedora-installer/dtb |
| 174 | APPEND loglevel=8 ip=dhcp inst.repo=http://10.0.0.2/mirrors/fedora/linux/development/rawhide/armhfp/os/ rd.shell cma=64M |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 175 | |
| 176 | U-Boot Implementation |
| 177 | ===================== |
| 178 | |
| 179 | Enabling the distro options |
| 180 | --------------------------- |
| 181 | |
Hans de Goede | f99c5cb | 2016-06-20 23:16:28 +0200 | [diff] [blame] | 182 | In your board's defconfig, enable the DISTRO_DEFAULTS option by adding |
| 183 | a line with "CONFIG_DISTRO_DEFAULTS=y". If you want to enable this |
| 184 | from Kconfig itself, for e.g. all boards using a specific SoC then |
Masahiro Yamada | 9afc6c5 | 2018-04-25 18:47:52 +0900 | [diff] [blame] | 185 | add a "imply DISTRO_DEFAULTS" to your SoC CONFIG option. |
Hans de Goede | f99c5cb | 2016-06-20 23:16:28 +0200 | [diff] [blame] | 186 | |
Simon Glass | 83b9be6 | 2022-04-24 23:31:26 -0600 | [diff] [blame] | 187 | |
| 188 | TO BE UPDATED: |
| 189 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 190 | In your board configuration file, include the following:: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 191 | |
Simon Glass | 0e84d96 | 2024-09-29 19:49:50 -0600 | [diff] [blame] | 192 | #ifndef CONFIG_XPL_BUILD |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 193 | #include <config_distro_bootcmd.h> |
| 194 | #endif |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 195 | |
| 196 | The first of those headers primarily enables a core set of U-Boot features, |
| 197 | such as support for MBR and GPT partitions, ext* and FAT filesystems, booting |
| 198 | raw zImage and initrd (rather than FIT- or uImage-wrapped files), etc. Network |
| 199 | boot support is also enabled here, which is useful in order to boot distro |
| 200 | installers given that distros do not commonly distribute bootable install |
| 201 | media for non-PC targets at present. |
| 202 | |
| 203 | Finally, a few options that are mostly relevant only when using U-Boot- |
| 204 | specific boot.scr scripts are enabled. This enables distros to generate a |
| 205 | U-Boot-specific boot.scr script rather than extlinux.conf as the boot |
| 206 | configuration file. While doing so is fully supported, and |
Adam Ford | c8d3462 | 2018-02-06 07:49:32 -0600 | [diff] [blame] | 207 | CONFIG_DISTRO_DEFAULTS exposes enough parameterization to boot.scr to |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 208 | allow for board-agnostic boot.scr content, this document recommends that |
| 209 | distros generate extlinux.conf rather than boot.scr. extlinux.conf is intended |
| 210 | to work across multiple bootloaders, whereas boot.scr will only work with |
| 211 | U-Boot. TODO: document the contract between U-Boot and boot.scr re: which |
| 212 | environment variables a generic boot.scr may rely upon. |
| 213 | |
| 214 | The second of those headers sets up the default environment so that $bootcmd |
| 215 | is defined in a way that searches attached disks for boot configuration files, |
| 216 | and executes them if found. |
| 217 | |
| 218 | Required Environment Variables |
| 219 | ------------------------------ |
| 220 | |
| 221 | The U-Boot "syslinux" and "pxe boot" commands require a number of environment |
| 222 | variables be set. Default values for these variables are often hard-coded into |
Tom Rini | c9edebe | 2022-12-04 10:03:50 -0500 | [diff] [blame] | 223 | CFG_EXTRA_ENV_SETTINGS in the board's U-Boot configuration file, so that |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 224 | the user doesn't have to configure them. |
| 225 | |
| 226 | fdt_addr: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 227 | Mandatory for any system that provides the DTB in HW (e.g. ROM) and wishes |
| 228 | to pass that DTB to Linux, rather than loading a DTB from the boot |
| 229 | filesystem. Prohibited for any other system. |
| 230 | |
| 231 | If specified a DTB to boot the system must be available at the given |
| 232 | address. |
| 233 | |
| 234 | fdt_addr_r: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 235 | Mandatory. The location in RAM where the DTB will be loaded or copied to when |
| 236 | processing the fdtdir/devicetreedir or fdt/devicetree options in |
| 237 | extlinux.conf. |
| 238 | |
| 239 | This is mandatory even when fdt_addr is provided, since extlinux.conf must |
| 240 | always be able to provide a DTB which overrides any copy provided by the HW. |
| 241 | |
| 242 | A size of 1MB for the FDT/DTB seems reasonable. |
| 243 | |
Edoardo Tomelleri | 6acf1b9 | 2022-09-21 15:26:33 +0200 | [diff] [blame] | 244 | fdtoverlay_addr_r: |
| 245 | Mandatory. The location in RAM where DTB overlays will be temporarily |
| 246 | stored and then applied in the load order to the fdt blob stored at the |
| 247 | address indicated in the fdt_addr_r environment variable. |
| 248 | |
Dennis Gilmore | 66cb0d0 | 2020-09-11 11:56:59 -0500 | [diff] [blame] | 249 | fdtfile: |
Dennis Gilmore | 66cb0d0 | 2020-09-11 11:56:59 -0500 | [diff] [blame] | 250 | Mandatory. the name of the DTB file for the specific board for instance |
| 251 | the espressobin v5 board the value is "marvell/armada-3720-espressobin.dtb" |
| 252 | while on a clearfog pro it is "armada-388-clearfog-pro.dtb" in the case of |
| 253 | a board providing its firmware based DTB this value can be used to override |
| 254 | the DTB with a different DTB. fdtfile will automatically be set for you if |
| 255 | it matches the format ${soc}-${board}.dtb which covers most 32 bit use cases. |
| 256 | AArch64 generally does not match as the Linux kernel put the dtb files under |
Wolfgang Denk | 9d328a6 | 2021-09-27 17:42:38 +0200 | [diff] [blame] | 257 | SoC vendor directories. |
Dennis Gilmore | 66cb0d0 | 2020-09-11 11:56:59 -0500 | [diff] [blame] | 258 | |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 259 | ramdisk_addr_r: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 260 | Mandatory. The location in RAM where the initial ramdisk will be loaded to |
| 261 | when processing the initrd option in extlinux.conf. |
| 262 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 263 | It is recommended that this location be highest in RAM out of fdt_addr_r, |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 264 | kernel_addr_r, and ramdisk_addr_r, so that the RAM disk can vary in size |
| 265 | and use any available RAM. |
| 266 | |
| 267 | kernel_addr_r: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 268 | Mandatory. The location in RAM where the kernel will be loaded to when |
| 269 | processing the kernel option in the extlinux.conf. |
| 270 | |
| 271 | The kernel should be located within the first 128M of RAM in order for the |
| 272 | kernel CONFIG_AUTO_ZRELADDR option to work, which is likely enabled on any |
| 273 | distro kernel. Since the kernel will decompress itself to 0x8000 after the |
Masahiro Yamada | 7790de7 | 2015-07-07 18:47:17 +0900 | [diff] [blame] | 274 | start of RAM, kernel_addr_r should not overlap that area, or the kernel will |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 275 | have to copy itself somewhere else first before decompression. |
| 276 | |
| 277 | A size of 16MB for the kernel is likely adequate. |
| 278 | |
Atish Patra | 99c469c | 2020-03-05 16:24:23 -0800 | [diff] [blame] | 279 | kernel_comp_addr_r: |
| 280 | Optional. This is only required if user wants to boot Linux from a compressed |
Heinrich Schuchardt | f3fb75d | 2021-02-17 08:06:05 +0100 | [diff] [blame] | 281 | Image(.gz, .bz2, .lzma, .lzo) using the booti command. It represents the |
| 282 | location in RAM where the compressed Image will be decompressed temporarily. |
| 283 | Once the decompression is complete, the decompressed data will be moved to |
| 284 | kernel_addr_r for booting. |
Atish Patra | 99c469c | 2020-03-05 16:24:23 -0800 | [diff] [blame] | 285 | |
| 286 | kernel_comp_size: |
| 287 | Optional. This is only required if user wants to boot Linux from a compressed |
| 288 | Image using booti command. It represents the size of the compressed file. The |
| 289 | size has to at least the size of loaded image for decompression to succeed. |
| 290 | |
Vagrant Cascadian | f4d4d1b | 2016-02-08 19:55:31 -0800 | [diff] [blame] | 291 | pxefile_addr_r: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 292 | Mandatory. The location in RAM where extlinux.conf will be loaded to prior |
| 293 | to processing. |
| 294 | |
| 295 | A size of 1MB for extlinux.conf is more than adequate. |
| 296 | |
| 297 | scriptaddr: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 298 | Mandatory, if the boot script is boot.scr rather than extlinux.conf. The |
| 299 | location in RAM where boot.scr will be loaded to prior to execution. |
| 300 | |
| 301 | A size of 1MB for extlinux.conf is more than adequate. |
| 302 | |
| 303 | For suggestions on memory locations for ARM systems, you must follow the |
| 304 | guidelines specified in Documentation/arm/Booting in the Linux kernel tree. |
| 305 | |
| 306 | For a commented example of setting these values, please see the definition of |
| 307 | MEM_LAYOUT_ENV_SETTINGS in include/configs/tegra124-common.h. |
| 308 | |
| 309 | Boot Target Configuration |
| 310 | ------------------------- |
| 311 | |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 312 | The `config_distro_bootcmd.h` file defines $bootcmd and many helper command |
| 313 | variables that automatically search attached disks for boot configuration files |
| 314 | and execute them. Boards must provide configure <config_distro_bootcmd.h> so |
| 315 | that it supports the correct set of possible boot device types. To provide this |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 316 | configuration, simply define macro BOOT_TARGET_DEVICES prior to including |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 317 | <config_distro_bootcmd.h>. For example:: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 318 | |
Simon Glass | 0e84d96 | 2024-09-29 19:49:50 -0600 | [diff] [blame] | 319 | #ifndef CONFIG_XPL_BUILD |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 320 | #define BOOT_TARGET_DEVICES(func) \ |
| 321 | func(MMC, mmc, 1) \ |
| 322 | func(MMC, mmc, 0) \ |
| 323 | func(USB, usb, 0) \ |
| 324 | func(PXE, pxe, na) \ |
| 325 | func(DHCP, dhcp, na) |
| 326 | #include <config_distro_bootcmd.h> |
| 327 | #endif |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 328 | |
| 329 | Each entry in the macro defines a single boot device (e.g. a specific eMMC |
| 330 | device or SD card) or type of boot device (e.g. USB disk). The parameters to |
| 331 | the func macro (passed in by the internal implementation of the header) are: |
| 332 | |
Pali Rohár | 7ab2200 | 2022-04-06 11:35:46 +0200 | [diff] [blame] | 333 | - Upper-case disk type (DHCP, HOST, IDE, MMC, NVME, PXE, SATA, SCSI, UBIFS, USB, |
| 334 | VIRTIO). |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 335 | - Lower-case disk type (same options as above). |
| 336 | - ID of the specific disk (MMC only) or ignored for other types. |
| 337 | |
| 338 | User Configuration |
| 339 | ================== |
| 340 | |
| 341 | Once the user has installed U-Boot, it is expected that the environment will |
| 342 | be reset to the default values in order to enable $bootcmd and friends, as set |
| 343 | up by <config_distro_bootcmd.h>. After this, various environment variables may |
| 344 | be altered to influence the boot process: |
| 345 | |
| 346 | boot_targets: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 347 | The list of boot locations searched. |
| 348 | |
| 349 | Example: mmc0, mmc1, usb, pxe |
| 350 | |
| 351 | Entries may be removed or re-ordered in this list to affect the boot order. |
| 352 | |
| 353 | boot_prefixes: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 354 | For disk-based booting, the list of directories within a partition that are |
| 355 | searched for boot configuration files (extlinux.conf, boot.scr). |
| 356 | |
| 357 | Example: / /boot/ |
| 358 | |
| 359 | Entries may be removed or re-ordered in this list to affect the set of |
| 360 | directories which are searched. |
| 361 | |
| 362 | boot_scripts: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 363 | The name of U-Boot style boot.scr files that $bootcmd searches for. |
| 364 | |
| 365 | Example: boot.scr.uimg boot.scr |
| 366 | |
| 367 | (Typically we expect extlinux.conf to be used, but execution of boot.scr is |
| 368 | maintained for backwards-compatibility.) |
| 369 | |
| 370 | Entries may be removed or re-ordered in this list to affect the set of |
| 371 | filenames which are supported. |
| 372 | |
| 373 | scan_dev_for_extlinux: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 374 | If you want to disable extlinux.conf on all disks, set the value to something |
| 375 | innocuous, e.g. setenv scan_dev_for_extlinux true. |
| 376 | |
| 377 | scan_dev_for_scripts: |
Dennis Gilmore | b977607 | 2015-01-22 11:34:20 -0700 | [diff] [blame] | 378 | If you want to disable boot.scr on all disks, set the value to something |
| 379 | innocuous, e.g. setenv scan_dev_for_scripts true. |
Karsten Merker | 3b2401b | 2015-03-21 14:15:38 +0100 | [diff] [blame] | 380 | |
Stephen Warren | 4c739fb | 2016-01-26 11:10:12 -0700 | [diff] [blame] | 381 | boot_net_usb_start: |
Stephen Warren | 4c739fb | 2016-01-26 11:10:12 -0700 | [diff] [blame] | 382 | If you want to prevent USB enumeration by distro boot commands which execute |
| 383 | network operations, set the value to something innocuous, e.g. setenv |
| 384 | boot_net_usb_start true. This would be useful if you know your Ethernet |
| 385 | device is not attached to USB, and you wish to increase boot speed by |
| 386 | avoiding unnecessary actions. |
Karsten Merker | 3b2401b | 2015-03-21 14:15:38 +0100 | [diff] [blame] | 387 | |
Stephen Warren | 3a74c64 | 2016-01-26 11:10:13 -0700 | [diff] [blame] | 388 | boot_net_pci_enum: |
Stephen Warren | 3a74c64 | 2016-01-26 11:10:13 -0700 | [diff] [blame] | 389 | If you want to prevent PCI enumeration by distro boot commands which execute |
| 390 | network operations, set the value to something innocuous, e.g. setenv |
| 391 | boot_net_pci_enum true. This would be useful if you know your Ethernet |
| 392 | device is not attached to PCI, and you wish to increase boot speed by |
| 393 | avoiding unnecessary actions. |
| 394 | |
Karsten Merker | 3b2401b | 2015-03-21 14:15:38 +0100 | [diff] [blame] | 395 | Interactively booting from a specific device at the u-boot prompt |
| 396 | ================================================================= |
| 397 | |
| 398 | For interactively booting from a user-selected device at the u-boot command |
| 399 | prompt, the environment provides predefined bootcmd_<target> variables for |
| 400 | every target defined in boot_targets, which can be run be the user. |
| 401 | |
| 402 | If the target is a storage device, the format of the target is always |
| 403 | <device type><device number>, e.g. mmc0. Specifying the device number is |
| 404 | mandatory for storage devices, even if only support for a single instance |
| 405 | of the storage device is actually implemented. |
| 406 | |
| 407 | For network targets (dhcp, pxe), only the device type gets specified; |
| 408 | they do not have a device number. |
| 409 | |
| 410 | Examples: |
| 411 | |
| 412 | - run bootcmd_usb0 |
| 413 | boots from the first USB mass storage device |
| 414 | |
| 415 | - run bootcmd_mmc1 |
| 416 | boots from the second MMC device |
| 417 | |
| 418 | - run bootcmd_pxe |
| 419 | boots by tftp using a pxelinux.cfg |
| 420 | |
| 421 | The list of possible targets consists of: |
| 422 | |
| 423 | - network targets |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 424 | |
Karsten Merker | 3b2401b | 2015-03-21 14:15:38 +0100 | [diff] [blame] | 425 | * dhcp |
| 426 | * pxe |
| 427 | |
| 428 | - storage targets (to which a device number must be appended) |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 429 | |
Karsten Merker | 3b2401b | 2015-03-21 14:15:38 +0100 | [diff] [blame] | 430 | * mmc |
| 431 | * sata |
| 432 | * scsi |
| 433 | * ide |
| 434 | * usb |
Lukas Auer | e8c4df4 | 2018-11-22 11:26:33 +0100 | [diff] [blame] | 435 | * virtio |
Karsten Merker | 3b2401b | 2015-03-21 14:15:38 +0100 | [diff] [blame] | 436 | |
| 437 | Other *boot* variables than the ones defined above are only for internal use |
| 438 | of the boot environment and are not guaranteed to exist or work in the same |
| 439 | way in future u-boot versions. In particular the <device type>_boot |
| 440 | variables (e.g. mmc_boot, usb_boot) are a strictly internal implementation |
| 441 | detail and must not be used as a public interface. |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 442 | |
Edoardo Tomelleri | 6acf1b9 | 2022-09-21 15:26:33 +0200 | [diff] [blame] | 443 | .. _`Boot Loader Specification`: https://systemd.io/BOOT_LOADER_SPECIFICATION/ |
Simon Glass | 5769531 | 2021-10-14 12:48:10 -0600 | [diff] [blame] | 444 | |
| 445 | .. sectionauthor:: (C) Copyright 2014 Red Hat Inc. |
| 446 | .. sectionauthor:: Copyright (c) 2014-2015, NVIDIA CORPORATION. All rights reserved. |
| 447 | .. sectionauthor:: Copyright (C) 2015 K. Merker <merker@debian.org> |