Pascal Brand | efe5659 | 2016-03-03 10:46:52 +0100 | [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 | |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 11 | DEBUG ?= 0 |
| 12 | |
Victor Chong | 7a71651 | 2017-09-11 15:18:44 +0100 | [diff] [blame] | 13 | include common.mk |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 14 | |
| 15 | ################################################################################ |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 16 | # Paths to git projects and various binaries |
| 17 | ################################################################################ |
Victor Chong | df54b11 | 2019-08-11 15:58:12 +0100 | [diff] [blame^] | 18 | TF_A_PATH ?= $(ROOT)/trusted-firmware-a |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 19 | |
| 20 | U-BOOT_PATH ?= $(ROOT)/u-boot |
| 21 | U-BOOT_BIN ?= $(U-BOOT_PATH)/u-boot.bin |
| 22 | |
| 23 | ################################################################################ |
| 24 | # Targets |
| 25 | ################################################################################ |
Jens Wiklander | d612e4a | 2018-05-04 14:21:17 +0200 | [diff] [blame] | 26 | all: arm-tf u-boot linux optee-os buildroot |
| 27 | clean: arm-tf-clean buildroot-clean u-boot-clean optee-os-clean |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 28 | |
Victor Chong | 7a71651 | 2017-09-11 15:18:44 +0100 | [diff] [blame] | 29 | include toolchain.mk |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 30 | |
| 31 | ################################################################################ |
| 32 | # ARM Trusted Firmware |
| 33 | ################################################################################ |
Victor Chong | 371d7c2 | 2019-08-08 17:17:14 +0100 | [diff] [blame] | 34 | TF_A_EXPORTS ?= \ |
Joakim Bech | 69a8a37 | 2016-04-26 11:05:04 +0200 | [diff] [blame] | 35 | CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)" |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 36 | |
Victor Chong | 371d7c2 | 2019-08-08 17:17:14 +0100 | [diff] [blame] | 37 | TF_A_FLAGS ?= \ |
Jens Wiklander | 2f42f80 | 2018-04-04 13:46:49 +0200 | [diff] [blame] | 38 | SCP_BL2=$(ROOT)/vexpress-firmware/SOFTWARE/scp_bl2.bin \ |
Jens Wiklander | 7abd3ed | 2017-09-04 10:22:40 +0200 | [diff] [blame] | 39 | BL32=$(OPTEE_OS_HEADER_V2_BIN) \ |
| 40 | BL32_EXTRA1=$(OPTEE_OS_PAGER_V2_BIN) \ |
| 41 | BL32_EXTRA2=$(OPTEE_OS_PAGEABLE_V2_BIN) \ |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 42 | BL33=$(U-BOOT_BIN) \ |
| 43 | DEBUG=0 \ |
| 44 | ARM_TSP_RAM_LOCATION=dram \ |
| 45 | PLAT=juno \ |
| 46 | SPD=opteed |
| 47 | |
| 48 | arm-tf: optee-os u-boot |
Victor Chong | 371d7c2 | 2019-08-08 17:17:14 +0100 | [diff] [blame] | 49 | $(TF_A_EXPORTS) $(MAKE) -C $(TF_A_PATH) $(TF_A_FLAGS) all fip |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 50 | |
| 51 | arm-tf-clean: |
Victor Chong | 371d7c2 | 2019-08-08 17:17:14 +0100 | [diff] [blame] | 52 | $(TF_A_EXPORTS) $(MAKE) -C $(TF_A_PATH) $(TF_A_FLAGS) clean |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 53 | |
| 54 | ################################################################################ |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 55 | # Das U-Boot |
| 56 | ################################################################################ |
| 57 | |
| 58 | U-BOOT_EXPORTS ?= CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)" |
| 59 | |
| 60 | U-BOOT_DEFCONFIG_FILES := \ |
| 61 | $(U-BOOT_PATH)/configs/vexpress_aemv8a_juno_defconfig \ |
| 62 | $(ROOT)/build/kconfigs/u-boot_juno.conf |
| 63 | |
| 64 | .PHONY: u-boot |
Victor Chong | 9f0d120 | 2016-04-23 16:28:31 +0100 | [diff] [blame] | 65 | u-boot: |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 66 | cd $(U-BOOT_PATH) && \ |
| 67 | scripts/kconfig/merge_config.sh $(U-BOOT_DEFCONFIG_FILES) |
| 68 | $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) all |
Victor Chong | 9f0d120 | 2016-04-23 16:28:31 +0100 | [diff] [blame] | 69 | |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 70 | u-boot-clean: |
| 71 | $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) clean |
| 72 | |
| 73 | ################################################################################ |
| 74 | # Linux kernel |
| 75 | ################################################################################ |
| 76 | LINUX_DEFCONFIG_COMMON_ARCH := arm64 |
| 77 | LINUX_DEFCONFIG_COMMON_FILES := \ |
| 78 | $(LINUX_PATH)/arch/arm64/configs/defconfig \ |
| 79 | $(CURDIR)/kconfigs/juno.conf |
| 80 | |
| 81 | linux-defconfig: $(LINUX_PATH)/.config |
| 82 | |
| 83 | LINUX_COMMON_FLAGS += ARCH=arm64 |
| 84 | |
| 85 | linux: linux-common |
| 86 | |
| 87 | linux-defconfig-clean: linux-defconfig-clean-common |
| 88 | |
| 89 | LINUX_CLEAN_COMMON_FLAGS += ARCH=arm64 |
| 90 | |
| 91 | linux-clean: linux-clean-common |
| 92 | |
| 93 | LINUX_CLEANER_COMMON_FLAGS += ARCH=arm64 |
| 94 | |
| 95 | linux-cleaner: linux-cleaner-common |
| 96 | |
| 97 | ################################################################################ |
| 98 | # OP-TEE |
| 99 | ################################################################################ |
Pascal Brand | efe5659 | 2016-03-03 10:46:52 +0100 | [diff] [blame] | 100 | OPTEE_OS_COMMON_FLAGS += PLATFORM=vexpress-juno |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 101 | optee-os: optee-os-common |
| 102 | |
| 103 | OPTEE_OS_CLEAN_COMMON_FLAGS += PLATFORM=vexpress-juno |
| 104 | optee-os-clean: optee-os-clean-common |
| 105 | |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 106 | |
Jens Wiklander | d612e4a | 2018-05-04 14:21:17 +0200 | [diff] [blame] | 107 | $(ROOT)/out-br/images/ramdisk.img: $(ROOT)/out-br/images/rootfs.cpio.gz |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 108 | $(U-BOOT_PATH)/tools/mkimage -A arm64 -O linux -T ramdisk -C gzip \ |
Jens Wiklander | d612e4a | 2018-05-04 14:21:17 +0200 | [diff] [blame] | 109 | -d $< $@ |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 110 | |
| 111 | FTP-UPLOAD = ftp-upload -v --host $(JUNO_IP) --dir SOFTWARE |
| 112 | |
| 113 | .PHONY: flash |
Jens Wiklander | d612e4a | 2018-05-04 14:21:17 +0200 | [diff] [blame] | 114 | flash: $(ROOT)/out-br/images/ramdisk.img |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 115 | @test -n "$(JUNO_IP)" || \ |
| 116 | (echo "JUNO_IP not set" ; exit 1) |
Jens Wiklander | 2f42f80 | 2018-04-04 13:46:49 +0200 | [diff] [blame] | 117 | $(FTP-UPLOAD) $(ROOT)/vexpress-firmware/SOFTWARE/scp_bl1.bin |
Victor Chong | 371d7c2 | 2019-08-08 17:17:14 +0100 | [diff] [blame] | 118 | $(FTP-UPLOAD) $(TF_A_PATH)/build/juno/release/bl1.bin |
| 119 | $(FTP-UPLOAD) $(TF_A_PATH)/build/juno/release/fip.bin |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 120 | $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/Image |
| 121 | $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/dts/arm/juno.dtb |
Fathi Boudra | 332f7d3 | 2017-10-27 14:49:57 +0300 | [diff] [blame] | 122 | $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/dts/arm/juno-r1.dtb |
| 123 | $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/dts/arm/juno-r2.dtb |
Jens Wiklander | d612e4a | 2018-05-04 14:21:17 +0200 | [diff] [blame] | 124 | $(FTP-UPLOAD) $(ROOT)/out-br/images/ramdisk.img |