uboot.mk 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639
  1. ################################################################################
  2. #
  3. # uboot
  4. #
  5. ################################################################################
  6. UBOOT_VERSION = $(call qstrip,$(BR2_TARGET_UBOOT_VERSION))
  7. UBOOT_BOARD_NAME = $(call qstrip,$(BR2_TARGET_UBOOT_BOARDNAME))
  8. UBOOT_LICENSE = GPL-2.0+
  9. ifeq ($(BR2_TARGET_UBOOT_LATEST_VERSION),y)
  10. UBOOT_LICENSE_FILES = Licenses/gpl-2.0.txt
  11. endif
  12. UBOOT_CPE_ID_VENDOR = denx
  13. UBOOT_CPE_ID_PRODUCT = u-boot
  14. UBOOT_INSTALL_IMAGES = YES
  15. # u-boot 2020.01+ needs make 4.0+
  16. UBOOT_DEPENDENCIES = host-pkgconf $(BR2_MAKE_HOST_DEPENDENCY)
  17. UBOOT_MAKE = $(BR2_MAKE)
  18. ifeq ($(BR2_TARGET_UBOOT_CUSTOM_TARBALL),y)
  19. # Handle custom U-Boot tarballs as specified by the configuration
  20. UBOOT_TARBALL = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_TARBALL_LOCATION))
  21. UBOOT_SITE = $(patsubst %/,%,$(dir $(UBOOT_TARBALL)))
  22. UBOOT_SOURCE = $(notdir $(UBOOT_TARBALL))
  23. else ifeq ($(BR2_TARGET_UBOOT_CUSTOM_GIT),y)
  24. UBOOT_SITE = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_URL))
  25. UBOOT_SITE_METHOD = git
  26. else ifeq ($(BR2_TARGET_UBOOT_CUSTOM_HG),y)
  27. UBOOT_SITE = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_URL))
  28. UBOOT_SITE_METHOD = hg
  29. else ifeq ($(BR2_TARGET_UBOOT_CUSTOM_SVN),y)
  30. UBOOT_SITE = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_URL))
  31. UBOOT_SITE_METHOD = svn
  32. else
  33. # Handle stable official U-Boot versions
  34. UBOOT_SITE = https://ftp.denx.de/pub/u-boot
  35. UBOOT_SOURCE = u-boot-$(UBOOT_VERSION).tar.bz2
  36. endif
  37. ifeq ($(BR2_TARGET_UBOOT)$(BR2_TARGET_UBOOT_LATEST_VERSION),y)
  38. BR_NO_CHECK_HASH_FOR += $(UBOOT_SOURCE)
  39. endif
  40. ifeq ($(BR2_TARGET_UBOOT_FORMAT_BIN),y)
  41. UBOOT_BINS += u-boot.bin
  42. endif
  43. ifeq ($(BR2_TARGET_UBOOT_FORMAT_DTB),y)
  44. UBOOT_BINS += u-boot.dtb
  45. endif
  46. ifeq ($(BR2_TARGET_UBOOT_FORMAT_ELF),y)
  47. UBOOT_BINS += u-boot
  48. # To make elf usable for debugging on ARC use special target
  49. ifeq ($(BR2_arc),y)
  50. UBOOT_MAKE_TARGET += mdbtrick
  51. endif
  52. endif
  53. ifeq ($(BR2_TARGET_UBOOT_FORMAT_REMAKE_ELF),y)
  54. UBOOT_BINS += u-boot.elf
  55. endif
  56. # Call 'make all' unconditionally
  57. UBOOT_MAKE_TARGET += all
  58. ifeq ($(BR2_TARGET_UBOOT_FORMAT_KWB),y)
  59. UBOOT_BINS += u-boot.kwb
  60. UBOOT_MAKE_TARGET += u-boot.kwb
  61. endif
  62. ifeq ($(BR2_TARGET_UBOOT_FORMAT_AIS),y)
  63. UBOOT_BINS += u-boot.ais
  64. UBOOT_MAKE_TARGET += u-boot.ais
  65. endif
  66. ifeq ($(BR2_TARGET_UBOOT_FORMAT_NAND_BIN),y)
  67. UBOOT_BINS += u-boot-nand.bin
  68. endif
  69. ifeq ($(BR2_TARGET_UBOOT_FORMAT_DTB_IMG),y)
  70. UBOOT_BINS += u-boot-dtb.img
  71. UBOOT_MAKE_TARGET += u-boot-dtb.img
  72. endif
  73. ifeq ($(BR2_TARGET_UBOOT_FORMAT_DTB_IMX),y)
  74. UBOOT_BINS += u-boot-dtb.imx
  75. UBOOT_MAKE_TARGET += u-boot-dtb.imx
  76. endif
  77. ifeq ($(BR2_TARGET_UBOOT_FORMAT_DTB_BIN),y)
  78. UBOOT_BINS += u-boot-dtb.bin
  79. UBOOT_MAKE_TARGET += u-boot-dtb.bin
  80. endif
  81. ifeq ($(BR2_TARGET_UBOOT_FORMAT_IMG),y)
  82. UBOOT_BINS += u-boot.img
  83. UBOOT_MAKE_TARGET += u-boot.img
  84. endif
  85. ifeq ($(BR2_TARGET_UBOOT_FORMAT_ITB),y)
  86. UBOOT_BINS += u-boot.itb
  87. ifneq ($(BR2_TARGET_UBOOT_USE_BINMAN),y)
  88. UBOOT_MAKE_TARGET += u-boot.itb
  89. endif
  90. endif
  91. ifeq ($(BR2_TARGET_UBOOT_FORMAT_QSPI_BIN),y)
  92. UBOOT_BINS += qspi.bin
  93. endif
  94. ifeq ($(BR2_TARGET_UBOOT_FORMAT_IMX),y)
  95. UBOOT_BINS += u-boot.imx
  96. UBOOT_MAKE_TARGET += u-boot.imx
  97. endif
  98. ifeq ($(BR2_TARGET_UBOOT_FORMAT_SB),y)
  99. UBOOT_BINS += u-boot.sb
  100. UBOOT_MAKE_TARGET += u-boot.sb
  101. # mxsimage needs OpenSSL
  102. UBOOT_DEPENDENCIES += host-elftosb host-openssl
  103. endif
  104. ifeq ($(BR2_TARGET_UBOOT_FORMAT_SD),y)
  105. # BootStream (.sb) is generated by U-Boot, we convert it to SD format
  106. UBOOT_BINS += u-boot.sd
  107. UBOOT_MAKE_TARGET += u-boot.sb
  108. UBOOT_DEPENDENCIES += host-elftosb host-openssl
  109. endif
  110. ifeq ($(BR2_TARGET_UBOOT_FORMAT_NAND),y)
  111. UBOOT_BINS += u-boot.nand
  112. UBOOT_MAKE_TARGET += u-boot.sb
  113. UBOOT_DEPENDENCIES += host-elftosb host-openssl
  114. endif
  115. ifeq ($(BR2_TARGET_UBOOT_FORMAT_STM32),y)
  116. UBOOT_BINS += u-boot.stm32
  117. ifeq ($(BR2_TARGET_UBOOT_BUILD_FORMAT_STM32_LEGACY),y)
  118. UBOOT_MAKE_TARGET += u-boot.stm32
  119. endif
  120. endif
  121. ifeq ($(BR2_TARGET_UBOOT_INITIAL_ENV),y)
  122. UBOOT_MAKE_TARGET += u-boot-initial-env
  123. define UBOOT_INSTALL_UBOOT_INITIAL_ENV
  124. $(INSTALL) -D -m 0644 $(@D)/u-boot-initial-env $(TARGET_DIR)/etc/u-boot-initial-env
  125. endef
  126. UBOOT_POST_INSTALL_TARGET_HOOKS += UBOOT_INSTALL_UBOOT_INITIAL_ENV
  127. endif
  128. ifeq ($(BR2_TARGET_UBOOT_FORMAT_CUSTOM),y)
  129. UBOOT_BINS += $(call qstrip,$(BR2_TARGET_UBOOT_FORMAT_CUSTOM_NAME))
  130. endif
  131. ifeq ($(BR2_TARGET_UBOOT_OMAP_IFT),y)
  132. UBOOT_BINS += u-boot.bin
  133. UBOOT_BIN_IFT = u-boot.bin.ift
  134. endif
  135. # The kernel calls AArch64 'arm64', but U-Boot calls it just 'arm', so
  136. # we have to special case it. Similar for i386/x86_64 -> x86
  137. ifeq ($(NORMALIZED_ARCH),arm64)
  138. UBOOT_ARCH = arm
  139. else ifneq ($(filter $(NORMALIZED_ARCH),i386 x86_64),)
  140. UBOOT_ARCH = x86
  141. else
  142. UBOOT_ARCH = $(NORMALIZED_ARCH)
  143. endif
  144. UBOOT_MAKE_OPTS += \
  145. CROSS_COMPILE="$(TARGET_CROSS)" \
  146. ARCH=$(UBOOT_ARCH) \
  147. HOSTCC="$(HOSTCC) $(subst -I/,-isystem /,$(subst -I /,-isystem /,$(HOST_CFLAGS)))" \
  148. HOSTLDFLAGS="$(HOST_LDFLAGS)" \
  149. $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_MAKEOPTS))
  150. # Disable FDPIC if enabled by default in toolchain
  151. ifeq ($(BR2_BINFMT_FDPIC),y)
  152. UBOOT_MAKE_OPTS += KCFLAGS=-mno-fdpic
  153. endif
  154. ifeq ($(BR2_TARGET_UBOOT_NEEDS_ATF_BL31),y)
  155. UBOOT_DEPENDENCIES += arm-trusted-firmware
  156. ifeq ($(BR2_TARGET_UBOOT_NEEDS_ATF_BL31_ELF),y)
  157. UBOOT_MAKE_OPTS += BL31=$(BINARIES_DIR)/bl31.elf
  158. define UBOOT_COPY_ATF_FIRMWARE
  159. cp $(BINARIES_DIR)/bl31.elf $(@D)/
  160. endef
  161. UBOOT_PRE_BUILD_HOOKS += UBOOT_COPY_ATF_FIRMWARE
  162. else
  163. UBOOT_MAKE_OPTS += BL31=$(BINARIES_DIR)/bl31.bin
  164. define UBOOT_COPY_ATF_FIRMWARE
  165. cp $(BINARIES_DIR)/bl31.bin $(@D)/
  166. endef
  167. UBOOT_PRE_BUILD_HOOKS += UBOOT_COPY_ATF_FIRMWARE
  168. endif
  169. endif
  170. ifeq ($(BR2_TARGET_UBOOT_NEEDS_OPTEE_TEE),y)
  171. UBOOT_DEPENDENCIES += optee-os
  172. ifeq ($(BR2_TARGET_UBOOT_NEEDS_OPTEE_TEE_ELF),y)
  173. UBOOT_MAKE_OPTS += TEE=$(BINARIES_DIR)/tee.elf
  174. else ifeq ($(BR2_TARGET_UBOOT_NEEDS_OPTEE_TEE_BIN),y)
  175. UBOOT_MAKE_OPTS += TEE=$(BINARIES_DIR)/tee.bin
  176. endif
  177. endif
  178. # TI K3 devices needs at least ti-sysfw (System Firmware) provided
  179. # by ti-k3-boot-firmware when built with u-boot's binman tool.
  180. # Some TI K3 devices using a split firmware boot flow (AM62,
  181. # j721e) also need the Device Manager (DM) firmware.
  182. ifeq ($(BR2_TARGET_TI_K3_BOOT_FIRMWARE),y)
  183. UBOOT_DEPENDENCIES += ti-k3-boot-firmware
  184. endif
  185. ifeq ($(BR2_TARGET_UBOOT_NEEDS_OPENSBI),y)
  186. UBOOT_DEPENDENCIES += opensbi
  187. UBOOT_MAKE_OPTS += OPENSBI=$(BINARIES_DIR)/fw_dynamic.bin
  188. endif
  189. # Mainline U-Boot versions can create the i.MX specific boot images
  190. # and need some NXP firmware blobs.
  191. ifeq ($(BR2_TARGET_UBOOT_NEEDS_IMX_FIRMWARE),y)
  192. UBOOT_DEPENDENCIES += firmware-imx
  193. UBOOT_IMX_FW_FILES = \
  194. $(if $(BR2_PACKAGE_FIRMWARE_IMX_NEEDS_HDMI_FW),signed_hdmi_imx8m.bin) \
  195. $(if $(BR2_PACKAGE_FIRMWARE_IMX_LPDDR4),lpddr4*.bin) \
  196. $(if $(BR2_PACKAGE_FIRMWARE_IMX_DDR4),ddr4*.bin) \
  197. $(if $(BR2_PACKAGE_FIRMWARE_IMX_DDR3),ddr3*.bin)
  198. define UBOOT_COPY_IMX_FW_FILES
  199. $(foreach fw,$(UBOOT_IMX_FW_FILES),\
  200. cp $(BINARIES_DIR)/$(fw) $(@D)/
  201. )
  202. endef
  203. UBOOT_PRE_BUILD_HOOKS += UBOOT_COPY_IMX_FW_FILES
  204. endif
  205. ifeq ($(BR2_TARGET_UBOOT_NEEDS_ROCKCHIP_RKBIN),y)
  206. UBOOT_DEPENDENCIES += rockchip-rkbin
  207. define UBOOT_INSTALL_UBOOT_ROCKCHIP_BIN
  208. $(INSTALL) -D -m 0644 $(@D)/u-boot-rockchip.bin $(BINARIES_DIR)/u-boot-rockchip.bin
  209. endef
  210. UBOOT_POST_INSTALL_IMAGES_HOOKS += UBOOT_INSTALL_UBOOT_ROCKCHIP_BIN
  211. ifneq ($(ROCKCHIP_RKBIN_BL31_FILENAME),)
  212. UBOOT_MAKE_OPTS += BL31=$(BINARIES_DIR)/$(notdir $(ROCKCHIP_RKBIN_BL31_FILENAME))
  213. endif
  214. ifneq ($(ROCKCHIP_RKBIN_TPL_FILENAME),)
  215. UBOOT_MAKE_OPTS += ROCKCHIP_TPL=$(BINARIES_DIR)/$(notdir $(ROCKCHIP_RKBIN_TPL_FILENAME))
  216. endif
  217. ifneq ($(ROCKCHIP_RKBIN_TEE_FILENAME),)
  218. UBOOT_MAKE_OPTS += TEE=$(BINARIES_DIR)/$(notdir $(ROCKCHIP_RKBIN_TEE_FILENAME))
  219. endif
  220. endif
  221. ifeq ($(BR2_TARGET_UBOOT_NEEDS_DTC),y)
  222. UBOOT_DEPENDENCIES += host-dtc
  223. UBOOT_MAKE_OPTS += DTC=$(HOST_DIR)/bin/dtc
  224. endif
  225. ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYTHON3),y)
  226. UBOOT_DEPENDENCIES += host-python3 host-python-setuptools
  227. endif
  228. ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYLIBFDT),y)
  229. UBOOT_DEPENDENCIES += host-python-pylibfdt
  230. endif
  231. ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYELFTOOLS),y)
  232. UBOOT_DEPENDENCIES += host-python-pyelftools
  233. endif
  234. ifeq ($(BR2_TARGET_UBOOT_NEEDS_OPENSSL),y)
  235. UBOOT_DEPENDENCIES += host-openssl
  236. endif
  237. ifeq ($(BR2_TARGET_UBOOT_NEEDS_LZOP),y)
  238. UBOOT_DEPENDENCIES += host-lzop
  239. endif
  240. ifeq ($(BR2_TARGET_UBOOT_NEEDS_GNUTLS),y)
  241. UBOOT_DEPENDENCIES += host-gnutls
  242. endif
  243. ifeq ($(BR2_TARGET_UBOOT_NEEDS_UTIL_LINUX),y)
  244. UBOOT_DEPENDENCIES += host-util-linux
  245. endif
  246. ifeq ($(BR2_TARGET_UBOOT_NEEDS_XXD),y)
  247. UBOOT_DEPENDENCIES += host-vim
  248. endif
  249. ifeq ($(BR2_TARGET_UBOOT_USE_BINMAN),y)
  250. # https://source.denx.de/u-boot/u-boot/-/blob/v2024.04/tools/binman/binman.rst?plain=1#L377
  251. # https://source.denx.de/u-boot/u-boot/-/blob/v2024.04/tools/buildman/requirements.txt
  252. UBOOT_DEPENDENCIES += \
  253. host-python-jsonschema \
  254. host-python-pyyaml \
  255. host-python-yamllint
  256. UBOOT_MAKE_OPTS += BINMAN_INDIRS=$(BINARIES_DIR)
  257. endif
  258. # prior to u-boot 2013.10 the license info was in COPYING. Copy it so
  259. # legal-info finds it
  260. define UBOOT_COPY_OLD_LICENSE_FILE
  261. if [ -f $(@D)/COPYING ]; then \
  262. $(INSTALL) -m 0644 -D $(@D)/COPYING $(@D)/Licenses/gpl-2.0.txt; \
  263. fi
  264. endef
  265. UBOOT_POST_EXTRACT_HOOKS += UBOOT_COPY_OLD_LICENSE_FILE
  266. UBOOT_POST_RSYNC_HOOKS += UBOOT_COPY_OLD_LICENSE_FILE
  267. # Older versions break on gcc 10+ because of redefined symbols
  268. define UBOOT_DROP_YYLLOC
  269. $(Q)grep -Z -l -r -E '^YYLTYPE yylloc;$$' $(@D) \
  270. |xargs -0 -r $(SED) '/^YYLTYPE yylloc;$$/d'
  271. endef
  272. UBOOT_POST_PATCH_HOOKS += UBOOT_DROP_YYLLOC
  273. ifneq ($(ARCH_XTENSA_OVERLAY_FILE),)
  274. define UBOOT_XTENSA_OVERLAY_EXTRACT
  275. $(call arch-xtensa-overlay-extract,$(@D),u-boot)
  276. endef
  277. UBOOT_POST_EXTRACT_HOOKS += UBOOT_XTENSA_OVERLAY_EXTRACT
  278. UBOOT_EXTRA_DOWNLOADS += $(ARCH_XTENSA_OVERLAY_URL)
  279. endif
  280. # Analogous code exists in linux/linux.mk. Basically, the generic
  281. # package infrastructure handles downloading and applying remote
  282. # patches. Local patches are handled depending on whether they are
  283. # directories or files.
  284. UBOOT_PATCHES = $(call qstrip,$(BR2_TARGET_UBOOT_PATCH))
  285. UBOOT_PATCH = $(filter ftp://% http://% https://%,$(UBOOT_PATCHES))
  286. define UBOOT_APPLY_LOCAL_PATCHES
  287. for p in $(filter-out ftp://% http://% https://%,$(UBOOT_PATCHES)) ; do \
  288. if test -d $$p ; then \
  289. $(APPLY_PATCHES) $(@D) $$p \*.patch || exit 1 ; \
  290. else \
  291. $(APPLY_PATCHES) $(@D) `dirname $$p` `basename $$p` || exit 1; \
  292. fi \
  293. done
  294. endef
  295. UBOOT_POST_PATCH_HOOKS += UBOOT_APPLY_LOCAL_PATCHES
  296. # Fixup inclusion of libfdt headers, which can fail in older u-boot versions
  297. # when libfdt-devel is installed system-wide.
  298. # The core change is equivalent to upstream commit
  299. # e0d20dc1521e74b82dbd69be53a048847798a90a (first in v2018.03). However, the fixup
  300. # is complicated by the fact that the underlying u-boot code changed multiple
  301. # times in history:
  302. # - The directory scripts/dtc/libfdt only exists since upstream commit
  303. # c0e032e0090d6541549b19cc47e06ccd1f302893 (first in v2017.11). For earlier
  304. # versions, create a dummy scripts/dtc/libfdt directory with symlinks for the
  305. # fdt-related files. This allows to use the same -I<path> option for both
  306. # cases.
  307. # - The variable 'srctree' used to be called 'SRCTREE' before upstream commit
  308. # 01286329b27b27eaeda045b469d41b1d9fce545a (first in v2014.04).
  309. # - The original location for libfdt, 'lib/libfdt/', used to be simply
  310. # 'libfdt' before upstream commit 0de71d507157c4bd4fddcd3a419140d2b986eed2
  311. # (first in v2010.06). Make the 'lib' part optional in the substitution to
  312. # handle this.
  313. define UBOOT_FIXUP_LIBFDT_INCLUDE
  314. $(Q)if [ ! -d $(@D)/scripts/dtc/libfdt ]; then \
  315. mkdir -p $(@D)/scripts/dtc/libfdt; \
  316. cd $(@D)/scripts/dtc/libfdt; \
  317. ln -s ../../../include/fdt.h .; \
  318. ln -s ../../../include/libfdt*.h .; \
  319. ln -s ../../../lib/libfdt/libfdt_internal.h .; \
  320. fi
  321. $(Q)$(SED) \
  322. 's%-I\ *\$$(srctree)/lib/libfdt%-I$$(srctree)/scripts/dtc/libfdt%; \
  323. s%-I\ *\$$(SRCTREE)\(/lib\)\?/libfdt%-I$$(SRCTREE)/scripts/dtc/libfdt%' \
  324. $(@D)/tools/Makefile
  325. endef
  326. UBOOT_POST_PATCH_HOOKS += UBOOT_FIXUP_LIBFDT_INCLUDE
  327. ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY),y)
  328. define UBOOT_CONFIGURE_CMDS
  329. $(TARGET_CONFIGURE_OPTS) \
  330. $(UBOOT_MAKE) -C $(@D) $(UBOOT_MAKE_OPTS) \
  331. $(UBOOT_BOARD_NAME)_config
  332. endef
  333. else ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_KCONFIG),y)
  334. ifeq ($(BR2_TARGET_UBOOT_USE_DEFCONFIG),y)
  335. UBOOT_KCONFIG_DEFCONFIG = $(call qstrip,$(BR2_TARGET_UBOOT_BOARD_DEFCONFIG))_defconfig
  336. else ifeq ($(BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG),y)
  337. UBOOT_KCONFIG_FILE = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE))
  338. endif # BR2_TARGET_UBOOT_USE_DEFCONFIG
  339. UBOOT_KCONFIG_FRAGMENT_FILES = $(call qstrip,$(BR2_TARGET_UBOOT_CONFIG_FRAGMENT_FILES))
  340. UBOOT_KCONFIG_EDITORS = menuconfig xconfig gconfig nconfig
  341. # UBOOT_MAKE_OPTS overrides HOSTCC / HOSTLDFLAGS to allow the build to
  342. # find our host-openssl. However, this triggers a bug in the kconfig
  343. # build script that causes it to build with /usr/include/ncurses.h
  344. # (which is typically wchar) but link with
  345. # $(HOST_DIR)/lib/libncurses.so (which is not). We don't actually
  346. # need any host-package for kconfig, so remove the HOSTCC/HOSTLDFLAGS
  347. # override again. In addition, host-ccache is not ready at kconfig
  348. # time, so use HOSTCC_NOCCACHE.
  349. UBOOT_KCONFIG_OPTS = $(UBOOT_MAKE_OPTS) HOSTCC="$(HOSTCC_NOCCACHE)" HOSTLDFLAGS=""
  350. ifeq ($(BR2_TARGET_UBOOT_DEFAULT_ENV_FILE_ENABLED),y)
  351. UBOOT_DEFAULT_ENV_FILE = $(call qstrip,$(BR2_TARGET_UBOOT_DEFAULT_ENV_FILE))
  352. define UBOOT_KCONFIG_DEFAULT_ENV_FILE
  353. $(call KCONFIG_SET_OPT,CONFIG_USE_DEFAULT_ENV_FILE,y)
  354. $(call KCONFIG_SET_OPT,CONFIG_DEFAULT_ENV_FILE,"$(shell readlink -f $(UBOOT_DEFAULT_ENV_FILE))")
  355. endef
  356. endif
  357. endif # BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY
  358. UBOOT_CUSTOM_DTS_PATH = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_DTS_PATH))
  359. define UBOOT_BUILD_CMDS
  360. $(if $(UBOOT_CUSTOM_DTS_PATH),
  361. cp -f $(UBOOT_CUSTOM_DTS_PATH) $(@D)/arch/$(UBOOT_ARCH)/dts/
  362. )
  363. $(TARGET_CONFIGURE_OPTS) \
  364. PKG_CONFIG="$(PKG_CONFIG_HOST_BINARY)" \
  365. PKG_CONFIG_SYSROOT_DIR="/" \
  366. PKG_CONFIG_ALLOW_SYSTEM_CFLAGS=1 \
  367. PKG_CONFIG_ALLOW_SYSTEM_LIBS=1 \
  368. PKG_CONFIG_LIBDIR="$(HOST_DIR)/lib/pkgconfig:$(HOST_DIR)/share/pkgconfig" \
  369. $(UBOOT_MAKE) -C $(@D) $(UBOOT_MAKE_OPTS) \
  370. $(UBOOT_MAKE_TARGET)
  371. $(if $(BR2_TARGET_UBOOT_FORMAT_SD),
  372. $(@D)/tools/mxsboot sd $(@D)/u-boot.sb $(@D)/u-boot.sd)
  373. $(if $(BR2_TARGET_UBOOT_FORMAT_NAND),
  374. $(@D)/tools/mxsboot \
  375. -w $(BR2_TARGET_UBOOT_FORMAT_NAND_PAGE_SIZE) \
  376. -o $(BR2_TARGET_UBOOT_FORMAT_NAND_OOB_SIZE) \
  377. -e $(BR2_TARGET_UBOOT_FORMAT_NAND_ERASE_SIZE) \
  378. nand $(@D)/u-boot.sb $(@D)/u-boot.nand)
  379. endef
  380. define UBOOT_BUILD_OMAP_IFT
  381. $(HOST_DIR)/bin/gpsign -f $(@D)/u-boot.bin \
  382. -c $(call qstrip,$(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG))
  383. endef
  384. define UBOOT_INSTALL_IMAGES_CMDS
  385. $(foreach f,$(UBOOT_BINS), \
  386. cp -dpf $(@D)/$(f) $(BINARIES_DIR)/
  387. )
  388. $(if $(BR2_TARGET_UBOOT_FORMAT_NAND),
  389. cp -dpf $(@D)/u-boot.sb $(BINARIES_DIR))
  390. $(if $(BR2_TARGET_UBOOT_SPL),
  391. $(foreach f,$(call qstrip,$(BR2_TARGET_UBOOT_SPL_NAME)), \
  392. cp -dpf $(@D)/$(f) $(BINARIES_DIR)/
  393. )
  394. )
  395. endef
  396. ifeq ($(BR2_TARGET_UBOOT_ZYNQMP),y)
  397. ifeq ($(BR2_TARGET_UBOOT_ZYNQMP_PMUFW_EMBEDDEDSW),y)
  398. UBOOT_DEPENDENCIES += xilinx-embeddedsw
  399. UBOOT_ZYNQMP_PMUFW_PATH = $(BINARIES_DIR)/pmufw.elf
  400. else ifeq ($(BR2_TARGET_UBOOT_ZYNQMP_PMUFW_PREBUILT),y)
  401. UBOOT_DEPENDENCIES += xilinx-prebuilt
  402. UBOOT_ZYNQMP_PMUFW_PATH = $(BINARIES_DIR)/pmufw.elf
  403. else
  404. UBOOT_ZYNQMP_PMUFW = $(call qstrip,$(BR2_TARGET_UBOOT_ZYNQMP_PMUFW))
  405. ifneq ($(findstring ://,$(UBOOT_ZYNQMP_PMUFW)),)
  406. UBOOT_EXTRA_DOWNLOADS += $(UBOOT_ZYNQMP_PMUFW)
  407. BR_NO_CHECK_HASH_FOR += $(notdir $(UBOOT_ZYNQMP_PMUFW))
  408. UBOOT_ZYNQMP_PMUFW_PATH = $(UBOOT_DL_DIR)/$(notdir $(UBOOT_ZYNQMP_PMUFW))
  409. else ifneq ($(UBOOT_ZYNQMP_PMUFW),)
  410. UBOOT_ZYNQMP_PMUFW_PATH = $(shell readlink -f $(UBOOT_ZYNQMP_PMUFW))
  411. endif #ifneq ($(findstring ://,$(UBOOT_ZYNQMP_PMUFW)),)
  412. endif #BR2_TARGET_UBOOT_ZYNQMP_PMUFW_PREBUILT
  413. ifeq ($(suffix $(UBOOT_ZYNQMP_PMUFW_PATH)),.elf)
  414. UBOOT_ZYNQMP_PMUFW_PATH_FINAL = $(basename $(UBOOT_ZYNQMP_PMUFW_PATH)).bin
  415. # objcopy is arch-agnostic so we can use $(TARGET_OBJCOPY) in lack of a
  416. # microblaze objcopy
  417. define UBOOT_ZYNQMP_PMUFW_CONVERT
  418. $(TARGET_OBJCOPY) -O binary -I elf32-little $(UBOOT_ZYNQMP_PMUFW_PATH) $(UBOOT_ZYNQMP_PMUFW_PATH_FINAL)
  419. endef
  420. UBOOT_PRE_BUILD_HOOKS += UBOOT_ZYNQMP_PMUFW_CONVERT
  421. else
  422. UBOOT_ZYNQMP_PMUFW_PATH_FINAL = $(UBOOT_ZYNQMP_PMUFW_PATH)
  423. endif
  424. define UBOOT_ZYNQMP_KCONFIG_PMUFW
  425. $(call KCONFIG_SET_OPT,CONFIG_PMUFW_INIT_FILE,"$(UBOOT_ZYNQMP_PMUFW_PATH_FINAL)")
  426. endef
  427. UBOOT_ZYNQMP_PM_CFG = $(call qstrip,$(BR2_TARGET_UBOOT_ZYNQMP_PM_CFG))
  428. ifneq ($(UBOOT_ZYNQMP_PM_CFG),)
  429. UBOOT_ZYNQMP_PM_CFG_BIN = $(UBOOT_DIR)/pm_cfg_obj.bin
  430. define UBOOT_ZYNQMP_KCONFIG_PM_CFG
  431. $(call KCONFIG_SET_OPT,CONFIG_ZYNQMP_SPL_PM_CFG_OBJ_FILE,"$(UBOOT_ZYNQMP_PM_CFG_BIN)", \
  432. $(@D)/.config)
  433. endef
  434. define UBOOT_ZYNQMP_PM_CFG_CONVERT
  435. $(UBOOT_DIR)/tools/zynqmp_pm_cfg_obj_convert.py \
  436. "$(UBOOT_ZYNQMP_PM_CFG)" \
  437. "$(UBOOT_ZYNQMP_PM_CFG_BIN)"
  438. endef
  439. UBOOT_PRE_BUILD_HOOKS += UBOOT_ZYNQMP_PM_CFG_CONVERT
  440. endif
  441. UBOOT_ZYNQMP_PSU_INIT = $(call qstrip,$(BR2_TARGET_UBOOT_ZYNQMP_PSU_INIT_FILE))
  442. UBOOT_ZYNQMP_PSU_INIT_PATH = $(shell readlink -f $(UBOOT_ZYNQMP_PSU_INIT))
  443. ifneq ($(UBOOT_ZYNQMP_PSU_INIT),)
  444. define UBOOT_ZYNQMP_KCONFIG_PSU_INIT
  445. $(call KCONFIG_SET_OPT,CONFIG_XILINX_PS_INIT_FILE,"$(UBOOT_ZYNQMP_PSU_INIT_PATH)")
  446. endef
  447. endif
  448. endif # BR2_TARGET_UBOOT_ZYNQMP
  449. define UBOOT_INSTALL_OMAP_IFT_IMAGE
  450. cp -dpf $(@D)/$(UBOOT_BIN_IFT) $(BINARIES_DIR)/
  451. endef
  452. ifeq ($(BR2_TARGET_UBOOT_OMAP_IFT),y)
  453. ifeq ($(BR_BUILDING),y)
  454. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG)),)
  455. $(error No gpsign config file. Check your BR2_TARGET_UBOOT_OMAP_IFT_CONFIG setting)
  456. endif
  457. ifeq ($(wildcard $(call qstrip,$(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG))),)
  458. $(error gpsign config file $(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG) not found. Check your BR2_TARGET_UBOOT_OMAP_IFT_CONFIG setting)
  459. endif
  460. endif
  461. UBOOT_DEPENDENCIES += host-omap-u-boot-utils
  462. UBOOT_POST_BUILD_HOOKS += UBOOT_BUILD_OMAP_IFT
  463. UBOOT_POST_INSTALL_IMAGES_HOOKS += UBOOT_INSTALL_OMAP_IFT_IMAGE
  464. endif
  465. ifeq ($(BR2_TARGET_UBOOT_ALTERA_SOCFPGA_IMAGE_CRC),y)
  466. ifeq ($(BR2_TARGET_UBOOT_SPL),y)
  467. UBOOT_CRC_ALTERA_SOCFPGA_INPUT_IMAGES = $(call qstrip,$(BR2_TARGET_UBOOT_SPL_NAME))
  468. UBOOT_CRC_ALTERA_SOCFPGA_HEADER_VERSION = 0
  469. else
  470. UBOOT_CRC_ALTERA_SOCFPGA_INPUT_IMAGES = u-boot-dtb.bin
  471. UBOOT_CRC_ALTERA_SOCFPGA_HEADER_VERSION = 1
  472. endif
  473. define UBOOT_CRC_ALTERA_SOCFPGA_IMAGE
  474. $(foreach f,$(UBOOT_CRC_ALTERA_SOCFPGA_INPUT_IMAGES), \
  475. $(HOST_DIR)/bin/mkpimage \
  476. -v $(UBOOT_CRC_ALTERA_SOCFPGA_HEADER_VERSION) \
  477. -o $(BINARIES_DIR)/$(notdir $(call qstrip,$(f))).crc \
  478. $(@D)/$(call qstrip,$(f))
  479. )
  480. endef
  481. UBOOT_DEPENDENCIES += host-mkpimage
  482. UBOOT_POST_INSTALL_IMAGES_HOOKS += UBOOT_CRC_ALTERA_SOCFPGA_IMAGE
  483. endif
  484. define UBOOT_KCONFIG_FIXUP_CMDS
  485. $(UBOOT_ZYNQMP_KCONFIG_PMUFW)
  486. $(UBOOT_ZYNQMP_KCONFIG_PM_CFG)
  487. $(UBOOT_ZYNQMP_KCONFIG_PSU_INIT)
  488. $(UBOOT_KCONFIG_DEFAULT_ENV_FILE)
  489. endef
  490. ifeq ($(BR2_TARGET_UBOOT)$(BR_BUILDING),yy)
  491. #
  492. # Check U-Boot board name (for legacy) or the defconfig/custom config
  493. # file options (for kconfig)
  494. #
  495. ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY),y)
  496. ifeq ($(UBOOT_BOARD_NAME),)
  497. $(error No U-Boot board name set. Check your BR2_TARGET_UBOOT_BOARDNAME setting)
  498. endif # UBOOT_BOARD_NAME
  499. else ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_KCONFIG),y)
  500. ifeq ($(BR2_TARGET_UBOOT_USE_DEFCONFIG),y)
  501. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_BOARD_DEFCONFIG)),)
  502. $(error No board defconfig name specified, check your BR2_TARGET_UBOOT_BOARD_DEFCONFIG setting)
  503. endif # qstrip BR2_TARGET_UBOOT_BOARD_DEFCONFIG
  504. endif # BR2_TARGET_UBOOT_USE_DEFCONFIG
  505. ifeq ($(BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG),y)
  506. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE)),)
  507. $(error No board configuration file specified, check your BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE setting)
  508. endif # qstrip BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE
  509. endif # BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG
  510. endif # BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY
  511. #
  512. # Check custom version option
  513. #
  514. ifeq ($(BR2_TARGET_UBOOT_CUSTOM_VERSION),y)
  515. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_VERSION_VALUE)),)
  516. $(error No custom U-Boot version specified. Check your BR2_TARGET_UBOOT_CUSTOM_VERSION_VALUE setting)
  517. endif # qstrip BR2_TARGET_UBOOT_CUSTOM_VERSION_VALUE
  518. endif # BR2_TARGET_UBOOT_CUSTOM_VERSION
  519. #
  520. # Check custom tarball option
  521. #
  522. ifeq ($(BR2_TARGET_UBOOT_CUSTOM_TARBALL),y)
  523. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_TARBALL_LOCATION)),)
  524. $(error No custom U-Boot tarball specified. Check your BR2_TARGET_UBOOT_CUSTOM_TARBALL_LOCATION setting)
  525. endif # qstrip BR2_TARGET_UBOOT_CUSTOM_TARBALL_LOCATION
  526. endif # BR2_TARGET_UBOOT_CUSTOM_TARBALL
  527. #
  528. # Check Git/Mercurial repo options
  529. #
  530. ifeq ($(BR2_TARGET_UBOOT_CUSTOM_GIT)$(BR2_TARGET_UBOOT_CUSTOM_HG),y)
  531. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_URL)),)
  532. $(error No custom U-Boot repository URL specified. Check your BR2_TARGET_UBOOT_CUSTOM_REPO_URL setting)
  533. endif # qstrip BR2_TARGET_UBOOT_CUSTOM_CUSTOM_REPO_URL
  534. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_VERSION)),)
  535. $(error No custom U-Boot repository version specified. Check your BR2_TARGET_UBOOT_CUSTOM_REPO_VERSION setting)
  536. endif # qstrip BR2_TARGET_UBOOT_CUSTOM_CUSTOM_REPO_VERSION
  537. endif # BR2_TARGET_UBOOT_CUSTOM_GIT || BR2_TARGET_UBOOT_CUSTOM_HG
  538. endif # BR2_TARGET_UBOOT && BR_BUILDING
  539. ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY),y)
  540. UBOOT_DEPENDENCIES += \
  541. $(BR2_BISON_HOST_DEPENDENCY) \
  542. $(BR2_FLEX_HOST_DEPENDENCY)
  543. $(eval $(generic-package))
  544. else ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_KCONFIG),y)
  545. UBOOT_MAKE_ENV = $(TARGET_MAKE_ENV)
  546. # Starting with 2021.10, the kconfig in uboot calls the cross-compiler
  547. # to check its capabilities. So we need the toolchain before we can
  548. # call the configurators.
  549. UBOOT_KCONFIG_DEPENDENCIES += \
  550. toolchain \
  551. $(BR2_MAKE_HOST_DEPENDENCY) \
  552. $(BR2_BISON_HOST_DEPENDENCY) \
  553. $(BR2_FLEX_HOST_DEPENDENCY)
  554. $(eval $(kconfig-package))
  555. endif # BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY