## SPDX-License-Identifier: GPL-2.0-only if PAYLOAD_LINUXBOOT choice prompt "Architecture" depends on LINUXBOOT_COMPILE_KERNEL || LINUXBOOT_BUILD_INITRAMFS default LINUXBOOT_X86_64 config LINUXBOOT_X86_64 bool "x86_64" depends on ARCH_X86 help AMD64 kernel and initramfs config LINUXBOOT_X86 bool "x86" depends on ARCH_X86 help X86 kernel and initramfs config LINUXBOOT_ARM bool "arm64" depends on ARCH_ARM select PAYLOAD_FIT_SUPPORT help arm kernel and initramfs config LINUXBOOT_ARM64 bool "arm64" depends on ARCH_ARM64 select PAYLOAD_FIT_SUPPORT help AARCH64 kernel and initramfs config LINUXBOOT_RISCV_RV32 bool "RISC-V" depends on ARCH_RISCV_RV32 select PAYLOAD_FIT_SUPPORT help RISC-V kernel and initramfs config LINUXBOOT_RISCV_RV64 bool "RISC-V" depends on ARCH_RISCV_RV64 select PAYLOAD_FIT_SUPPORT help RISC-V kernel and initramfs endchoice comment "Linux kernel" config LINUXBOOT_COMPILE_KERNEL bool "Compile kernel" default n config LINUXBOOT_KERNEL_PATH string "Path to kernel" default "build/uImage" if LINUXBOOT_KERNEL_UIMAGE default "build/bzImage" if LINUXBOOT_KERNEL_BZIMAGE help The kernel path is either and absolute path or relative to the LinuxBoot directory if LINUXBOOT_COMPILE_KERNEL config LINUXBOOT_CROSS_COMPILE string "cross compiler" default "" # e.g. "aarch64-linux-gnu-" help Choose a custom cross compiler toolchain to use. It can be useful if you don't want to use the coreboot toolchain or experience problems using it. config LINUXBOOT_KERNEL_VERSION string "kernel version" default "6.3" help Choose the Linux kernel version number. (x.x.x) Release candidate kernels (rc) are currently are not supported. config LINUXBOOT_KERNEL_CONFIGFILE string "Config file path" default "i386/defconfig" if LINUXBOOT_X86 default "x86_64/defconfig" if LINUXBOOT_X86_64 default "arm64/defconfig" if LINUXBOOT_ARM64 default "riscv/defconfig-32" if LINUXBOOT_RISCV_RV32 default "riscv/defconfig-64" if LINUXBOOT_RISCV_RV64 help Path to the kernel configuration file. Note: this can be a defconfig file or a complete .config file. choice prompt "Kernel binary format" default LINUXBOOT_KERNEL_BZIMAGE if LINUXBOOT_X86 || LINUXBOOT_X86_64 default LINUXBOOT_KERNEL_UIMAGE if LINUXBOOT_ARM64 || LINUXBOOT_RISCV_RV32 || LINUXBOOT_RISCV_RV64 config LINUXBOOT_KERNEL_BZIMAGE bool "bzImage" depends on LINUXBOOT_X86 || LINUXBOOT_X86_64 config LINUXBOOT_KERNEL_UIMAGE bool "uImage" depends on LINUXBOOT_ARM64 || LINUXBOOT_RISCV_RV32 || LINUXBOOT_RISCV_RV64 endchoice config LINUXBOOT_DTS_FILE string "Compiled devicetree file" depends on LINUXBOOT_ARM64 || LINUXBOOT_RISCV_RV32 || LINUXBOOT_RISCV_RV64 default "empty.dts" endif #LINUXBOOT_COMPILE_KERNEL config LINUX_COMMAND_LINE string "Kernel command-line" default "" help Add your own kernel command-line arguments. config PAYLOAD_FILE default "payloads/external/LinuxBoot/build/Image" comment "Linux initramfs" config LINUXBOOT_BUILD_INITRAMFS bool "Build initramfs" default n config LINUXBOOT_INITRAMFS_PATH string "Path to initramfs" default "build/initramfs_u-root.cpio" if LINUXBOOT_UROOT if LINUXBOOT_BUILD_INITRAMFS choice prompt "Initramfs" default LINUXBOOT_UROOT config LINUXBOOT_UROOT bool "u-root" depends on !LINUXBOOT_RISCV_RV32 # not supported by u-root help Enable u-root linuxboot mode. See http://u-root.tk/ for more information. endchoice if LINUXBOOT_UROOT choice prompt "U-root version" default LINUXBOOT_UROOT_MAIN config LINUXBOOT_UROOT_CUSTOM bool "custom" help choose a custom u-root branch config LINUXBOOT_UROOT_MAIN bool "main" help Latest u-root version config LINUXBOOT_UROOT_V7_0_0 bool "v7.0.0" config LINUXBOOT_UROOT_V6_0_0 bool "v6.0.0" config LINUXBOOT_UROOT_V5_0_0 bool "v5.0.0" config LINUXBOOT_UROOT_V4_0_0 bool "v4.0.0" config LINUXBOOT_UROOT_V3_0_0 bool "v3.0.0" config LINUXBOOT_UROOT_V2_0_0 bool "v2.0.0" config LINUXBOOT_UROOT_V1_0_0 bool "v1.0.0" endchoice config LINUXBOOT_UROOT_CHECKOUT string "U-root custom branch" depends on LINUXBOOT_UROOT_CUSTOM config LINUXBOOT_UROOT_VERSION string default LINUXBOOT_UROOT_CHECKOUT if LINUXBOOT_UROOT_CUSTOM default "main" if LINUXBOOT_UROOT_MAIN default "v7.0.0" if LINUXBOOT_UROOT_V7_0_0 default "v6.0.0" if LINUXBOOT_UROOT_V6_0_0 default "v5.0.0" if LINUXBOOT_UROOT_V5_0_0 default "v4.0.0" if LINUXBOOT_UROOT_V4_0_0 default "v3.0.0" if LINUXBOOT_UROOT_V3_0_0 default "v2.0.0" if LINUXBOOT_UROOT_V2_0_0 default "v1.0.0" if LINUXBOOT_UROOT_V1_0_0 choice prompt "Build format" default LINUXBOOT_UROOT_BB help u-root build format (e.g. bb or source). (default "bb") config LINUXBOOT_UROOT_BB bool "bb" config LINUXBOOT_UROOT_SOURCE bool "source (experimental)" endchoice config LINUXBOOT_UROOT_FORMAT string default "bb" if LINUXBOOT_UROOT_BB default "source" if LINUXBOOT_UROOT_SOURCE config LINUXBOOT_UROOT_FILES string "Add files to u-root base" help Additional files, directories, and binaries (with their ldd dependencies) to add to archive. Can be speficified multiple times. config LINUXBOOT_UROOT_INITCMD string "Init target" default "init" help Symlink target for /init. Can be an absolute path or a u-root command name. (default "init") config LINUXBOOT_UROOT_SHELL string "default shell" default "elvish" help Default shell. Can be an absolute path or a u-root command name. (default "elvish") config LINUXBOOT_UROOT_COMMANDS string "U-root commands" default "boot coreboot-app" help List of additional modules to include, separated by space. (default "boot coreboot-app") if LINUXBOOT_UROOT_MAIN choice prompt "Choose a specific bootloader" default SPECIFIC_BOOTLOADER_SYSTEMBOOT help Specify a bootloader which starts after u-root init. It will be a symlink to /bin/uinit. Default: systemboot config SPECIFIC_BOOTLOADER_NONE bool "none" help Leave u-root to decide which bootloaders to load first after init, if any at all. Most likely u-root will start into the defined u-root shell. config SPECIFIC_BOOTLOADER_SYSTEMBOOT bool "systemboot" help If systemboot has been used as a bootloader wrapper in the past, enable this option. It will invoke -uinitcmd=systemboot and result in a BIOS/UEFI BDS boot behavior. config SPECIFIC_BOOTLOADER_BOOT2 bool "boot2" config SPECIFIC_BOOTLOADER_PXEBOOT bool "pxeboot" config SPECIFIC_BOOTLOADER_STBOOT bool "stboot" config SPECIFIC_BOOTLOADER_CUSTOM bool "custom" endchoice config SPECIFIC_BOOTLOADER_CUSTOM_CMD string "Specify a custom program to start" depends on SPECIFIC_BOOTLOADER_CUSTOM help This option will symlink the input to /bin/unit which will set it as the first boot program after the u-root init. Program flags are not symlinkable. config LINUXBOOT_UROOT_UINITCMD string default "" if SPECIFIC_BOOTLOADER_NONE default "systemboot" if SPECIFIC_BOOTLOADER_SYSTEMBOOT default "boot2" if SPECIFIC_BOOTLOADER_BOOT2 default "pxeboot" if SPECIFIC_BOOTLOADER_PXEBOOT default "stboot" if SPECIFIC_BOOTLOADER_STBOOT default SPECIFIC_BOOTLOADER_CUSTOM_CMD if SPECIFIC_BOOTLOADER_CUSTOM endif #LINUXBOOT_UROOT_MAIN endif #LINUXBOOT_UROOT endif #LINUXBOOT_BUILD_INITRAMFS choice prompt "Initramfs compression format" default LINUXBOOT_INITRAMFS_COMPRESSION_XZ config LINUXBOOT_INITRAMFS_COMPRESSION_NONE bool "none" config LINUXBOOT_INITRAMFS_COMPRESSION_XZ bool "xz compression" endchoice config LINUXBOOT_INITRAMFS_SUFFIX string default "" if LINUXBOOT_INITRAMFS_COMPRESSION_NONE default ".xz" if LINUXBOOT_INITRAMFS_COMPRESSION_XZ endif #PAYLOAD_LINUXBOOT