1592e37f6da505c46c02b997dcff706b4492b892
[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)/$(LINARO_NAME)-$(LINARO_RELEASE).$(LINARO_VERSION)/bin/arm-linux-gnueabi- \
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 USE_COHERENT_MEM=0 \
115 FIP_ALIGN=0x100 \
116 DDR_TOPOLOGY=$(DDR_TOPOLOGY) \
117 CLOCKSPRESET=$(CLOCKSPRESET) \
118 A3700_UTILS_COMMIT_ID=$(A3700_UTILS_RELEASE) \
119 MV_DDR_COMMIT_ID=$(MV_DDR_RELEASE) \
120 all \
121 mrvl_flash \
122 mrvl_uart
123
124 A3700_UTILS_NAME:=a3700-utils
125 A3700_UTILS_RELEASE:=2efdb10f
126 A3700_UTILS_SOURCE=$(A3700_UTILS_NAME)-$(A3700_UTILS_RELEASE).tar.bz2
127
128 define Download/a3700-utils
129 FILE:=$(A3700_UTILS_SOURCE)
130 PROTO:=git
131 URL:=https://github.com/MarvellEmbeddedProcessors/A3700-utils-marvell.git
132 VERSION:=2efdb10f3524c534d276002adf81fec06e0f1cf2
133 MIRROR_HASH:=4476e1bacfa7abb4a1303c6cf3aa7d067038b24090dfd5da13ca2a72a0d5c7a4
134 SUBDIR:=$(A3700_UTILS_NAME)
135 endef
136
137 MV_DDR_NAME:=mv-ddr-marvell
138 MV_DDR_RELEASE:=02e23dbc
139 MV_DDR_SOURCE:=$(MV_DDR_NAME)-$(MV_DDR_RELEASE).tar.bz2
140
141 define Download/mv-ddr-marvell
142 FILE:=$(MV_DDR_SOURCE)
143 PROTO:=git
144 URL:=https://github.com/MarvellEmbeddedProcessors/mv-ddr-marvell.git
145 VERSION:=02e23dbcf8dd22e038986052d99319a0eba8f25f
146 MIRROR_HASH:=d87dcc288b3895d1a1a78908fc607976d500b317ef81edfe667035579df0b440
147 SUBDIR:=$(MV_DDR_NAME)
148 endef
149
150 LINARO_NAME:=gcc-linaro
151 LINARO_RELEASE:=6
152 LINARO_VERSION:=5.0-2018.12-$(HOST_ARCH)_arm-linux-gnueabi
153 LINARO_SOURCE=$(LINARO_NAME)-$(LINARO_RELEASE).$(LINARO_VERSION).tar.xz
154
155 define Download/gcc-linaro
156 FILE:=$(LINARO_SOURCE)
157 URL:=https://releases.linaro.org/components/toolchain/binaries/latest-$(LINARO_RELEASE)/arm-linux-gnueabi/
158 HASH:=2d4a92d6c8b384ae404b2e02c1c412e3ec18f9b714135acf046b2b1b510e9ace
159 endef
160
161 define Build/Clean
162 rm -rf \
163 $(STAGING_DIR_IMAGE)/$(A3700_UTILS_NAME) \
164 $(STAGING_DIR_IMAGE)/$(MV_DDR_NAME) \
165 $(STAGING_DIR_IMAGE)/$(LINARO_NAME)-$(LINARO_RELEASE).$(LINARO_VERSION)
166 endef
167
168 define Build/Prepare
169 # Download sources
170 $(eval $(call Download,a3700-utils))
171 $(eval $(call Download,mv-ddr-marvell))
172 $(eval $(call Download,gcc-linaro))
173
174 $(call Build/Prepare/Default,)
175
176 mkdir -p $(STAGING_DIR_IMAGE)
177 $(TAR) -C $(STAGING_DIR_IMAGE) -xf $(DL_DIR)/$(A3700_UTILS_SOURCE)
178 echo "master" > $(STAGING_DIR_IMAGE)/$(A3700_UTILS_NAME)/branch.txt
179 $(call PatchDir/Default,$(STAGING_DIR_IMAGE)/$(A3700_UTILS_NAME),./patches-a3700-utils)
180 $(TAR) -C $(STAGING_DIR_IMAGE) -xf $(DL_DIR)/$(MV_DDR_SOURCE)
181 echo "master" > $(STAGING_DIR_IMAGE)/$(MV_DDR_NAME)/branch.txt
182 $(call PatchDir/Default,$(STAGING_DIR_IMAGE)/$(MV_DDR_NAME),./patches-mv-ddr-marvell)
183 $(TAR) -C $(STAGING_DIR_IMAGE) -xf $(DL_DIR)/$(LINARO_SOURCE)
184 endef
185
186 $(eval $(call BuildPackage/Trusted-Firmware-A))