blob: 7a1fa58a0c36ec008bfa7458ebc4cea02648c81b [file] [log] [blame]
Pascal Brandd6536da2015-09-01 10:38:43 +02001#
2# Common definition to all platforms
3#
4
Pascal Brand070d9552015-09-01 15:33:22 +02005BASH ?= bash
Pascal Brandd6536da2015-09-01 10:38:43 +02006ROOT ?= $(shell pwd)/..
7
Pascal Brandd6536da2015-09-01 10:38:43 +02008LINUX_PATH ?= $(ROOT)/linux
Victor Chong9f0d1202016-04-23 16:28:31 +01009OPTEE_GENDRV_MODULE ?= $(LINUX_PATH)/drivers/tee/optee/optee.ko
Pascal Brand440ef9c2015-09-08 16:01:58 +020010GEN_ROOTFS_PATH ?= $(ROOT)/gen_rootfs
11GEN_ROOTFS_FILELIST ?= $(GEN_ROOTFS_PATH)/filelist-tee.txt
Pascal Brandd6536da2015-09-01 10:38:43 +020012OPTEE_OS_PATH ?= $(ROOT)/optee_os
13OPTEE_CLIENT_PATH ?= $(ROOT)/optee_client
14OPTEE_CLIENT_EXPORT ?= $(OPTEE_CLIENT_PATH)/out/export
Pascal Brandd6536da2015-09-01 10:38:43 +020015OPTEE_TEST_PATH ?= $(ROOT)/optee_test
16OPTEE_TEST_OUT_PATH ?= $(ROOT)/optee_test/out
17
Pascal Brand23ef2052016-03-09 15:25:01 +010018CFG_TEE_CORE_LOG_LEVEL ?= 3
19
Pascal Brandd6536da2015-09-01 10:38:43 +020020CCACHE ?= $(shell which ccache) # Don't remove this comment (space is needed)
21
Pascal Brand6044eb52016-02-23 15:48:31 +010022
23################################################################################
24# Check coherency of compilation mode
25################################################################################
26
27ifneq ($(COMPILE_NS_USER),)
28ifeq ($(COMPILE_NS_KERNEL),)
29$(error COMPILE_NS_KERNEL must be defined as COMPILE_NS_USER=$(COMPILE_NS_USER) is defined)
30endif
31ifeq (,$(filter $(COMPILE_NS_USER),32 64))
32$(error COMPILE_NS_USER=$(COMPILE_NS_USER) - Should be 32 or 64)
33endif
34endif
35
36ifneq ($(COMPILE_NS_KERNEL),)
37ifeq ($(COMPILE_NS_USER),)
38$(error COMPILE_NS_USER must be defined as COMPILE_NS_KERNEL=$(COMPILE_NS_KERNEL) is defined)
39endif
40ifeq (,$(filter $(COMPILE_NS_KERNEL),32 64))
41$(error COMPILE_NS_KERNEL=$(COMPILE_NS_KERNEL) - Should be 32 or 64)
42endif
43endif
44
45ifeq ($(COMPILE_NS_KERNEL),32)
46ifneq ($(COMPILE_NS_USER),32)
47$(error COMPILE_NS_USER=$(COMPILE_NS_USER) - Should be 32 as COMPILE_NS_KERNEL=$(COMPILE_NS_KERNEL))
48endif
49endif
50
51ifneq ($(COMPILE_S_USER),)
52ifeq ($(COMPILE_S_KERNEL),)
53$(error COMPILE_S_KERNEL must be defined as COMPILE_S_USER=$(COMPILE_S_USER) is defined)
54endif
55ifeq (,$(filter $(COMPILE_S_USER),32 64))
56$(error COMPILE_S_USER=$(COMPILE_S_USER) - Should be 32 or 64)
57endif
58endif
59
60ifneq ($(COMPILE_S_KERNEL),)
61OPTEE_OS_COMMON_EXTRA_FLAGS ?= O=out/arm
62OPTEE_OS_BIN ?= $(OPTEE_OS_PATH)/out/arm/core/tee.bin
63ifeq ($(COMPILE_S_USER),)
64$(error COMPILE_S_USER must be defined as COMPILE_S_KERNEL=$(COMPILE_S_KERNEL) is defined)
65endif
66ifeq (,$(filter $(COMPILE_S_KERNEL),32 64))
67$(error COMPILE_S_KERNEL=$(COMPILE_S_KERNEL) - Should be 32 or 64)
68endif
69endif
70
71ifeq ($(COMPILE_S_KERNEL),32)
72ifneq ($(COMPILE_S_USER),32)
73$(error COMPILE_S_USER=$(COMPILE_S_USER) - Should be 32 as COMPILE_S_KERNEL=$(COMPILE_S_KERNEL))
74endif
75endif
76
77
78################################################################################
79# set the compiler when COMPILE_xxx are defined
80################################################################################
Pascal Brandefe56592016-03-03 10:46:52 +010081CROSS_COMPILE_NS_USER ?= "$(CCACHE)$(AARCH$(COMPILE_NS_USER)_CROSS_COMPILE)"
82CROSS_COMPILE_NS_KERNEL ?= "$(CCACHE)$(AARCH$(COMPILE_NS_KERNEL)_CROSS_COMPILE)"
83CROSS_COMPILE_S_USER ?= "$(CCACHE)$(AARCH$(COMPILE_S_USER)_CROSS_COMPILE)"
84CROSS_COMPILE_S_KERNEL ?= "$(CCACHE)$(AARCH$(COMPILE_S_KERNEL)_CROSS_COMPILE)"
Pascal Brand6044eb52016-02-23 15:48:31 +010085
86ifeq ($(COMPILE_S_USER),32)
Pascal Brand6044eb52016-02-23 15:48:31 +010087OPTEE_OS_TA_DEV_KIT_DIR ?= $(OPTEE_OS_PATH)/out/arm/export-ta_arm32
88endif
89ifeq ($(COMPILE_S_USER),64)
Pascal Brand6044eb52016-02-23 15:48:31 +010090OPTEE_OS_TA_DEV_KIT_DIR ?= $(OPTEE_OS_PATH)/out/arm/export-ta_arm64
91endif
92
Pascal Brand6044eb52016-02-23 15:48:31 +010093ifeq ($(COMPILE_S_KERNEL),64)
Pascal Brand6044eb52016-02-23 15:48:31 +010094OPTEE_OS_COMMON_EXTRA_FLAGS += CFG_ARM64_core=y
95endif
96
97
Pascal Brandd6536da2015-09-01 10:38:43 +020098################################################################################
Pascal Brand070d9552015-09-01 15:33:22 +020099# defines, macros, configuration etc
100################################################################################
101define KERNEL_VERSION
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200102$(shell cd $(LINUX_PATH) && $(MAKE) --no-print-directory kernelversion)
Pascal Brand070d9552015-09-01 15:33:22 +0200103endef
104DEBUG ?= 0
105
106################################################################################
Pascal Brandcb452602015-10-13 10:46:33 +0200107# default target is all
108################################################################################
109all:
110
111################################################################################
Pascal Brand440ef9c2015-09-08 16:01:58 +0200112# Busybox
113################################################################################
114BUSYBOX_COMMON_TARGET ?= TOBEDEFINED
115BUSYBOX_CLEAN_COMMON_TARGET ?= TOBEDEFINED
Pascal Brand440ef9c2015-09-08 16:01:58 +0200116
117busybox-common: linux
118 cd $(GEN_ROOTFS_PATH) && \
Pascal Brandefe56592016-03-03 10:46:52 +0100119 CROSS_COMPILE=$(CROSS_COMPILE_NS_USER) \
Pascal Brand440ef9c2015-09-08 16:01:58 +0200120 PATH=${PATH}:$(LINUX_PATH)/usr \
121 $(GEN_ROOTFS_PATH)/generate-cpio-rootfs.sh \
122 $(BUSYBOX_COMMON_TARGET)
123
124busybox-clean-common:
125 cd $(GEN_ROOTFS_PATH) && \
126 $(GEN_ROOTFS_PATH)/generate-cpio-rootfs.sh \
127 $(BUSYBOX_CLEAN_COMMON_TARGET)
128
129busybox-cleaner-common:
130 rm -rf $(GEN_ROOTFS_PATH)/build
131 rm -rf $(GEN_ROOTFS_PATH)/filelist-final.txt
Victor Chong87f5fcf2015-11-26 10:52:52 +0900132
Pascal Brande3d85982015-09-10 17:20:42 +0200133################################################################################
134# Linux
135################################################################################
136LINUX_COMMON_FLAGS ?= LOCALVERSION= CROSS_COMPILE=$(CROSS_COMPILE_NS_KERNEL)
137
138linux-common: linux-defconfig
139 $(MAKE) -C $(LINUX_PATH) $(LINUX_COMMON_FLAGS)
140
Jerome Forissiere1002382015-11-26 11:36:00 +0100141$(LINUX_PATH)/.config: $(LINUX_DEFCONFIG_COMMON_FILES)
142 cd $(LINUX_PATH) && \
143 ARCH=$(LINUX_DEFCONFIG_COMMON_ARCH) \
144 scripts/kconfig/merge_config.sh $(LINUX_DEFCONFIG_COMMON_FILES)
145
Pascal Brande3d85982015-09-10 17:20:42 +0200146linux-defconfig-clean-common:
Victor Chong87f5fcf2015-11-26 10:52:52 +0900147 rm -f $(LINUX_PATH)/.config
Pascal Brande3d85982015-09-10 17:20:42 +0200148
Victor Chong87f5fcf2015-11-26 10:52:52 +0900149# LINUX_CLEAN_COMMON_FLAGS can be defined in specific makefiles (hikey.mk,...)
150# if necessary
151
Pascal Brande3d85982015-09-10 17:20:42 +0200152linux-clean-common: linux-defconfig-clean
153 $(MAKE) -C $(LINUX_PATH) $(LINUX_CLEAN_COMMON_FLAGS) clean
154
Victor Chong87f5fcf2015-11-26 10:52:52 +0900155# LINUX_CLEANER_COMMON_FLAGS can be defined in specific makefiles (hikey.mk,...)
156# if necessary
Pascal Brande3d85982015-09-10 17:20:42 +0200157
158linux-cleaner-common: linux-defconfig-clean
Victor Chong87f5fcf2015-11-26 10:52:52 +0900159 $(MAKE) -C $(LINUX_PATH) $(LINUX_CLEANER_COMMON_FLAGS) distclean
Pascal Brande3d85982015-09-10 17:20:42 +0200160
Pascal Brand440ef9c2015-09-08 16:01:58 +0200161################################################################################
Pascal Brand9a0f50f2015-09-08 15:34:17 +0200162# EDK2 / Tianocore
163################################################################################
164# Make sure edksetup.sh only will be called once and that we don't rebuild
165# BaseTools again and again.
166$(EDK2_PATH)/Conf/target.txt:
167 set -e && cd $(EDK2_PATH) && $(BASH) edksetup.sh && \
168 $(MAKE) -j1 -C $(EDK2_PATH)/BaseTools
169
170edk2-common: $(EDK2_PATH)/Conf/target.txt
171 set -e && cd $(EDK2_PATH) && $(BASH) edksetup.sh && \
172 $(call edk2-call)
173
174edk2-clean-common:
175 set -e && cd $(EDK2_PATH) && $(BASH) edksetup.sh && \
176 $(call edk2-call) clean && \
177 $(MAKE) -j1 -C $(EDK2_PATH)/BaseTools clean && \
178 rm -f $(EDK2_PATH)/Conf/target.txt
179
180################################################################################
Pascal Brand070d9552015-09-01 15:33:22 +0200181# OP-TEE
182################################################################################
Pascal Brand6044eb52016-02-23 15:48:31 +0100183OPTEE_OS_COMMON_FLAGS ?= \
184 $(OPTEE_OS_COMMON_EXTRA_FLAGS) \
185 CROSS_COMPILE=$(CROSS_COMPILE_S_USER) \
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200186 CROSS_COMPILE_core=$(CROSS_COMPILE_S_KERNEL) \
Victor Chongbadc7922015-12-08 17:23:20 +0000187 CROSS_COMPILE_ta_arm64=$(AARCH64_CROSS_COMPILE) \
188 CROSS_COMPILE_ta_arm32=$(AARCH32_CROSS_COMPILE) \
Pascal Brand23ef2052016-03-09 15:25:01 +0100189 CFG_TEE_CORE_LOG_LEVEL=$(CFG_TEE_CORE_LOG_LEVEL) \
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200190 DEBUG=$(DEBUG)
191
Pascal Brand070d9552015-09-01 15:33:22 +0200192optee-os-common:
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200193 $(MAKE) -C $(OPTEE_OS_PATH) $(OPTEE_OS_COMMON_FLAGS)
194
Pascal Brand6044eb52016-02-23 15:48:31 +0100195OPTEE_OS_CLEAN_COMMON_FLAGS ?= $(OPTEE_OS_COMMON_EXTRA_FLAGS)
Pascal Brand070d9552015-09-01 15:33:22 +0200196
Pascal Brandb130ea22015-10-13 13:18:36 +0200197optee-os-clean-common: xtest-clean
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200198 $(MAKE) -C $(OPTEE_OS_PATH) $(OPTEE_OS_CLEAN_COMMON_FLAGS) clean
199
200OPTEE_CLIENT_COMMON_FLAGS ?= CROSS_COMPILE=$(CROSS_COMPILE_NS_USER)
Pascal Brand070d9552015-09-01 15:33:22 +0200201
202optee-client-common:
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200203 $(MAKE) -C $(OPTEE_CLIENT_PATH) $(OPTEE_CLIENT_COMMON_FLAGS)
204
Victor Chong87f5fcf2015-11-26 10:52:52 +0900205# OPTEE_CLIENT_CLEAN_COMMON_FLAGS can be defined in specific makefiles
206# (hikey.mk,...) if necessary
Pascal Brand070d9552015-09-01 15:33:22 +0200207
208optee-client-clean-common:
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200209 $(MAKE) -C $(OPTEE_CLIENT_PATH) $(OPTEE_CLIENT_CLEAN_COMMON_FLAGS) \
210 clean
211
Pascal Brand070d9552015-09-01 15:33:22 +0200212################################################################################
Pascal Brandd6536da2015-09-01 10:38:43 +0200213# xtest / optee_test
214################################################################################
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200215XTEST_COMMON_FLAGS ?= CROSS_COMPILE_HOST=$(CROSS_COMPILE_NS_USER)\
216 CROSS_COMPILE_TA=$(CROSS_COMPILE_S_USER) \
217 TA_DEV_KIT_DIR=$(OPTEE_OS_TA_DEV_KIT_DIR) \
218 CFG_DEV_PATH=$(ROOT) \
Pascal Brand6044eb52016-02-23 15:48:31 +0100219 COMPILE_NS_USER=$(COMPILE_NS_USER) \
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200220 O=$(OPTEE_TEST_OUT_PATH)
221
Pascal Brandd6536da2015-09-01 10:38:43 +0200222xtest-common: optee-os optee-client
Pascal Branddc83b9a2015-09-24 02:43:25 +0200223 $(MAKE) -C $(OPTEE_TEST_PATH) $(XTEST_COMMON_FLAGS)
Pascal Brandd6536da2015-09-01 10:38:43 +0200224
Victor Chong87f5fcf2015-11-26 10:52:52 +0900225XTEST_CLEAN_COMMON_FLAGS ?= TA_DEV_KIT_DIR=$(OPTEE_OS_TA_DEV_KIT_DIR)
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200226
Pascal Brandd6536da2015-09-01 10:38:43 +0200227xtest-clean-common:
Pascal Branddc83b9a2015-09-24 02:43:25 +0200228 $(MAKE) -C $(OPTEE_TEST_PATH) $(XTEST_CLEAN_COMMON_FLAGS) clean
Pascal Brandd6536da2015-09-01 10:38:43 +0200229
Pascal Branddc83b9a2015-09-24 02:43:25 +0200230XTEST_PATCH_COMMON_FLAGS ?= $(XTEST_COMMON_FLAGS)
Jerome Forissierae45fbf2015-09-04 09:40:17 +0200231
Pascal Branddc83b9a2015-09-24 02:43:25 +0200232xtest-patch-common:
233 $(MAKE) -C $(OPTEE_TEST_PATH) $(XTEST_PATCH_COMMON_FLAGS) patch