CONFIG_TA_ARCH    = 32
include ../../build/teegris_config.mk
TARGET_TA_NAME    = 00000000-0000-0000-0000-496343475244
OUT_DIR           = $(CURRENT_PATH)/dist/obj
OUT_DIR_OBJ_LIB   = $(CURRENT_PATH)/dist/obj-lib
OS_TYPE           = android
#USE_SCRYPTO       = FALSE # not used internally
#CONFIG_SW_SYSROOT = $(PLATFORM_ROOT)/swd/arch-arm # teegris_config.mk
#CONFIG_CC_SW      = ${CONFIG_SW_TOOLCHAIN_ROOT}/toolchains/arm-secureos-gnueabi-gcc_6_3-linux-x86/bin/arm*-secureos-gnueabi-gcc # teegris_config.mk
#CONFIG_STRIP_SW   = ${CONFIG_SW_TOOLCHAIN_ROOT}/toolchains/arm-secureos-gnueabi-gcc_6_3-linux-x86/bin/arm*-secureos-gnueabi-strip # teegris_config.mk
#CONFIG_LDFLAGS_SW := -Wl,-z,relro,-z,now # teegris_config.mk

UNSIGNED_TA := $(OUT_DIR)/unsigned_TA
STRIPPED_TA := $(OUT_DIR)/stripped_TA
SIGNED_TA   := $(OUT_DIR)/$(TARGET_TA_NAME)

TRUSTLET_DIR = .

$(info [ICCC] Used TEEGRIS ver $(TEEGRIS_VERSION))
#CONFIG_SIGN_TYPE  = ss_teegris_ta_rp # teegris_config.mk
#CONFIG_MODEL_NAME = TEEGRIS_$(shell echo $(TEEGRIS_BUILD_MODEL) | tr [a-z] [A-Z])_SAMSUNG_DRV # teegris_config.mk

# Build info
CFLAGS += -DTARGET_BUILD_VARIANT=\"$(TARGET_BUILD_VARIANT)\"
CFLAGS += -DTEEGRIS_VERSION=\"$(TEEGRIS_VERSION)\"
CFLAGS += -DTEEGRIS_BUILD_MODEL=\"$(TEEGRIS_BUILD_MODEL)\"

CFLAGS += \
    -Wall \
    -Wextra \
    -Wno-unused \
    -fstack-protector-all \
    -D_FORTIFY_SOURCE=2 \
    -O2 \
    -fpie

# ICCC src, header
ICCC_SRC = $(TRUSTLET_DIR)/src
INCLUDE_DIRS += -I$(TRUSTLET_DIR)/inc
SRCS := $(wildcard $(ICCC_SRC)/*.c)

# Chipset info
ifeq ($(TEEGRIS_BUILD_MODEL), MT8768T)
CFLAGS += -DMT8768T
CFLAGS += -DTZ_TAG_MTK
ICCC_MTK_SRC += $(TRUSTLET_DIR)/src/mediatek
INCLUDE_DIRS += -I$(TRUSTLET_DIR)/inc/mediatek
SRCS += $(wildcard $(ICCC_MTK_SRC)/*.c)
endif

INCLUDE_DIRS += -I$(CONFIG_SW_SYSROOT)/usr/include
LIBS += -ltzsl -lgcc
LIB_DIRS += -L$(CONFIG_SW_SYSROOT)/usr/lib

# Support scrypto
LIBS += -lscrypto

# Support ICCC Guardian-M
# Local debug - LIB_DIRS += -L$(TRUSTLET_DIR)/external/GRDM/TEE/lib/Debug/teegris/mt8768t/nxpV4
# Local release - LIB_DIRS += -L$(TRUSTLET_DIR)/external/GRDM/TEE/lib/Release/teegris/mt8768t/nxpV4
# Official release - ../SEM/lib/teegris/mt8768t/nxpV4/
INCLUDE_DIRS += -I$(TRUSTLET_DIR)/external/GRDM/TEE/header
LIBS += -l:grdm.lib
LIB_DIRS += -L$(GRDM_LIB_PATH)

OBJS := $(patsubst %.c,%.o,$(SRCS))

INCLUDE_DIRS += -I$(TRUSTLET_DIR)/../tz_icccgrd_common/public

# Generate .OL
OBJ_LIB_SRC += $(TRUSTLET_DIR)/../tz_icccgrd_common/tl/icccOperations_grdm.c
OBJ_LIB = $(patsubst %.cxx,%.ol,$(patsubst %.c,%.ol,$(OBJ_LIB_SRC)))
OBJ_LIB_BIN = $(addprefix $(OUT_DIR_OBJ_LIB)/,$(notdir $(OBJ_LIB)))

# Prepare Includes
ifeq ($(TEEGRIS_TA_DIST_PATH),)
	TEEGRIS_TA_DIST_PATH := dist
endif

.PHONY: all
all: make_ol_dist $(OBJ_LIB) info_ta make_dist $(STRIPPED_TA) $(SIGNED_TA) copy_dist copy_ol_dist build_done

.PHONY: build_done
build_done: make_dist $(SIGNED_TA) copy_dist
	$(info Build Done.)

$(UNSIGNED_TA): $(OBJS)
	@$(CONFIG_CC_SW) $(CFLAGS) $(CONFIG_LDFLAGS_SW) -o $(UNSIGNED_TA) $(OBJS) $(LIBS) $(INCLUDE_DIRS) $(LIB_DIRS)

$(STRIPPED_TA): $(UNSIGNED_TA) make_dist
	@$(CONFIG_STRIP_SW) $(STRIP_FLAGS_SW) $(UNSIGNED_TA) -o $(STRIPPED_TA)

$(SIGNED_TA): $(STRIPPED_TA) make_dist $(test_TA_with_keys)
	@$(signing_command_drv)

%.o: %.c
	@echo Compiling ICCC src: $@
	@$(CONFIG_CC_SW) -c -o $*.o $(CFLAGS) $(INCLUDE_DIRS) $<

%.ol: %.c
	@echo Compiling icccOperations_grdm.ol: $@
	@$(CONFIG_CC_SW) $(CFLAGS) $(INCLUDE_DIRS) $(CONFIG_LDFLAGS_SW) -c $< -o $(addprefix $(OUT_DIR_OBJ_LIB)/,$(notdir $@))

.PHONY: make_dist
make_dist:
	@$(MKDIR) $(OUT_DIR)

.PHONY: make_ol_dist
make_ol_dist:
	@$(MKDIR) $(OUT_DIR_OBJ_LIB)

.PHONY: copy_dist
copy_dist: make_dist $(SIGNED_TA)
	@echo Copy $(SIGNED_TA) $(TEEGRIS_TA_DIST_PATH)
	@$(CP) $(SIGNED_TA) $(TEEGRIS_TA_DIST_PATH)

.PHONY: copy_ol_dist
copy_ol_dist: make_ol_dist
	@echo Copy $(OUT_DIR_OBJ_LIB)/icccOperations_grdm.ol $(TEEGRIS_TA_DIST_PATH)
	@$(CP) $(OUT_DIR_OBJ_LIB)/icccOperations_grdm.ol $(TEEGRIS_TA_DIST_PATH)

.PHONY: info_ta
info_ta:
	$(info [ICCC] Building TA: $(TARGET_TA_NAME) ; $(CFLAGS))

.PHONY: clean
clean:
	@$(RM) $(OUT_DIR_OBJ_LIB)
	@$(RM) $(OUT_DIR)
	@$(RM) $(DIST_DIR)
	@echo 'Clean Done.'
