blob: e171f3ac97746c9361fbd60afac4418f1d7b3496 [file] [log] [blame]
Pascal Brandefe56592016-03-03 10:46:52 +01001################################################################################
2# Following variables defines how the NS_USER (Non Secure User - Client
3# Application), NS_KERNEL (Non Secure Kernel), S_KERNEL (Secure Kernel) and
4# S_USER (Secure User - TA) are compiled
5################################################################################
6override COMPILE_NS_USER := 64
7override COMPILE_NS_KERNEL := 64
8override COMPILE_S_USER := 64
9override COMPILE_S_KERNEL := 64
10
Victor Chong7a716512017-09-11 15:18:44 +010011include common.mk
Jens Wiklanderbab50842016-02-17 15:45:10 +010012
13################################################################################
Jens Wiklanderbab50842016-02-17 15:45:10 +010014# Paths to git projects and various binaries
15################################################################################
Victor Chongdf54b112019-08-11 15:58:12 +010016TF_A_PATH ?= $(ROOT)/trusted-firmware-a
Jens Wiklanderbab50842016-02-17 15:45:10 +010017
18U-BOOT_PATH ?= $(ROOT)/u-boot
19U-BOOT_BIN ?= $(U-BOOT_PATH)/u-boot.bin
20
21################################################################################
22# Targets
23################################################################################
Jens Wiklanderd612e4a2018-05-04 14:21:17 +020024all: arm-tf u-boot linux optee-os buildroot
25clean: arm-tf-clean buildroot-clean u-boot-clean optee-os-clean
Jens Wiklanderbab50842016-02-17 15:45:10 +010026
Victor Chong7a716512017-09-11 15:18:44 +010027include toolchain.mk
Jens Wiklanderbab50842016-02-17 15:45:10 +010028
29################################################################################
30# ARM Trusted Firmware
31################################################################################
Victor Chong371d7c22019-08-08 17:17:14 +010032TF_A_EXPORTS ?= \
Joakim Bech69a8a372016-04-26 11:05:04 +020033 CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)"
Jens Wiklanderbab50842016-02-17 15:45:10 +010034
Victor Chong371d7c22019-08-08 17:17:14 +010035TF_A_FLAGS ?= \
Jens Wiklander2f42f802018-04-04 13:46:49 +020036 SCP_BL2=$(ROOT)/vexpress-firmware/SOFTWARE/scp_bl2.bin \
Jens Wiklander7abd3ed2017-09-04 10:22:40 +020037 BL32=$(OPTEE_OS_HEADER_V2_BIN) \
38 BL32_EXTRA1=$(OPTEE_OS_PAGER_V2_BIN) \
39 BL32_EXTRA2=$(OPTEE_OS_PAGEABLE_V2_BIN) \
Jens Wiklanderbab50842016-02-17 15:45:10 +010040 BL33=$(U-BOOT_BIN) \
41 DEBUG=0 \
42 ARM_TSP_RAM_LOCATION=dram \
43 PLAT=juno \
44 SPD=opteed
45
46arm-tf: optee-os u-boot
Victor Chong371d7c22019-08-08 17:17:14 +010047 $(TF_A_EXPORTS) $(MAKE) -C $(TF_A_PATH) $(TF_A_FLAGS) all fip
Jens Wiklanderbab50842016-02-17 15:45:10 +010048
49arm-tf-clean:
Victor Chong371d7c22019-08-08 17:17:14 +010050 $(TF_A_EXPORTS) $(MAKE) -C $(TF_A_PATH) $(TF_A_FLAGS) clean
Jens Wiklanderbab50842016-02-17 15:45:10 +010051
52################################################################################
Jens Wiklanderbab50842016-02-17 15:45:10 +010053# Das U-Boot
54################################################################################
55
56U-BOOT_EXPORTS ?= CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)"
57
58U-BOOT_DEFCONFIG_FILES := \
59 $(U-BOOT_PATH)/configs/vexpress_aemv8a_juno_defconfig \
60 $(ROOT)/build/kconfigs/u-boot_juno.conf
61
62.PHONY: u-boot
Victor Chong9f0d1202016-04-23 16:28:31 +010063u-boot:
Jens Wiklanderbab50842016-02-17 15:45:10 +010064 cd $(U-BOOT_PATH) && \
65 scripts/kconfig/merge_config.sh $(U-BOOT_DEFCONFIG_FILES)
66 $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) all
Victor Chong9f0d1202016-04-23 16:28:31 +010067
Jens Wiklanderbab50842016-02-17 15:45:10 +010068u-boot-clean:
69 $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) clean
70
71################################################################################
72# Linux kernel
73################################################################################
74LINUX_DEFCONFIG_COMMON_ARCH := arm64
75LINUX_DEFCONFIG_COMMON_FILES := \
76 $(LINUX_PATH)/arch/arm64/configs/defconfig \
77 $(CURDIR)/kconfigs/juno.conf
78
79linux-defconfig: $(LINUX_PATH)/.config
80
81LINUX_COMMON_FLAGS += ARCH=arm64
82
83linux: linux-common
84
85linux-defconfig-clean: linux-defconfig-clean-common
86
87LINUX_CLEAN_COMMON_FLAGS += ARCH=arm64
88
89linux-clean: linux-clean-common
90
91LINUX_CLEANER_COMMON_FLAGS += ARCH=arm64
92
93linux-cleaner: linux-cleaner-common
94
95################################################################################
96# OP-TEE
97################################################################################
Pascal Brandefe56592016-03-03 10:46:52 +010098OPTEE_OS_COMMON_FLAGS += PLATFORM=vexpress-juno
Jens Wiklanderbab50842016-02-17 15:45:10 +010099optee-os: optee-os-common
100
101OPTEE_OS_CLEAN_COMMON_FLAGS += PLATFORM=vexpress-juno
102optee-os-clean: optee-os-clean-common
103
Jens Wiklanderbab50842016-02-17 15:45:10 +0100104
Jens Wiklanderd612e4a2018-05-04 14:21:17 +0200105$(ROOT)/out-br/images/ramdisk.img: $(ROOT)/out-br/images/rootfs.cpio.gz
Jens Wiklanderbab50842016-02-17 15:45:10 +0100106 $(U-BOOT_PATH)/tools/mkimage -A arm64 -O linux -T ramdisk -C gzip \
Jens Wiklanderd612e4a2018-05-04 14:21:17 +0200107 -d $< $@
Jens Wiklanderbab50842016-02-17 15:45:10 +0100108
109FTP-UPLOAD = ftp-upload -v --host $(JUNO_IP) --dir SOFTWARE
110
111.PHONY: flash
Jens Wiklanderd612e4a2018-05-04 14:21:17 +0200112flash: $(ROOT)/out-br/images/ramdisk.img
Jens Wiklanderbab50842016-02-17 15:45:10 +0100113 @test -n "$(JUNO_IP)" || \
114 (echo "JUNO_IP not set" ; exit 1)
Jens Wiklander2f42f802018-04-04 13:46:49 +0200115 $(FTP-UPLOAD) $(ROOT)/vexpress-firmware/SOFTWARE/scp_bl1.bin
Victor Chong371d7c22019-08-08 17:17:14 +0100116 $(FTP-UPLOAD) $(TF_A_PATH)/build/juno/release/bl1.bin
117 $(FTP-UPLOAD) $(TF_A_PATH)/build/juno/release/fip.bin
Jens Wiklanderbab50842016-02-17 15:45:10 +0100118 $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/Image
119 $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/dts/arm/juno.dtb
Fathi Boudra332f7d32017-10-27 14:49:57 +0300120 $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/dts/arm/juno-r1.dtb
121 $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/dts/arm/juno-r2.dtb
Jens Wiklanderd612e4a2018-05-04 14:21:17 +0200122 $(FTP-UPLOAD) $(ROOT)/out-br/images/ramdisk.img