uboot-mediatek: mt7621: use silent stage1 by default
[openwrt/staging/jow.git] / package / boot / uboot-mediatek / Makefile
1 include $(TOPDIR)/rules.mk
2 include $(INCLUDE_DIR)/kernel.mk
3
4 PKG_VERSION:=2022.07
5 PKG_HASH:=92b08eb49c24da14c1adbf70a71ae8f37cc53eeb4230e859ad8b6733d13dcf5e
6 PKG_BUILD_DEPENDS:=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 endef
38
39 define U-Boot/mt7620_rfb
40 NAME:=MT7620 Reference Board
41 UBOOT_CONFIG:=mt7620_rfb
42 BUILD_DEVICES:=ralink_mt7620a-evb
43 BUILD_TARGET:=ramips
44 BUILD_SUBTARGET:=mt7620
45 UBOOT_IMAGE:=u-boot-with-spl.bin
46 endef
47
48 define U-Boot/mt7620_mt7530_rfb
49 NAME:=MT7620+MT7530 Reference Board
50 UBOOT_CONFIG:=mt7620_mt7530_rfb
51 BUILD_DEVICES:=ralink_mt7620a-mt7530-evb
52 BUILD_TARGET:=ramips
53 BUILD_SUBTARGET:=mt7620
54 UBOOT_IMAGE:=u-boot-with-spl.bin
55 endef
56
57 define U-Boot/mt7621_rfb
58 NAME:=MT7621 Reference Board
59 UBOOT_CONFIG:=mt7621_rfb
60 BUILD_DEVICES:=mediatek_mt7621-eval-board
61 BUILD_TARGET:=ramips
62 BUILD_SUBTARGET:=mt7621
63 UBOOT_IMAGE:=u-boot-mt7621.bin
64 endef
65
66 define U-Boot/mt7621_nand_rfb
67 NAME:=MT7621 Reference Board (NAND)
68 UBOOT_CONFIG:=mt7621_nand_rfb
69 BUILD_DEVICES:=mediatek_mt7621-eval-board
70 BUILD_TARGET:=ramips
71 BUILD_SUBTARGET:=mt7621
72 UBOOT_IMAGE:=u-boot-mt7621.bin
73 endef
74
75 define U-Boot/mt7622_rfb1
76 NAME:=MT7622 Reference Board 1
77 UBOOT_CONFIG:=mt7622_rfb
78 BUILD_DEVICES:=mediatek_mt7622-rfb1 mediatek_mt7622-rfb1-ubi
79 BUILD_SUBTARGET:=mt7622
80 endef
81
82 define U-Boot/mt7622_linksys_e8450
83 NAME:=Linksys E8450
84 UBOOT_CONFIG:=mt7622_linksys_e8450
85 BUILD_DEVICES:=linksys_e8450-ubi
86 BUILD_SUBTARGET:=mt7622
87 UBOOT_IMAGE:=u-boot.fip
88 BL2_BOOTDEV:=snand
89 BL2_DDRBLOB:=1
90 DEPENDS:=+trusted-firmware-a-mt7622-snand-1ddr
91 endef
92
93 define U-Boot/mt7622_bananapi_bpi-r64-emmc
94 NAME:=BananaPi R64 (eMMC)
95 UBOOT_CONFIG:=mt7622_bananapi_bpi-r64-emmc
96 BUILD_DEVICES:=bananapi_bpi-r64
97 BUILD_SUBTARGET:=mt7622
98 UBOOT_IMAGE:=u-boot.fip
99 BL2_BOOTDEV:=emmc
100 BL2_DDRBLOB:=2
101 DEPENDS:=+trusted-firmware-a-mt7622-emmc-2ddr
102 endef
103
104 define U-Boot/mt7622_bananapi_bpi-r64-sdmmc
105 NAME:=BananaPi R64 (SDMMC)
106 UBOOT_CONFIG:=mt7622_bananapi_bpi-r64-sdmmc
107 BUILD_DEVICES:=bananapi_bpi-r64
108 BUILD_SUBTARGET:=mt7622
109 UBOOT_IMAGE:=u-boot.fip
110 BL2_BOOTDEV:=sdmmc
111 BL2_DDRBLOB:=2
112 DEPENDS:=+trusted-firmware-a-mt7622-sdmmc-2ddr
113 endef
114
115 define U-Boot/mt7622_bananapi_bpi-r64-snand
116 NAME:=BananaPi R64 (SNAND)
117 UBOOT_CONFIG:=mt7622_bananapi_bpi-r64-snand
118 BUILD_DEVICES:=bananapi_bpi-r64
119 BUILD_SUBTARGET:=mt7622
120 UBOOT_IMAGE:=u-boot.fip
121 BL2_BOOTDEV:=snand
122 BL2_DDRBLOB:=2
123 DEPENDS:=+trusted-firmware-a-mt7622-snand-2ddr
124 endef
125
126 define U-Boot/mt7622_ubnt_unifi-6-lr
127 NAME:=Ubiquiti UniFi 6 LR
128 UBOOT_CONFIG:=mt7622_ubnt_unifi-6-lr
129 BUILD_DEVICES:=ubnt_unifi-6-lr-v1-ubootmod ubnt_unifi-6-lr-v2-ubootmod
130 BUILD_SUBTARGET:=mt7622
131 UBOOT_IMAGE:=u-boot.fip
132 BL2_BOOTDEV:=nor
133 BL2_DDRBLOB:=2
134 DEPENDS:=+trusted-firmware-a-mt7622-nor-2ddr
135 endef
136
137 define U-Boot/mt7623a_unielec_u7623
138 NAME:=UniElec U7623 (mt7623)
139 BUILD_DEVICES:=unielec_u7623-02
140 BUILD_SUBTARGET:=mt7623
141 UBOOT_CONFIG:=mt7623a_unielec_u7623_02
142 endef
143
144 define U-Boot/mt7623n_bpir2
145 NAME:=Banana Pi R2 (mt7623)
146 BUILD_DEVICES:=bananapi_bpi-r2
147 BUILD_SUBTARGET:=mt7623
148 UBOOT_IMAGE:=u-boot.bin
149 UBOOT_CONFIG:=mt7623n_bpir2
150 endef
151
152 define U-Boot/mt7628_rfb
153 NAME:=MT7628 Reference Board
154 BUILD_DEVICES:=mediatek_mt7628an-eval-board
155 BUILD_TARGET:=ramips
156 BUILD_SUBTARGET:=mt76x8
157 UBOOT_CONFIG:=mt7628_rfb
158 UBOOT_IMAGE:=u-boot-with-spl.bin
159 endef
160
161 define U-Boot/ravpower_rp-wd009
162 NAME:=RAVPower RP-WD009
163 BUILD_TARGET:=ramips
164 BUILD_DEVICES:=ravpower_rp-wd009
165 BUILD_SUBTARGET:=mt76x8
166 UBOOT_CONFIG:=ravpower-rp-wd009-ram
167 UBOOT_IMAGE:=u-boot.bin
168 endef
169
170 define U-Boot/mt7629_rfb
171 NAME:=MT7629 Reference Board
172 BUILD_SUBTARGET:=mt7629
173 BUILD_DEVICES:=mediatek_mt7629-rfb
174 UBOOT_CONFIG:=mt7629_rfb
175 endef
176
177 UBOOT_TARGETS := \
178 mt7620_mt7530_rfb \
179 mt7620_rfb \
180 mt7621_nand_rfb \
181 mt7621_rfb \
182 mt7622_bananapi_bpi-r64-emmc \
183 mt7622_bananapi_bpi-r64-sdmmc \
184 mt7622_bananapi_bpi-r64-snand \
185 mt7622_linksys_e8450 \
186 mt7622_rfb1 \
187 mt7622_ubnt_unifi-6-lr \
188 mt7623n_bpir2 \
189 mt7623a_unielec_u7623 \
190 mt7628_rfb \
191 ravpower_rp-wd009 \
192 mt7629_rfb
193
194 ifdef CONFIG_TARGET_mediatek
195 UBOOT_MAKE_FLAGS += $(UBOOT_IMAGE:.fip=.bin)
196 endif
197
198 define Build/fip-image
199 $(STAGING_DIR_HOST)/bin/fiptool create \
200 --soc-fw $(STAGING_DIR_IMAGE)/$(BUILD_SUBTARGET)-$(BL2_BOOTDEV)-$(BL2_DDRBLOB)ddr-bl31.bin \
201 --nt-fw $(PKG_BUILD_DIR)/u-boot.bin \
202 $(PKG_BUILD_DIR)/u-boot.fip
203 endef
204
205 ifdef CONFIG_TARGET_ramips_mt7621
206 define Build/Prepare
207 $(call Build/Prepare/Default)
208 ifdef CONFIG_DEBUG
209 $(CP) $(DL_DIR)/mt7621_stage_sram.bin $(PKG_BUILD_DIR)/
210 else
211 $(CP) $(DL_DIR)/mt7621_stage_sram_noprint.bin $(PKG_BUILD_DIR)/mt7621_stage_sram.bin
212 endif
213 endef
214 endif
215
216 define Build/Configure
217 $(call Build/Configure/U-Boot)
218 sed -i 's/CONFIG_TOOLS_LIBCRYPTO=y/# CONFIG_TOOLS_LIBCRYPTO is not set/' $(PKG_BUILD_DIR)/.config
219 endef
220
221 define Build/Compile
222 $(call Build/Compile/U-Boot)
223 ifeq ($(UBOOT_IMAGE),u-boot.fip))
224 $(call Build/fip-image)
225 endif
226 endef
227
228 # don't stage files to bindir, let target/linux/mediatek/image/*.mk do that
229 ifdef CONFIG_TARGET_mediatek
230 define Package/u-boot/install
231 endef
232 endif
233
234 define Build/InstallDev
235 $(INSTALL_DIR) $(STAGING_DIR_IMAGE)
236 $(INSTALL_DATA) $(PKG_BUILD_DIR)/$(UBOOT_IMAGE) $(STAGING_DIR_IMAGE)/$(BUILD_VARIANT)-$(UBOOT_IMAGE)
237 endef
238
239 $(eval $(call BuildPackage/U-Boot))