| ################################################################################ |
| # |
| # uboot |
| # |
| ################################################################################ |
| |
| UBOOT_VERSION = $(call qstrip,$(BR2_TARGET_UBOOT_VERSION)) |
| UBOOT_BOARD_NAME = $(call qstrip,$(BR2_TARGET_UBOOT_BOARDNAME)) |
| |
| UBOOT_LICENSE = GPL-2.0+ |
| ifeq ($(BR2_TARGET_UBOOT_LATEST_VERSION),y) |
| UBOOT_LICENSE_FILES = Licenses/gpl-2.0.txt |
| endif |
| UBOOT_CPE_ID_VENDOR = denx |
| UBOOT_CPE_ID_PRODUCT = u-boot |
| |
| UBOOT_INSTALL_IMAGES = YES |
| |
| # u-boot 2020.01+ needs make 4.0+ |
| UBOOT_DEPENDENCIES = host-pkgconf $(BR2_MAKE_HOST_DEPENDENCY) |
| UBOOT_MAKE = $(BR2_MAKE) |
| |
| ifeq ($(BR2_TARGET_UBOOT_CUSTOM_TARBALL),y) |
| # Handle custom U-Boot tarballs as specified by the configuration |
| UBOOT_TARBALL = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_TARBALL_LOCATION)) |
| UBOOT_SITE = $(patsubst %/,%,$(dir $(UBOOT_TARBALL))) |
| UBOOT_SOURCE = $(notdir $(UBOOT_TARBALL)) |
| else ifeq ($(BR2_TARGET_UBOOT_CUSTOM_GIT),y) |
| UBOOT_SITE = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_URL)) |
| UBOOT_SITE_METHOD = git |
| else ifeq ($(BR2_TARGET_UBOOT_CUSTOM_HG),y) |
| UBOOT_SITE = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_URL)) |
| UBOOT_SITE_METHOD = hg |
| else ifeq ($(BR2_TARGET_UBOOT_CUSTOM_SVN),y) |
| UBOOT_SITE = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_URL)) |
| UBOOT_SITE_METHOD = svn |
| else |
| # Handle stable official U-Boot versions |
| UBOOT_SITE = https://ftp.denx.de/pub/u-boot |
| UBOOT_SOURCE = u-boot-$(UBOOT_VERSION).tar.bz2 |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT)$(BR2_TARGET_UBOOT_LATEST_VERSION),y) |
| BR_NO_CHECK_HASH_FOR += $(UBOOT_SOURCE) |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_BIN),y) |
| UBOOT_BINS += u-boot.bin |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_DTB),y) |
| UBOOT_BINS += u-boot.dtb |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_ELF),y) |
| UBOOT_BINS += u-boot |
| # To make elf usable for debuging on ARC use special target |
| ifeq ($(BR2_arc),y) |
| UBOOT_MAKE_TARGET += mdbtrick |
| endif |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_REMAKE_ELF),y) |
| UBOOT_BINS += u-boot.elf |
| endif |
| |
| # Call 'make all' unconditionally |
| UBOOT_MAKE_TARGET += all |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_KWB),y) |
| UBOOT_BINS += u-boot.kwb |
| UBOOT_MAKE_TARGET += u-boot.kwb |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_AIS),y) |
| UBOOT_BINS += u-boot.ais |
| UBOOT_MAKE_TARGET += u-boot.ais |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_NAND_BIN),y) |
| UBOOT_BINS += u-boot-nand.bin |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_DTB_IMG),y) |
| UBOOT_BINS += u-boot-dtb.img |
| UBOOT_MAKE_TARGET += u-boot-dtb.img |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_DTB_IMX),y) |
| UBOOT_BINS += u-boot-dtb.imx |
| UBOOT_MAKE_TARGET += u-boot-dtb.imx |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_DTB_BIN),y) |
| UBOOT_BINS += u-boot-dtb.bin |
| UBOOT_MAKE_TARGET += u-boot-dtb.bin |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_IMG),y) |
| UBOOT_BINS += u-boot.img |
| UBOOT_MAKE_TARGET += u-boot.img |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_ITB),y) |
| UBOOT_BINS += u-boot.itb |
| UBOOT_MAKE_TARGET += u-boot.itb |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_IMX),y) |
| UBOOT_BINS += u-boot.imx |
| UBOOT_MAKE_TARGET += u-boot.imx |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_SB),y) |
| UBOOT_BINS += u-boot.sb |
| UBOOT_MAKE_TARGET += u-boot.sb |
| # mxsimage needs OpenSSL |
| UBOOT_DEPENDENCIES += host-elftosb host-openssl |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_SD),y) |
| # BootStream (.sb) is generated by U-Boot, we convert it to SD format |
| UBOOT_BINS += u-boot.sd |
| UBOOT_MAKE_TARGET += u-boot.sb |
| UBOOT_DEPENDENCIES += host-elftosb host-openssl |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_NAND),y) |
| UBOOT_BINS += u-boot.nand |
| UBOOT_MAKE_TARGET += u-boot.sb |
| UBOOT_DEPENDENCIES += host-elftosb host-openssl |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_STM32),y) |
| UBOOT_BINS += u-boot.stm32 |
| ifeq ($(BR2_TARGET_UBOOT_BUILD_FORMAT_STM32_LEGACY),y) |
| UBOOT_MAKE_TARGET += u-boot.stm32 |
| endif |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_INITIAL_ENV),y) |
| UBOOT_MAKE_TARGET += u-boot-initial-env |
| define UBOOT_INSTALL_UBOOT_INITIAL_ENV |
| $(INSTALL) -D -m 0644 $(@D)/u-boot-initial-env $(TARGET_DIR)/etc/u-boot-initial-env |
| endef |
| UBOOT_POST_INSTALL_TARGET_HOOKS += UBOOT_INSTALL_UBOOT_INITIAL_ENV |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_FORMAT_CUSTOM),y) |
| UBOOT_BINS += $(call qstrip,$(BR2_TARGET_UBOOT_FORMAT_CUSTOM_NAME)) |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_OMAP_IFT),y) |
| UBOOT_BINS += u-boot.bin |
| UBOOT_BIN_IFT = u-boot.bin.ift |
| endif |
| |
| # The kernel calls AArch64 'arm64', but U-Boot calls it just 'arm', so |
| # we have to special case it. Similar for i386/x86_64 -> x86 |
| ifeq ($(NORMALIZED_ARCH),arm64) |
| UBOOT_ARCH = arm |
| else ifneq ($(filter $(NORMALIZED_ARCH),i386 x86_64),) |
| UBOOT_ARCH = x86 |
| else |
| UBOOT_ARCH = $(NORMALIZED_ARCH) |
| endif |
| |
| UBOOT_MAKE_OPTS += \ |
| CROSS_COMPILE="$(TARGET_CROSS)" \ |
| ARCH=$(UBOOT_ARCH) \ |
| HOSTCC="$(HOSTCC) $(subst -I/,-isystem /,$(subst -I /,-isystem /,$(HOST_CFLAGS)))" \ |
| HOSTLDFLAGS="$(HOST_LDFLAGS)" \ |
| $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_MAKEOPTS)) |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_ATF_BL31),y) |
| UBOOT_DEPENDENCIES += arm-trusted-firmware |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_ATF_BL31_ELF),y) |
| UBOOT_MAKE_OPTS += BL31=$(BINARIES_DIR)/bl31.elf |
| define UBOOT_COPY_ATF_FIRMWARE |
| cp $(BINARIES_DIR)/bl31.elf $(@D)/ |
| endef |
| UBOOT_PRE_BUILD_HOOKS += UBOOT_COPY_ATF_FIRMWARE |
| else |
| UBOOT_MAKE_OPTS += BL31=$(BINARIES_DIR)/bl31.bin |
| define UBOOT_COPY_ATF_FIRMWARE |
| cp $(BINARIES_DIR)/bl31.bin $(@D)/ |
| endef |
| UBOOT_PRE_BUILD_HOOKS += UBOOT_COPY_ATF_FIRMWARE |
| endif |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_OPTEE_TEE),y) |
| UBOOT_DEPENDENCIES += optee-os |
| UBOOT_MAKE_OPTS += TEE=$(BINARIES_DIR)/tee.elf |
| endif |
| |
| # TI K3 devices needs at least ti-sysfw (System Firmware) provided |
| # by ti-k3-boot-firmware when built with u-boot's binman tool. |
| # Some TI K3 devices using a split firmware boot flow (AM62, |
| # j721e) also need the Device Manager (DM) firmware. |
| ifeq ($(BR2_TARGET_TI_K3_BOOT_FIRMWARE),y) |
| UBOOT_DEPENDENCIES += ti-k3-boot-firmware |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_OPENSBI),y) |
| UBOOT_DEPENDENCIES += opensbi |
| UBOOT_MAKE_OPTS += OPENSBI=$(BINARIES_DIR)/fw_dynamic.bin |
| endif |
| |
| # Mainline U-Boot versions can create the i.MX specific boot images |
| # and need some NXP firmware blobs. |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_IMX_FIRMWARE),y) |
| UBOOT_DEPENDENCIES += firmware-imx |
| UBOOT_IMX_FW_FILES = \ |
| $(if $(BR2_PACKAGE_FIRMWARE_IMX_NEEDS_HDMI_FW),signed_hdmi_imx8m.bin) \ |
| $(if $(BR2_PACKAGE_FIRMWARE_IMX_LPDDR4),lpddr4*.bin) \ |
| $(if $(BR2_PACKAGE_FIRMWARE_IMX_DDR4),ddr4*.bin) \ |
| $(if $(BR2_PACKAGE_FIRMWARE_IMX_DDR3),ddr3*.bin) |
| |
| define UBOOT_COPY_IMX_FW_FILES |
| $(foreach fw,$(UBOOT_IMX_FW_FILES),\ |
| cp $(BINARIES_DIR)/$(fw) $(@D)/ |
| ) |
| endef |
| UBOOT_PRE_BUILD_HOOKS += UBOOT_COPY_IMX_FW_FILES |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_ROCKCHIP_RKBIN),y) |
| UBOOT_DEPENDENCIES += rockchip-rkbin |
| define UBOOT_INSTALL_UBOOT_ROCKCHIP_BIN |
| $(INSTALL) -D -m 0644 $(@D)/u-boot-rockchip.bin $(BINARIES_DIR)/u-boot-rockchip.bin |
| endef |
| UBOOT_POST_INSTALL_IMAGES_HOOKS += UBOOT_INSTALL_UBOOT_ROCKCHIP_BIN |
| ifneq ($(ROCKCHIP_RKBIN_BL31_FILENAME),) |
| UBOOT_MAKE_OPTS += BL31=$(BINARIES_DIR)/$(notdir $(ROCKCHIP_RKBIN_BL31_FILENAME)) |
| endif |
| ifneq ($(ROCKCHIP_RKBIN_TPL_FILENAME),) |
| UBOOT_MAKE_OPTS += ROCKCHIP_TPL=$(BINARIES_DIR)/$(notdir $(ROCKCHIP_RKBIN_TPL_FILENAME)) |
| endif |
| ifneq ($(ROCKCHIP_RKBIN_TEE_FILENAME),) |
| UBOOT_MAKE_OPTS += TEE=$(BINARIES_DIR)/$(notdir $(ROCKCHIP_RKBIN_TEE_FILENAME)) |
| endif |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_DTC),y) |
| UBOOT_DEPENDENCIES += host-dtc |
| UBOOT_MAKE_OPTS += DTC=$(HOST_DIR)/bin/dtc |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYTHON3),y) |
| UBOOT_DEPENDENCIES += host-python3 host-python-setuptools |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYLIBFDT),y) |
| UBOOT_DEPENDENCIES += host-python-pylibfdt |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYELFTOOLS),y) |
| UBOOT_DEPENDENCIES += host-python-pyelftools |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_OPENSSL),y) |
| UBOOT_DEPENDENCIES += host-openssl |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_LZOP),y) |
| UBOOT_DEPENDENCIES += host-lzop |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_GNUTLS),y) |
| UBOOT_DEPENDENCIES += host-gnutls |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_UTIL_LINUX),y) |
| UBOOT_DEPENDENCIES += host-util-linux |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_NEEDS_XXD),y) |
| UBOOT_DEPENDENCIES += host-vim |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_USE_BINMAN),y) |
| # https://source.denx.de/u-boot/u-boot/-/blob/v2024.04/tools/binman/binman.rst?plain=1#L377 |
| # https://source.denx.de/u-boot/u-boot/-/blob/v2024.04/tools/buildman/requirements.txt |
| UBOOT_DEPENDENCIES += \ |
| host-python-jsonschema \ |
| host-python-pyyaml \ |
| host-python-yamllint |
| UBOOT_MAKE_OPTS += BINMAN_INDIRS=$(BINARIES_DIR) |
| endif |
| |
| # prior to u-boot 2013.10 the license info was in COPYING. Copy it so |
| # legal-info finds it |
| define UBOOT_COPY_OLD_LICENSE_FILE |
| if [ -f $(@D)/COPYING ]; then \ |
| $(INSTALL) -m 0644 -D $(@D)/COPYING $(@D)/Licenses/gpl-2.0.txt; \ |
| fi |
| endef |
| |
| UBOOT_POST_EXTRACT_HOOKS += UBOOT_COPY_OLD_LICENSE_FILE |
| UBOOT_POST_RSYNC_HOOKS += UBOOT_COPY_OLD_LICENSE_FILE |
| |
| # Older versions break on gcc 10+ because of redefined symbols |
| define UBOOT_DROP_YYLLOC |
| $(Q)grep -Z -l -r -E '^YYLTYPE yylloc;$$' $(@D) \ |
| |xargs -0 -r $(SED) '/^YYLTYPE yylloc;$$/d' |
| endef |
| UBOOT_POST_PATCH_HOOKS += UBOOT_DROP_YYLLOC |
| |
| ifneq ($(ARCH_XTENSA_OVERLAY_FILE),) |
| define UBOOT_XTENSA_OVERLAY_EXTRACT |
| $(call arch-xtensa-overlay-extract,$(@D),u-boot) |
| endef |
| UBOOT_POST_EXTRACT_HOOKS += UBOOT_XTENSA_OVERLAY_EXTRACT |
| UBOOT_EXTRA_DOWNLOADS += $(ARCH_XTENSA_OVERLAY_URL) |
| endif |
| |
| # Analogous code exists in linux/linux.mk. Basically, the generic |
| # package infrastructure handles downloading and applying remote |
| # patches. Local patches are handled depending on whether they are |
| # directories or files. |
| UBOOT_PATCHES = $(call qstrip,$(BR2_TARGET_UBOOT_PATCH)) |
| UBOOT_PATCH = $(filter ftp://% http://% https://%,$(UBOOT_PATCHES)) |
| |
| define UBOOT_APPLY_LOCAL_PATCHES |
| for p in $(filter-out ftp://% http://% https://%,$(UBOOT_PATCHES)) ; do \ |
| if test -d $$p ; then \ |
| $(APPLY_PATCHES) $(@D) $$p \*.patch || exit 1 ; \ |
| else \ |
| $(APPLY_PATCHES) $(@D) `dirname $$p` `basename $$p` || exit 1; \ |
| fi \ |
| done |
| endef |
| UBOOT_POST_PATCH_HOOKS += UBOOT_APPLY_LOCAL_PATCHES |
| |
| # Fixup inclusion of libfdt headers, which can fail in older u-boot versions |
| # when libfdt-devel is installed system-wide. |
| # The core change is equivalent to upstream commit |
| # e0d20dc1521e74b82dbd69be53a048847798a90a (first in v2018.03). However, the fixup |
| # is complicated by the fact that the underlying u-boot code changed multiple |
| # times in history: |
| # - The directory scripts/dtc/libfdt only exists since upstream commit |
| # c0e032e0090d6541549b19cc47e06ccd1f302893 (first in v2017.11). For earlier |
| # versions, create a dummy scripts/dtc/libfdt directory with symlinks for the |
| # fdt-related files. This allows to use the same -I<path> option for both |
| # cases. |
| # - The variable 'srctree' used to be called 'SRCTREE' before upstream commit |
| # 01286329b27b27eaeda045b469d41b1d9fce545a (first in v2014.04). |
| # - The original location for libfdt, 'lib/libfdt/', used to be simply |
| # 'libfdt' before upstream commit 0de71d507157c4bd4fddcd3a419140d2b986eed2 |
| # (first in v2010.06). Make the 'lib' part optional in the substitution to |
| # handle this. |
| define UBOOT_FIXUP_LIBFDT_INCLUDE |
| $(Q)if [ ! -d $(@D)/scripts/dtc/libfdt ]; then \ |
| mkdir -p $(@D)/scripts/dtc/libfdt; \ |
| cd $(@D)/scripts/dtc/libfdt; \ |
| ln -s ../../../include/fdt.h .; \ |
| ln -s ../../../include/libfdt*.h .; \ |
| ln -s ../../../lib/libfdt/libfdt_internal.h .; \ |
| fi |
| $(Q)$(SED) \ |
| 's%-I\ *\$$(srctree)/lib/libfdt%-I$$(srctree)/scripts/dtc/libfdt%; \ |
| s%-I\ *\$$(SRCTREE)\(/lib\)\?/libfdt%-I$$(SRCTREE)/scripts/dtc/libfdt%' \ |
| $(@D)/tools/Makefile |
| endef |
| UBOOT_POST_PATCH_HOOKS += UBOOT_FIXUP_LIBFDT_INCLUDE |
| |
| ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY),y) |
| define UBOOT_CONFIGURE_CMDS |
| $(TARGET_CONFIGURE_OPTS) \ |
| $(UBOOT_MAKE) -C $(@D) $(UBOOT_MAKE_OPTS) \ |
| $(UBOOT_BOARD_NAME)_config |
| endef |
| else ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_KCONFIG),y) |
| ifeq ($(BR2_TARGET_UBOOT_USE_DEFCONFIG),y) |
| UBOOT_KCONFIG_DEFCONFIG = $(call qstrip,$(BR2_TARGET_UBOOT_BOARD_DEFCONFIG))_defconfig |
| else ifeq ($(BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG),y) |
| UBOOT_KCONFIG_FILE = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE)) |
| endif # BR2_TARGET_UBOOT_USE_DEFCONFIG |
| |
| UBOOT_KCONFIG_FRAGMENT_FILES = $(call qstrip,$(BR2_TARGET_UBOOT_CONFIG_FRAGMENT_FILES)) |
| UBOOT_KCONFIG_EDITORS = menuconfig xconfig gconfig nconfig |
| |
| # UBOOT_MAKE_OPTS overrides HOSTCC / HOSTLDFLAGS to allow the build to |
| # find our host-openssl. However, this triggers a bug in the kconfig |
| # build script that causes it to build with /usr/include/ncurses.h |
| # (which is typically wchar) but link with |
| # $(HOST_DIR)/lib/libncurses.so (which is not). We don't actually |
| # need any host-package for kconfig, so remove the HOSTCC/HOSTLDFLAGS |
| # override again. In addition, host-ccache is not ready at kconfig |
| # time, so use HOSTCC_NOCCACHE. |
| UBOOT_KCONFIG_OPTS = $(UBOOT_MAKE_OPTS) HOSTCC="$(HOSTCC_NOCCACHE)" HOSTLDFLAGS="" |
| |
| ifeq ($(BR2_TARGET_UBOOT_DEFAULT_ENV_FILE_ENABLED),y) |
| UBOOT_DEFAULT_ENV_FILE = $(call qstrip,$(BR2_TARGET_UBOOT_DEFAULT_ENV_FILE)) |
| define UBOOT_KCONFIG_DEFAULT_ENV_FILE |
| $(call KCONFIG_SET_OPT,CONFIG_USE_DEFAULT_ENV_FILE,y) |
| $(call KCONFIG_SET_OPT,CONFIG_DEFAULT_ENV_FILE,"$(shell readlink -f $(UBOOT_DEFAULT_ENV_FILE))") |
| endef |
| endif |
| endif # BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY |
| |
| UBOOT_CUSTOM_DTS_PATH = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_DTS_PATH)) |
| |
| define UBOOT_BUILD_CMDS |
| $(if $(UBOOT_CUSTOM_DTS_PATH), |
| cp -f $(UBOOT_CUSTOM_DTS_PATH) $(@D)/arch/$(UBOOT_ARCH)/dts/ |
| ) |
| $(TARGET_CONFIGURE_OPTS) \ |
| PKG_CONFIG="$(PKG_CONFIG_HOST_BINARY)" \ |
| PKG_CONFIG_SYSROOT_DIR="/" \ |
| PKG_CONFIG_ALLOW_SYSTEM_CFLAGS=1 \ |
| PKG_CONFIG_ALLOW_SYSTEM_LIBS=1 \ |
| PKG_CONFIG_LIBDIR="$(HOST_DIR)/lib/pkgconfig:$(HOST_DIR)/share/pkgconfig" \ |
| $(UBOOT_MAKE) -C $(@D) $(UBOOT_MAKE_OPTS) \ |
| $(UBOOT_MAKE_TARGET) |
| $(if $(BR2_TARGET_UBOOT_FORMAT_SD), |
| $(@D)/tools/mxsboot sd $(@D)/u-boot.sb $(@D)/u-boot.sd) |
| $(if $(BR2_TARGET_UBOOT_FORMAT_NAND), |
| $(@D)/tools/mxsboot \ |
| -w $(BR2_TARGET_UBOOT_FORMAT_NAND_PAGE_SIZE) \ |
| -o $(BR2_TARGET_UBOOT_FORMAT_NAND_OOB_SIZE) \ |
| -e $(BR2_TARGET_UBOOT_FORMAT_NAND_ERASE_SIZE) \ |
| nand $(@D)/u-boot.sb $(@D)/u-boot.nand) |
| endef |
| |
| define UBOOT_BUILD_OMAP_IFT |
| $(HOST_DIR)/bin/gpsign -f $(@D)/u-boot.bin \ |
| -c $(call qstrip,$(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG)) |
| endef |
| |
| define UBOOT_INSTALL_IMAGES_CMDS |
| $(foreach f,$(UBOOT_BINS), \ |
| cp -dpf $(@D)/$(f) $(BINARIES_DIR)/ |
| ) |
| $(if $(BR2_TARGET_UBOOT_FORMAT_NAND), |
| cp -dpf $(@D)/u-boot.sb $(BINARIES_DIR)) |
| $(if $(BR2_TARGET_UBOOT_SPL), |
| $(foreach f,$(call qstrip,$(BR2_TARGET_UBOOT_SPL_NAME)), \ |
| cp -dpf $(@D)/$(f) $(BINARIES_DIR)/ |
| ) |
| ) |
| endef |
| |
| ifeq ($(BR2_TARGET_UBOOT_ZYNQMP),y) |
| |
| ifeq ($(BR2_TARGET_UBOOT_ZYNQMP_PMUFW_PREBUILT),y) |
| UBOOT_DEPENDENCIES += xilinx-prebuilt |
| UBOOT_ZYNQMP_PMUFW_PATH = $(BINARIES_DIR)/pmufw.elf |
| else |
| UBOOT_ZYNQMP_PMUFW = $(call qstrip,$(BR2_TARGET_UBOOT_ZYNQMP_PMUFW)) |
| |
| ifneq ($(findstring ://,$(UBOOT_ZYNQMP_PMUFW)),) |
| UBOOT_EXTRA_DOWNLOADS += $(UBOOT_ZYNQMP_PMUFW) |
| BR_NO_CHECK_HASH_FOR += $(notdir $(UBOOT_ZYNQMP_PMUFW)) |
| UBOOT_ZYNQMP_PMUFW_PATH = $(UBOOT_DL_DIR)/$(notdir $(UBOOT_ZYNQMP_PMUFW)) |
| else ifneq ($(UBOOT_ZYNQMP_PMUFW),) |
| UBOOT_ZYNQMP_PMUFW_PATH = $(shell readlink -f $(UBOOT_ZYNQMP_PMUFW)) |
| endif #ifneq ($(findstring ://,$(UBOOT_ZYNQMP_PMUFW)),) |
| |
| endif #BR2_TARGET_UBOOT_ZYNQMP_PMUFW_PREBUILT |
| |
| ifeq ($(suffix $(UBOOT_ZYNQMP_PMUFW_PATH)),.elf) |
| UBOOT_ZYNQMP_PMUFW_PATH_FINAL = $(basename $(UBOOT_ZYNQMP_PMUFW_PATH)).bin |
| # objcopy is arch-agnostic so we can use $(TARGET_OBJCOPY) in lack of a |
| # microblaze objcopy |
| define UBOOT_ZYNQMP_PMUFW_CONVERT |
| $(TARGET_OBJCOPY) -O binary -I elf32-little $(UBOOT_ZYNQMP_PMUFW_PATH) $(UBOOT_ZYNQMP_PMUFW_PATH_FINAL) |
| endef |
| UBOOT_PRE_BUILD_HOOKS += UBOOT_ZYNQMP_PMUFW_CONVERT |
| else |
| UBOOT_ZYNQMP_PMUFW_PATH_FINAL = $(UBOOT_ZYNQMP_PMUFW_PATH) |
| endif |
| define UBOOT_ZYNQMP_KCONFIG_PMUFW |
| $(call KCONFIG_SET_OPT,CONFIG_PMUFW_INIT_FILE,"$(UBOOT_ZYNQMP_PMUFW_PATH_FINAL)") |
| endef |
| |
| UBOOT_ZYNQMP_PM_CFG = $(call qstrip,$(BR2_TARGET_UBOOT_ZYNQMP_PM_CFG)) |
| ifneq ($(UBOOT_ZYNQMP_PM_CFG),) |
| UBOOT_ZYNQMP_PM_CFG_BIN = $(UBOOT_DIR)/pm_cfg_obj.bin |
| define UBOOT_ZYNQMP_KCONFIG_PM_CFG |
| $(call KCONFIG_SET_OPT,CONFIG_ZYNQMP_SPL_PM_CFG_OBJ_FILE,"$(UBOOT_ZYNQMP_PM_CFG_BIN)", \ |
| $(@D)/.config) |
| endef |
| |
| define UBOOT_ZYNQMP_PM_CFG_CONVERT |
| $(UBOOT_DIR)/tools/zynqmp_pm_cfg_obj_convert.py \ |
| "$(UBOOT_ZYNQMP_PM_CFG)" \ |
| "$(UBOOT_ZYNQMP_PM_CFG_BIN)" |
| endef |
| UBOOT_PRE_BUILD_HOOKS += UBOOT_ZYNQMP_PM_CFG_CONVERT |
| endif |
| |
| UBOOT_ZYNQMP_PSU_INIT = $(call qstrip,$(BR2_TARGET_UBOOT_ZYNQMP_PSU_INIT_FILE)) |
| UBOOT_ZYNQMP_PSU_INIT_PATH = $(shell readlink -f $(UBOOT_ZYNQMP_PSU_INIT)) |
| |
| ifneq ($(UBOOT_ZYNQMP_PSU_INIT),) |
| define UBOOT_ZYNQMP_KCONFIG_PSU_INIT |
| $(call KCONFIG_SET_OPT,CONFIG_XILINX_PS_INIT_FILE,"$(UBOOT_ZYNQMP_PSU_INIT_PATH)") |
| endef |
| endif |
| |
| endif # BR2_TARGET_UBOOT_ZYNQMP |
| |
| define UBOOT_INSTALL_OMAP_IFT_IMAGE |
| cp -dpf $(@D)/$(UBOOT_BIN_IFT) $(BINARIES_DIR)/ |
| endef |
| |
| ifeq ($(BR2_TARGET_UBOOT_OMAP_IFT),y) |
| ifeq ($(BR_BUILDING),y) |
| ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG)),) |
| $(error No gpsign config file. Check your BR2_TARGET_UBOOT_OMAP_IFT_CONFIG setting) |
| endif |
| ifeq ($(wildcard $(call qstrip,$(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG))),) |
| $(error gpsign config file $(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG) not found. Check your BR2_TARGET_UBOOT_OMAP_IFT_CONFIG setting) |
| endif |
| endif |
| UBOOT_DEPENDENCIES += host-omap-u-boot-utils |
| UBOOT_POST_BUILD_HOOKS += UBOOT_BUILD_OMAP_IFT |
| UBOOT_POST_INSTALL_IMAGES_HOOKS += UBOOT_INSTALL_OMAP_IFT_IMAGE |
| endif |
| |
| ifeq ($(BR2_TARGET_UBOOT_ALTERA_SOCFPGA_IMAGE_CRC),y) |
| ifeq ($(BR2_TARGET_UBOOT_SPL),y) |
| UBOOT_CRC_ALTERA_SOCFPGA_INPUT_IMAGES = $(call qstrip,$(BR2_TARGET_UBOOT_SPL_NAME)) |
| UBOOT_CRC_ALTERA_SOCFPGA_HEADER_VERSION = 0 |
| else |
| UBOOT_CRC_ALTERA_SOCFPGA_INPUT_IMAGES = u-boot-dtb.bin |
| UBOOT_CRC_ALTERA_SOCFPGA_HEADER_VERSION = 1 |
| endif |
| define UBOOT_CRC_ALTERA_SOCFPGA_IMAGE |
| $(foreach f,$(UBOOT_CRC_ALTERA_SOCFPGA_INPUT_IMAGES), \ |
| $(HOST_DIR)/bin/mkpimage \ |
| -v $(UBOOT_CRC_ALTERA_SOCFPGA_HEADER_VERSION) \ |
| -o $(BINARIES_DIR)/$(notdir $(call qstrip,$(f))).crc \ |
| $(@D)/$(call qstrip,$(f)) |
| ) |
| endef |
| UBOOT_DEPENDENCIES += host-mkpimage |
| UBOOT_POST_INSTALL_IMAGES_HOOKS += UBOOT_CRC_ALTERA_SOCFPGA_IMAGE |
| endif |
| |
| define UBOOT_KCONFIG_FIXUP_CMDS |
| $(UBOOT_ZYNQMP_KCONFIG_PMUFW) |
| $(UBOOT_ZYNQMP_KCONFIG_PM_CFG) |
| $(UBOOT_ZYNQMP_KCONFIG_PSU_INIT) |
| $(UBOOT_KCONFIG_DEFAULT_ENV_FILE) |
| endef |
| |
| ifeq ($(BR2_TARGET_UBOOT)$(BR_BUILDING),yy) |
| |
| # |
| # Check U-Boot board name (for legacy) or the defconfig/custom config |
| # file options (for kconfig) |
| # |
| ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY),y) |
| ifeq ($(UBOOT_BOARD_NAME),) |
| $(error No U-Boot board name set. Check your BR2_TARGET_UBOOT_BOARDNAME setting) |
| endif # UBOOT_BOARD_NAME |
| else ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_KCONFIG),y) |
| ifeq ($(BR2_TARGET_UBOOT_USE_DEFCONFIG),y) |
| ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_BOARD_DEFCONFIG)),) |
| $(error No board defconfig name specified, check your BR2_TARGET_UBOOT_BOARD_DEFCONFIG setting) |
| endif # qstrip BR2_TARGET_UBOOT_BOARD_DEFCONFIG |
| endif # BR2_TARGET_UBOOT_USE_DEFCONFIG |
| ifeq ($(BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG),y) |
| ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE)),) |
| $(error No board configuration file specified, check your BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE setting) |
| endif # qstrip BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE |
| endif # BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG |
| endif # BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY |
| |
| # |
| # Check custom version option |
| # |
| ifeq ($(BR2_TARGET_UBOOT_CUSTOM_VERSION),y) |
| ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_VERSION_VALUE)),) |
| $(error No custom U-Boot version specified. Check your BR2_TARGET_UBOOT_CUSTOM_VERSION_VALUE setting) |
| endif # qstrip BR2_TARGET_UBOOT_CUSTOM_VERSION_VALUE |
| endif # BR2_TARGET_UBOOT_CUSTOM_VERSION |
| |
| # |
| # Check custom tarball option |
| # |
| ifeq ($(BR2_TARGET_UBOOT_CUSTOM_TARBALL),y) |
| ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_TARBALL_LOCATION)),) |
| $(error No custom U-Boot tarball specified. Check your BR2_TARGET_UBOOT_CUSTOM_TARBALL_LOCATION setting) |
| endif # qstrip BR2_TARGET_UBOOT_CUSTOM_TARBALL_LOCATION |
| endif # BR2_TARGET_UBOOT_CUSTOM_TARBALL |
| |
| # |
| # Check Git/Mercurial repo options |
| # |
| ifeq ($(BR2_TARGET_UBOOT_CUSTOM_GIT)$(BR2_TARGET_UBOOT_CUSTOM_HG),y) |
| ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_URL)),) |
| $(error No custom U-Boot repository URL specified. Check your BR2_TARGET_UBOOT_CUSTOM_REPO_URL setting) |
| endif # qstrip BR2_TARGET_UBOOT_CUSTOM_CUSTOM_REPO_URL |
| ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_VERSION)),) |
| $(error No custom U-Boot repository version specified. Check your BR2_TARGET_UBOOT_CUSTOM_REPO_VERSION setting) |
| endif # qstrip BR2_TARGET_UBOOT_CUSTOM_CUSTOM_REPO_VERSION |
| endif # BR2_TARGET_UBOOT_CUSTOM_GIT || BR2_TARGET_UBOOT_CUSTOM_HG |
| |
| endif # BR2_TARGET_UBOOT && BR_BUILDING |
| |
| ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY),y) |
| UBOOT_DEPENDENCIES += \ |
| $(BR2_BISON_HOST_DEPENDENCY) \ |
| $(BR2_FLEX_HOST_DEPENDENCY) |
| $(eval $(generic-package)) |
| else ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_KCONFIG),y) |
| UBOOT_MAKE_ENV = $(TARGET_MAKE_ENV) |
| # Starting with 2021.10, the kconfig in uboot calls the cross-compiler |
| # to check its capabilities. So we need the toolchain before we can |
| # call the configurators. |
| UBOOT_KCONFIG_DEPENDENCIES += \ |
| toolchain \ |
| $(BR2_MAKE_HOST_DEPENDENCY) \ |
| $(BR2_BISON_HOST_DEPENDENCY) \ |
| $(BR2_FLEX_HOST_DEPENDENCY) |
| $(eval $(kconfig-package)) |
| endif # BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY |