Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 1 | ################################################################################ |
| 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 | ################################################################################ |
| 6 | override COMPILE_NS_USER := 64 |
| 7 | override COMPILE_NS_KERNEL := 64 |
| 8 | override COMPILE_S_USER := 64 |
| 9 | override COMPILE_S_KERNEL := 64 |
| 10 | |
Victor Chong | 7a71651 | 2017-09-11 15:18:44 +0100 | [diff] [blame] | 11 | include common.mk |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 12 | |
| 13 | ################################################################################ |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 14 | # Paths to git projects and various binaries |
| 15 | ################################################################################ |
| 16 | ARM_TF_PATH ?= $(ROOT)/arm-trusted-firmware |
| 17 | ARM_TF_OUT ?= $(ARM_TF_PATH)/build/rpi3/debug |
| 18 | ARM_TF_BIN ?= $(ARM_TF_OUT)/bl31.bin |
| 19 | ARM_TF_TMP ?= $(ARM_TF_OUT)/bl31.tmp |
| 20 | ARM_TF_HEAD ?= $(ARM_TF_OUT)/bl31.head |
| 21 | ARM_TF_BOOT ?= $(ARM_TF_OUT)/optee.bin |
| 22 | |
| 23 | U-BOOT_PATH ?= $(ROOT)/u-boot |
| 24 | U-BOOT_BIN ?= $(U-BOOT_PATH)/u-boot.bin |
Igor Opaniuk | accde81 | 2017-07-14 17:36:56 +0300 | [diff] [blame] | 25 | U-BOOT_RPI_BIN ?= $(U-BOOT_PATH)/u-boot-rpi.bin |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 26 | |
Igor Opaniuk | 67959e1 | 2016-12-21 15:19:27 +0200 | [diff] [blame] | 27 | RPI3_FIRMWARE_PATH ?= $(BUILD_PATH)/rpi3/firmware |
| 28 | RPI3_HEAD_BIN ?= $(ROOT)/out/head.bin |
| 29 | RPI3_BOOT_CONFIG ?= $(RPI3_FIRMWARE_PATH)/config.txt |
| 30 | RPI3_UBOOT_ENV ?= $(ROOT)/out/uboot.env |
| 31 | RPI3_UBOOT_ENV_TXT ?= $(RPI3_FIRMWARE_PATH)/uboot.env.txt |
Igor Opaniuk | 29da21d | 2017-09-14 23:55:10 +0300 | [diff] [blame] | 32 | RPI3_STOCK_FW_PATH ?= $(ROOT)/firmware |
Igor Opaniuk | 67959e1 | 2016-12-21 15:19:27 +0200 | [diff] [blame] | 33 | RPI3_STOCK_FW_PATH_BOOT ?= $(RPI3_STOCK_FW_PATH)/boot |
Igor Opaniuk | 67959e1 | 2016-12-21 15:19:27 +0200 | [diff] [blame] | 34 | OPTEE_OS_PAGER ?= $(OPTEE_OS_PATH)/out/arm/core/tee-pager.bin |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 35 | |
| 36 | LINUX_IMAGE ?= $(LINUX_PATH)/arch/arm64/boot/Image |
| 37 | LINUX_DTB ?= $(LINUX_PATH)/arch/arm64/boot/dts/broadcom/bcm2710-rpi-3-b.dtb |
| 38 | MODULE_OUTPUT ?= $(ROOT)/module_output |
| 39 | |
| 40 | ################################################################################ |
| 41 | # Targets |
| 42 | ################################################################################ |
Igor Opaniuk | d522638 | 2017-07-14 18:11:07 +0300 | [diff] [blame] | 43 | ifeq ($(CFG_TEE_BENCHMARK),y) |
| 44 | all: benchmark-app |
| 45 | clean: benchmark-app-clean |
| 46 | endif |
Igor Opaniuk | 29da21d | 2017-09-14 23:55:10 +0300 | [diff] [blame] | 47 | all: arm-tf optee-os optee-client xtest u-boot u-boot-rpi-bin\ |
Igor Opaniuk | 584efe5 | 2017-08-07 01:41:48 +0300 | [diff] [blame] | 48 | linux update_rootfs optee-examples |
Igor Opaniuk | d503411 | 2017-09-04 23:46:42 +0300 | [diff] [blame] | 49 | clean: arm-tf-clean busybox-clean u-boot-clean u-boot-rpi-bin-clean \ |
Igor Opaniuk | 29da21d | 2017-09-14 23:55:10 +0300 | [diff] [blame] | 50 | optee-os-clean optee-client-clean head-bin-clean \ |
Igor Opaniuk | 584efe5 | 2017-08-07 01:41:48 +0300 | [diff] [blame] | 51 | optee-examples-clean |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 52 | |
Victor Chong | 7a71651 | 2017-09-11 15:18:44 +0100 | [diff] [blame] | 53 | include toolchain.mk |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 54 | |
| 55 | ################################################################################ |
| 56 | # ARM Trusted Firmware |
| 57 | ################################################################################ |
| 58 | ARM_TF_EXPORTS ?= \ |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 59 | CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)" |
| 60 | |
| 61 | ARM_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 | |
| 70 | arm-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 | |
| 79 | arm-tf-clean: |
| 80 | $(ARM_TF_EXPORTS) $(MAKE) -C $(ARM_TF_PATH) $(ARM_TF_FLAGS) clean |
| 81 | |
| 82 | ################################################################################ |
| 83 | # Das U-Boot |
| 84 | ################################################################################ |
| 85 | |
Joakim Bech | 025e632 | 2018-05-23 08:37:57 +0200 | [diff] [blame] | 86 | U-BOOT_EXPORTS ?= CROSS_COMPILE=$(AARCH64_CROSS_COMPILE) ARCH=arm64 |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 87 | |
| 88 | .PHONY: u-boot |
Jerome Forissier | e8caec7 | 2016-12-15 17:07:07 +0100 | [diff] [blame] | 89 | u-boot: $(RPI3_HEAD_BIN) |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 90 | $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) rpi_3_defconfig |
| 91 | $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) all |
Igor Opaniuk | c176f57 | 2016-12-19 22:47:09 +0200 | [diff] [blame] | 92 | $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) tools |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 93 | |
| 94 | u-boot-clean: |
| 95 | $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) clean |
| 96 | |
Igor Opaniuk | accde81 | 2017-07-14 17:36:56 +0300 | [diff] [blame] | 97 | u-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 Opaniuk | c176f57 | 2016-12-19 22:47:09 +0200 | [diff] [blame] | 99 | |
Igor Opaniuk | accde81 | 2017-07-14 17:36:56 +0300 | [diff] [blame] | 100 | u-boot-rpi-bin-clean: |
| 101 | rm -f $(U-BOOT_RPI_BIN) |
Igor Opaniuk | c176f57 | 2016-12-19 22:47:09 +0200 | [diff] [blame] | 102 | |
Jerome Forissier | e8caec7 | 2016-12-15 17:07:07 +0100 | [diff] [blame] | 103 | $(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 | |
| 108 | head-bin-clean: |
| 109 | rm -f $(RPI3_HEAD_BIN) $(ROOT)/out/head.o |
| 110 | |
Igor Opaniuk | c176f57 | 2016-12-19 22:47:09 +0200 | [diff] [blame] | 111 | $(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 | |
| 115 | u-boot-env-clean: |
| 116 | rm -f $(RPI3_UBOOT_ENV) |
| 117 | |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 118 | ################################################################################ |
| 119 | # Busybox |
| 120 | ################################################################################ |
| 121 | BUSYBOX_COMMON_TARGET = rpi3 |
| 122 | BUSYBOX_CLEAN_COMMON_TARGET = rpi3 clean |
| 123 | |
| 124 | busybox: busybox-common |
| 125 | |
| 126 | busybox-clean: busybox-clean-common |
| 127 | |
| 128 | busybox-cleaner: busybox-cleaner-common |
| 129 | ################################################################################ |
| 130 | # Linux kernel |
| 131 | ################################################################################ |
| 132 | LINUX_DEFCONFIG_COMMON_ARCH := arm64 |
| 133 | LINUX_DEFCONFIG_COMMON_FILES := \ |
| 134 | $(LINUX_PATH)/arch/arm64/configs/bcmrpi3_defconfig \ |
| 135 | $(CURDIR)/kconfigs/rpi3.conf |
| 136 | |
| 137 | linux-defconfig: $(LINUX_PATH)/.config |
| 138 | |
| 139 | LINUX_COMMON_FLAGS += ARCH=arm64 |
| 140 | |
| 141 | linux: linux-common |
| 142 | $(MAKE) -C $(LINUX_PATH) $(LINUX_COMMON_FLAGS) INSTALL_MOD_STRIP=1 INSTALL_MOD_PATH=$(MODULE_OUTPUT) modules_install |
| 143 | |
| 144 | linux-defconfig-clean: linux-defconfig-clean-common |
| 145 | |
| 146 | LINUX_CLEAN_COMMON_FLAGS += ARCH=arm64 |
| 147 | |
| 148 | linux-clean: linux-clean-common |
| 149 | |
| 150 | LINUX_CLEANER_COMMON_FLAGS += ARCH=arm64 |
| 151 | |
| 152 | linux-cleaner: linux-cleaner-common |
| 153 | |
| 154 | ################################################################################ |
| 155 | # OP-TEE |
| 156 | ################################################################################ |
| 157 | OPTEE_OS_COMMON_FLAGS += PLATFORM=rpi3 |
| 158 | optee-os: optee-os-common |
| 159 | |
| 160 | OPTEE_OS_CLEAN_COMMON_FLAGS += PLATFORM=rpi3 |
| 161 | optee-os-clean: optee-os-clean-common |
| 162 | |
| 163 | optee-client: optee-client-common |
| 164 | |
| 165 | optee-client-clean: optee-client-clean-common |
| 166 | |
| 167 | ################################################################################ |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 168 | # xtest / optee_test |
| 169 | ################################################################################ |
| 170 | xtest: xtest-common |
| 171 | |
| 172 | xtest-clean: xtest-clean-common |
| 173 | |
| 174 | xtest-patch: xtest-patch-common |
| 175 | |
| 176 | ################################################################################ |
Igor Opaniuk | 584efe5 | 2017-08-07 01:41:48 +0300 | [diff] [blame] | 177 | # Sample applications / optee_examples |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 178 | ################################################################################ |
Igor Opaniuk | 584efe5 | 2017-08-07 01:41:48 +0300 | [diff] [blame] | 179 | optee-examples: optee-examples-common |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 180 | |
Igor Opaniuk | 584efe5 | 2017-08-07 01:41:48 +0300 | [diff] [blame] | 181 | optee-examples-clean: optee-examples-clean-common |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 182 | |
| 183 | ################################################################################ |
Igor Opaniuk | d522638 | 2017-07-14 18:11:07 +0300 | [diff] [blame] | 184 | # benchmark |
| 185 | ################################################################################ |
| 186 | benchmark-app: benchmark-app-common |
| 187 | |
| 188 | benchmark-app-clean: benchmark-app-clean-common |
| 189 | |
| 190 | ################################################################################ |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 191 | # Root FS |
| 192 | ################################################################################ |
| 193 | .PHONY: filelist-tee |
Igor Opaniuk | 29da21d | 2017-09-14 23:55:10 +0300 | [diff] [blame] | 194 | filelist-tee: linux |
Etienne Carriere | 5e11351 | 2016-10-21 10:13:57 +0200 | [diff] [blame] | 195 | filelist-tee: filelist-tee-common |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 196 | @echo "dir /usr/bin 755 0 0" >> $(GEN_ROOTFS_FILELIST) |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 197 | @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 Opaniuk | accde81 | 2017-07-14 17:36:56 +0300 | [diff] [blame] | 203 | @echo "file /boot/u-boot-rpi.bin $(U-BOOT_RPI_BIN) 755 0 0" >> $(GEN_ROOTFS_FILELIST) |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 204 | @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 Opaniuk | 29da21d | 2017-09-14 23:55:10 +0300 | [diff] [blame] | 219 | update_rootfs: arm-tf u-boot |
Etienne Carriere | 5e11351 | 2016-10-21 10:13:57 +0200 | [diff] [blame] | 220 | update_rootfs: update_rootfs-common |
Philip Attfield | 3f9250f | 2016-09-14 07:43:32 +0200 | [diff] [blame] | 221 | |
| 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 |
| 226 | img-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" |