blob: 5dadb9e1259584d3e4b388eab2695434a6641aab [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
Jens Wiklanderbab50842016-02-17 15:45:10 +010011DEBUG ?= 0
12
13-include common.mk
14
15################################################################################
Jens Wiklanderbab50842016-02-17 15:45:10 +010016# Paths to git projects and various binaries
17################################################################################
18ARM_TF_PATH ?= $(ROOT)/arm-trusted-firmware
19
20U-BOOT_PATH ?= $(ROOT)/u-boot
21U-BOOT_BIN ?= $(U-BOOT_PATH)/u-boot.bin
22
23################################################################################
24# Targets
25################################################################################
Jens Wiklandercc182e42016-03-29 11:02:32 +020026all: arm-tf u-boot linux optee-os optee-client xtest update_rootfs
Jens Wiklanderbab50842016-02-17 15:45:10 +010027all-clean: arm-tf-clean busybox-clean u-boot-clean optee-os-clean \
Jens Wiklandercc182e42016-03-29 11:02:32 +020028 optee-client-clean
Jens Wiklanderbab50842016-02-17 15:45:10 +010029
30
31-include toolchain.mk
32
33################################################################################
34# ARM Trusted Firmware
35################################################################################
36ARM_TF_EXPORTS ?= \
37 CFLAGS="-O0 -gdwarf-2" \
Joakim Bech69a8a372016-04-26 11:05:04 +020038 CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)"
Jens Wiklanderbab50842016-02-17 15:45:10 +010039
40ARM_TF_FLAGS ?= \
41 SCP_BL2=$(ROOT)/vexpress-firmware/SOFTWARE/bl30.bin \
42 BL32=$(OPTEE_OS_BIN) \
43 BL33=$(U-BOOT_BIN) \
44 DEBUG=0 \
45 ARM_TSP_RAM_LOCATION=dram \
46 PLAT=juno \
47 SPD=opteed
48
49arm-tf: optee-os u-boot
50 $(ARM_TF_EXPORTS) $(MAKE) -C $(ARM_TF_PATH) $(ARM_TF_FLAGS) all fip
51
52arm-tf-clean:
53 $(ARM_TF_EXPORTS) $(MAKE) -C $(ARM_TF_PATH) $(ARM_TF_FLAGS) clean
54
55################################################################################
56# Busybox
57################################################################################
Pascal Brandefe56592016-03-03 10:46:52 +010058BUSYBOX_COMMON_TARGET = fvp
59BUSYBOX_CLEAN_COMMON_TARGET = fvp clean
Jens Wiklanderbab50842016-02-17 15:45:10 +010060
61busybox: busybox-common
62
63busybox-clean: busybox-clean-common
64
65busybox-cleaner: busybox-cleaner-common
66
67################################################################################
68# Das U-Boot
69################################################################################
70
71U-BOOT_EXPORTS ?= CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)"
72
73U-BOOT_DEFCONFIG_FILES := \
74 $(U-BOOT_PATH)/configs/vexpress_aemv8a_juno_defconfig \
75 $(ROOT)/build/kconfigs/u-boot_juno.conf
76
77.PHONY: u-boot
Victor Chong9f0d1202016-04-23 16:28:31 +010078u-boot:
Jens Wiklanderbab50842016-02-17 15:45:10 +010079 cd $(U-BOOT_PATH) && \
80 scripts/kconfig/merge_config.sh $(U-BOOT_DEFCONFIG_FILES)
81 $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) all
Victor Chong9f0d1202016-04-23 16:28:31 +010082
Jens Wiklanderbab50842016-02-17 15:45:10 +010083u-boot-clean:
84 $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) clean
85
86################################################################################
87# Linux kernel
88################################################################################
89LINUX_DEFCONFIG_COMMON_ARCH := arm64
90LINUX_DEFCONFIG_COMMON_FILES := \
91 $(LINUX_PATH)/arch/arm64/configs/defconfig \
92 $(CURDIR)/kconfigs/juno.conf
93
94linux-defconfig: $(LINUX_PATH)/.config
95
96LINUX_COMMON_FLAGS += ARCH=arm64
97
98linux: linux-common
99
100linux-defconfig-clean: linux-defconfig-clean-common
101
102LINUX_CLEAN_COMMON_FLAGS += ARCH=arm64
103
104linux-clean: linux-clean-common
105
106LINUX_CLEANER_COMMON_FLAGS += ARCH=arm64
107
108linux-cleaner: linux-cleaner-common
109
110################################################################################
111# OP-TEE
112################################################################################
Pascal Brandefe56592016-03-03 10:46:52 +0100113OPTEE_OS_COMMON_FLAGS += PLATFORM=vexpress-juno
Jens Wiklanderbab50842016-02-17 15:45:10 +0100114optee-os: optee-os-common
115
116OPTEE_OS_CLEAN_COMMON_FLAGS += PLATFORM=vexpress-juno
117optee-os-clean: optee-os-clean-common
118
119optee-client: optee-client-common
120
121optee-client-clean: optee-client-clean-common
Jens Wiklanderbab50842016-02-17 15:45:10 +0100122################################################################################
123# xtest / optee_test
124################################################################################
125xtest: xtest-common
126
127xtest-clean: xtest-clean-common
128
129xtest-patch: xtest-patch-common
130
131################################################################################
132# Root FS
133################################################################################
134.PHONY: filelist-tee
135filelist-tee:
136 @echo "# xtest / optee_test" > $(GEN_ROOTFS_FILELIST)
137 @find $(OPTEE_TEST_OUT_PATH) -type f -name "xtest" | sed 's/\(.*\)/file \/bin\/xtest \1 755 0 0/g' >> $(GEN_ROOTFS_FILELIST)
138 @echo "# TAs" >> $(GEN_ROOTFS_FILELIST)
139 @echo "dir /lib/optee_armtz 755 0 0" >> $(GEN_ROOTFS_FILELIST)
140 @find $(OPTEE_TEST_OUT_PATH) -name "*.ta" | \
141 sed 's/\(.*\)\/\(.*\)/file \/lib\/optee_armtz\/\2 \1\/\2 444 0 0/g' >> $(GEN_ROOTFS_FILELIST)
142 @echo "# Secure storage dig" >> $(GEN_ROOTFS_FILELIST)
143 @echo "dir /data 755 0 0" >> $(GEN_ROOTFS_FILELIST)
144 @echo "dir /data/tee 755 0 0" >> $(GEN_ROOTFS_FILELIST)
Victor Chongcfb99cf2016-04-26 10:51:58 +0100145 @if [ -e $(OPTEE_GENDRV_MODULE) ]; then \
146 echo "# OP-TEE device" >> $(GEN_ROOTFS_FILELIST); \
147 echo "dir /lib/modules 755 0 0" >> $(GEN_ROOTFS_FILELIST); \
148 echo "dir /lib/modules/$(call KERNEL_VERSION) 755 0 0" >> $(GEN_ROOTFS_FILELIST); \
149 echo "file /lib/modules/$(call KERNEL_VERSION)/optee.ko $(OPTEE_GENDRV_MODULE) 755 0 0" >> $(GEN_ROOTFS_FILELIST); \
150 fi
Jens Wiklanderbab50842016-02-17 15:45:10 +0100151 @echo "# OP-TEE Client" >> $(GEN_ROOTFS_FILELIST)
152 @echo "file /bin/tee-supplicant $(OPTEE_CLIENT_EXPORT)/bin/tee-supplicant 755 0 0" >> $(GEN_ROOTFS_FILELIST)
Joakim Bech69a8a372016-04-26 11:05:04 +0200153 @echo "file /lib/libteec.so.1.0 $(OPTEE_CLIENT_EXPORT)/lib/libteec.so.1.0 755 0 0" >> $(GEN_ROOTFS_FILELIST)
154 @echo "slink /lib/libteec.so.1 libteec.so.1.0 755 0 0" >> $(GEN_ROOTFS_FILELIST)
155 @echo "slink /lib/libteec.so libteec.so.1 755 0 0" >> $(GEN_ROOTFS_FILELIST)
Jens Wiklanderbab50842016-02-17 15:45:10 +0100156
157.PHONY: update_rootfs
Jens Wiklandercc182e42016-03-29 11:02:32 +0200158update_rootfs: u-boot busybox optee-client xtest filelist-tee
Jens Wiklanderbab50842016-02-17 15:45:10 +0100159 cat $(GEN_ROOTFS_PATH)/filelist-final.txt $(GEN_ROOTFS_PATH)/filelist-tee.txt > $(GEN_ROOTFS_PATH)/filelist.tmp
160 cd $(GEN_ROOTFS_PATH) && \
161 $(LINUX_PATH)/usr/gen_init_cpio $(GEN_ROOTFS_PATH)/filelist.tmp | gzip > $(GEN_ROOTFS_PATH)/filesystem.cpio.gz
162 $(U-BOOT_PATH)/tools/mkimage -A arm64 -O linux -T ramdisk -C gzip \
163 -d $(GEN_ROOTFS_PATH)/filesystem.cpio.gz \
164 $(GEN_ROOTFS_PATH)/ramdisk.img
165
166FTP-UPLOAD = ftp-upload -v --host $(JUNO_IP) --dir SOFTWARE
167
168.PHONY: flash
169flash:
170 @test -n "$(JUNO_IP)" || \
171 (echo "JUNO_IP not set" ; exit 1)
172 $(FTP-UPLOAD) $(ROOT)/vexpress-firmware/SOFTWARE/bl0.bin
173 $(FTP-UPLOAD) $(ARM_TF_PATH)/build/juno/release/bl1.bin
174 $(FTP-UPLOAD) $(ARM_TF_PATH)/build/juno/release/fip.bin
175 $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/Image
176 $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/dts/arm/juno.dtb
177 $(FTP-UPLOAD) $(ROOT)/gen_rootfs/ramdisk.img