uboot.mk 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508
  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 ($(UBOOT_VERSION),custom)
  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 debuging on ARC use special target
  49. ifeq ($(BR2_arc),y)
  50. UBOOT_MAKE_TARGET += mdbtrick
  51. endif
  52. endif
  53. # Call 'make all' unconditionally
  54. UBOOT_MAKE_TARGET += all
  55. ifeq ($(BR2_TARGET_UBOOT_FORMAT_KWB),y)
  56. UBOOT_BINS += u-boot.kwb
  57. UBOOT_MAKE_TARGET += u-boot.kwb
  58. endif
  59. ifeq ($(BR2_TARGET_UBOOT_FORMAT_AIS),y)
  60. UBOOT_BINS += u-boot.ais
  61. UBOOT_MAKE_TARGET += u-boot.ais
  62. endif
  63. ifeq ($(BR2_TARGET_UBOOT_FORMAT_NAND_BIN),y)
  64. UBOOT_BINS += u-boot-nand.bin
  65. endif
  66. ifeq ($(BR2_TARGET_UBOOT_FORMAT_DTB_IMG),y)
  67. UBOOT_BINS += u-boot-dtb.img
  68. UBOOT_MAKE_TARGET += u-boot-dtb.img
  69. endif
  70. ifeq ($(BR2_TARGET_UBOOT_FORMAT_DTB_IMX),y)
  71. UBOOT_BINS += u-boot-dtb.imx
  72. UBOOT_MAKE_TARGET += u-boot-dtb.imx
  73. endif
  74. ifeq ($(BR2_TARGET_UBOOT_FORMAT_DTB_BIN),y)
  75. UBOOT_BINS += u-boot-dtb.bin
  76. UBOOT_MAKE_TARGET += u-boot-dtb.bin
  77. endif
  78. ifeq ($(BR2_TARGET_UBOOT_FORMAT_IMG),y)
  79. UBOOT_BINS += u-boot.img
  80. UBOOT_MAKE_TARGET += u-boot.img
  81. endif
  82. ifeq ($(BR2_TARGET_UBOOT_FORMAT_ITB),y)
  83. UBOOT_BINS += u-boot.itb
  84. UBOOT_MAKE_TARGET += u-boot.itb
  85. endif
  86. ifeq ($(BR2_TARGET_UBOOT_FORMAT_IMX),y)
  87. UBOOT_BINS += u-boot.imx
  88. UBOOT_MAKE_TARGET += u-boot.imx
  89. endif
  90. ifeq ($(BR2_TARGET_UBOOT_FORMAT_SB),y)
  91. UBOOT_BINS += u-boot.sb
  92. UBOOT_MAKE_TARGET += u-boot.sb
  93. # mxsimage needs OpenSSL
  94. UBOOT_DEPENDENCIES += host-elftosb host-openssl
  95. endif
  96. ifeq ($(BR2_TARGET_UBOOT_FORMAT_SD),y)
  97. # BootStream (.sb) is generated by U-Boot, we convert it to SD format
  98. UBOOT_BINS += u-boot.sd
  99. UBOOT_MAKE_TARGET += u-boot.sb
  100. UBOOT_DEPENDENCIES += host-elftosb host-openssl
  101. endif
  102. ifeq ($(BR2_TARGET_UBOOT_FORMAT_NAND),y)
  103. UBOOT_BINS += u-boot.nand
  104. UBOOT_MAKE_TARGET += u-boot.sb
  105. UBOOT_DEPENDENCIES += host-elftosb host-openssl
  106. endif
  107. ifeq ($(BR2_TARGET_UBOOT_FORMAT_STM32),y)
  108. UBOOT_BINS += u-boot.stm32
  109. UBOOT_MAKE_TARGET += u-boot.stm32
  110. endif
  111. ifeq ($(BR2_TARGET_UBOOT_FORMAT_CUSTOM),y)
  112. UBOOT_BINS += $(call qstrip,$(BR2_TARGET_UBOOT_FORMAT_CUSTOM_NAME))
  113. endif
  114. ifeq ($(BR2_TARGET_UBOOT_OMAP_IFT),y)
  115. UBOOT_BINS += u-boot.bin
  116. UBOOT_BIN_IFT = u-boot.bin.ift
  117. endif
  118. # The kernel calls AArch64 'arm64', but U-Boot calls it just 'arm', so
  119. # we have to special case it. Similar for i386/x86_64 -> x86
  120. ifeq ($(KERNEL_ARCH),arm64)
  121. UBOOT_ARCH = arm
  122. else ifneq ($(filter $(KERNEL_ARCH),i386 x86_64),)
  123. UBOOT_ARCH = x86
  124. else
  125. UBOOT_ARCH = $(KERNEL_ARCH)
  126. endif
  127. UBOOT_MAKE_OPTS += \
  128. CROSS_COMPILE="$(TARGET_CROSS)" \
  129. ARCH=$(UBOOT_ARCH) \
  130. HOSTCC="$(HOSTCC) $(subst -I/,-isystem /,$(subst -I /,-isystem /,$(HOST_CFLAGS)))" \
  131. HOSTLDFLAGS="$(HOST_LDFLAGS)" \
  132. $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_MAKEOPTS))
  133. ifeq ($(BR2_TARGET_UBOOT_NEEDS_ATF_BL31),y)
  134. UBOOT_DEPENDENCIES += arm-trusted-firmware
  135. ifeq ($(BR2_TARGET_UBOOT_NEEDS_ATF_BL31_ELF),y)
  136. UBOOT_MAKE_OPTS += BL31=$(BINARIES_DIR)/bl31.elf
  137. else
  138. UBOOT_MAKE_OPTS += BL31=$(BINARIES_DIR)/bl31.bin
  139. endif
  140. endif
  141. ifeq ($(BR2_TARGET_UBOOT_NEEDS_OPENSBI),y)
  142. UBOOT_DEPENDENCIES += opensbi
  143. UBOOT_MAKE_OPTS += OPENSBI=$(BINARIES_DIR)/fw_dynamic.bin
  144. endif
  145. ifeq ($(BR2_TARGET_UBOOT_NEEDS_DTC),y)
  146. UBOOT_DEPENDENCIES += host-dtc
  147. endif
  148. ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYTHON2),y)
  149. UBOOT_DEPENDENCIES += host-python host-python-setuptools
  150. else ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYTHON3),y)
  151. UBOOT_DEPENDENCIES += host-python3 host-python3-setuptools
  152. endif
  153. ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYLIBFDT),y)
  154. UBOOT_DEPENDENCIES += host-swig
  155. endif
  156. ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYELFTOOLS),y)
  157. ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYTHON2),y)
  158. UBOOT_DEPENDENCIES += host-python-pyelftools
  159. else ifeq ($(BR2_TARGET_UBOOT_NEEDS_PYTHON3),y)
  160. UBOOT_DEPENDENCIES += host-python3-pyelftools
  161. endif
  162. endif
  163. ifeq ($(BR2_TARGET_UBOOT_NEEDS_OPENSSL),y)
  164. UBOOT_DEPENDENCIES += host-openssl
  165. endif
  166. ifeq ($(BR2_TARGET_UBOOT_NEEDS_LZOP),y)
  167. UBOOT_DEPENDENCIES += host-lzop
  168. endif
  169. # prior to u-boot 2013.10 the license info was in COPYING. Copy it so
  170. # legal-info finds it
  171. define UBOOT_COPY_OLD_LICENSE_FILE
  172. if [ -f $(@D)/COPYING ]; then \
  173. $(INSTALL) -m 0644 -D $(@D)/COPYING $(@D)/Licenses/gpl-2.0.txt; \
  174. fi
  175. endef
  176. UBOOT_POST_EXTRACT_HOOKS += UBOOT_COPY_OLD_LICENSE_FILE
  177. UBOOT_POST_RSYNC_HOOKS += UBOOT_COPY_OLD_LICENSE_FILE
  178. ifneq ($(ARCH_XTENSA_OVERLAY_FILE),)
  179. define UBOOT_XTENSA_OVERLAY_EXTRACT
  180. $(call arch-xtensa-overlay-extract,$(@D),u-boot)
  181. endef
  182. UBOOT_POST_EXTRACT_HOOKS += UBOOT_XTENSA_OVERLAY_EXTRACT
  183. UBOOT_EXTRA_DOWNLOADS += $(ARCH_XTENSA_OVERLAY_URL)
  184. endif
  185. # Analogous code exists in linux/linux.mk. Basically, the generic
  186. # package infrastructure handles downloading and applying remote
  187. # patches. Local patches are handled depending on whether they are
  188. # directories or files.
  189. UBOOT_PATCHES = $(call qstrip,$(BR2_TARGET_UBOOT_PATCH))
  190. UBOOT_PATCH = $(filter ftp://% http://% https://%,$(UBOOT_PATCHES))
  191. define UBOOT_APPLY_LOCAL_PATCHES
  192. for p in $(filter-out ftp://% http://% https://%,$(UBOOT_PATCHES)) ; do \
  193. if test -d $$p ; then \
  194. $(APPLY_PATCHES) $(@D) $$p \*.patch || exit 1 ; \
  195. else \
  196. $(APPLY_PATCHES) $(@D) `dirname $$p` `basename $$p` || exit 1; \
  197. fi \
  198. done
  199. endef
  200. UBOOT_POST_PATCH_HOOKS += UBOOT_APPLY_LOCAL_PATCHES
  201. # Fixup inclusion of libfdt headers, which can fail in older u-boot versions
  202. # when libfdt-devel is installed system-wide.
  203. # The core change is equivalent to upstream commit
  204. # e0d20dc1521e74b82dbd69be53a048847798a90a (first in v2018.03). However, the fixup
  205. # is complicated by the fact that the underlying u-boot code changed multiple
  206. # times in history:
  207. # - The directory scripts/dtc/libfdt only exists since upstream commit
  208. # c0e032e0090d6541549b19cc47e06ccd1f302893 (first in v2017.11). For earlier
  209. # versions, create a dummy scripts/dtc/libfdt directory with symlinks for the
  210. # fdt-related files. This allows to use the same -I<path> option for both
  211. # cases.
  212. # - The variable 'srctree' used to be called 'SRCTREE' before upstream commit
  213. # 01286329b27b27eaeda045b469d41b1d9fce545a (first in v2014.04).
  214. # - The original location for libfdt, 'lib/libfdt/', used to be simply
  215. # 'libfdt' before upstream commit 0de71d507157c4bd4fddcd3a419140d2b986eed2
  216. # (first in v2010.06). Make the 'lib' part optional in the substitution to
  217. # handle this.
  218. define UBOOT_FIXUP_LIBFDT_INCLUDE
  219. $(Q)if [ ! -d $(@D)/scripts/dtc/libfdt ]; then \
  220. mkdir -p $(@D)/scripts/dtc/libfdt; \
  221. cd $(@D)/scripts/dtc/libfdt; \
  222. ln -s ../../../include/fdt.h .; \
  223. ln -s ../../../include/libfdt*.h .; \
  224. ln -s ../../../lib/libfdt/libfdt_internal.h .; \
  225. fi
  226. $(Q)$(SED) \
  227. 's%-I\ *\$$(srctree)/lib/libfdt%-I$$(srctree)/scripts/dtc/libfdt%; \
  228. s%-I\ *\$$(SRCTREE)\(/lib\)\?/libfdt%-I$$(SRCTREE)/scripts/dtc/libfdt%' \
  229. $(@D)/tools/Makefile
  230. endef
  231. UBOOT_POST_PATCH_HOOKS += UBOOT_FIXUP_LIBFDT_INCLUDE
  232. ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY),y)
  233. define UBOOT_CONFIGURE_CMDS
  234. $(TARGET_CONFIGURE_OPTS) \
  235. $(UBOOT_MAKE) -C $(@D) $(UBOOT_MAKE_OPTS) \
  236. $(UBOOT_BOARD_NAME)_config
  237. endef
  238. else ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_KCONFIG),y)
  239. ifeq ($(BR2_TARGET_UBOOT_USE_DEFCONFIG),y)
  240. UBOOT_KCONFIG_DEFCONFIG = $(call qstrip,$(BR2_TARGET_UBOOT_BOARD_DEFCONFIG))_defconfig
  241. else ifeq ($(BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG),y)
  242. UBOOT_KCONFIG_FILE = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE))
  243. endif # BR2_TARGET_UBOOT_USE_DEFCONFIG
  244. UBOOT_KCONFIG_FRAGMENT_FILES = $(call qstrip,$(BR2_TARGET_UBOOT_CONFIG_FRAGMENT_FILES))
  245. UBOOT_KCONFIG_EDITORS = menuconfig xconfig gconfig nconfig
  246. # UBOOT_MAKE_OPTS overrides HOSTCC / HOSTLDFLAGS to allow the build to
  247. # find our host-openssl. However, this triggers a bug in the kconfig
  248. # build script that causes it to build with /usr/include/ncurses.h
  249. # (which is typically wchar) but link with
  250. # $(HOST_DIR)/lib/libncurses.so (which is not). We don't actually
  251. # need any host-package for kconfig, so remove the HOSTCC/HOSTLDFLAGS
  252. # override again. In addition, host-ccache is not ready at kconfig
  253. # time, so use HOSTCC_NOCCACHE.
  254. UBOOT_KCONFIG_OPTS = $(UBOOT_MAKE_OPTS) HOSTCC="$(HOSTCC_NOCCACHE)" HOSTLDFLAGS=""
  255. endif # BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY
  256. UBOOT_CUSTOM_DTS_PATH = $(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_DTS_PATH))
  257. define UBOOT_BUILD_CMDS
  258. $(if $(UBOOT_CUSTOM_DTS_PATH),
  259. cp -f $(UBOOT_CUSTOM_DTS_PATH) $(@D)/arch/$(UBOOT_ARCH)/dts/
  260. )
  261. $(TARGET_CONFIGURE_OPTS) \
  262. PKG_CONFIG="$(PKG_CONFIG_HOST_BINARY)" \
  263. PKG_CONFIG_SYSROOT_DIR="/" \
  264. PKG_CONFIG_ALLOW_SYSTEM_CFLAGS=1 \
  265. PKG_CONFIG_ALLOW_SYSTEM_LIBS=1 \
  266. PKG_CONFIG_LIBDIR="$(HOST_DIR)/lib/pkgconfig:$(HOST_DIR)/share/pkgconfig" \
  267. $(UBOOT_MAKE) -C $(@D) $(UBOOT_MAKE_OPTS) \
  268. $(UBOOT_MAKE_TARGET)
  269. $(if $(BR2_TARGET_UBOOT_FORMAT_SD),
  270. $(@D)/tools/mxsboot sd $(@D)/u-boot.sb $(@D)/u-boot.sd)
  271. $(if $(BR2_TARGET_UBOOT_FORMAT_NAND),
  272. $(@D)/tools/mxsboot \
  273. -w $(BR2_TARGET_UBOOT_FORMAT_NAND_PAGE_SIZE) \
  274. -o $(BR2_TARGET_UBOOT_FORMAT_NAND_OOB_SIZE) \
  275. -e $(BR2_TARGET_UBOOT_FORMAT_NAND_ERASE_SIZE) \
  276. nand $(@D)/u-boot.sb $(@D)/u-boot.nand)
  277. endef
  278. define UBOOT_BUILD_OMAP_IFT
  279. $(HOST_DIR)/bin/gpsign -f $(@D)/u-boot.bin \
  280. -c $(call qstrip,$(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG))
  281. endef
  282. define UBOOT_INSTALL_IMAGES_CMDS
  283. $(foreach f,$(UBOOT_BINS), \
  284. cp -dpf $(@D)/$(f) $(BINARIES_DIR)/
  285. )
  286. $(if $(BR2_TARGET_UBOOT_FORMAT_NAND),
  287. cp -dpf $(@D)/u-boot.sb $(BINARIES_DIR))
  288. $(if $(BR2_TARGET_UBOOT_SPL),
  289. $(foreach f,$(call qstrip,$(BR2_TARGET_UBOOT_SPL_NAME)), \
  290. cp -dpf $(@D)/$(f) $(BINARIES_DIR)/
  291. )
  292. )
  293. endef
  294. ifeq ($(BR2_TARGET_UBOOT_ZYNQMP),y)
  295. UBOOT_ZYNQMP_PMUFW = $(call qstrip,$(BR2_TARGET_UBOOT_ZYNQMP_PMUFW))
  296. ifneq ($(findstring ://,$(UBOOT_ZYNQMP_PMUFW)),)
  297. UBOOT_EXTRA_DOWNLOADS += $(UBOOT_ZYNQMP_PMUFW)
  298. BR_NO_CHECK_HASH_FOR += $(notdir $(UBOOT_ZYNQMP_PMUFW))
  299. UBOOT_ZYNQMP_PMUFW_PATH = $(UBOOT_DL_DIR)/$(notdir $(UBOOT_ZYNQMP_PMUFW))
  300. else ifneq ($(UBOOT_ZYNQMP_PMUFW),)
  301. UBOOT_ZYNQMP_PMUFW_PATH = $(shell readlink -f $(UBOOT_ZYNQMP_PMUFW))
  302. endif
  303. define UBOOT_ZYNQMP_KCONFIG_PMUFW
  304. $(call KCONFIG_SET_OPT,CONFIG_PMUFW_INIT_FILE,"$(UBOOT_ZYNQMP_PMUFW_PATH)")
  305. endef
  306. UBOOT_ZYNQMP_PM_CFG = $(call qstrip,$(BR2_TARGET_UBOOT_ZYNQMP_PM_CFG))
  307. ifneq ($(UBOOT_ZYNQMP_PM_CFG),)
  308. UBOOT_ZYNQMP_PM_CFG_BIN = $(UBOOT_DIR)/pm_cfg_obj.bin
  309. define UBOOT_ZYNQMP_KCONFIG_PM_CFG
  310. $(call KCONFIG_SET_OPT,CONFIG_ZYNQMP_SPL_PM_CFG_OBJ_FILE,"$(UBOOT_ZYNQMP_PM_CFG_BIN)", \
  311. $(@D)/.config)
  312. endef
  313. define UBOOT_ZYNQMP_PM_CFG_CONVERT
  314. $(UBOOT_DIR)/tools/zynqmp_pm_cfg_obj_convert.py \
  315. "$(UBOOT_ZYNQMP_PM_CFG)" \
  316. "$(UBOOT_ZYNQMP_PM_CFG_BIN)"
  317. endef
  318. UBOOT_PRE_BUILD_HOOKS += UBOOT_ZYNQMP_PM_CFG_CONVERT
  319. endif
  320. UBOOT_ZYNQMP_PSU_INIT = $(call qstrip,$(BR2_TARGET_UBOOT_ZYNQMP_PSU_INIT_FILE))
  321. UBOOT_ZYNQMP_PSU_INIT_PATH = $(shell readlink -f $(UBOOT_ZYNQMP_PSU_INIT))
  322. ifneq ($(UBOOT_ZYNQMP_PSU_INIT),)
  323. define UBOOT_ZYNQMP_KCONFIG_PSU_INIT
  324. $(call KCONFIG_SET_OPT,CONFIG_XILINX_PS_INIT_FILE,"$(UBOOT_ZYNQMP_PSU_INIT_PATH)")
  325. endef
  326. endif
  327. endif # BR2_TARGET_UBOOT_ZYNQMP
  328. define UBOOT_INSTALL_OMAP_IFT_IMAGE
  329. cp -dpf $(@D)/$(UBOOT_BIN_IFT) $(BINARIES_DIR)/
  330. endef
  331. ifeq ($(BR2_TARGET_UBOOT_OMAP_IFT),y)
  332. ifeq ($(BR_BUILDING),y)
  333. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG)),)
  334. $(error No gpsign config file. Check your BR2_TARGET_UBOOT_OMAP_IFT_CONFIG setting)
  335. endif
  336. ifeq ($(wildcard $(call qstrip,$(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG))),)
  337. $(error gpsign config file $(BR2_TARGET_UBOOT_OMAP_IFT_CONFIG) not found. Check your BR2_TARGET_UBOOT_OMAP_IFT_CONFIG setting)
  338. endif
  339. endif
  340. UBOOT_DEPENDENCIES += host-omap-u-boot-utils
  341. UBOOT_POST_BUILD_HOOKS += UBOOT_BUILD_OMAP_IFT
  342. UBOOT_POST_INSTALL_IMAGES_HOOKS += UBOOT_INSTALL_OMAP_IFT_IMAGE
  343. endif
  344. ifeq ($(BR2_TARGET_UBOOT_ZYNQ_IMAGE),y)
  345. define UBOOT_GENERATE_ZYNQ_IMAGE
  346. $(HOST_DIR)/bin/python2 \
  347. $(HOST_DIR)/bin/zynq-boot-bin.py \
  348. -u $(@D)/$(firstword $(call qstrip,$(BR2_TARGET_UBOOT_SPL_NAME))) \
  349. -o $(BINARIES_DIR)/BOOT.BIN
  350. endef
  351. UBOOT_DEPENDENCIES += host-zynq-boot-bin
  352. UBOOT_POST_INSTALL_IMAGES_HOOKS += UBOOT_GENERATE_ZYNQ_IMAGE
  353. endif
  354. ifeq ($(BR2_TARGET_UBOOT_ALTERA_SOCFPGA_IMAGE_CRC),y)
  355. ifeq ($(BR2_TARGET_UBOOT_SPL),y)
  356. UBOOT_CRC_ALTERA_SOCFPGA_INPUT_IMAGES = $(call qstrip,$(BR2_TARGET_UBOOT_SPL_NAME))
  357. UBOOT_CRC_ALTERA_SOCFPGA_HEADER_VERSION = 0
  358. else
  359. UBOOT_CRC_ALTERA_SOCFPGA_INPUT_IMAGES = u-boot-dtb.bin
  360. UBOOT_CRC_ALTERA_SOCFPGA_HEADER_VERSION = 1
  361. endif
  362. define UBOOT_CRC_ALTERA_SOCFPGA_IMAGE
  363. $(foreach f,$(UBOOT_CRC_ALTERA_SOCFPGA_INPUT_IMAGES), \
  364. $(HOST_DIR)/bin/mkpimage \
  365. -v $(UBOOT_CRC_ALTERA_SOCFPGA_HEADER_VERSION) \
  366. -o $(BINARIES_DIR)/$(notdir $(call qstrip,$(f))).crc \
  367. $(@D)/$(call qstrip,$(f))
  368. )
  369. endef
  370. UBOOT_DEPENDENCIES += host-mkpimage
  371. UBOOT_POST_INSTALL_IMAGES_HOOKS += UBOOT_CRC_ALTERA_SOCFPGA_IMAGE
  372. endif
  373. define UBOOT_KCONFIG_FIXUP_CMDS
  374. $(UBOOT_ZYNQMP_KCONFIG_PMUFW)
  375. $(UBOOT_ZYNQMP_KCONFIG_PM_CFG)
  376. $(UBOOT_ZYNQMP_KCONFIG_PSU_INIT)
  377. endef
  378. ifeq ($(BR2_TARGET_UBOOT)$(BR_BUILDING),yy)
  379. #
  380. # Check U-Boot board name (for legacy) or the defconfig/custom config
  381. # file options (for kconfig)
  382. #
  383. ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY),y)
  384. ifeq ($(UBOOT_BOARD_NAME),)
  385. $(error No U-Boot board name set. Check your BR2_TARGET_UBOOT_BOARDNAME setting)
  386. endif # UBOOT_BOARD_NAME
  387. else ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_KCONFIG),y)
  388. ifeq ($(BR2_TARGET_UBOOT_USE_DEFCONFIG),y)
  389. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_BOARD_DEFCONFIG)),)
  390. $(error No board defconfig name specified, check your BR2_TARGET_UBOOT_BOARD_DEFCONFIG setting)
  391. endif # qstrip BR2_TARGET_UBOOT_BOARD_DEFCONFIG
  392. endif # BR2_TARGET_UBOOT_USE_DEFCONFIG
  393. ifeq ($(BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG),y)
  394. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE)),)
  395. $(error No board configuration file specified, check your BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE setting)
  396. endif # qstrip BR2_TARGET_UBOOT_CUSTOM_CONFIG_FILE
  397. endif # BR2_TARGET_UBOOT_USE_CUSTOM_CONFIG
  398. endif # BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY
  399. #
  400. # Check custom version option
  401. #
  402. ifeq ($(BR2_TARGET_UBOOT_CUSTOM_VERSION),y)
  403. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_VERSION_VALUE)),)
  404. $(error No custom U-Boot version specified. Check your BR2_TARGET_UBOOT_CUSTOM_VERSION_VALUE setting)
  405. endif # qstrip BR2_TARGET_UBOOT_CUSTOM_VERSION_VALUE
  406. endif # BR2_TARGET_UBOOT_CUSTOM_VERSION
  407. #
  408. # Check custom tarball option
  409. #
  410. ifeq ($(BR2_TARGET_UBOOT_CUSTOM_TARBALL),y)
  411. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_TARBALL_LOCATION)),)
  412. $(error No custom U-Boot tarball specified. Check your BR2_TARGET_UBOOT_CUSTOM_TARBALL_LOCATION setting)
  413. endif # qstrip BR2_TARGET_UBOOT_CUSTOM_TARBALL_LOCATION
  414. endif # BR2_TARGET_UBOOT_CUSTOM_TARBALL
  415. #
  416. # Check Git/Mercurial repo options
  417. #
  418. ifeq ($(BR2_TARGET_UBOOT_CUSTOM_GIT)$(BR2_TARGET_UBOOT_CUSTOM_HG),y)
  419. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_URL)),)
  420. $(error No custom U-Boot repository URL specified. Check your BR2_TARGET_UBOOT_CUSTOM_REPO_URL setting)
  421. endif # qstrip BR2_TARGET_UBOOT_CUSTOM_CUSTOM_REPO_URL
  422. ifeq ($(call qstrip,$(BR2_TARGET_UBOOT_CUSTOM_REPO_VERSION)),)
  423. $(error No custom U-Boot repository version specified. Check your BR2_TARGET_UBOOT_CUSTOM_REPO_VERSION setting)
  424. endif # qstrip BR2_TARGET_UBOOT_CUSTOM_CUSTOM_REPO_VERSION
  425. endif # BR2_TARGET_UBOOT_CUSTOM_GIT || BR2_TARGET_UBOOT_CUSTOM_HG
  426. endif # BR2_TARGET_UBOOT && BR_BUILDING
  427. ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY),y)
  428. UBOOT_DEPENDENCIES += \
  429. $(BR2_BISON_HOST_DEPENDENCY) \
  430. $(BR2_FLEX_HOST_DEPENDENCY)
  431. $(eval $(generic-package))
  432. else ifeq ($(BR2_TARGET_UBOOT_BUILD_SYSTEM_KCONFIG),y)
  433. UBOOT_MAKE_ENV = $(TARGET_MAKE_ENV)
  434. UBOOT_KCONFIG_DEPENDENCIES += \
  435. $(BR2_MAKE_HOST_DEPENDENCY) \
  436. $(BR2_BISON_HOST_DEPENDENCY) \
  437. $(BR2_FLEX_HOST_DEPENDENCY)
  438. $(eval $(kconfig-package))
  439. endif # BR2_TARGET_UBOOT_BUILD_SYSTEM_LEGACY