Tom Rini | 83d290c | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 2 | /* |
| 3 | * (C) Copyright 2014 |
| 4 | * NVIDIA Corporation <www.nvidia.com> |
| 5 | * |
| 6 | * Copyright 2014 Red Hat, Inc. |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 7 | */ |
| 8 | |
| 9 | #ifndef _CONFIG_CMD_DISTRO_BOOTCMD_H |
| 10 | #define _CONFIG_CMD_DISTRO_BOOTCMD_H |
| 11 | |
Stephen Warren | 90b7caa | 2015-03-10 15:40:58 -0600 | [diff] [blame] | 12 | /* |
| 13 | * A note on error handling: It is possible for BOOT_TARGET_DEVICES to |
| 14 | * reference a device that is not enabled in the U-Boot configuration, e.g. |
| 15 | * it may include MMC in the list without CONFIG_CMD_MMC being enabled. Given |
| 16 | * that BOOT_TARGET_DEVICES is a macro that's expanded by the C pre-processor |
| 17 | * at compile time, it's not possible to detect and report such problems via |
| 18 | * a simple #ifdef/#error combination. Still, the code needs to report errors. |
| 19 | * The best way I've found to do this is to make BOOT_TARGET_DEVICES expand to |
| 20 | * reference a non-existent symbol, and have the name of that symbol encode |
| 21 | * the error message. Consequently, this file contains references to e.g. |
| 22 | * BOOT_TARGET_DEVICES_references_MMC_without_CONFIG_CMD_MMC. Given the |
| 23 | * prevalence of capitals here, this looks like a pre-processor macro and |
| 24 | * hence seems like it should be all capitals, but it's really an error |
| 25 | * message that includes some other pre-processor symbols in the text. |
| 26 | */ |
| 27 | |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 28 | #define BOOTENV_SHARED_BLKDEV_BODY(devtypel) \ |
| 29 | "if " #devtypel " dev ${devnum}; then " \ |
AKASHI Takahiro | 13dd666 | 2018-12-04 15:46:55 +0900 | [diff] [blame] | 30 | "devtype=" #devtypel "; " \ |
Sjoerd Simons | 735b1cf | 2015-01-05 18:13:38 +0100 | [diff] [blame] | 31 | "run scan_dev_for_boot_part; " \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 32 | "fi\0" |
| 33 | |
| 34 | #define BOOTENV_SHARED_BLKDEV(devtypel) \ |
| 35 | #devtypel "_boot=" \ |
| 36 | BOOTENV_SHARED_BLKDEV_BODY(devtypel) |
| 37 | |
| 38 | #define BOOTENV_DEV_BLKDEV(devtypeu, devtypel, instance) \ |
| 39 | "bootcmd_" #devtypel #instance "=" \ |
AKASHI Takahiro | 13dd666 | 2018-12-04 15:46:55 +0900 | [diff] [blame] | 40 | "devnum=" #instance "; " \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 41 | "run " #devtypel "_boot\0" |
| 42 | |
| 43 | #define BOOTENV_DEV_NAME_BLKDEV(devtypeu, devtypel, instance) \ |
| 44 | #devtypel #instance " " |
| 45 | |
Sjoerd Simons | d0bce0d | 2015-04-13 22:54:24 +0200 | [diff] [blame] | 46 | #ifdef CONFIG_SANDBOX |
| 47 | #define BOOTENV_SHARED_HOST BOOTENV_SHARED_BLKDEV(host) |
| 48 | #define BOOTENV_DEV_HOST BOOTENV_DEV_BLKDEV |
| 49 | #define BOOTENV_DEV_NAME_HOST BOOTENV_DEV_NAME_BLKDEV |
| 50 | #else |
| 51 | #define BOOTENV_SHARED_HOST |
| 52 | #define BOOTENV_DEV_HOST \ |
| 53 | BOOT_TARGET_DEVICES_references_HOST_without_CONFIG_SANDBOX |
| 54 | #define BOOTENV_DEV_NAME_HOST \ |
| 55 | BOOT_TARGET_DEVICES_references_HOST_without_CONFIG_SANDBOX |
| 56 | #endif |
| 57 | |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 58 | #ifdef CONFIG_CMD_MMC |
| 59 | #define BOOTENV_SHARED_MMC BOOTENV_SHARED_BLKDEV(mmc) |
| 60 | #define BOOTENV_DEV_MMC BOOTENV_DEV_BLKDEV |
| 61 | #define BOOTENV_DEV_NAME_MMC BOOTENV_DEV_NAME_BLKDEV |
| 62 | #else |
| 63 | #define BOOTENV_SHARED_MMC |
| 64 | #define BOOTENV_DEV_MMC \ |
| 65 | BOOT_TARGET_DEVICES_references_MMC_without_CONFIG_CMD_MMC |
| 66 | #define BOOTENV_DEV_NAME_MMC \ |
| 67 | BOOT_TARGET_DEVICES_references_MMC_without_CONFIG_CMD_MMC |
| 68 | #endif |
| 69 | |
Roy Spliet | 40d2154 | 2015-09-17 18:46:59 -0400 | [diff] [blame] | 70 | #ifdef CONFIG_CMD_UBIFS |
| 71 | #define BOOTENV_SHARED_UBIFS \ |
| 72 | "ubifs_boot=" \ |
Derald D. Woods | 6e1364f | 2018-01-20 21:16:13 -0600 | [diff] [blame] | 73 | "env exists bootubipart || " \ |
| 74 | "env set bootubipart UBI; " \ |
| 75 | "env exists bootubivol || " \ |
| 76 | "env set bootubivol boot; " \ |
| 77 | "if ubi part ${bootubipart} && " \ |
| 78 | "ubifsmount ubi${devnum}:${bootubivol}; " \ |
| 79 | "then " \ |
AKASHI Takahiro | 13dd666 | 2018-12-04 15:46:55 +0900 | [diff] [blame] | 80 | "devtype=ubi; " \ |
Derald D. Woods | 6e1364f | 2018-01-20 21:16:13 -0600 | [diff] [blame] | 81 | "run scan_dev_for_boot; " \ |
Roy Spliet | 40d2154 | 2015-09-17 18:46:59 -0400 | [diff] [blame] | 82 | "fi\0" |
| 83 | #define BOOTENV_DEV_UBIFS BOOTENV_DEV_BLKDEV |
| 84 | #define BOOTENV_DEV_NAME_UBIFS BOOTENV_DEV_NAME_BLKDEV |
| 85 | #else |
| 86 | #define BOOTENV_SHARED_UBIFS |
| 87 | #define BOOTENV_DEV_UBIFS \ |
| 88 | BOOT_TARGET_DEVICES_references_UBIFS_without_CONFIG_CMD_UBIFS |
| 89 | #define BOOTENV_DEV_NAME_UBIFS \ |
| 90 | BOOT_TARGET_DEVICES_references_UBIFS_without_CONFIG_CMD_UBIFS |
| 91 | #endif |
| 92 | |
Alexander Graf | 74522c8 | 2016-03-10 00:26:15 +0100 | [diff] [blame] | 93 | #ifdef CONFIG_EFI_LOADER |
| 94 | #if defined(CONFIG_ARM64) |
| 95 | #define BOOTEFI_NAME "bootaa64.efi" |
| 96 | #elif defined(CONFIG_ARM) |
| 97 | #define BOOTEFI_NAME "bootarm.efi" |
Heinrich Schuchardt | a53fbf4 | 2017-11-24 22:32:35 +0100 | [diff] [blame] | 98 | #elif defined(CONFIG_X86_RUN_32BIT) |
| 99 | #define BOOTEFI_NAME "bootia32.efi" |
| 100 | #elif defined(CONFIG_X86_RUN_64BIT) |
| 101 | #define BOOTEFI_NAME "bootx64.efi" |
Lukas Auer | 862e2e7 | 2018-11-22 11:26:12 +0100 | [diff] [blame] | 102 | #elif defined(CONFIG_ARCH_RV32I) |
Alexander Graf | 2c6903f | 2018-04-23 07:59:48 +0200 | [diff] [blame] | 103 | #define BOOTEFI_NAME "bootriscv32.efi" |
Lukas Auer | 862e2e7 | 2018-11-22 11:26:12 +0100 | [diff] [blame] | 104 | #elif defined(CONFIG_ARCH_RV64I) |
Alexander Graf | 2c6903f | 2018-04-23 07:59:48 +0200 | [diff] [blame] | 105 | #define BOOTEFI_NAME "bootriscv64.efi" |
Alexander Graf | 74522c8 | 2016-03-10 00:26:15 +0100 | [diff] [blame] | 106 | #endif |
| 107 | #endif |
| 108 | |
| 109 | #ifdef BOOTEFI_NAME |
Alexander Graf | ff2545a | 2016-04-14 16:07:54 +0200 | [diff] [blame] | 110 | #if defined(CONFIG_ARM) && !defined(CONFIG_ARM64) |
| 111 | /* |
| 112 | * On 32bit ARM systems there is a reasonable number of systems that follow |
| 113 | * the $soc-$board$boardver.dtb name scheme for their device trees. Use that |
| 114 | * scheme if we don't have an explicit fdtfile variable. |
| 115 | */ |
| 116 | #define BOOTENV_EFI_SET_FDTFILE_FALLBACK \ |
| 117 | "if test -z \"${fdtfile}\" -a -n \"${soc}\"; then " \ |
| 118 | "setenv efi_fdtfile ${soc}-${board}${boardver}.dtb; " \ |
| 119 | "fi; " |
| 120 | #else |
Peter Robinson | fe66992 | 2020-04-02 00:28:55 +0100 | [diff] [blame] | 121 | #ifndef BOOTENV_EFI_SET_FDTFILE_FALLBACK |
Alexander Graf | ff2545a | 2016-04-14 16:07:54 +0200 | [diff] [blame] | 122 | #define BOOTENV_EFI_SET_FDTFILE_FALLBACK |
| 123 | #endif |
Peter Robinson | fe66992 | 2020-04-02 00:28:55 +0100 | [diff] [blame] | 124 | #endif |
Alexander Graf | ff2545a | 2016-04-14 16:07:54 +0200 | [diff] [blame] | 125 | |
Heinrich Schuchardt | ff2f532 | 2021-01-15 19:02:50 +0100 | [diff] [blame] | 126 | #ifdef CONFIG_CMD_BOOTEFI_BOOTMGR |
| 127 | #define BOOTENV_EFI_BOOTMGR \ |
Michael Walle | f386690 | 2020-09-29 08:54:48 +0200 | [diff] [blame] | 128 | "boot_efi_bootmgr=" \ |
Peter Hoyes | e9496ec | 2022-03-31 11:53:22 +0100 | [diff] [blame] | 129 | "if fdt addr -q ${fdt_addr_r}; then " \ |
Rob Clark | 9975fe9 | 2017-09-13 18:05:38 -0400 | [diff] [blame] | 130 | "bootefi bootmgr ${fdt_addr_r};" \ |
| 131 | "else " \ |
Michael Walle | f386690 | 2020-09-29 08:54:48 +0200 | [diff] [blame] | 132 | "bootefi bootmgr;" \ |
Heinrich Schuchardt | ff2f532 | 2021-01-15 19:02:50 +0100 | [diff] [blame] | 133 | "fi\0" |
| 134 | #else |
| 135 | #define BOOTENV_EFI_BOOTMGR |
| 136 | #endif |
| 137 | |
| 138 | #define BOOTENV_SHARED_EFI \ |
| 139 | BOOTENV_EFI_BOOTMGR \ |
Michael Walle | f386690 | 2020-09-29 08:54:48 +0200 | [diff] [blame] | 140 | \ |
| 141 | "boot_efi_binary=" \ |
Alexander Graf | 74522c8 | 2016-03-10 00:26:15 +0100 | [diff] [blame] | 142 | "load ${devtype} ${devnum}:${distro_bootpart} " \ |
| 143 | "${kernel_addr_r} efi/boot/"BOOTEFI_NAME"; " \ |
Peter Hoyes | e9496ec | 2022-03-31 11:53:22 +0100 | [diff] [blame] | 144 | "if fdt addr -q ${fdt_addr_r}; then " \ |
Alexander Graf | 1c39809 | 2016-04-14 16:07:53 +0200 | [diff] [blame] | 145 | "bootefi ${kernel_addr_r} ${fdt_addr_r};" \ |
Derald D. Woods | 6e1364f | 2018-01-20 21:16:13 -0600 | [diff] [blame] | 146 | "else " \ |
Alexander Graf | 1c39809 | 2016-04-14 16:07:53 +0200 | [diff] [blame] | 147 | "bootefi ${kernel_addr_r} ${fdtcontroladdr};" \ |
| 148 | "fi\0" \ |
Alexander Graf | 74522c8 | 2016-03-10 00:26:15 +0100 | [diff] [blame] | 149 | \ |
| 150 | "load_efi_dtb=" \ |
| 151 | "load ${devtype} ${devnum}:${distro_bootpart} " \ |
Alexander Graf | ff2545a | 2016-04-14 16:07:54 +0200 | [diff] [blame] | 152 | "${fdt_addr_r} ${prefix}${efi_fdtfile}\0" \ |
Alexander Graf | 74522c8 | 2016-03-10 00:26:15 +0100 | [diff] [blame] | 153 | \ |
| 154 | "efi_dtb_prefixes=/ /dtb/ /dtb/current/\0" \ |
| 155 | "scan_dev_for_efi=" \ |
Alexander Graf | ff2545a | 2016-04-14 16:07:54 +0200 | [diff] [blame] | 156 | "setenv efi_fdtfile ${fdtfile}; " \ |
| 157 | BOOTENV_EFI_SET_FDTFILE_FALLBACK \ |
Alexander Graf | 74522c8 | 2016-03-10 00:26:15 +0100 | [diff] [blame] | 158 | "for prefix in ${efi_dtb_prefixes}; do " \ |
| 159 | "if test -e ${devtype} " \ |
| 160 | "${devnum}:${distro_bootpart} " \ |
Alexander Graf | ff2545a | 2016-04-14 16:07:54 +0200 | [diff] [blame] | 161 | "${prefix}${efi_fdtfile}; then " \ |
Alexander Graf | 74522c8 | 2016-03-10 00:26:15 +0100 | [diff] [blame] | 162 | "run load_efi_dtb; " \ |
| 163 | "fi;" \ |
| 164 | "done;" \ |
Michael Walle | f386690 | 2020-09-29 08:54:48 +0200 | [diff] [blame] | 165 | "run boot_efi_bootmgr;" \ |
Alexander Graf | 74522c8 | 2016-03-10 00:26:15 +0100 | [diff] [blame] | 166 | "if test -e ${devtype} ${devnum}:${distro_bootpart} " \ |
| 167 | "efi/boot/"BOOTEFI_NAME"; then " \ |
| 168 | "echo Found EFI removable media binary " \ |
| 169 | "efi/boot/"BOOTEFI_NAME"; " \ |
| 170 | "run boot_efi_binary; " \ |
| 171 | "echo EFI LOAD FAILED: continuing...; " \ |
Alexander Graf | ff2545a | 2016-04-14 16:07:54 +0200 | [diff] [blame] | 172 | "fi; " \ |
| 173 | "setenv efi_fdtfile\0" |
Alexander Graf | 74522c8 | 2016-03-10 00:26:15 +0100 | [diff] [blame] | 174 | #define SCAN_DEV_FOR_EFI "run scan_dev_for_efi;" |
| 175 | #else |
| 176 | #define BOOTENV_SHARED_EFI |
| 177 | #define SCAN_DEV_FOR_EFI |
| 178 | #endif |
| 179 | |
Simon Glass | 10e40d5 | 2017-06-14 21:28:25 -0600 | [diff] [blame] | 180 | #ifdef CONFIG_SATA |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 181 | #define BOOTENV_SHARED_SATA BOOTENV_SHARED_BLKDEV(sata) |
| 182 | #define BOOTENV_DEV_SATA BOOTENV_DEV_BLKDEV |
| 183 | #define BOOTENV_DEV_NAME_SATA BOOTENV_DEV_NAME_BLKDEV |
| 184 | #else |
| 185 | #define BOOTENV_SHARED_SATA |
| 186 | #define BOOTENV_DEV_SATA \ |
Simon Glass | 10e40d5 | 2017-06-14 21:28:25 -0600 | [diff] [blame] | 187 | BOOT_TARGET_DEVICES_references_SATA_without_CONFIG_SATA |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 188 | #define BOOTENV_DEV_NAME_SATA \ |
Simon Glass | 10e40d5 | 2017-06-14 21:28:25 -0600 | [diff] [blame] | 189 | BOOT_TARGET_DEVICES_references_SATA_without_CONFIG_SATA |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 190 | #endif |
| 191 | |
Heinrich Schuchardt | 9493e39 | 2018-12-21 02:18:16 +0100 | [diff] [blame] | 192 | #ifdef CONFIG_NVME |
| 193 | #define BOOTENV_RUN_NVME_INIT "run nvme_init; " |
| 194 | #define BOOTENV_SET_NVME_NEED_INIT "setenv nvme_need_init; " |
| 195 | #define BOOTENV_SHARED_NVME \ |
| 196 | "nvme_init=" \ |
| 197 | "if ${nvme_need_init}; then " \ |
| 198 | "setenv nvme_need_init false; " \ |
| 199 | "nvme scan; " \ |
| 200 | "fi\0" \ |
| 201 | \ |
| 202 | "nvme_boot=" \ |
Patrick Wildt | 52e1d93 | 2019-10-03 11:10:57 +0200 | [diff] [blame] | 203 | BOOTENV_RUN_PCI_ENUM \ |
Heinrich Schuchardt | 9493e39 | 2018-12-21 02:18:16 +0100 | [diff] [blame] | 204 | BOOTENV_RUN_NVME_INIT \ |
| 205 | BOOTENV_SHARED_BLKDEV_BODY(nvme) |
| 206 | #define BOOTENV_DEV_NVME BOOTENV_DEV_BLKDEV |
| 207 | #define BOOTENV_DEV_NAME_NVME BOOTENV_DEV_NAME_BLKDEV |
| 208 | #else |
| 209 | #define BOOTENV_RUN_NVME_INIT |
| 210 | #define BOOTENV_SET_NVME_NEED_INIT |
| 211 | #define BOOTENV_SHARED_NVME |
| 212 | #define BOOTENV_DEV_NVME \ |
| 213 | BOOT_TARGET_DEVICES_references_NVME_without_CONFIG_NVME |
| 214 | #define BOOTENV_DEV_NAME_NVME \ |
| 215 | BOOT_TARGET_DEVICES_references_NVME_without_CONFIG_NVME |
| 216 | #endif |
| 217 | |
Simon Glass | c649e3c | 2016-05-01 11:36:02 -0600 | [diff] [blame] | 218 | #ifdef CONFIG_SCSI |
Hans de Goede | a03bdaa | 2014-09-16 09:26:23 +0200 | [diff] [blame] | 219 | #define BOOTENV_RUN_SCSI_INIT "run scsi_init; " |
AKASHI Takahiro | 13dd666 | 2018-12-04 15:46:55 +0900 | [diff] [blame] | 220 | #define BOOTENV_SET_SCSI_NEED_INIT "scsi_need_init=; " |
Hans de Goede | a03bdaa | 2014-09-16 09:26:23 +0200 | [diff] [blame] | 221 | #define BOOTENV_SHARED_SCSI \ |
| 222 | "scsi_init=" \ |
| 223 | "if ${scsi_need_init}; then " \ |
AKASHI Takahiro | 13dd666 | 2018-12-04 15:46:55 +0900 | [diff] [blame] | 224 | "scsi_need_init=false; " \ |
Hans de Goede | a03bdaa | 2014-09-16 09:26:23 +0200 | [diff] [blame] | 225 | "scsi scan; " \ |
| 226 | "fi\0" \ |
| 227 | \ |
| 228 | "scsi_boot=" \ |
Neil Armstrong | d565a35 | 2021-09-17 09:37:05 +0200 | [diff] [blame] | 229 | BOOTENV_RUN_PCI_ENUM \ |
Hans de Goede | a03bdaa | 2014-09-16 09:26:23 +0200 | [diff] [blame] | 230 | BOOTENV_RUN_SCSI_INIT \ |
| 231 | BOOTENV_SHARED_BLKDEV_BODY(scsi) |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 232 | #define BOOTENV_DEV_SCSI BOOTENV_DEV_BLKDEV |
| 233 | #define BOOTENV_DEV_NAME_SCSI BOOTENV_DEV_NAME_BLKDEV |
| 234 | #else |
Hans de Goede | a03bdaa | 2014-09-16 09:26:23 +0200 | [diff] [blame] | 235 | #define BOOTENV_RUN_SCSI_INIT |
| 236 | #define BOOTENV_SET_SCSI_NEED_INIT |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 237 | #define BOOTENV_SHARED_SCSI |
| 238 | #define BOOTENV_DEV_SCSI \ |
Simon Glass | c649e3c | 2016-05-01 11:36:02 -0600 | [diff] [blame] | 239 | BOOT_TARGET_DEVICES_references_SCSI_without_CONFIG_SCSI |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 240 | #define BOOTENV_DEV_NAME_SCSI \ |
Simon Glass | c649e3c | 2016-05-01 11:36:02 -0600 | [diff] [blame] | 241 | BOOT_TARGET_DEVICES_references_SCSI_without_CONFIG_SCSI |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 242 | #endif |
| 243 | |
Simon Glass | fc843a0 | 2017-05-17 03:25:30 -0600 | [diff] [blame] | 244 | #ifdef CONFIG_IDE |
Joshua Watt | d5e994f | 2019-06-20 16:31:35 -0500 | [diff] [blame] | 245 | #define BOOTENV_RUN_IDE_INIT "run ide_init; " |
| 246 | #define BOOTENV_SET_IDE_NEED_INIT "setenv ide_need_init; " |
| 247 | #define BOOTENV_SHARED_IDE \ |
| 248 | "ide_init=" \ |
| 249 | "if ${ide_need_init}; then " \ |
| 250 | "setenv ide_need_init false; " \ |
| 251 | "ide reset; " \ |
| 252 | "fi\0" \ |
| 253 | \ |
| 254 | "ide_boot=" \ |
| 255 | BOOTENV_RUN_IDE_INIT \ |
| 256 | BOOTENV_SHARED_BLKDEV_BODY(ide) |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 257 | #define BOOTENV_DEV_IDE BOOTENV_DEV_BLKDEV |
| 258 | #define BOOTENV_DEV_NAME_IDE BOOTENV_DEV_NAME_BLKDEV |
| 259 | #else |
Joshua Watt | d5e994f | 2019-06-20 16:31:35 -0500 | [diff] [blame] | 260 | #define BOOTENV_RUN_IDE_INIT |
| 261 | #define BOOTENV_SET_IDE_NEED_INIT |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 262 | #define BOOTENV_SHARED_IDE |
| 263 | #define BOOTENV_DEV_IDE \ |
Simon Glass | fc843a0 | 2017-05-17 03:25:30 -0600 | [diff] [blame] | 264 | BOOT_TARGET_DEVICES_references_IDE_without_CONFIG_IDE |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 265 | #define BOOTENV_DEV_NAME_IDE \ |
Simon Glass | fc843a0 | 2017-05-17 03:25:30 -0600 | [diff] [blame] | 266 | BOOT_TARGET_DEVICES_references_IDE_without_CONFIG_IDE |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 267 | #endif |
| 268 | |
Simon Glass | e15ba68 | 2021-08-01 18:54:38 -0600 | [diff] [blame] | 269 | #if defined(CONFIG_PCI) |
David Abdurachmanov | f0ebcf8 | 2019-07-22 11:38:11 +0300 | [diff] [blame] | 270 | #define BOOTENV_RUN_PCI_ENUM "run boot_pci_enum; " |
Stephen Warren | 986691f | 2016-01-26 11:10:13 -0700 | [diff] [blame] | 271 | #define BOOTENV_SHARED_PCI \ |
David Abdurachmanov | f0ebcf8 | 2019-07-22 11:38:11 +0300 | [diff] [blame] | 272 | "boot_pci_enum=pci enum\0" |
Stephen Warren | 986691f | 2016-01-26 11:10:13 -0700 | [diff] [blame] | 273 | #else |
David Abdurachmanov | f0ebcf8 | 2019-07-22 11:38:11 +0300 | [diff] [blame] | 274 | #define BOOTENV_RUN_PCI_ENUM |
Stephen Warren | 986691f | 2016-01-26 11:10:13 -0700 | [diff] [blame] | 275 | #define BOOTENV_SHARED_PCI |
| 276 | #endif |
| 277 | |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 278 | #ifdef CONFIG_CMD_USB |
Stephen Warren | 3483b75 | 2016-01-26 11:10:12 -0700 | [diff] [blame] | 279 | #define BOOTENV_RUN_NET_USB_START "run boot_net_usb_start; " |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 280 | #define BOOTENV_SHARED_USB \ |
Stephen Warren | 3483b75 | 2016-01-26 11:10:12 -0700 | [diff] [blame] | 281 | "boot_net_usb_start=usb start\0" \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 282 | "usb_boot=" \ |
Stephen Warren | 3483b75 | 2016-01-26 11:10:12 -0700 | [diff] [blame] | 283 | "usb start; " \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 284 | BOOTENV_SHARED_BLKDEV_BODY(usb) |
| 285 | #define BOOTENV_DEV_USB BOOTENV_DEV_BLKDEV |
| 286 | #define BOOTENV_DEV_NAME_USB BOOTENV_DEV_NAME_BLKDEV |
| 287 | #else |
Stephen Warren | 3483b75 | 2016-01-26 11:10:12 -0700 | [diff] [blame] | 288 | #define BOOTENV_RUN_NET_USB_START |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 289 | #define BOOTENV_SHARED_USB |
| 290 | #define BOOTENV_DEV_USB \ |
| 291 | BOOT_TARGET_DEVICES_references_USB_without_CONFIG_CMD_USB |
| 292 | #define BOOTENV_DEV_NAME_USB \ |
| 293 | BOOT_TARGET_DEVICES_references_USB_without_CONFIG_CMD_USB |
| 294 | #endif |
| 295 | |
Lukas Auer | a8da9ff | 2018-11-22 11:26:33 +0100 | [diff] [blame] | 296 | #ifdef CONFIG_CMD_VIRTIO |
David Abdurachmanov | f0ebcf8 | 2019-07-22 11:38:11 +0300 | [diff] [blame] | 297 | #define BOOTENV_RUN_VIRTIO_INIT "run virtio_init; " |
| 298 | #define BOOTENV_SET_VIRTIO_NEED_INIT "virtio_need_init=; " |
| 299 | #define BOOTENV_SHARED_VIRTIO \ |
| 300 | "virtio_init=" \ |
| 301 | "if ${virtio_need_init}; then " \ |
| 302 | "virtio_need_init=false; " \ |
| 303 | "virtio scan; " \ |
| 304 | "fi\0" \ |
| 305 | \ |
| 306 | "virtio_boot=" \ |
| 307 | BOOTENV_RUN_PCI_ENUM \ |
| 308 | BOOTENV_RUN_VIRTIO_INIT \ |
| 309 | BOOTENV_SHARED_BLKDEV_BODY(virtio) |
Lukas Auer | a8da9ff | 2018-11-22 11:26:33 +0100 | [diff] [blame] | 310 | #define BOOTENV_DEV_VIRTIO BOOTENV_DEV_BLKDEV |
| 311 | #define BOOTENV_DEV_NAME_VIRTIO BOOTENV_DEV_NAME_BLKDEV |
| 312 | #else |
David Abdurachmanov | f0ebcf8 | 2019-07-22 11:38:11 +0300 | [diff] [blame] | 313 | #define BOOTENV_RUN_VIRTIO_INIT |
| 314 | #define BOOTENV_SET_VIRTIO_NEED_INIT |
Lukas Auer | a8da9ff | 2018-11-22 11:26:33 +0100 | [diff] [blame] | 315 | #define BOOTENV_SHARED_VIRTIO |
| 316 | #define BOOTENV_DEV_VIRTIO \ |
| 317 | BOOT_TARGET_DEVICES_references_VIRTIO_without_CONFIG_CMD_VIRTIO |
| 318 | #define BOOTENV_DEV_NAME_VIRTIO \ |
| 319 | BOOT_TARGET_DEVICES_references_VIRTIO_without_CONFIG_CMD_VIRTIO |
| 320 | #endif |
| 321 | |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 322 | #if defined(CONFIG_CMD_DHCP) |
Alexander Graf | 20898ea | 2016-05-06 21:01:07 +0200 | [diff] [blame] | 323 | #if defined(CONFIG_EFI_LOADER) |
Alexander Graf | 2c6903f | 2018-04-23 07:59:48 +0200 | [diff] [blame] | 324 | /* http://www.iana.org/assignments/dhcpv6-parameters/dhcpv6-parameters.xml */ |
Simon Glass | a4958a7 | 2018-09-15 00:50:52 -0600 | [diff] [blame] | 325 | #if defined(CONFIG_ARM64) || defined(__aarch64__) |
Alexander Graf | 20898ea | 2016-05-06 21:01:07 +0200 | [diff] [blame] | 326 | #define BOOTENV_EFI_PXE_ARCH "0xb" |
| 327 | #define BOOTENV_EFI_PXE_VCI "PXEClient:Arch:00011:UNDI:003000" |
Simon Glass | a4958a7 | 2018-09-15 00:50:52 -0600 | [diff] [blame] | 328 | #elif defined(CONFIG_ARM) || defined(__arm__) |
Alexander Graf | 20898ea | 2016-05-06 21:01:07 +0200 | [diff] [blame] | 329 | #define BOOTENV_EFI_PXE_ARCH "0xa" |
| 330 | #define BOOTENV_EFI_PXE_VCI "PXEClient:Arch:00010:UNDI:003000" |
Simon Glass | a4958a7 | 2018-09-15 00:50:52 -0600 | [diff] [blame] | 331 | #elif defined(CONFIG_X86) || defined(__x86_64__) |
Alexander Graf | 20898ea | 2016-05-06 21:01:07 +0200 | [diff] [blame] | 332 | #define BOOTENV_EFI_PXE_ARCH "0x7" |
| 333 | #define BOOTENV_EFI_PXE_VCI "PXEClient:Arch:00007:UNDI:003000" |
Simon Glass | a4958a7 | 2018-09-15 00:50:52 -0600 | [diff] [blame] | 334 | #elif defined(__i386__) |
| 335 | #define BOOTENV_EFI_PXE_ARCH "0x6" |
| 336 | #define BOOTENV_EFI_PXE_VCI "PXEClient:Arch:00006:UNDI:003000" |
Lukas Auer | 862e2e7 | 2018-11-22 11:26:12 +0100 | [diff] [blame] | 337 | #elif defined(CONFIG_ARCH_RV32I) || ((defined(__riscv) && __riscv_xlen == 32)) |
Alexander Graf | 2c6903f | 2018-04-23 07:59:48 +0200 | [diff] [blame] | 338 | #define BOOTENV_EFI_PXE_ARCH "0x19" |
| 339 | #define BOOTENV_EFI_PXE_VCI "PXEClient:Arch:00025:UNDI:003000" |
Lukas Auer | 862e2e7 | 2018-11-22 11:26:12 +0100 | [diff] [blame] | 340 | #elif defined(CONFIG_ARCH_RV64I) || ((defined(__riscv) && __riscv_xlen == 64)) |
Alexander Graf | 2c6903f | 2018-04-23 07:59:48 +0200 | [diff] [blame] | 341 | #define BOOTENV_EFI_PXE_ARCH "0x1b" |
| 342 | #define BOOTENV_EFI_PXE_VCI "PXEClient:Arch:00027:UNDI:003000" |
Simon Glass | a4958a7 | 2018-09-15 00:50:52 -0600 | [diff] [blame] | 343 | #elif defined(CONFIG_SANDBOX) |
| 344 | # error "sandbox EFI support is only supported on ARM and x86" |
Alexander Graf | 20898ea | 2016-05-06 21:01:07 +0200 | [diff] [blame] | 345 | #else |
| 346 | #error Please specify an EFI client identifier |
| 347 | #endif |
| 348 | |
| 349 | /* |
| 350 | * Ask the dhcp server for an EFI binary. If we get one, check for a |
| 351 | * device tree in the same folder. Then boot everything. If the file was |
| 352 | * not an EFI binary, we just return from the bootefi command and continue. |
| 353 | */ |
| 354 | #define BOOTENV_EFI_RUN_DHCP \ |
| 355 | "setenv efi_fdtfile ${fdtfile}; " \ |
| 356 | BOOTENV_EFI_SET_FDTFILE_FALLBACK \ |
| 357 | "setenv efi_old_vci ${bootp_vci};" \ |
| 358 | "setenv efi_old_arch ${bootp_arch};" \ |
| 359 | "setenv bootp_vci " BOOTENV_EFI_PXE_VCI ";" \ |
| 360 | "setenv bootp_arch " BOOTENV_EFI_PXE_ARCH ";" \ |
| 361 | "if dhcp ${kernel_addr_r}; then " \ |
| 362 | "tftpboot ${fdt_addr_r} dtb/${efi_fdtfile};" \ |
Peter Hoyes | e9496ec | 2022-03-31 11:53:22 +0100 | [diff] [blame] | 363 | "if fdt addr -q ${fdt_addr_r}; then " \ |
Alexander Graf | 20898ea | 2016-05-06 21:01:07 +0200 | [diff] [blame] | 364 | "bootefi ${kernel_addr_r} ${fdt_addr_r}; " \ |
| 365 | "else " \ |
| 366 | "bootefi ${kernel_addr_r} ${fdtcontroladdr};" \ |
| 367 | "fi;" \ |
| 368 | "fi;" \ |
| 369 | "setenv bootp_vci ${efi_old_vci};" \ |
| 370 | "setenv bootp_arch ${efi_old_arch};" \ |
| 371 | "setenv efi_fdtfile;" \ |
| 372 | "setenv efi_old_arch;" \ |
| 373 | "setenv efi_old_vci;" |
| 374 | #else |
| 375 | #define BOOTENV_EFI_RUN_DHCP |
| 376 | #endif |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 377 | #define BOOTENV_DEV_DHCP(devtypeu, devtypel, instance) \ |
| 378 | "bootcmd_dhcp=" \ |
Andre Przywara | ccadfca | 2021-07-12 00:07:09 +0100 | [diff] [blame] | 379 | "devtype=" #devtypel "; " \ |
Stephen Warren | 3483b75 | 2016-01-26 11:10:12 -0700 | [diff] [blame] | 380 | BOOTENV_RUN_NET_USB_START \ |
David Abdurachmanov | f0ebcf8 | 2019-07-22 11:38:11 +0300 | [diff] [blame] | 381 | BOOTENV_RUN_PCI_ENUM \ |
Stephen Warren | cc11b39 | 2015-01-19 16:39:11 -0700 | [diff] [blame] | 382 | "if dhcp ${scriptaddr} ${boot_script_dhcp}; then " \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 383 | "source ${scriptaddr}; " \ |
Alexander Graf | 20898ea | 2016-05-06 21:01:07 +0200 | [diff] [blame] | 384 | "fi;" \ |
| 385 | BOOTENV_EFI_RUN_DHCP \ |
| 386 | "\0" |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 387 | #define BOOTENV_DEV_NAME_DHCP(devtypeu, devtypel, instance) \ |
| 388 | "dhcp " |
| 389 | #else |
| 390 | #define BOOTENV_DEV_DHCP \ |
| 391 | BOOT_TARGET_DEVICES_references_DHCP_without_CONFIG_CMD_DHCP |
| 392 | #define BOOTENV_DEV_NAME_DHCP \ |
| 393 | BOOT_TARGET_DEVICES_references_DHCP_without_CONFIG_CMD_DHCP |
| 394 | #endif |
| 395 | |
| 396 | #if defined(CONFIG_CMD_DHCP) && defined(CONFIG_CMD_PXE) |
| 397 | #define BOOTENV_DEV_PXE(devtypeu, devtypel, instance) \ |
| 398 | "bootcmd_pxe=" \ |
Stephen Warren | 3483b75 | 2016-01-26 11:10:12 -0700 | [diff] [blame] | 399 | BOOTENV_RUN_NET_USB_START \ |
David Abdurachmanov | f0ebcf8 | 2019-07-22 11:38:11 +0300 | [diff] [blame] | 400 | BOOTENV_RUN_PCI_ENUM \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 401 | "dhcp; " \ |
| 402 | "if pxe get; then " \ |
| 403 | "pxe boot; " \ |
| 404 | "fi\0" |
| 405 | #define BOOTENV_DEV_NAME_PXE(devtypeu, devtypel, instance) \ |
| 406 | "pxe " |
| 407 | #else |
| 408 | #define BOOTENV_DEV_PXE \ |
| 409 | BOOT_TARGET_DEVICES_references_PXE_without_CONFIG_CMD_DHCP_or_PXE |
| 410 | #define BOOTENV_DEV_NAME_PXE \ |
| 411 | BOOT_TARGET_DEVICES_references_PXE_without_CONFIG_CMD_DHCP_or_PXE |
| 412 | #endif |
| 413 | |
| 414 | #define BOOTENV_DEV_NAME(devtypeu, devtypel, instance) \ |
| 415 | BOOTENV_DEV_NAME_##devtypeu(devtypeu, devtypel, instance) |
| 416 | #define BOOTENV_BOOT_TARGETS \ |
| 417 | "boot_targets=" BOOT_TARGET_DEVICES(BOOTENV_DEV_NAME) "\0" |
| 418 | |
| 419 | #define BOOTENV_DEV(devtypeu, devtypel, instance) \ |
| 420 | BOOTENV_DEV_##devtypeu(devtypeu, devtypel, instance) |
| 421 | #define BOOTENV \ |
Sjoerd Simons | d0bce0d | 2015-04-13 22:54:24 +0200 | [diff] [blame] | 422 | BOOTENV_SHARED_HOST \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 423 | BOOTENV_SHARED_MMC \ |
Stephen Warren | 986691f | 2016-01-26 11:10:13 -0700 | [diff] [blame] | 424 | BOOTENV_SHARED_PCI \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 425 | BOOTENV_SHARED_USB \ |
| 426 | BOOTENV_SHARED_SATA \ |
| 427 | BOOTENV_SHARED_SCSI \ |
Heinrich Schuchardt | 9493e39 | 2018-12-21 02:18:16 +0100 | [diff] [blame] | 428 | BOOTENV_SHARED_NVME \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 429 | BOOTENV_SHARED_IDE \ |
Roy Spliet | 40d2154 | 2015-09-17 18:46:59 -0400 | [diff] [blame] | 430 | BOOTENV_SHARED_UBIFS \ |
Alexander Graf | 74522c8 | 2016-03-10 00:26:15 +0100 | [diff] [blame] | 431 | BOOTENV_SHARED_EFI \ |
Lukas Auer | a8da9ff | 2018-11-22 11:26:33 +0100 | [diff] [blame] | 432 | BOOTENV_SHARED_VIRTIO \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 433 | "boot_prefixes=/ /boot/\0" \ |
| 434 | "boot_scripts=boot.scr.uimg boot.scr\0" \ |
Stephen Warren | cc11b39 | 2015-01-19 16:39:11 -0700 | [diff] [blame] | 435 | "boot_script_dhcp=boot.scr.uimg\0" \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 436 | BOOTENV_BOOT_TARGETS \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 437 | \ |
Martyn Welch | ad5fbc6 | 2018-11-06 12:23:53 +0000 | [diff] [blame] | 438 | "boot_syslinux_conf=extlinux/extlinux.conf\0" \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 439 | "boot_extlinux=" \ |
Sjoerd Simons | 59d03cb | 2015-08-28 15:01:54 +0200 | [diff] [blame] | 440 | "sysboot ${devtype} ${devnum}:${distro_bootpart} any " \ |
Martyn Welch | ad5fbc6 | 2018-11-06 12:23:53 +0000 | [diff] [blame] | 441 | "${scriptaddr} ${prefix}${boot_syslinux_conf}\0" \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 442 | \ |
| 443 | "scan_dev_for_extlinux=" \ |
Sjoerd Simons | 59d03cb | 2015-08-28 15:01:54 +0200 | [diff] [blame] | 444 | "if test -e ${devtype} " \ |
| 445 | "${devnum}:${distro_bootpart} " \ |
Martyn Welch | ad5fbc6 | 2018-11-06 12:23:53 +0000 | [diff] [blame] | 446 | "${prefix}${boot_syslinux_conf}; then " \ |
| 447 | "echo Found ${prefix}${boot_syslinux_conf}; " \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 448 | "run boot_extlinux; " \ |
| 449 | "echo SCRIPT FAILED: continuing...; " \ |
| 450 | "fi\0" \ |
| 451 | \ |
| 452 | "boot_a_script=" \ |
Sjoerd Simons | 59d03cb | 2015-08-28 15:01:54 +0200 | [diff] [blame] | 453 | "load ${devtype} ${devnum}:${distro_bootpart} " \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 454 | "${scriptaddr} ${prefix}${script}; " \ |
| 455 | "source ${scriptaddr}\0" \ |
| 456 | \ |
| 457 | "scan_dev_for_scripts=" \ |
| 458 | "for script in ${boot_scripts}; do " \ |
Sjoerd Simons | 59d03cb | 2015-08-28 15:01:54 +0200 | [diff] [blame] | 459 | "if test -e ${devtype} " \ |
| 460 | "${devnum}:${distro_bootpart} " \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 461 | "${prefix}${script}; then " \ |
| 462 | "echo Found U-Boot script " \ |
| 463 | "${prefix}${script}; " \ |
| 464 | "run boot_a_script; " \ |
| 465 | "echo SCRIPT FAILED: continuing...; " \ |
| 466 | "fi; " \ |
| 467 | "done\0" \ |
| 468 | \ |
| 469 | "scan_dev_for_boot=" \ |
Sjoerd Simons | 59d03cb | 2015-08-28 15:01:54 +0200 | [diff] [blame] | 470 | "echo Scanning ${devtype} " \ |
| 471 | "${devnum}:${distro_bootpart}...; " \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 472 | "for prefix in ${boot_prefixes}; do " \ |
| 473 | "run scan_dev_for_extlinux; " \ |
| 474 | "run scan_dev_for_scripts; " \ |
Alexander Graf | 74522c8 | 2016-03-10 00:26:15 +0100 | [diff] [blame] | 475 | "done;" \ |
| 476 | SCAN_DEV_FOR_EFI \ |
| 477 | "\0" \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 478 | \ |
Sjoerd Simons | 735b1cf | 2015-01-05 18:13:38 +0100 | [diff] [blame] | 479 | "scan_dev_for_boot_part=" \ |
Sjoerd Simons | f643d92 | 2015-02-25 23:23:52 +0100 | [diff] [blame] | 480 | "part list ${devtype} ${devnum} -bootable devplist; " \ |
| 481 | "env exists devplist || setenv devplist 1; " \ |
Sjoerd Simons | 59d03cb | 2015-08-28 15:01:54 +0200 | [diff] [blame] | 482 | "for distro_bootpart in ${devplist}; do " \ |
| 483 | "if fstype ${devtype} " \ |
| 484 | "${devnum}:${distro_bootpart} " \ |
Sjoerd Simons | 735b1cf | 2015-01-05 18:13:38 +0100 | [diff] [blame] | 485 | "bootfstype; then " \ |
| 486 | "run scan_dev_for_boot; " \ |
| 487 | "fi; " \ |
AKASHI Takahiro | 13dd666 | 2018-12-04 15:46:55 +0900 | [diff] [blame] | 488 | "done; " \ |
| 489 | "setenv devplist\0" \ |
Sjoerd Simons | 735b1cf | 2015-01-05 18:13:38 +0100 | [diff] [blame] | 490 | \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 491 | BOOT_TARGET_DEVICES(BOOTENV_DEV) \ |
| 492 | \ |
Sjoerd Simons | 453c6cc | 2015-01-05 18:13:39 +0100 | [diff] [blame] | 493 | "distro_bootcmd=" BOOTENV_SET_SCSI_NEED_INIT \ |
Heinrich Schuchardt | 9493e39 | 2018-12-21 02:18:16 +0100 | [diff] [blame] | 494 | BOOTENV_SET_NVME_NEED_INIT \ |
Joshua Watt | d5e994f | 2019-06-20 16:31:35 -0500 | [diff] [blame] | 495 | BOOTENV_SET_IDE_NEED_INIT \ |
David Abdurachmanov | f0ebcf8 | 2019-07-22 11:38:11 +0300 | [diff] [blame] | 496 | BOOTENV_SET_VIRTIO_NEED_INIT \ |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 497 | "for target in ${boot_targets}; do " \ |
| 498 | "run bootcmd_${target}; " \ |
| 499 | "done\0" |
| 500 | |
Dennis Gilmore | 2a43201 | 2014-07-30 16:37:14 -0600 | [diff] [blame] | 501 | #endif /* _CONFIG_CMD_DISTRO_BOOTCMD_H */ |