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 | |
Etienne Carriere | 3768a2b | 2019-05-14 17:13:19 +0200 | [diff] [blame] | 11 | OPTEE_OS_PLATFORM = vexpress-juno |
| 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 | |
Jens Wiklander | 2460679 | 2021-06-29 10:48:00 +0200 | [diff] [blame] | 23 | SCP_BLX_URL ?= https://downloads.trustedfirmware.org/tf-a/css_scp_2.8.0/juno |
| 24 | |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 25 | ################################################################################ |
| 26 | # Targets |
| 27 | ################################################################################ |
Jens Wiklander | 2460679 | 2021-06-29 10:48:00 +0200 | [diff] [blame] | 28 | all: scp-blx arm-tf u-boot linux optee-os buildroot |
| 29 | clean: scp-blx-clean arm-tf-clean buildroot-clean u-boot-clean optee-os-clean |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 30 | |
Victor Chong | 7a71651 | 2017-09-11 15:18:44 +0100 | [diff] [blame] | 31 | include toolchain.mk |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 32 | |
| 33 | ################################################################################ |
Jens Wiklander | 2460679 | 2021-06-29 10:48:00 +0200 | [diff] [blame] | 34 | # SCP BL1 and BL2 |
| 35 | ################################################################################ |
| 36 | .PHONY: scp-blx |
| 37 | scp-blx: $(ROOT)/out-firmware/scp_bl1.bin $(ROOT)/out-firmware/scp_bl2.bin |
| 38 | |
| 39 | .PHONY: scp-blx |
| 40 | scp-blx-clean: |
| 41 | @rm -f $(ROOT)/out-firmware/scp_bl1.bin |
| 42 | @rm -f $(ROOT)/out-firmware/scp_bl2.bin |
| 43 | @rm -f $(ROOT)/out-firmware/tmp/scp_bl1.bin |
| 44 | @rm -f $(ROOT)/out-firmware/tmp/scp_bl2.bin |
| 45 | |
| 46 | define dlscp |
| 47 | @mkdir -p $(ROOT)/out-firmware/tmp |
| 48 | @rm -f $(ROOT)/out-firmware/tmp/$1 |
| 49 | @rm -f $(ROOT)/out-firmware/$1 |
| 50 | @(cd $(ROOT)/out-firmware/tmp/ && wget $(SCP_BLX_URL)/$1) |
| 51 | @(echo $2 $(ROOT)/out-firmware/tmp/$1 | sha256sum -c) |
| 52 | @(mv $(ROOT)/out-firmware/tmp/$1 $(ROOT)/out-firmware/$1) |
| 53 | endef |
| 54 | |
| 55 | $(ROOT)/out-firmware/scp_bl1.bin: |
| 56 | $(call dlscp,scp_bl1.bin,1c690a7d93c82d39d18b720920ced7a712fdcfc744224b4f067e56013522fece) |
| 57 | |
| 58 | $(ROOT)/out-firmware/scp_bl2.bin: |
| 59 | $(call dlscp,scp_bl2.bin,533eb4a3f9d91e759b98288edf4c1441abe6f7fbc5da87825a8f1bb1b7942aa5) |
| 60 | |
| 61 | ################################################################################ |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 62 | # ARM Trusted Firmware |
| 63 | ################################################################################ |
Victor Chong | 371d7c2 | 2019-08-08 17:17:14 +0100 | [diff] [blame] | 64 | TF_A_EXPORTS ?= \ |
Joakim Bech | 69a8a37 | 2016-04-26 11:05:04 +0200 | [diff] [blame] | 65 | CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)" |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 66 | |
Victor Chong | 371d7c2 | 2019-08-08 17:17:14 +0100 | [diff] [blame] | 67 | TF_A_FLAGS ?= \ |
Jens Wiklander | 2460679 | 2021-06-29 10:48:00 +0200 | [diff] [blame] | 68 | SCP_BL2=$(ROOT)/out-firmware/scp_bl2.bin \ |
Jens Wiklander | 7abd3ed | 2017-09-04 10:22:40 +0200 | [diff] [blame] | 69 | BL32=$(OPTEE_OS_HEADER_V2_BIN) \ |
| 70 | BL32_EXTRA1=$(OPTEE_OS_PAGER_V2_BIN) \ |
| 71 | BL32_EXTRA2=$(OPTEE_OS_PAGEABLE_V2_BIN) \ |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 72 | BL33=$(U-BOOT_BIN) \ |
| 73 | DEBUG=0 \ |
| 74 | ARM_TSP_RAM_LOCATION=dram \ |
| 75 | PLAT=juno \ |
| 76 | SPD=opteed |
| 77 | |
Jens Wiklander | 2460679 | 2021-06-29 10:48:00 +0200 | [diff] [blame] | 78 | arm-tf: scp-blx optee-os u-boot |
Victor Chong | 371d7c2 | 2019-08-08 17:17:14 +0100 | [diff] [blame] | 79 | $(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] | 80 | |
| 81 | arm-tf-clean: |
Victor Chong | 371d7c2 | 2019-08-08 17:17:14 +0100 | [diff] [blame] | 82 | $(TF_A_EXPORTS) $(MAKE) -C $(TF_A_PATH) $(TF_A_FLAGS) clean |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 83 | |
| 84 | ################################################################################ |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 85 | # Das U-Boot |
| 86 | ################################################################################ |
| 87 | |
| 88 | U-BOOT_EXPORTS ?= CROSS_COMPILE="$(CCACHE)$(AARCH64_CROSS_COMPILE)" |
| 89 | |
| 90 | U-BOOT_DEFCONFIG_FILES := \ |
| 91 | $(U-BOOT_PATH)/configs/vexpress_aemv8a_juno_defconfig \ |
| 92 | $(ROOT)/build/kconfigs/u-boot_juno.conf |
| 93 | |
| 94 | .PHONY: u-boot |
Victor Chong | 9f0d120 | 2016-04-23 16:28:31 +0100 | [diff] [blame] | 95 | u-boot: |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 96 | cd $(U-BOOT_PATH) && \ |
| 97 | scripts/kconfig/merge_config.sh $(U-BOOT_DEFCONFIG_FILES) |
| 98 | $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) all |
Victor Chong | 9f0d120 | 2016-04-23 16:28:31 +0100 | [diff] [blame] | 99 | |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 100 | u-boot-clean: |
| 101 | $(U-BOOT_EXPORTS) $(MAKE) -C $(U-BOOT_PATH) clean |
| 102 | |
| 103 | ################################################################################ |
| 104 | # Linux kernel |
| 105 | ################################################################################ |
| 106 | LINUX_DEFCONFIG_COMMON_ARCH := arm64 |
| 107 | LINUX_DEFCONFIG_COMMON_FILES := \ |
| 108 | $(LINUX_PATH)/arch/arm64/configs/defconfig \ |
| 109 | $(CURDIR)/kconfigs/juno.conf |
| 110 | |
| 111 | linux-defconfig: $(LINUX_PATH)/.config |
| 112 | |
| 113 | LINUX_COMMON_FLAGS += ARCH=arm64 |
| 114 | |
| 115 | linux: linux-common |
| 116 | |
| 117 | linux-defconfig-clean: linux-defconfig-clean-common |
| 118 | |
| 119 | LINUX_CLEAN_COMMON_FLAGS += ARCH=arm64 |
| 120 | |
| 121 | linux-clean: linux-clean-common |
| 122 | |
| 123 | LINUX_CLEANER_COMMON_FLAGS += ARCH=arm64 |
| 124 | |
| 125 | linux-cleaner: linux-cleaner-common |
| 126 | |
| 127 | ################################################################################ |
| 128 | # OP-TEE |
| 129 | ################################################################################ |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 130 | optee-os: optee-os-common |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 131 | optee-os-clean: optee-os-clean-common |
| 132 | |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 133 | |
Jens Wiklander | d612e4a | 2018-05-04 14:21:17 +0200 | [diff] [blame] | 134 | $(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] | 135 | $(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] | 136 | -d $< $@ |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 137 | |
| 138 | FTP-UPLOAD = ftp-upload -v --host $(JUNO_IP) --dir SOFTWARE |
| 139 | |
| 140 | .PHONY: flash |
Jens Wiklander | d612e4a | 2018-05-04 14:21:17 +0200 | [diff] [blame] | 141 | flash: $(ROOT)/out-br/images/ramdisk.img |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 142 | @test -n "$(JUNO_IP)" || \ |
| 143 | (echo "JUNO_IP not set" ; exit 1) |
Jens Wiklander | 2460679 | 2021-06-29 10:48:00 +0200 | [diff] [blame] | 144 | $(FTP-UPLOAD) $(ROOT)/out-firmware/scp_bl1.bin |
Victor Chong | 371d7c2 | 2019-08-08 17:17:14 +0100 | [diff] [blame] | 145 | $(FTP-UPLOAD) $(TF_A_PATH)/build/juno/release/bl1.bin |
| 146 | $(FTP-UPLOAD) $(TF_A_PATH)/build/juno/release/fip.bin |
Jens Wiklander | bab5084 | 2016-02-17 15:45:10 +0100 | [diff] [blame] | 147 | $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/Image |
| 148 | $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/dts/arm/juno.dtb |
Fathi Boudra | 332f7d3 | 2017-10-27 14:49:57 +0300 | [diff] [blame] | 149 | $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/dts/arm/juno-r1.dtb |
| 150 | $(FTP-UPLOAD) $(ROOT)/linux/arch/arm64/boot/dts/arm/juno-r2.dtb |
Jens Wiklander | d612e4a | 2018-05-04 14:21:17 +0200 | [diff] [blame] | 151 | $(FTP-UPLOAD) $(ROOT)/out-br/images/ramdisk.img |