procd: make mDNS TXT record parsing more solid
[openwrt/openwrt.git] / package / boot / arm-trusted-firmware-mvebu / Makefile
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
8 include $(TOPDIR)/rules.mk
9
10 PKG_VERSION:=2.5
11 PKG_RELEASE:=$(AUTORELEASE)
12 PKG_HASH:=ad8a2ffcbcd12d919723da07630fc0840c3c2fba7656d1462e45488e42995d7c
13
14 PKG_MAINTAINER:=Vladimir Vid <vladimir.vid@sartura.hr>
15
16 include $(INCLUDE_DIR)/trusted-firmware-a.mk
17 include $(INCLUDE_DIR)/package.mk
18
19 define Trusted-Firmware-A/Default
20 BUILD_TARGET:=mvebu
21 BUILD_SUBTARGET:=cortexa53
22 TFA_IMAGE:=flash-image.bin uart-images.tgz.bin
23 UBOOT:=
24 DDR_TOPOLOGY:=
25 CLOCKSPRESET:=
26 endef
27
28
29 define Trusted-Firmware-A/espressobin-512mb
30 NAME:=Marvell ESPRESSObin (512MB)
31 DEPENDS:=+u-boot-espressobin
32 BUILD_DEVICES:=globalscale_espressobin
33 UBOOT:=espressobin
34 DDR_TOPOLOGY:=0
35 CLOCKSPRESET:=CPU_1000_DDR_800
36 PLAT:=a3700
37 endef
38
39 define Trusted-Firmware-A/espressobin-v3-v5-1gb-1cs
40 NAME:=Marvell ESPRESSObin V3-V5 (1GB 1CS)
41 DEPENDS:=+u-boot-espressobin
42 BUILD_DEVICES:=globalscale_espressobin
43 UBOOT:=espressobin
44 DDR_TOPOLOGY:=4
45 CLOCKSPRESET:=CPU_1000_DDR_800
46 PLAT:=a3700
47 endef
48
49 define Trusted-Firmware-A/espressobin-v3-v5-1gb-2cs
50 NAME:=Marvell ESPRESSObin V3-V5 (1GB, 2CS)
51 DEPENDS:=+u-boot-espressobin
52 BUILD_DEVICES:=globalscale_espressobin
53 UBOOT:=espressobin
54 DDR_TOPOLOGY:=2
55 CLOCKSPRESET:=CPU_1000_DDR_800
56 PLAT:=a3700
57 endef
58
59 define Trusted-Firmware-A/espressobin-v3-v5-2gb
60 NAME:=Marvell ESPRESSObin V3-V5 (2GB)
61 DEPENDS:=+u-boot-espressobin
62 BUILD_DEVICES:=globalscale_espressobin
63 UBOOT:=espressobin
64 DDR_TOPOLOGY:=7
65 CLOCKSPRESET:=CPU_1000_DDR_800
66 PLAT:=a3700
67 endef
68
69 define Trusted-Firmware-A/espressobin-v7-1gb
70 NAME:=Marvell ESPRESSObin V7 (1GB)
71 DEPENDS:=+u-boot-espressobin
72 BUILD_DEVICES:=globalscale_espressobin-v7
73 UBOOT:=espressobin
74 DDR_TOPOLOGY:=5
75 CLOCKSPRESET:=CPU_1000_DDR_800
76 PLAT:=a3700
77 endef
78
79 define Trusted-Firmware-A/espressobin-v7-2gb
80 NAME:=Marvell ESPRESSObin V7 (2GB)
81 DEPENDS:=+u-boot-espressobin
82 BUILD_DEVICES:=globalscale_espressobin-v7
83 UBOOT:=espressobin
84 DDR_TOPOLOGY:=6
85 CLOCKSPRESET:=CPU_1000_DDR_800
86 PLAT:=a3700
87 endef
88
89 define Trusted-Firmware-A/udpu
90 NAME:=Methode uDPU
91 DEPENDS:=+u-boot-uDPU
92 BUILD_DEVICES:=methode_udpu
93 UBOOT:=uDPU
94 DDR_TOPOLOGY:=0
95 CLOCKSPRESET:=CPU_1000_DDR_800
96 PLAT:=a3700
97 endef
98
99
100 TFA_TARGETS:= \
101 espressobin-512mb \
102 espressobin-v3-v5-1gb-1cs \
103 espressobin-v3-v5-1gb-2cs \
104 espressobin-v3-v5-2gb \
105 espressobin-v7-1gb \
106 espressobin-v7-2gb \
107 udpu
108
109 TFA_MAKE_FLAGS += \
110 CROSS_CM3=$(STAGING_DIR_IMAGE)/$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION)/bin/arm-none-eabi- \
111 BL33=$(STAGING_DIR_IMAGE)/$(UBOOT)-u-boot.bin \
112 MV_DDR_PATH=$(STAGING_DIR_IMAGE)/$(MV_DDR_NAME) \
113 WTP=$(STAGING_DIR_IMAGE)/$(A3700_UTILS_NAME) \
114 WTMI_IMG=$(STAGING_DIR_IMAGE)/$(MOX_BB_NAME)-$(MOX_BB_RELEASE)/wtmi_app.bin \
115 CRYPTOPP_PATH=$(STAGING_DIR_IMAGE)/$(CRYPTOPP_NAME) \
116 USE_COHERENT_MEM=0 \
117 FIP_ALIGN=0x100 \
118 DDR_TOPOLOGY=$(DDR_TOPOLOGY) \
119 CLOCKSPRESET=$(CLOCKSPRESET) \
120 A3700_UTILS_COMMIT_ID=$(A3700_UTILS_RELEASE) \
121 MV_DDR_COMMIT_ID=$(MV_DDR_RELEASE) \
122 all \
123 mrvl_flash \
124 mrvl_uart
125
126 A3700_UTILS_NAME:=a3700-utils
127 A3700_UTILS_RELEASE:=97f01f5f
128 A3700_UTILS_SOURCE=$(A3700_UTILS_NAME)-$(A3700_UTILS_RELEASE).tar.bz2
129
130 define Download/a3700-utils
131 FILE:=$(A3700_UTILS_SOURCE)
132 PROTO:=git
133 URL:=https://github.com/MarvellEmbeddedProcessors/A3700-utils-marvell.git
134 VERSION:=97f01f5feaf9ef6168e2a2096abaf56371939e58
135 MIRROR_HASH:=1e391c4dafb7b3363a17282e229d056a95575c0f4fb2f71e21db8044668aea78
136 SUBDIR:=$(A3700_UTILS_NAME)
137 endef
138
139 CRYPTOPP_NAME:=cryptopp
140 CRYPTOPP_RELEASE:=f210224
141 CRYPTOPP_SOURCE=$(CRYPTOPP_NAME)-$(CRYPTOPP_RELEASE).tar.bz2
142
143 define Download/cryptopp
144 FILE:=$(CRYPTOPP_SOURCE)
145 PROTO:=git
146 URL:=https://github.com/weidai11/cryptopp.git
147 VERSION:=f2102243e6fdd48c0b2a393a0993cca228f20573
148 MIRROR_HASH:=74ec9e48ee04b9f2d9a1d8c4f2392ed0ab52780d7af0f70405d7bbb23d1504fa
149 SUBDIR:=$(CRYPTOPP_NAME)
150 endef
151
152 MV_DDR_NAME:=mv-ddr-marvell
153 MV_DDR_RELEASE:=efcad0e2
154 MV_DDR_SOURCE:=$(MV_DDR_NAME)-$(MV_DDR_RELEASE).tar.bz2
155
156 define Download/mv-ddr-marvell
157 FILE:=$(MV_DDR_SOURCE)
158 PROTO:=git
159 URL:=https://github.com/MarvellEmbeddedProcessors/mv-ddr-marvell.git
160 VERSION:=efcad0e2fae66a8b6f84a4dd2326f5add67569d5
161 MIRROR_HASH:=99363f928ee1239fd42d651b495d163a60cdab00c24770a3c5e192efa7169d62
162 SUBDIR:=$(MV_DDR_NAME)
163 endef
164
165 MOX_BB_NAME:=mox-boot-builder
166 MOX_BB_RELEASE:=v2021.09.07
167 MOX_BB_SOURCE:=$(MOX_BB_NAME)-$(MOX_BB_RELEASE).tar.bz2
168
169 define Download/mox-boot-builder
170 FILE:=$(MOX_BB_SOURCE)
171 URL:=https://gitlab.nic.cz/turris/mox-boot-builder/-/archive/$(MOX_BB_RELEASE)
172 HASH:=fd5fe276a3b0dee3177d61c017907a8eb23cd2169478fa78e9a3a836cfe3a4a8
173 endef
174
175 CM3_GCC_NAME:=gcc-arm
176 CM3_GCC_RELEASE:=10.2-2020.11
177 CM3_GCC_VERSION:=$(HOST_ARCH)-arm-none-eabi
178 CM3_GCC_SOURCE=$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION).tar.xz
179
180 define Download/cm3-gcc
181 FILE:=$(CM3_GCC_SOURCE)
182 URL:=https://developer.arm.com/-/media/Files/downloads/gnu-a/$(CM3_GCC_RELEASE)/binrel
183 ifeq ($(HOST_ARCH),aarch64)
184 HASH:=1a42eecafa03dc6f32b8ae49ffcd15114dc818efbd72292fa6bab58233940bb9
185 else
186 HASH:=bf7ee185936d22d787b80c8da573f72ead5675695331fb8b590f0133ef1f6bb9
187 endif
188 endef
189
190 define Build/Clean
191 rm -rf \
192 $(STAGING_DIR_IMAGE)/$(CRYPTOPP_NAME) \
193 $(STAGING_DIR_IMAGE)/$(A3700_UTILS_NAME) \
194 $(STAGING_DIR_IMAGE)/$(MV_DDR_NAME) \
195 $(STAGING_DIR_IMAGE)/$(MOX_BB_NAME)-$(MOX_BB_RELEASE) \
196 $(STAGING_DIR_IMAGE)/$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION)
197 endef
198
199 define Build/Prepare
200 # Download sources
201 $(eval $(call Download,a3700-utils))
202 $(eval $(call Download,mv-ddr-marvell))
203 $(eval $(call Download,mox-boot-builder))
204 $(eval $(call Download,cryptopp))
205 $(eval $(call Download,cm3-gcc))
206
207 $(call Build/Prepare/Default,)
208
209 mkdir -p $(STAGING_DIR_IMAGE)
210 $(TAR) -C $(STAGING_DIR_IMAGE) -xf $(DL_DIR)/$(CRYPTOPP_SOURCE)
211 $(TAR) -C $(STAGING_DIR_IMAGE) -xf $(DL_DIR)/$(A3700_UTILS_SOURCE)
212 echo "master" > $(STAGING_DIR_IMAGE)/$(A3700_UTILS_NAME)/branch.txt
213 $(call PatchDir/Default,$(STAGING_DIR_IMAGE)/$(A3700_UTILS_NAME),./patches-a3700-utils)
214 $(TAR) -C $(STAGING_DIR_IMAGE) -xf $(DL_DIR)/$(MV_DDR_SOURCE)
215 echo "master" > $(STAGING_DIR_IMAGE)/$(MV_DDR_NAME)/branch.txt
216 $(call PatchDir/Default,$(STAGING_DIR_IMAGE)/$(MV_DDR_NAME),./patches-mv-ddr-marvell)
217 $(TAR) -C $(STAGING_DIR_IMAGE) -xf $(DL_DIR)/$(MOX_BB_SOURCE)
218 $(call PatchDir/Default,$(STAGING_DIR_IMAGE)/$(MOX_BB_NAME)-$(MOX_BB_RELEASE),./patches-mox-boot-builder)
219 $(TAR) -C $(STAGING_DIR_IMAGE) -xf $(DL_DIR)/$(CM3_GCC_SOURCE)
220 endef
221
222 define Build/Compile
223 +$(MAKE) \
224 CROSS_CM3=$(STAGING_DIR_IMAGE)/$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION)/bin/arm-none-eabi- \
225 WTMI_VERSION=$(MOX_BB_RELEASE) \
226 CRYPTOPP_PATH=$PWD/cryptopp/ \
227 -C $(STAGING_DIR_IMAGE)/$(MOX_BB_NAME)-$(MOX_BB_RELEASE) \
228 wtmi_app.bin
229 $(call Build/Compile/Default)
230 endef
231
232 $(eval $(call BuildPackage/Trusted-Firmware-A))