include $(TOPDIR)/rules.mk
-PKG_NAME:=arm-trusted-firmware-mvebu
-PKG_VERSION:=2.2
-PKG_RELEASE:=2
-
-PKG_SOURCE_PROTO:=git
-PKG_SOURCE:=$(PKG_NAME)-$(PKG_RELEASE).tar.xz
-PKG_SOURCE_URL:=https://git.trustedfirmware.org/TF-A/trusted-firmware-a.git
-PKG_SOURCE_DATE:=2020-01-21
-PKG_SOURCE_VERSION:=3b3d406ebc6f5dae6b5c9170c674183026e7301b
-PKG_MIRROR_HASH:=7c63da237c52808e1fe49458d5a4ac804a8eb4c365e26c6b2b709256e8fc041f
+PKG_VERSION:=2.7
+PKG_RELEASE:=6
+PKG_HASH:=53422dc649153838e03820330ba17cb10afe3e330ecde0db11e4d5f1361a33e6
PKG_MAINTAINER:=Vladimir Vid <vladimir.vid@sartura.hr>
+include $(INCLUDE_DIR)/kernel.mk
+include $(INCLUDE_DIR)/trusted-firmware-a.mk
include $(INCLUDE_DIR)/package.mk
-define Package/arm-trusted-firmware-mvebu
- SECTION:=boot
- CATEGORY:=Boot Loaders
- TITLE:=ARM Trusted Firmware for mvebu devices
+define Trusted-Firmware-A/Default
+ BUILD_TARGET:=mvebu
+ BUILD_SUBTARGET:=cortexa53
+ TFA_IMAGE:=flash-image.bin uart-images.tgz.bin
+ UBOOT:=
+ DDR_TOPOLOGY:=
+ CLOCKSPRESET:=
+endef
+
+
+define Trusted-Firmware-A/espressobin-512mb
+ NAME:=Marvell ESPRESSObin (512MB)
+ DEPENDS:=+u-boot-espressobin
+ BUILD_DEVICES:=globalscale_espressobin
+ UBOOT:=espressobin
+ DDR_TOPOLOGY:=0
+ CLOCKSPRESET:=CPU_1000_DDR_800
+ PLAT:=a3700
+endef
+
+define Trusted-Firmware-A/espressobin-v3-v5-1gb-1cs
+ NAME:=Marvell ESPRESSObin V3-V5 (1GB 1CS)
+ DEPENDS:=+u-boot-espressobin
+ BUILD_DEVICES:=globalscale_espressobin
+ UBOOT:=espressobin
+ DDR_TOPOLOGY:=4
+ CLOCKSPRESET:=CPU_1000_DDR_800
+ PLAT:=a3700
+endef
+
+define Trusted-Firmware-A/espressobin-v3-v5-1gb-2cs
+ NAME:=Marvell ESPRESSObin V3-V5 (1GB, 2CS)
+ DEPENDS:=+u-boot-espressobin
+ BUILD_DEVICES:=globalscale_espressobin
+ UBOOT:=espressobin
+ DDR_TOPOLOGY:=2
+ CLOCKSPRESET:=CPU_1000_DDR_800
+ PLAT:=a3700
+endef
+
+define Trusted-Firmware-A/espressobin-v3-v5-2gb
+ NAME:=Marvell ESPRESSObin V3-V5 (2GB)
+ DEPENDS:=+u-boot-espressobin
+ BUILD_DEVICES:=globalscale_espressobin
+ UBOOT:=espressobin
+ DDR_TOPOLOGY:=7
+ CLOCKSPRESET:=CPU_1000_DDR_800
+ PLAT:=a3700
+endef
+
+define Trusted-Firmware-A/espressobin-v7-1gb
+ NAME:=Marvell ESPRESSObin V7 (1GB)
+ DEPENDS:=+u-boot-espressobin
+ BUILD_DEVICES:=globalscale_espressobin-v7
+ UBOOT:=espressobin
+ DDR_TOPOLOGY:=5
+ CLOCKSPRESET:=CPU_1000_DDR_800
+ PLAT:=a3700
+endef
+
+define Trusted-Firmware-A/espressobin-v7-2gb
+ NAME:=Marvell ESPRESSObin V7 (2GB)
+ DEPENDS:=+u-boot-espressobin
+ BUILD_DEVICES:=globalscale_espressobin-v7
+ UBOOT:=espressobin
+ DDR_TOPOLOGY:=6
+ CLOCKSPRESET:=CPU_1000_DDR_800
+ PLAT:=a3700
endef
-define Package/arm-trusted-firmware-mvebu/uDPU
-$(call Package/arm-trusted-firmware-mvebu)
- BOARDNAME:=uDPU
- TITLE:=ARM Trusted Firmware for Methode uDPU
+define Trusted-Firmware-A/udpu
+ NAME:=Methode uDPU
DEPENDS:=+u-boot-uDPU
+ BUILD_DEVICES:=methode_udpu
UBOOT:=uDPU
+ DDR_TOPOLOGY:=0
CLOCKSPRESET:=CPU_1000_DDR_800
PLAT:=a3700
endef
+define Trusted-Firmware-A/edpu
+ NAME:=Methode eDPU
+ DEPENDS:=+u-boot-eDPU
+ BUILD_DEVICES:=methode_edpu
+ UBOOT:=eDPU
+ DDR_TOPOLOGY:=0
+ CLOCKSPRESET:=CPU_1000_DDR_800
+ PLAT:=a3700
+endef
+
+
+TFA_TARGETS:= \
+ espressobin-512mb \
+ espressobin-v3-v5-1gb-1cs \
+ espressobin-v3-v5-1gb-2cs \
+ espressobin-v3-v5-2gb \
+ espressobin-v7-1gb \
+ espressobin-v7-2gb \
+ udpu \
+ edpu
+
+TFA_MAKE_FLAGS += \
+ CROSS_CM3=$(BUILD_DIR)/$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION)/bin/arm-none-eabi- \
+ BL33=$(STAGING_DIR_IMAGE)/$(UBOOT)-u-boot.bin \
+ MV_DDR_PATH=$(BUILD_DIR)/$(MV_DDR_NAME) \
+ WTP=$(BUILD_DIR)/$(A3700_UTILS_NAME) \
+ WTMI_IMG=$(BUILD_DIR)/$(MOX_BB_NAME)/wtmi_app.bin \
+ CRYPTOPP_PATH=$(BUILD_DIR)/$(CRYPTOPP_NAME) \
+ HOST_LDFLAGS="$(HOST_LDFLAGS)" \
+ HOST_CPPFLAGS="$(HOST_CPPFLAGS)" \
+ USE_COHERENT_MEM=0 \
+ FIP_ALIGN=0x100 \
+ DDR_TOPOLOGY=$(DDR_TOPOLOGY) \
+ CLOCKSPRESET=$(CLOCKSPRESET) \
+ A3700_UTILS_COMMIT_ID=$(A3700_UTILS_RELEASE) \
+ MV_DDR_COMMIT_ID=$(MV_DDR_RELEASE) \
+ all \
+ mrvl_flash \
+ mrvl_uart
+
A3700_UTILS_NAME:=a3700-utils
-A3700_UTILS_RELEASE:=18.12.1
+A3700_UTILS_RELEASE:=a3e1c67
A3700_UTILS_SOURCE=$(A3700_UTILS_NAME)-$(A3700_UTILS_RELEASE).tar.bz2
define Download/a3700-utils
FILE:=$(A3700_UTILS_SOURCE)
PROTO:=git
URL:=https://github.com/MarvellEmbeddedProcessors/A3700-utils-marvell.git
- VERSION:=e6bb176fb9936d9160e53ae09275000dc6440686
- MIRROR_HASH:=c3edf71cbf1fc2e5482d36e36a34c79d682d2c87fdfb909b4dc6327a171e7bd4
+ VERSION:=a3e1c67bb378e1d8a938e1b826cb602af83628d2
+ MIRROR_HASH:=0e6b8ef6423dcb52a5e282669a8aeebc6eea2d45a7c3a2c9a2fc7a749b3275a7
SUBDIR:=$(A3700_UTILS_NAME)
endef
+CRYPTOPP_NAME:=cryptopp
+CRYPTOPP_RELEASE:=4d0cad5
+CRYPTOPP_SOURCE=$(CRYPTOPP_NAME)-$(CRYPTOPP_RELEASE).tar.bz2
+
+define Download/cryptopp
+ FILE:=$(CRYPTOPP_SOURCE)
+ PROTO:=git
+ URL:=https://github.com/weidai11/cryptopp.git
+ VERSION:=4d0cad5401d1a2c998b314bc89288c9620d3021d
+ MIRROR_HASH:=74ec9e48ee04b9f2d9a1d8c4f2392ed0ab52780d7af0f70405d7bbb23d1504fa
+ SUBDIR:=$(CRYPTOPP_NAME)
+endef
+
MV_DDR_NAME:=mv-ddr-marvell
-MV_DDR_RELEASE:=mainline
+MV_DDR_RELEASE:=541616b
MV_DDR_SOURCE:=$(MV_DDR_NAME)-$(MV_DDR_RELEASE).tar.bz2
define Download/mv-ddr-marvell
FILE:=$(MV_DDR_SOURCE)
PROTO:=git
URL:=https://github.com/MarvellEmbeddedProcessors/mv-ddr-marvell.git
- VERSION:=a881467ef0f0185e6570dd0483023fde93cbb5f5
- MIRROR_HASH:=19f34817616c583b2b5f2612705857cf2120f6c2132355217899b1403c3fd336
+ VERSION:=541616bc5d25a0167c9901546255c55973e2c0f0
+ MIRROR_HASH:=9e86a986c7400ed1a72165a88150b6c494ebd87303b16314b43e5785e3f13068
SUBDIR:=$(MV_DDR_NAME)
endef
-LINARO_NAME:=gcc-linaro
-LINARO_RELEASE:=6
-LINARO_VERSION:=5.0-2018.12-$(HOST_ARCH)_arm-linux-gnueabi
-LINARO_SOURCE=$(LINARO_NAME)-$(LINARO_RELEASE).$(LINARO_VERSION).tar.xz
+MOX_BB_NAME:=mox-boot-builder
+MOX_BB_RELEASE:=604f8f51
+MOX_BB_SOURCE:=$(MOX_BB_NAME)-$(MOX_BB_RELEASE).tar.bz2
+
+define Download/mox-boot-builder
+ FILE:=$(MOX_BB_SOURCE)
+ PROTO:=git
+ SUBMODULES:=skip
+ URL:=https://gitlab.nic.cz/turris/mox-boot-builder.git
+ VERSION:=604f8f51d97b4e59fa6d1e579101daa194d6ed2d
+ MIRROR_HASH:=b09337a7dde140f57e40133b6e7b7e1eb338e7cea9b15a3af6874824462f15f7
+ SUBDIR:=$(MOX_BB_NAME)
+endef
-define Download/gcc-linaro
- FILE:=$(LINARO_SOURCE)
- URL:=https://releases.linaro.org/components/toolchain/binaries/latest-$(LINARO_RELEASE)/arm-linux-gnueabi/
- HASH:=2d4a92d6c8b384ae404b2e02c1c412e3ec18f9b714135acf046b2b1b510e9ace
+CM3_GCC_NAME:=gcc-arm
+CM3_GCC_RELEASE:=11.2-2022.02
+CM3_GCC_VERSION:=$(HOST_ARCH)-arm-none-eabi
+CM3_GCC_SOURCE=$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION).tar.xz
+
+define Download/cm3-gcc
+ FILE:=$(CM3_GCC_SOURCE)
+ URL:=https://developer.arm.com/-/media/Files/downloads/gnu/$(CM3_GCC_RELEASE)/binrel
+ifeq ($(HOST_ARCH),aarch64)
+ HASH:=ef1d82e5894e3908cb7ed49c5485b5b95deefa32872f79c2b5f6f5447cabf55f
+else
+ HASH:=8c5acd5ae567c0100245b0556941c237369f210bceb196edfe5a2e7532c60326
+endif
+endef
+
+define Build/Clean
+ rm -rf \
+ $(BUILD_DIR)/$(CRYPTOPP_NAME) \
+ $(BUILD_DIR)/$(A3700_UTILS_NAME) \
+ $(BUILD_DIR)/$(MV_DDR_NAME) \
+ $(BUILD_DIR)/$(MOX_BB_NAME) \
+ $(BUILD_DIR)/$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION)
endef
define Build/Prepare
# Download sources
$(eval $(call Download,a3700-utils))
$(eval $(call Download,mv-ddr-marvell))
- $(eval $(call Download,gcc-linaro))
+ $(eval $(call Download,mox-boot-builder))
+ $(eval $(call Download,cryptopp))
+ $(eval $(call Download,cm3-gcc))
$(call Build/Prepare/Default,)
- mkdir -p $(STAGING_DIR_IMAGE)
- $(TAR) -C $(STAGING_DIR_IMAGE) -xf $(DL_DIR)/$(A3700_UTILS_SOURCE)
- $(TAR) -C $(STAGING_DIR_IMAGE) -xf $(DL_DIR)/$(MV_DDR_SOURCE)
- $(TAR) -C $(STAGING_DIR_IMAGE) -xf $(DL_DIR)/$(LINARO_SOURCE)
+ $(TAR) -C $(BUILD_DIR) -xf $(DL_DIR)/$(CRYPTOPP_SOURCE)
+ $(TAR) -C $(BUILD_DIR) -xf $(DL_DIR)/$(A3700_UTILS_SOURCE)
+ $(call PatchDir/Default,$(BUILD_DIR)/$(A3700_UTILS_NAME),./patches-a3700-utils)
+ $(TAR) -C $(BUILD_DIR) -xf $(DL_DIR)/$(MV_DDR_SOURCE)
+ $(call PatchDir/Default,$(BUILD_DIR)/$(MV_DDR_NAME),./patches-mv-ddr-marvell)
+ $(TAR) -C $(BUILD_DIR) -xf $(DL_DIR)/$(MOX_BB_SOURCE)
+ $(call PatchDir/Default,$(BUILD_DIR)/$(MOX_BB_NAME),./patches-mox-boot-builder)
+ $(TAR) -C $(BUILD_DIR) -xf $(DL_DIR)/$(CM3_GCC_SOURCE)
endef
-TARGET_CFLAGS = ""
-
-MAKE_VARS= \
- CROSS_COMPILE="$(TARGET_CROSS)"
-
-MAKE_FLAGS = \
- CROSS_CM3=$(STAGING_DIR_IMAGE)/$(LINARO_NAME)-$(LINARO_RELEASE).$(LINARO_VERSION)/bin/arm-linux-gnueabi- \
- BL33=$(STAGING_DIR_IMAGE)/$(UBOOT)-u-boot.bin \
- MV_DDR_PATH=$(STAGING_DIR_IMAGE)/$(MV_DDR_NAME) \
- WTP=$(STAGING_DIR_IMAGE)/$(A3700_UTILS_NAME) \
- CLOCKSPRESET=$(CLOCKSPRESET) \
- PLAT=$(PLAT) \
- all \
- fip
-
-define Build/InstallDev
- $(CP) $(PKG_BUILD_DIR)/build/$(PLAT)/release/flash-image.bin $(BIN_DIR)/u-boot-$(BOARDNAME)/
+define Build/Compile
+ +$(MAKE) \
+ CROSS_CM3=$(BUILD_DIR)/$(CM3_GCC_NAME)-$(CM3_GCC_RELEASE)-$(CM3_GCC_VERSION)/bin/arm-none-eabi- \
+ WTMI_VERSION=$(MOX_BB_RELEASE) \
+ CRYPTOPP_PATH=$PWD/cryptopp/ \
+ -C $(BUILD_DIR)/$(MOX_BB_NAME) \
+ wtmi_app.bin
+ $(call Build/Compile/Default)
endef
-$(eval $(call BuildPackage,arm-trusted-firmware-mvebu/uDPU))
+$(eval $(call BuildPackage/Trusted-Firmware-A))