Makefile 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. #
  2. # Copyright (C) 2019 Sartura Ltd.
  3. #
  4. # This is free software, licensed under the GNU General Public License v2.
  5. # See /LICENSE for more information.
  6. #
  7. include $(TOPDIR)/rules.mk
  8. PKG_VERSION:=2.9
  9. PKG_RELEASE:=1
  10. PKG_HASH:=76a66a1de0c01aeb83dfc7b72b51173fe62c6e51d6fca17cc562393117bed08b
  11. PKG_MAINTAINER:=Vladimir Vid <[email protected]>
  12. include $(INCLUDE_DIR)/kernel.mk
  13. include $(INCLUDE_DIR)/trusted-firmware-a.mk
  14. include $(INCLUDE_DIR)/package.mk
  15. define Trusted-Firmware-A/Default
  16. BUILD_TARGET:=mvebu
  17. BUILD_SUBTARGET:=cortexa53
  18. TFA_IMAGE:=flash-image.bin uart-images.tgz.bin
  19. UBOOT:=
  20. DDR_TOPOLOGY:=
  21. CLOCKSPRESET:=
  22. endef
  23. define Trusted-Firmware-A/espressobin-512mb
  24. NAME:=Marvell ESPRESSObin (512MB)
  25. DEPENDS:=+u-boot-espressobin
  26. BUILD_DEVICES:=globalscale_espressobin
  27. UBOOT:=espressobin
  28. DDR_TOPOLOGY:=0
  29. CLOCKSPRESET:=CPU_1000_DDR_800
  30. PLAT:=a3700
  31. endef
  32. define Trusted-Firmware-A/espressobin-v3-v5-1gb-1cs
  33. NAME:=Marvell ESPRESSObin V3-V5 (1GB 1CS)
  34. DEPENDS:=+u-boot-espressobin
  35. BUILD_DEVICES:=globalscale_espressobin
  36. UBOOT:=espressobin
  37. DDR_TOPOLOGY:=4
  38. CLOCKSPRESET:=CPU_1000_DDR_800
  39. PLAT:=a3700
  40. endef
  41. define Trusted-Firmware-A/espressobin-v3-v5-1gb-2cs
  42. NAME:=Marvell ESPRESSObin V3-V5 (1GB, 2CS)
  43. DEPENDS:=+u-boot-espressobin
  44. BUILD_DEVICES:=globalscale_espressobin
  45. UBOOT:=espressobin
  46. DDR_TOPOLOGY:=2
  47. CLOCKSPRESET:=CPU_1000_DDR_800
  48. PLAT:=a3700
  49. endef
  50. define Trusted-Firmware-A/espressobin-v3-v5-2gb
  51. NAME:=Marvell ESPRESSObin V3-V5 (2GB)
  52. DEPENDS:=+u-boot-espressobin
  53. BUILD_DEVICES:=globalscale_espressobin
  54. UBOOT:=espressobin
  55. DDR_TOPOLOGY:=7
  56. CLOCKSPRESET:=CPU_1000_DDR_800
  57. PLAT:=a3700
  58. endef
  59. define Trusted-Firmware-A/espressobin-v7-1gb
  60. NAME:=Marvell ESPRESSObin V7 (1GB)
  61. DEPENDS:=+u-boot-espressobin
  62. BUILD_DEVICES:=globalscale_espressobin-v7
  63. UBOOT:=espressobin
  64. DDR_TOPOLOGY:=5
  65. CLOCKSPRESET:=CPU_1000_DDR_800
  66. PLAT:=a3700
  67. endef
  68. define Trusted-Firmware-A/espressobin-v7-2gb
  69. NAME:=Marvell ESPRESSObin V7 (2GB)
  70. DEPENDS:=+u-boot-espressobin
  71. BUILD_DEVICES:=globalscale_espressobin-v7
  72. UBOOT:=espressobin
  73. DDR_TOPOLOGY:=6
  74. CLOCKSPRESET:=CPU_1000_DDR_800
  75. PLAT:=a3700
  76. endef
  77. define Trusted-Firmware-A/udpu
  78. NAME:=Methode uDPU
  79. DEPENDS:=+u-boot-uDPU
  80. BUILD_DEVICES:=methode_udpu
  81. UBOOT:=uDPU
  82. DDR_TOPOLOGY:=0
  83. CLOCKSPRESET:=CPU_1000_DDR_800
  84. PLAT:=a3700
  85. endef
  86. define Trusted-Firmware-A/edpu
  87. NAME:=Methode eDPU
  88. DEPENDS:=+u-boot-eDPU
  89. BUILD_DEVICES:=methode_edpu
  90. UBOOT:=eDPU
  91. DDR_TOPOLOGY:=0
  92. CLOCKSPRESET:=CPU_1000_DDR_800
  93. PLAT:=a3700
  94. endef
  95. TFA_TARGETS:= \
  96. espressobin-512mb \
  97. espressobin-v3-v5-1gb-1cs \
  98. espressobin-v3-v5-1gb-2cs \
  99. espressobin-v3-v5-2gb \
  100. espressobin-v7-1gb \
  101. espressobin-v7-2gb \
  102. udpu \
  103. edpu
  104. TFA_MAKE_FLAGS += \
  105. CROSS_CM3=$(BUILD_DIR)/$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION)/bin/arm-none-eabi- \
  106. BL33=$(STAGING_DIR_IMAGE)/$(UBOOT)-u-boot.bin \
  107. MV_DDR_PATH=$(BUILD_DIR)/$(MV_DDR_NAME) \
  108. WTP=$(BUILD_DIR)/$(A3700_UTILS_NAME) \
  109. WTMI_IMG=$(BUILD_DIR)/$(MOX_BB_NAME)/wtmi_app.bin \
  110. CRYPTOPP_PATH=$(BUILD_DIR)/$(CRYPTOPP_NAME) \
  111. HOST_LDFLAGS="$(HOST_LDFLAGS)" \
  112. HOST_CPPFLAGS="$(HOST_CPPFLAGS)" \
  113. USE_COHERENT_MEM=0 \
  114. FIP_ALIGN=0x100 \
  115. DDR_TOPOLOGY=$(DDR_TOPOLOGY) \
  116. CLOCKSPRESET=$(CLOCKSPRESET) \
  117. A3700_UTILS_COMMIT_ID=$(A3700_UTILS_RELEASE) \
  118. MV_DDR_COMMIT_ID=$(MV_DDR_RELEASE) \
  119. all \
  120. mrvl_flash \
  121. mrvl_uart
  122. A3700_UTILS_NAME:=a3700-utils
  123. A3700_UTILS_RELEASE:=a3e1c67
  124. A3700_UTILS_SOURCE=$(A3700_UTILS_NAME)-$(A3700_UTILS_RELEASE).tar.bz2
  125. define Download/a3700-utils
  126. FILE:=$(A3700_UTILS_SOURCE)
  127. PROTO:=git
  128. URL:=https://github.com/MarvellEmbeddedProcessors/A3700-utils-marvell.git
  129. VERSION:=a3e1c67bb378e1d8a938e1b826cb602af83628d2
  130. MIRROR_HASH:=0e6b8ef6423dcb52a5e282669a8aeebc6eea2d45a7c3a2c9a2fc7a749b3275a7
  131. SUBDIR:=$(A3700_UTILS_NAME)
  132. endef
  133. CRYPTOPP_NAME:=cryptopp
  134. CRYPTOPP_RELEASE:=4d0cad5
  135. CRYPTOPP_SOURCE=$(CRYPTOPP_NAME)-$(CRYPTOPP_RELEASE).tar.bz2
  136. define Download/cryptopp
  137. FILE:=$(CRYPTOPP_SOURCE)
  138. PROTO:=git
  139. URL:=https://github.com/weidai11/cryptopp.git
  140. VERSION:=4d0cad5401d1a2c998b314bc89288c9620d3021d
  141. MIRROR_HASH:=74ec9e48ee04b9f2d9a1d8c4f2392ed0ab52780d7af0f70405d7bbb23d1504fa
  142. SUBDIR:=$(CRYPTOPP_NAME)
  143. endef
  144. MV_DDR_NAME:=mv-ddr-marvell
  145. MV_DDR_RELEASE:=541616b
  146. MV_DDR_SOURCE:=$(MV_DDR_NAME)-$(MV_DDR_RELEASE).tar.bz2
  147. define Download/mv-ddr-marvell
  148. FILE:=$(MV_DDR_SOURCE)
  149. PROTO:=git
  150. URL:=https://github.com/MarvellEmbeddedProcessors/mv-ddr-marvell.git
  151. VERSION:=541616bc5d25a0167c9901546255c55973e2c0f0
  152. MIRROR_HASH:=9e86a986c7400ed1a72165a88150b6c494ebd87303b16314b43e5785e3f13068
  153. SUBDIR:=$(MV_DDR_NAME)
  154. endef
  155. MOX_BB_NAME:=mox-boot-builder
  156. MOX_BB_RELEASE:=604f8f51
  157. MOX_BB_SOURCE:=$(MOX_BB_NAME)-$(MOX_BB_RELEASE).tar.bz2
  158. define Download/mox-boot-builder
  159. FILE:=$(MOX_BB_SOURCE)
  160. PROTO:=git
  161. SUBMODULES:=skip
  162. URL:=https://gitlab.nic.cz/turris/mox-boot-builder.git
  163. VERSION:=604f8f51d97b4e59fa6d1e579101daa194d6ed2d
  164. MIRROR_HASH:=b09337a7dde140f57e40133b6e7b7e1eb338e7cea9b15a3af6874824462f15f7
  165. SUBDIR:=$(MOX_BB_NAME)
  166. endef
  167. CM3_GCC_NAME:=arm-gnu-toolchain
  168. CM3_GCC_RELEASE:=12.3.rel1
  169. CM3_GCC_VERSION:=$(HOST_ARCH)-arm-none-eabi
  170. CM3_GCC_SOURCE=$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION).tar.xz
  171. define Download/cm3-gcc
  172. FILE:=$(CM3_GCC_SOURCE)
  173. URL:=https://developer.arm.com/-/media/Files/downloads/gnu/$(CM3_GCC_RELEASE)/binrel
  174. ifeq ($(HOST_ARCH),aarch64)
  175. HASH:=14c0487d5753f6071d24e568881f7c7e67f80dd83165dec5164b3731394af431
  176. else
  177. HASH:=12a2815644318ebcceaf84beabb665d0924b6e79e21048452c5331a56332b309
  178. endif
  179. endef
  180. define Build/Clean
  181. rm -rf \
  182. $(BUILD_DIR)/$(CRYPTOPP_NAME) \
  183. $(BUILD_DIR)/$(A3700_UTILS_NAME) \
  184. $(BUILD_DIR)/$(MV_DDR_NAME) \
  185. $(BUILD_DIR)/$(MOX_BB_NAME) \
  186. $(BUILD_DIR)/$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION)
  187. endef
  188. define Build/Prepare
  189. # Download sources
  190. $(eval $(call Download,a3700-utils))
  191. $(eval $(call Download,mv-ddr-marvell))
  192. $(eval $(call Download,mox-boot-builder))
  193. $(eval $(call Download,cryptopp))
  194. $(eval $(call Download,cm3-gcc))
  195. $(call Build/Prepare/Default,)
  196. $(TAR) -C $(BUILD_DIR) -xf $(DL_DIR)/$(CRYPTOPP_SOURCE)
  197. $(TAR) -C $(BUILD_DIR) -xf $(DL_DIR)/$(A3700_UTILS_SOURCE)
  198. $(call PatchDir/Default,$(BUILD_DIR)/$(A3700_UTILS_NAME),./patches-a3700-utils)
  199. $(TAR) -C $(BUILD_DIR) -xf $(DL_DIR)/$(MV_DDR_SOURCE)
  200. $(call PatchDir/Default,$(BUILD_DIR)/$(MV_DDR_NAME),./patches-mv-ddr-marvell)
  201. $(TAR) -C $(BUILD_DIR) -xf $(DL_DIR)/$(MOX_BB_SOURCE)
  202. $(call PatchDir/Default,$(BUILD_DIR)/$(MOX_BB_NAME),./patches-mox-boot-builder)
  203. $(TAR) -C $(BUILD_DIR) -xf $(DL_DIR)/$(CM3_GCC_SOURCE)
  204. endef
  205. define Build/Compile
  206. +$(MAKE) \
  207. CROSS_CM3=$(BUILD_DIR)/$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION)/bin/arm-none-eabi- \
  208. WTMI_VERSION=$(MOX_BB_RELEASE) \
  209. CRYPTOPP_PATH=$PWD/cryptopp/ \
  210. -C $(BUILD_DIR)/$(MOX_BB_NAME) \
  211. wtmi_app.bin
  212. $(call Build/Compile/Default)
  213. endef
  214. $(eval $(call BuildPackage/Trusted-Firmware-A))