uboot-mediatek: add patches for MT7988 and builds for RFB
[openwrt/staging/jow.git] / package / boot / uboot-mediatek / Makefile
1 include $(TOPDIR)/rules.mk
2 include $(INCLUDE_DIR)/kernel.mk
3
4 PKG_VERSION:=2023.07.02
5 PKG_HASH:=6b6a48581c14abb0f95bd87c1af4d740922406d7b801002a9f94727fdde021d5
6 PKG_BUILD_DEPENDS:=!(TARGET_ramips||TARGET_mediatek_mt7623):arm-trusted-firmware-tools/host
7
8 include $(INCLUDE_DIR)/u-boot.mk
9 include $(INCLUDE_DIR)/package.mk
10 include $(INCLUDE_DIR)/host-build.mk
11
12 MT7621_LOWLEVEL_PRELOADER_URL:=https://raw.githubusercontent.com/mtk-openwrt/mt7621-lowlevel-preloader/a03b07c60bf1ba4add9b671d32caa102fe948180/
13
14 define Download/mt7621-stage-sram
15 FILE:=mt7621_stage_sram.bin
16 URL:=$(MT7621_LOWLEVEL_PRELOADER_URL)
17 HASH:=1dda68aa089f0ff262e01539b990dea478952e9fb68bcc0a8cd6f76f0135c62e
18 endef
19
20 define Download/mt7621-stage-sram-noprint
21 FILE:=mt7621_stage_sram_noprint.bin
22 URL:=$(MT7621_LOWLEVEL_PRELOADER_URL)
23 HASH:=8ee419275144fc298e9444d413d98e965a55d283152a74ea6a1f8de79eb516b6
24 endef
25
26 ifdef CONFIG_TARGET_ramips_mt7621
27 ifdef CONFIG_DEBUG
28 $(eval $(call Download,mt7621-stage-sram))
29 else
30 $(eval $(call Download,mt7621-stage-sram-noprint))
31 endif
32 endif
33
34 define U-Boot/Default
35 BUILD_TARGET:=mediatek
36 UBOOT_IMAGE:=u-boot-mtk.bin
37 HIDDEN:=1
38 endef
39
40 define U-Boot/mt7620_rfb
41 NAME:=MT7620 Reference Board
42 UBOOT_CONFIG:=mt7620_rfb
43 BUILD_DEVICES:=ralink_mt7620a-evb
44 BUILD_TARGET:=ramips
45 BUILD_SUBTARGET:=mt7620
46 UBOOT_IMAGE:=u-boot-with-spl.bin
47 endef
48
49 define U-Boot/mt7620_mt7530_rfb
50 NAME:=MT7620+MT7530 Reference Board
51 UBOOT_CONFIG:=mt7620_mt7530_rfb
52 BUILD_DEVICES:=ralink_mt7620a-mt7530-evb
53 BUILD_TARGET:=ramips
54 BUILD_SUBTARGET:=mt7620
55 UBOOT_IMAGE:=u-boot-with-spl.bin
56 endef
57
58 define U-Boot/mt7621_rfb
59 NAME:=MT7621 Reference Board
60 UBOOT_CONFIG:=mt7621_rfb
61 BUILD_DEVICES:=mediatek_mt7621-eval-board
62 BUILD_TARGET:=ramips
63 BUILD_SUBTARGET:=mt7621
64 UBOOT_IMAGE:=u-boot-mt7621.bin
65 endef
66
67 define U-Boot/mt7621_nand_rfb
68 NAME:=MT7621 Reference Board (NAND)
69 UBOOT_CONFIG:=mt7621_nand_rfb
70 BUILD_DEVICES:=mediatek_mt7621-eval-board
71 BUILD_TARGET:=ramips
72 BUILD_SUBTARGET:=mt7621
73 UBOOT_IMAGE:=u-boot-mt7621.bin
74 endef
75
76 define U-Boot/mt7622_rfb1
77 NAME:=MT7622 Reference Board 1
78 UBOOT_CONFIG:=mt7622_rfb
79 BUILD_DEVICES:=mediatek_mt7622-rfb1 mediatek_mt7622-rfb1-ubi
80 BUILD_SUBTARGET:=mt7622
81 endef
82
83 define U-Boot/mt7622_linksys_e8450
84 NAME:=Linksys E8450
85 UBOOT_CONFIG:=mt7622_linksys_e8450
86 BUILD_DEVICES:=linksys_e8450-ubi
87 BUILD_SUBTARGET:=mt7622
88 UBOOT_IMAGE:=u-boot.fip
89 BL2_BOOTDEV:=snand
90 BL2_DDRBLOB:=1
91 DEPENDS:=+trusted-firmware-a-mt7622-snand-1ddr
92 endef
93
94 define U-Boot/mt7622_bananapi_bpi-r64-emmc
95 NAME:=BananaPi R64 (eMMC)
96 UBOOT_CONFIG:=mt7622_bananapi_bpi-r64-emmc
97 BUILD_DEVICES:=bananapi_bpi-r64
98 BUILD_SUBTARGET:=mt7622
99 UBOOT_IMAGE:=u-boot.fip
100 BL2_BOOTDEV:=emmc
101 BL2_DDRBLOB:=2
102 DEPENDS:=+trusted-firmware-a-mt7622-emmc-2ddr
103 endef
104
105 define U-Boot/mt7622_bananapi_bpi-r64-sdmmc
106 NAME:=BananaPi R64 (SDMMC)
107 UBOOT_CONFIG:=mt7622_bananapi_bpi-r64-sdmmc
108 BUILD_DEVICES:=bananapi_bpi-r64
109 BUILD_SUBTARGET:=mt7622
110 UBOOT_IMAGE:=u-boot.fip
111 BL2_BOOTDEV:=sdmmc
112 BL2_DDRBLOB:=2
113 DEPENDS:=+trusted-firmware-a-mt7622-sdmmc-2ddr
114 endef
115
116 define U-Boot/mt7622_bananapi_bpi-r64-snand
117 NAME:=BananaPi R64 (SNAND)
118 UBOOT_CONFIG:=mt7622_bananapi_bpi-r64-snand
119 BUILD_DEVICES:=bananapi_bpi-r64
120 BUILD_SUBTARGET:=mt7622
121 UBOOT_IMAGE:=u-boot.fip
122 BL2_BOOTDEV:=snand
123 BL2_DDRBLOB:=2
124 DEPENDS:=+trusted-firmware-a-mt7622-snand-2ddr
125 endef
126
127 define U-Boot/mt7622_ubnt_unifi-6-lr
128 NAME:=Ubiquiti UniFi 6 LR
129 UBOOT_CONFIG:=mt7622_ubnt_unifi-6-lr
130 BUILD_DEVICES:=ubnt_unifi-6-lr-v1-ubootmod ubnt_unifi-6-lr-v2-ubootmod
131 BUILD_SUBTARGET:=mt7622
132 UBOOT_IMAGE:=u-boot.fip
133 BL2_BOOTDEV:=nor
134 BL2_DDRBLOB:=2
135 DEPENDS:=+trusted-firmware-a-mt7622-nor-2ddr
136 FIP_COMPRESS:=1
137 endef
138
139 define U-Boot/mt7623a_unielec_u7623
140 NAME:=UniElec U7623 (mt7623)
141 BUILD_DEVICES:=unielec_u7623-02
142 BUILD_SUBTARGET:=mt7623
143 UBOOT_CONFIG:=mt7623a_unielec_u7623_02
144 endef
145
146 define U-Boot/mt7623n_bpir2
147 NAME:=Banana Pi R2 (mt7623)
148 BUILD_DEVICES:=bananapi_bpi-r2
149 BUILD_SUBTARGET:=mt7623
150 UBOOT_IMAGE:=u-boot.bin
151 UBOOT_CONFIG:=mt7623n_bpir2
152 endef
153
154 define U-Boot/mt7628_rfb
155 NAME:=MT7628 Reference Board
156 BUILD_DEVICES:=mediatek_mt7628an-eval-board
157 BUILD_TARGET:=ramips
158 BUILD_SUBTARGET:=mt76x8
159 UBOOT_CONFIG:=mt7628_rfb
160 UBOOT_IMAGE:=u-boot-with-spl.bin
161 endef
162
163 define U-Boot/ravpower_rp-wd009
164 NAME:=RAVPower RP-WD009
165 BUILD_TARGET:=ramips
166 BUILD_DEVICES:=ravpower_rp-wd009
167 BUILD_SUBTARGET:=mt76x8
168 UBOOT_CONFIG:=ravpower-rp-wd009-ram
169 UBOOT_IMAGE:=u-boot.bin
170 endef
171
172 define U-Boot/mt7629_rfb
173 NAME:=MT7629 Reference Board
174 BUILD_SUBTARGET:=mt7629
175 BUILD_DEVICES:=mediatek_mt7629-rfb
176 UBOOT_CONFIG:=mt7629_rfb
177 endef
178
179 define U-Boot/mt7981_h3c_magic-nx30-pro
180 NAME:=H3C Magic NX30 Pro
181 BUILD_SUBTARGET:=filogic
182 BUILD_DEVICES:=h3c_magic-nx30-pro
183 UBOOT_CONFIG:=mt7981_h3c_magic-nx30-pro
184 UBOOT_IMAGE:=u-boot.fip
185 BL2_BOOTDEV:=spim-nand
186 BL2_SOC:=mt7981
187 BL2_DDRTYPE:=ddr3
188 DEPENDS:=+trusted-firmware-a-mt7981-spim-nand-ddr3
189 endef
190
191 define U-Boot/mt7981_qihoo_360t7
192 NAME:=Qihoo 360T7
193 BUILD_SUBTARGET:=filogic
194 BUILD_DEVICES:=qihoo_360t7
195 UBOOT_CONFIG:=mt7981_qihoo-360t7
196 UBOOT_IMAGE:=u-boot.fip
197 BL2_BOOTDEV:=spim-nand
198 BL2_SOC:=mt7981
199 BL2_DDRTYPE:=ddr3
200 DEPENDS:=+trusted-firmware-a-mt7981-spim-nand-ddr3
201 endef
202
203 define U-Boot/mt7981_xiaomi_mi-router-wr30u
204 NAME:=Xiaomi Router WR30U
205 BUILD_SUBTARGET:=filogic
206 BUILD_DEVICES:=xiaomi_mi-router-wr30u-ubootmod
207 UBOOT_CONFIG:=mt7981_xiaomi_mi-router-wr30u
208 UBOOT_IMAGE:=u-boot.fip
209 BL2_BOOTDEV:=spim-nand
210 BL2_SOC:=mt7981
211 BL2_DDRTYPE:=ddr3
212 DEPENDS:=+trusted-firmware-a-mt7981-spim-nand-ddr3
213 endef
214
215 define U-Boot/mt7986_rfb
216 NAME:=MT7986 Reference Board
217 BUILD_SUBTARGET:=filogic
218 BUILD_DEVICES:=mediatek_mt7986-rfb
219 UBOOT_CONFIG:=mt7986_rfb
220 UBOOT_IMAGE:=u-boot.fip
221 BL2_BOOTDEV:=sdmmc
222 BL2_SOC:=mt7986
223 BL2_DDRTYPE:=ddr4
224 DEPENDS:=+trusted-firmware-a-mt7986-sdmmc-ddr4
225 endef
226
227 define U-Boot/mt7986_bananapi_bpi-r3-emmc
228 NAME:=BananaPi BPi-R3
229 BUILD_SUBTARGET:=filogic
230 BUILD_DEVICES:=bananapi_bpi-r3
231 UBOOT_CONFIG:=mt7986a_bpi-r3-emmc
232 UBOOT_IMAGE:=u-boot.fip
233 BL2_BOOTDEV:=emmc
234 BL2_SOC:=mt7986
235 BL2_DDRTYPE:=ddr4
236 DEPENDS:=+trusted-firmware-a-mt7986-emmc-ddr4
237 endef
238
239 define U-Boot/mt7986_bananapi_bpi-r3-sdmmc
240 NAME:=BananaPi BPi-R3
241 BUILD_SUBTARGET:=filogic
242 BUILD_DEVICES:=bananapi_bpi-r3
243 UBOOT_CONFIG:=mt7986a_bpi-r3-sd
244 UBOOT_IMAGE:=u-boot.fip
245 BL2_BOOTDEV:=sdmmc
246 BL2_SOC:=mt7986
247 BL2_DDRTYPE:=ddr4
248 DEPENDS:=+trusted-firmware-a-mt7986-sdmmc-ddr4
249 endef
250
251 define U-Boot/mt7986_bananapi_bpi-r3-snand
252 NAME:=BananaPi BPi-R3
253 BUILD_SUBTARGET:=filogic
254 BUILD_DEVICES:=bananapi_bpi-r3
255 UBOOT_CONFIG:=mt7986a_bpi-r3-snand
256 UBOOT_IMAGE:=u-boot.fip
257 BL2_BOOTDEV:=spim-nand
258 BL2_SOC:=mt7986
259 BL2_DDRTYPE:=ddr4
260 DEPENDS:=+trusted-firmware-a-mt7986-spim-nand-ddr4
261 endef
262
263 define U-Boot/mt7986_bananapi_bpi-r3-nor
264 NAME:=BananaPi BPi-R3
265 BUILD_SUBTARGET:=filogic
266 BUILD_DEVICES:=bananapi_bpi-r3
267 UBOOT_CONFIG:=mt7986a_bpi-r3-nor
268 UBOOT_IMAGE:=u-boot.fip
269 BL2_BOOTDEV:=nor
270 BL2_SOC:=mt7986
271 BL2_DDRTYPE:=ddr4
272 DEPENDS:=+trusted-firmware-a-mt7986-nor-ddr4
273 FIP_COMPRESS:=1
274 endef
275
276 define U-Boot/mt7986_tplink_tl-xdr4288
277 NAME:=TP-LINK TL-XDR4288
278 BUILD_SUBTARGET:=filogic
279 BUILD_DEVICES:=tplink_tl-xdr4288
280 UBOOT_CONFIG:=mt7986_tplink_tl-xdr4288
281 UBOOT_IMAGE:=u-boot.fip
282 BL2_BOOTDEV:=spim-nand
283 BL2_SOC:=mt7986
284 BL2_DDRTYPE:=ddr3
285 DEPENDS:=+trusted-firmware-a-mt7986-spim-nand-ddr3
286 endef
287
288 define U-Boot/mt7986_tplink_tl-xdr6086
289 NAME:=TP-LINK TL-XDR6086
290 BUILD_SUBTARGET:=filogic
291 BUILD_DEVICES:=tplink_tl-xdr6086
292 UBOOT_CONFIG:=mt7986_tplink_tl-xdr6086
293 UBOOT_IMAGE:=u-boot.fip
294 BL2_BOOTDEV:=spim-nand
295 BL2_SOC:=mt7986
296 BL2_DDRTYPE:=ddr3
297 DEPENDS:=+trusted-firmware-a-mt7986-spim-nand-ddr3
298 endef
299
300 define U-Boot/mt7986_tplink_tl-xdr6088
301 NAME:=TP-LINK TL-XDR6088
302 BUILD_SUBTARGET:=filogic
303 BUILD_DEVICES:=tplink_tl-xdr6088
304 UBOOT_CONFIG:=mt7986_tplink_tl-xdr6088
305 UBOOT_IMAGE:=u-boot.fip
306 BL2_BOOTDEV:=spim-nand
307 BL2_SOC:=mt7986
308 BL2_DDRTYPE:=ddr3
309 DEPENDS:=+trusted-firmware-a-mt7986-spim-nand-ddr3
310 endef
311
312 define U-Boot/mt7986_xiaomi_redmi-router-ax6000
313 NAME:=Xiaomi Redmi AX6000
314 BUILD_SUBTARGET:=filogic
315 BUILD_DEVICES:=xiaomi_redmi-router-ax6000-ubootmod
316 UBOOT_CONFIG:=mt7986_xiaomi_redmi-ax6000
317 UBOOT_IMAGE:=u-boot.fip
318 BL2_BOOTDEV:=spim-nand
319 BL2_SOC:=mt7986
320 BL2_DDRTYPE:=ddr4
321 DEPENDS:=+trusted-firmware-a-mt7986-spim-nand-ddr4
322 endef
323
324 define U-Boot/mt7988_rfb-spim-nand
325 NAME:=MT7988 Reference Board
326 BUILD_SUBTARGET:=filogic
327 BUILD_DEVICES:=mediatek_mt7988a-rfb-nand
328 UBOOT_CONFIG:=mt7988_rfb
329 UBOOT_IMAGE:=u-boot.fip
330 BL2_BOOTDEV:=spim-nand
331 BL2_SOC:=mt7988
332 BL2_DDRTYPE:=ddr4
333 DEPENDS:=+trusted-firmware-a-mt7988-spim-nand-ddr4
334 endef
335
336 define U-Boot/mt7988_rfb-snand
337 NAME:=MT7988 Reference Board
338 BUILD_SUBTARGET:=filogic
339 BUILD_DEVICES:=mediatek_mt7988a-rfb-nand
340 UBOOT_CONFIG:=mt7988_rfb
341 UBOOT_IMAGE:=u-boot.fip
342 BL2_BOOTDEV:=snand
343 BL2_SOC:=mt7988
344 BL2_DDRTYPE:=ddr4
345 DEPENDS:=+trusted-firmware-a-mt7988-snand-ddr4
346 endef
347
348 define U-Boot/mt7988_rfb-nor
349 NAME:=MT7988 Reference Board
350 BUILD_SUBTARGET:=filogic
351 BUILD_DEVICES:=mediatek_mt7988a-rfb-nand
352 UBOOT_CONFIG:=mt7988_rfb
353 UBOOT_IMAGE:=u-boot.fip
354 BL2_BOOTDEV:=nor
355 BL2_SOC:=mt7988
356 BL2_DDRTYPE:=ddr4
357 DEPENDS:=+trusted-firmware-a-mt7988-nor-ddr4
358 endef
359
360 define U-Boot/mt7988_rfb-emmc
361 NAME:=MT7988 Reference Board
362 BUILD_SUBTARGET:=filogic
363 BUILD_DEVICES:=mediatek_mt7988a-rfb-nand
364 UBOOT_CONFIG:=mt7988_rfb
365 UBOOT_IMAGE:=u-boot.fip
366 BL2_BOOTDEV:=emmc
367 BL2_SOC:=mt7988
368 BL2_DDRTYPE:=ddr4
369 DEPENDS:=+trusted-firmware-a-mt7988-emmc-ddr4
370 endef
371
372 define U-Boot/mt7988_rfb-sd
373 NAME:=MT7988 Reference Board
374 BUILD_SUBTARGET:=filogic
375 BUILD_DEVICES:=mediatek_mt7988a-rfb-nand
376 UBOOT_CONFIG:=mt7988_sd_rfb
377 UBOOT_IMAGE:=u-boot.fip
378 BL2_BOOTDEV:=sdmmc
379 BL2_SOC:=mt7988
380 BL2_DDRTYPE:=ddr4
381 DEPENDS:=+trusted-firmware-a-mt7988-sdmmc-ddr4
382 endef
383
384 UBOOT_TARGETS := \
385 mt7620_mt7530_rfb \
386 mt7620_rfb \
387 mt7621_nand_rfb \
388 mt7621_rfb \
389 mt7622_bananapi_bpi-r64-emmc \
390 mt7622_bananapi_bpi-r64-sdmmc \
391 mt7622_bananapi_bpi-r64-snand \
392 mt7622_linksys_e8450 \
393 mt7622_rfb1 \
394 mt7622_ubnt_unifi-6-lr \
395 mt7623n_bpir2 \
396 mt7623a_unielec_u7623 \
397 mt7628_rfb \
398 ravpower_rp-wd009 \
399 mt7629_rfb \
400 mt7981_h3c_magic-nx30-pro \
401 mt7981_qihoo_360t7 \
402 mt7981_xiaomi_mi-router-wr30u \
403 mt7986_bananapi_bpi-r3-emmc \
404 mt7986_bananapi_bpi-r3-sdmmc \
405 mt7986_bananapi_bpi-r3-snand \
406 mt7986_bananapi_bpi-r3-nor \
407 mt7986_tplink_tl-xdr4288 \
408 mt7986_tplink_tl-xdr6086 \
409 mt7986_tplink_tl-xdr6088 \
410 mt7986_xiaomi_redmi-router-ax6000 \
411 mt7986_rfb \
412 mt7988_rfb-spim-nand \
413 mt7988_rfb-snand \
414 mt7988_rfb-nor \
415 mt7988_rfb-emmc \
416 mt7988_rfb-sd
417
418 ifdef CONFIG_TARGET_mediatek
419 UBOOT_MAKE_FLAGS += $(UBOOT_IMAGE:.fip=.bin)
420 endif
421
422 define Build/fip-image
423 $(if $(FIP_COMPRESS),\
424 xz -f -e -k -9 -C crc32 $(STAGING_DIR_IMAGE)/$(if $(BL2_SOC),$(BL2_SOC),$(BUILD_SUBTARGET))-$(BL2_BOOTDEV)-$(if $(BL2_DDRTYPE),$(BL2_DDRTYPE)-)$(if $(BL2_DDRBLOB),$(BL2_DDRBLOB)ddr-)bl31.bin ;\
425 xz -f -e -k -9 -C crc32 $(PKG_BUILD_DIR)/u-boot.bin \
426 )
427 $(STAGING_DIR_HOST)/bin/fiptool create \
428 --soc-fw $(STAGING_DIR_IMAGE)/$(if $(BL2_SOC),$(BL2_SOC),$(BUILD_SUBTARGET))-$(BL2_BOOTDEV)-$(if $(BL2_DDRTYPE),$(BL2_DDRTYPE)-)$(if $(BL2_DDRBLOB),$(BL2_DDRBLOB)ddr-)bl31.bin$(if $(FIP_COMPRESS),.xz) \
429 --nt-fw $(PKG_BUILD_DIR)/u-boot.bin$(if $(FIP_COMPRESS),.xz) \
430 $(PKG_BUILD_DIR)/u-boot.fip
431 endef
432
433 ifdef CONFIG_TARGET_ramips_mt7621
434 define Build/Prepare
435 $(call Build/Prepare/Default)
436 ifdef CONFIG_DEBUG
437 $(CP) $(DL_DIR)/mt7621_stage_sram.bin $(PKG_BUILD_DIR)/
438 else
439 $(CP) $(DL_DIR)/mt7621_stage_sram_noprint.bin $(PKG_BUILD_DIR)/mt7621_stage_sram.bin
440 endif
441 endef
442 endif
443
444 define Build/Configure
445 $(call Build/Configure/U-Boot)
446 sed -i 's/CONFIG_TOOLS_LIBCRYPTO=y/# CONFIG_TOOLS_LIBCRYPTO is not set/' $(PKG_BUILD_DIR)/.config
447 endef
448
449 define Build/Compile
450 $(call Build/Compile/U-Boot)
451 ifeq ($(UBOOT_IMAGE),u-boot.fip)
452 $(call Build/fip-image)
453 endif
454 endef
455
456 # don't stage files to bindir, let target/linux/mediatek/image/*.mk do that
457 ifdef CONFIG_TARGET_mediatek
458 define Package/u-boot/install
459 endef
460 endif
461
462 define Build/InstallDev
463 $(INSTALL_DIR) $(STAGING_DIR_IMAGE)
464 $(INSTALL_DATA) $(PKG_BUILD_DIR)/$(UBOOT_IMAGE) $(STAGING_DIR_IMAGE)/$(BUILD_VARIANT)-$(UBOOT_IMAGE)
465 endef
466
467 $(eval $(call BuildPackage/U-Boot))