blob: 449aa3af8eebe2867d55415368e2cc326c2848db [file] [log] [blame]
Philip Attfield3f9250f2016-09-14 07:43:32 +02001################################################################################
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
Philip Attfield3f9250f2016-09-14 07:43:32 +020012
13################################################################################
Philip Attfield3f9250f2016-09-14 07:43:32 +020014# Paths to git projects and various binaries
15################################################################################
16ARM_TF_PATH ?= $(ROOT)/arm-trusted-firmware
17ARM_TF_OUT ?= $(ARM_TF_PATH)/build/rpi3/debug
18ARM_TF_BIN ?= $(ARM_TF_OUT)/bl31.bin
19ARM_TF_TMP ?= $(ARM_TF_OUT)/bl31.tmp
20ARM_TF_HEAD ?= $(ARM_TF_OUT)/bl31.head
21ARM_TF_BOOT ?= $(ARM_TF_OUT)/optee.bin
22
23U-BOOT_PATH ?= $(ROOT)/u-boot
24U-BOOT_BIN ?= $(U-BOOT_PATH)/u-boot.bin
Igor Opaniukaccde812017-07-14 17:36:56 +030025U-BOOT_RPI_BIN ?= $(U-BOOT_PATH)/u-boot-rpi.bin
Philip Attfield3f9250f2016-09-14 07:43:32 +020026
Igor Opaniuk67959e12016-12-21 15:19:27 +020027RPI3_FIRMWARE_PATH ?= $(BUILD_PATH)/rpi3/firmware
28RPI3_HEAD_BIN ?= $(ROOT)/out/head.bin
29RPI3_BOOT_CONFIG ?= $(RPI3_FIRMWARE_PATH)/config.txt
30RPI3_UBOOT_ENV ?= $(ROOT)/out/uboot.env
31RPI3_UBOOT_ENV_TXT ?= $(RPI3_FIRMWARE_PATH)/uboot.env.txt
Igor Opaniuk29da21d2017-09-14 23:55:10 +030032RPI3_STOCK_FW_PATH ?= $(ROOT)/firmware
Igor Opaniuk67959e12016-12-21 15:19:27 +020033RPI3_STOCK_FW_PATH_BOOT ?= $(RPI3_STOCK_FW_PATH)/boot
Igor Opaniuk67959e12016-12-21 15:19:27 +020034OPTEE_OS_PAGER ?= $(OPTEE_OS_PATH)/out/arm/core/tee-pager.bin
Philip Attfield3f9250f2016-09-14 07:43:32 +020035
36LINUX_IMAGE ?= $(LINUX_PATH)/arch/arm64/boot/Image
37LINUX_DTB ?= $(LINUX_PATH)/arch/arm64/boot/dts/broadcom/bcm2710-rpi-3-b.dtb
38MODULE_OUTPUT ?= $(ROOT)/module_output
39
40################################################################################
41# Targets
42################################################################################
Igor Opaniukd5226382017-07-14 18:11:07 +030043ifeq ($(CFG_TEE_BENCHMARK),y)
44all: benchmark-app
45clean: benchmark-app-clean
46endif
Igor Opaniuk29da21d2017-09-14 23:55:10 +030047all: arm-tf optee-os optee-client xtest u-boot u-boot-rpi-bin\
Igor Opaniuk584efe52017-08-07 01:41:48 +030048 linux update_rootfs optee-examples
Igor Opaniukd5034112017-09-04 23:46:42 +030049clean: arm-tf-clean busybox-clean u-boot-clean u-boot-rpi-bin-clean \
Igor Opaniuk29da21d2017-09-14 23:55:10 +030050 optee-os-clean optee-client-clean head-bin-clean \
Igor Opaniuk584efe52017-08-07 01:41:48 +030051 optee-examples-clean
Philip Attfield3f9250f2016-09-14 07:43:32 +020052
Victor Chong7a716512017-09-11 15:18:44 +010053include toolchain.mk
Philip Attfield3f9250f2016-09-14 07:43:32 +020054
55################################################################################
56# ARM Trusted Firmware
57################################################################################
58ARM_TF_EXPORTS ?= \
Philip Attfield3f9250f2016-09-14 07:43:32 +020059 CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)"
60
61ARM_TF_FLAGS ?= \
62 BL32=$(OPTEE_OS_BIN) \
63 DEBUG=1 \
64 V=0 \
65 CRASH_REPORTING=1 \
66 LOG_LEVEL=40 \
67 PLAT=rpi3 \
68 SPD=opteed
69
70arm-tf: optee-os
71 $(ARM_TF_EXPORTS) $(MAKE) -C $(ARM_TF_PATH) $(ARM_TF_FLAGS) all
72 cd $(ARM_TF_OUT) && \
73 dd if=/dev/zero of=scratch bs=1c count=131072 && \
74 cat $(ARM_TF_BIN) scratch > $(ARM_TF_TMP) && \
75 dd if=$(ARM_TF_TMP) of=$(ARM_TF_HEAD) bs=1c count=131072 && \
76 cat $(ARM_TF_HEAD) $(OPTEE_OS_PAGER) > $(ARM_TF_BOOT) && \
77 rm scratch $(ARM_TF_TMP) $(ARM_TF_HEAD)
78
79arm-tf-clean:
80 $(ARM_TF_EXPORTS) $(MAKE) -C $(ARM_TF_PATH) $(ARM_TF_FLAGS) clean
81
82################################################################################
83# Das U-Boot
84################################################################################
85
Joakim Bech025e6322018-05-23 08:37:57 +020086U-BOOT_EXPORTS ?= CROSS_COMPILE=$(AARCH64_CROSS_COMPILE) ARCH=arm64
Philip Attfield3f9250f2016-09-14 07:43:32 +020087
88.PHONY: u-boot
Jerome Forissiere8caec72016-12-15 17:07:07 +010089u-boot: $(RPI3_HEAD_BIN)
Philip Attfield3f9250f2016-09-14 07:43:32 +020090 $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) rpi_3_defconfig
91 $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) all
Igor Opaniukc176f572016-12-19 22:47:09 +020092 $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) tools
Philip Attfield3f9250f2016-09-14 07:43:32 +020093
94u-boot-clean:
95 $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) clean
96
Igor Opaniukaccde812017-07-14 17:36:56 +030097u-boot-rpi-bin: $(RPI3_UBOOT_ENV) u-boot
98 cd $(U-BOOT_PATH) && cat $(RPI3_HEAD_BIN) $(U-BOOT_BIN) > $(U-BOOT_RPI_BIN)
Igor Opaniukc176f572016-12-19 22:47:09 +020099
Igor Opaniukaccde812017-07-14 17:36:56 +0300100u-boot-rpi-bin-clean:
101 rm -f $(U-BOOT_RPI_BIN)
Igor Opaniukc176f572016-12-19 22:47:09 +0200102
Jerome Forissiere8caec72016-12-15 17:07:07 +0100103$(RPI3_HEAD_BIN): $(RPI3_FIRMWARE_PATH)/head.S
104 mkdir -p $(ROOT)/out/
105 $(AARCH64_CROSS_COMPILE)as $< -o $(ROOT)/out/head.o
106 $(AARCH64_CROSS_COMPILE)objcopy -O binary $(ROOT)/out/head.o $@
107
108head-bin-clean:
109 rm -f $(RPI3_HEAD_BIN) $(ROOT)/out/head.o
110
Igor Opaniukc176f572016-12-19 22:47:09 +0200111$(RPI3_UBOOT_ENV): $(RPI3_UBOOT_ENV_TXT) u-boot
112 mkdir -p $(ROOT)/out
113 $(U-BOOT_PATH)/tools/mkenvimage -s 0x4000 -o $(ROOT)/out/uboot.env $(RPI3_UBOOT_ENV_TXT)
114
115u-boot-env-clean:
116 rm -f $(RPI3_UBOOT_ENV)
117
Philip Attfield3f9250f2016-09-14 07:43:32 +0200118################################################################################
119# Busybox
120################################################################################
121BUSYBOX_COMMON_TARGET = rpi3
122BUSYBOX_CLEAN_COMMON_TARGET = rpi3 clean
123
124busybox: busybox-common
125
126busybox-clean: busybox-clean-common
127
128busybox-cleaner: busybox-cleaner-common
129################################################################################
130# Linux kernel
131################################################################################
132LINUX_DEFCONFIG_COMMON_ARCH := arm64
133LINUX_DEFCONFIG_COMMON_FILES := \
134 $(LINUX_PATH)/arch/arm64/configs/bcmrpi3_defconfig \
135 $(CURDIR)/kconfigs/rpi3.conf
136
137linux-defconfig: $(LINUX_PATH)/.config
138
139LINUX_COMMON_FLAGS += ARCH=arm64
140
141linux: linux-common
142 $(MAKE) -C $(LINUX_PATH) $(LINUX_COMMON_FLAGS) INSTALL_MOD_STRIP=1 INSTALL_MOD_PATH=$(MODULE_OUTPUT) modules_install
143
144linux-defconfig-clean: linux-defconfig-clean-common
145
146LINUX_CLEAN_COMMON_FLAGS += ARCH=arm64
147
148linux-clean: linux-clean-common
149
150LINUX_CLEANER_COMMON_FLAGS += ARCH=arm64
151
152linux-cleaner: linux-cleaner-common
153
154################################################################################
155# OP-TEE
156################################################################################
157OPTEE_OS_COMMON_FLAGS += PLATFORM=rpi3
158optee-os: optee-os-common
159
160OPTEE_OS_CLEAN_COMMON_FLAGS += PLATFORM=rpi3
161optee-os-clean: optee-os-clean-common
162
163optee-client: optee-client-common
164
165optee-client-clean: optee-client-clean-common
166
167################################################################################
Philip Attfield3f9250f2016-09-14 07:43:32 +0200168# xtest / optee_test
169################################################################################
170xtest: xtest-common
171
172xtest-clean: xtest-clean-common
173
174xtest-patch: xtest-patch-common
175
176################################################################################
Igor Opaniuk584efe52017-08-07 01:41:48 +0300177# Sample applications / optee_examples
Philip Attfield3f9250f2016-09-14 07:43:32 +0200178################################################################################
Igor Opaniuk584efe52017-08-07 01:41:48 +0300179optee-examples: optee-examples-common
Philip Attfield3f9250f2016-09-14 07:43:32 +0200180
Igor Opaniuk584efe52017-08-07 01:41:48 +0300181optee-examples-clean: optee-examples-clean-common
Philip Attfield3f9250f2016-09-14 07:43:32 +0200182
183################################################################################
Igor Opaniukd5226382017-07-14 18:11:07 +0300184# benchmark
185################################################################################
186benchmark-app: benchmark-app-common
187
188benchmark-app-clean: benchmark-app-clean-common
189
190################################################################################
Philip Attfield3f9250f2016-09-14 07:43:32 +0200191# Root FS
192################################################################################
193.PHONY: filelist-tee
Igor Opaniuk29da21d2017-09-14 23:55:10 +0300194filelist-tee: linux
Etienne Carriere5e113512016-10-21 10:13:57 +0200195filelist-tee: filelist-tee-common
Philip Attfield3f9250f2016-09-14 07:43:32 +0200196 @echo "dir /usr/bin 755 0 0" >> $(GEN_ROOTFS_FILELIST)
Philip Attfield3f9250f2016-09-14 07:43:32 +0200197 @echo "dir /boot 755 0 0" >> $(GEN_ROOTFS_FILELIST)
198 @echo "file /boot/bcm2710-rpi-3-b.dtb $(LINUX_DTB) 755 0 0" >> $(GEN_ROOTFS_FILELIST)
199 @echo "file /boot/config.txt $(RPI3_BOOT_CONFIG) 755 0 0" >> $(GEN_ROOTFS_FILELIST)
200 @echo "file /boot/Image $(LINUX_IMAGE) 755 0 0" >> $(GEN_ROOTFS_FILELIST)
201 @echo "file /boot/optee.bin $(ARM_TF_BOOT) 755 0 0" >> $(GEN_ROOTFS_FILELIST)
202 @echo "file /boot/uboot.env $(RPI3_UBOOT_ENV) 755 0 0" >> $(GEN_ROOTFS_FILELIST)
Igor Opaniukaccde812017-07-14 17:36:56 +0300203 @echo "file /boot/u-boot-rpi.bin $(U-BOOT_RPI_BIN) 755 0 0" >> $(GEN_ROOTFS_FILELIST)
Philip Attfield3f9250f2016-09-14 07:43:32 +0200204 @cd $(MODULE_OUTPUT) && find ! -path . -type d | sed 's/\.\(.*\)/dir \1 755 0 0/g' >> $(GEN_ROOTFS_FILELIST)
205 @cd $(MODULE_OUTPUT) && find -type f | sed "s|\.\(.*\)|file \1 $(MODULE_OUTPUT)\1 755 0 0|g" >> $(GEN_ROOTFS_FILELIST)
206 @echo "file /boot/bootcode.bin $(RPI3_STOCK_FW_PATH)/boot/bootcode.bin 755 0 0" >> $(GEN_ROOTFS_FILELIST)
207 @echo "file /boot/COPYING.linux $(RPI3_STOCK_FW_PATH)/boot/COPYING.linux 755 0 0" >> $(GEN_ROOTFS_FILELIST)
208 @echo "file /boot/fixup_cd.dat $(RPI3_STOCK_FW_PATH)/boot/fixup_cd.dat 755 0 0" >> $(GEN_ROOTFS_FILELIST)
209 @echo "file /boot/fixup.dat $(RPI3_STOCK_FW_PATH)/boot/fixup.dat 755 0 0" >> $(GEN_ROOTFS_FILELIST)
210 @echo "file /boot/fixup_db.dat $(RPI3_STOCK_FW_PATH)/boot/fixup_db.dat 755 0 0" >> $(GEN_ROOTFS_FILELIST)
211 @echo "file /boot/fixup_x.dat $(RPI3_STOCK_FW_PATH)/boot/fixup_x.dat 755 0 0" >> $(GEN_ROOTFS_FILELIST)
212 @echo "file /boot/LICENCE.broadcom $(RPI3_STOCK_FW_PATH)/boot/LICENCE.broadcom 755 0 0" >> $(GEN_ROOTFS_FILELIST)
213 @echo "file /boot/start_cd.elf $(RPI3_STOCK_FW_PATH)/boot/start_cd.elf 755 0 0" >> $(GEN_ROOTFS_FILELIST)
214 @echo "file /boot/start_db.elf $(RPI3_STOCK_FW_PATH)/boot/start_db.elf 755 0 0" >> $(GEN_ROOTFS_FILELIST)
215 @echo "file /boot/start.elf $(RPI3_STOCK_FW_PATH)/boot/start.elf 755 0 0" >> $(GEN_ROOTFS_FILELIST)
216 @echo "file /boot/start_x.elf $(RPI3_STOCK_FW_PATH)/boot/start_x.elf 755 0 0" >> $(GEN_ROOTFS_FILELIST)
217
218.PHONY: update_rootfs
Igor Opaniuk29da21d2017-09-14 23:55:10 +0300219update_rootfs: arm-tf u-boot
Etienne Carriere5e113512016-10-21 10:13:57 +0200220update_rootfs: update_rootfs-common
Philip Attfield3f9250f2016-09-14 07:43:32 +0200221
222# Creating images etc, could wipe out a drive on the system, therefore we don't
223# want to automate that in script or make target. Instead we just simply provide
224# the steps here.
225.PHONY: img-help
226img-help:
227 @echo "$$ fdisk /dev/sdx # where sdx is the name of your sd-card"
228 @echo " > p # prints partition table"
229 @echo " > d # repeat until all partitions are deleted"
230 @echo " > n # create a new partition"
231 @echo " > p # create primary"
232 @echo " > 1 # make it the first partition"
233 @echo " > <enter> # use the default sector"
234 @echo " > +32M # create a boot partition with 32MB of space"
235 @echo " > n # create rootfs partition"
236 @echo " > p"
237 @echo " > 2"
238 @echo " > <enter>"
239 @echo " > <enter> # fill the remaining disk, adjust size to fit your needs"
240 @echo " > t # change partition type"
241 @echo " > 1 # select first partition"
242 @echo " > e # use type 'e' (FAT16)"
243 @echo " > a # make partition bootable"
244 @echo " > 1 # select first partition"
245 @echo " > p # double check everything looks right"
246 @echo " > w # write partition table to disk."
247 @echo ""
248 @echo "run the following as root"
249 @echo " $$ mkfs.vfat -F16 -n BOOT /dev/sdx1"
250 @echo " $$ mkdir -p /media/boot"
251 @echo " $$ mount /dev/sdx1 /media/boot"
252 @echo " $$ cd /media"
253 @echo " $$ gunzip -cd $(GEN_ROOTFS_PATH)/filesystem.cpio.gz | sudo cpio -idmv \"boot/*\""
254 @echo " $$ umount boot"
255 @echo ""
256 @echo "run the following as root"
257 @echo " $$ mkfs.ext4 -L rootfs /dev/sdx2"
258 @echo " $$ mkdir -p /media/rootfs"
259 @echo " $$ mount /dev/sdx2 /media/rootfs"
260 @echo " $$ cd rootfs"
261 @echo " $$ gunzip -cd $(GEN_ROOTFS_PATH)/filesystem.cpio.gz | sudo cpio -idmv"
262 @echo " $$ rm -rf /media/rootfs/boot/*"
263 @echo " $$ cd .. && umount rootfs"