uboot-mediatek: add TP-Link TL-XDR4288 and TL-XDR608x
[openwrt/openwrt.git] / package / boot / uboot-mediatek / Makefile
1 include $(TOPDIR)/rules.mk
2 include $(INCLUDE_DIR)/kernel.mk
3
4 PKG_VERSION:=2023.04
5 PKG_HASH:=e31cac91545ff41b71cec5d8c22afd695645cd6e2a442ccdacacd60534069341
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/mt7986_rfb
180 NAME:=MT7986 Reference Board
181 BUILD_SUBTARGET:=filogic
182 BUILD_DEVICES:=mediatek_mt7986-rfb
183 UBOOT_CONFIG:=mt7986_rfb
184 UBOOT_IMAGE:=u-boot.fip
185 BL2_BOOTDEV:=sdmmc
186 BL2_SOC:=mt7986
187 BL2_DDRTYPE:=ddr4
188 DEPENDS:=+trusted-firmware-a-mt7986-sdmmc-ddr4
189 endef
190
191 define U-Boot/mt7986_bananapi_bpi-r3-emmc
192 NAME:=BananaPi BPi-R3
193 BUILD_SUBTARGET:=filogic
194 BUILD_DEVICES:=bananapi_bpi-r3
195 UBOOT_CONFIG:=mt7986a_bpi-r3-emmc
196 UBOOT_IMAGE:=u-boot.fip
197 BL2_BOOTDEV:=emmc
198 BL2_SOC:=mt7986
199 BL2_DDRTYPE:=ddr4
200 DEPENDS:=+trusted-firmware-a-mt7986-emmc-ddr4
201 endef
202
203 define U-Boot/mt7986_bananapi_bpi-r3-sdmmc
204 NAME:=BananaPi BPi-R3
205 BUILD_SUBTARGET:=filogic
206 BUILD_DEVICES:=bananapi_bpi-r3
207 UBOOT_CONFIG:=mt7986a_bpi-r3-sd
208 UBOOT_IMAGE:=u-boot.fip
209 BL2_BOOTDEV:=sdmmc
210 BL2_SOC:=mt7986
211 BL2_DDRTYPE:=ddr4
212 DEPENDS:=+trusted-firmware-a-mt7986-sdmmc-ddr4
213 endef
214
215 define U-Boot/mt7986_bananapi_bpi-r3-snand
216 NAME:=BananaPi BPi-R3
217 BUILD_SUBTARGET:=filogic
218 BUILD_DEVICES:=bananapi_bpi-r3
219 UBOOT_CONFIG:=mt7986a_bpi-r3-snand
220 UBOOT_IMAGE:=u-boot.fip
221 BL2_BOOTDEV:=spim-nand
222 BL2_SOC:=mt7986
223 BL2_DDRTYPE:=ddr4
224 DEPENDS:=+trusted-firmware-a-mt7986-spim-nand-ddr4
225 endef
226
227 define U-Boot/mt7986_bananapi_bpi-r3-nor
228 NAME:=BananaPi BPi-R3
229 BUILD_SUBTARGET:=filogic
230 BUILD_DEVICES:=bananapi_bpi-r3
231 UBOOT_CONFIG:=mt7986a_bpi-r3-nor
232 UBOOT_IMAGE:=u-boot.fip
233 BL2_BOOTDEV:=nor
234 BL2_SOC:=mt7986
235 BL2_DDRTYPE:=ddr4
236 DEPENDS:=+trusted-firmware-a-mt7986-nor-ddr4
237 FIP_COMPRESS:=1
238 endef
239
240 define U-Boot/mt7986_tplink_tl-xdr4288
241 NAME:=TP-LINK TL-XDR4288
242 BUILD_SUBTARGET:=filogic
243 BUILD_DEVICES:=tplink_tl-xdr4288
244 UBOOT_CONFIG:=mt7986_tplink_tl-xdr4288
245 UBOOT_IMAGE:=u-boot.fip
246 BL2_BOOTDEV:=spim-nand
247 BL2_SOC:=mt7986
248 BL2_DDRTYPE:=ddr3
249 DEPENDS:=+trusted-firmware-a-mt7986-spim-nand-ddr3
250 endef
251
252 define U-Boot/mt7986_tplink_tl-xdr6086
253 NAME:=TP-LINK TL-XDR6086
254 BUILD_SUBTARGET:=filogic
255 BUILD_DEVICES:=tplink_tl-xdr6086
256 UBOOT_CONFIG:=mt7986_tplink_tl-xdr6086
257 UBOOT_IMAGE:=u-boot.fip
258 BL2_BOOTDEV:=spim-nand
259 BL2_SOC:=mt7986
260 BL2_DDRTYPE:=ddr3
261 DEPENDS:=+trusted-firmware-a-mt7986-spim-nand-ddr3
262 endef
263
264 define U-Boot/mt7986_tplink_tl-xdr6088
265 NAME:=TP-LINK TL-XDR6088
266 BUILD_SUBTARGET:=filogic
267 BUILD_DEVICES:=tplink_tl-xdr6088
268 UBOOT_CONFIG:=mt7986_tplink_tl-xdr6088
269 UBOOT_IMAGE:=u-boot.fip
270 BL2_BOOTDEV:=spim-nand
271 BL2_SOC:=mt7986
272 BL2_DDRTYPE:=ddr3
273 DEPENDS:=+trusted-firmware-a-mt7986-spim-nand-ddr3
274 endef
275
276 define U-Boot/mt7986_xiaomi_redmi-router-ax6000
277 NAME:=Xiaomi Redmi AX6000
278 BUILD_SUBTARGET:=filogic
279 BUILD_DEVICES:=xiaomi_redmi-router-ax6000-ubootmod
280 UBOOT_CONFIG:=mt7986_xiaomi_redmi-ax6000
281 UBOOT_IMAGE:=u-boot.fip
282 BL2_BOOTDEV:=spim-nand
283 BL2_SOC:=mt7986
284 BL2_DDRTYPE:=ddr4
285 DEPENDS:=+trusted-firmware-a-mt7986-spim-nand-ddr4
286 endef
287
288 UBOOT_TARGETS := \
289 mt7620_mt7530_rfb \
290 mt7620_rfb \
291 mt7621_nand_rfb \
292 mt7621_rfb \
293 mt7622_bananapi_bpi-r64-emmc \
294 mt7622_bananapi_bpi-r64-sdmmc \
295 mt7622_bananapi_bpi-r64-snand \
296 mt7622_linksys_e8450 \
297 mt7622_rfb1 \
298 mt7622_ubnt_unifi-6-lr \
299 mt7623n_bpir2 \
300 mt7623a_unielec_u7623 \
301 mt7628_rfb \
302 ravpower_rp-wd009 \
303 mt7629_rfb \
304 mt7986_bananapi_bpi-r3-emmc \
305 mt7986_bananapi_bpi-r3-sdmmc \
306 mt7986_bananapi_bpi-r3-snand \
307 mt7986_bananapi_bpi-r3-nor \
308 mt7986_tplink_tl-xdr4288 \
309 mt7986_tplink_tl-xdr6086 \
310 mt7986_tplink_tl-xdr6088 \
311 mt7986_xiaomi_redmi-router-ax6000 \
312 mt7986_rfb
313
314 ifdef CONFIG_TARGET_mediatek
315 UBOOT_MAKE_FLAGS += $(UBOOT_IMAGE:.fip=.bin)
316 endif
317
318 define Build/fip-image
319 $(if $(FIP_COMPRESS),\
320 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 ;\
321 xz -f -e -k -9 -C crc32 $(PKG_BUILD_DIR)/u-boot.bin \
322 )
323 $(STAGING_DIR_HOST)/bin/fiptool create \
324 --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) \
325 --nt-fw $(PKG_BUILD_DIR)/u-boot.bin$(if $(FIP_COMPRESS),.xz) \
326 $(PKG_BUILD_DIR)/u-boot.fip
327 endef
328
329 ifdef CONFIG_TARGET_ramips_mt7621
330 define Build/Prepare
331 $(call Build/Prepare/Default)
332 ifdef CONFIG_DEBUG
333 $(CP) $(DL_DIR)/mt7621_stage_sram.bin $(PKG_BUILD_DIR)/
334 else
335 $(CP) $(DL_DIR)/mt7621_stage_sram_noprint.bin $(PKG_BUILD_DIR)/mt7621_stage_sram.bin
336 endif
337 endef
338 endif
339
340 define Build/Configure
341 $(call Build/Configure/U-Boot)
342 sed -i 's/CONFIG_TOOLS_LIBCRYPTO=y/# CONFIG_TOOLS_LIBCRYPTO is not set/' $(PKG_BUILD_DIR)/.config
343 endef
344
345 define Build/Compile
346 $(call Build/Compile/U-Boot)
347 ifeq ($(UBOOT_IMAGE),u-boot.fip)
348 $(call Build/fip-image)
349 endif
350 endef
351
352 # don't stage files to bindir, let target/linux/mediatek/image/*.mk do that
353 ifdef CONFIG_TARGET_mediatek
354 define Package/u-boot/install
355 endef
356 endif
357
358 define Build/InstallDev
359 $(INSTALL_DIR) $(STAGING_DIR_IMAGE)
360 $(INSTALL_DATA) $(PKG_BUILD_DIR)/$(UBOOT_IMAGE) $(STAGING_DIR_IMAGE)/$(BUILD_VARIANT)-$(UBOOT_IMAGE)
361 endef
362
363 $(eval $(call BuildPackage/U-Boot))