COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR ?= $(abspath ../../../../../..)

include $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/imports.mak

CC = "$(IAR_ARMCOMPILER)/bin/iccarm"
LNK = "$(IAR_ARMCOMPILER)/bin/ilinkarm"

SYSCFG_CMD_STUB = $(SYSCONFIG_TOOL) --compiler iar --product $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/.metadata/product.json --product $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/.metadata/product.json
SYSCFG_FILES := $(shell $(SYSCFG_CMD_STUB) --listGeneratedFiles --listReferencedFiles --output . ../mcuboot.syscfg)

SYSCFG_C_FILES = $(filter %.c,$(SYSCFG_FILES))
SYSCFG_H_FILES = $(filter %.h,$(SYSCFG_FILES))
SYSCFG_OPT_FILES = $(filter %.opt,$(SYSCFG_FILES))

OBJECTS = mcuboot_config_led_debug.obj mcuboot_app.obj keys.obj flash_map_backend_flash_map_backend.obj flash_map_backend_ext_flash.obj bootutil_src_security_cnt.obj bootutil_src_boot_record.obj bootutil_src_image_ed25519.obj bootutil_src_bootutil_misc.obj bootutil_src_image_rsa.obj bootutil_src_image_validate.obj bootutil_src_bootutil_public.obj bootutil_src_loader.obj bootutil_src_caps.obj bootutil_src_swap_misc.obj bootutil_src_encrypted.obj bootutil_src_swap_move.obj bootutil_src_fault_injection_hardening.obj bootutil_src_fault_injection_hardening_delay_rng_mbedtls.obj bootutil_src_swap_scratch.obj bootutil_src_image_ec.obj bootutil_src_tlv.obj bootutil_src_image_ec256.obj mbedtls-asn1_asn1parse.obj mbedtls-asn1_platform_util.obj ti-crypto_sl_crypto.obj ecdsa_lpf3.obj flash_map_backend_bsp_spi_lpf3.obj $(patsubst %.c,%.obj,$(notdir $(SYSCFG_C_FILES)))
NAME = mcuboot

CFLAGS += -I.. \
    -I. \
    $(addprefix -f,$(SYSCFG_OPT_FILES)) \
    -Ohz \
    -I${PROJECT_ROOT} \
    -I${PROJECT_ROOT}/${ConfigName} \
    -DEXCLUDE_TRACE \
    -DBOOT_LOADER \
    -DSPI_CTL0_SPO_LOW=SPI_CTL0_SPO_LO \
    -DSPI_CTL0_SPO_HIGH=SPI_CTL0_SPO_HI \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/ti \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/kernel/nortos \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/kernel/nortos/posix \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/third_party/ecc/include \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/ti/devices/cc23x0r5/driverlib \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/ti \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/ti/common/cc26xx/sha2 \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/ti/common/cc26xx/ecc \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/ti/common/flash/no_rtos/extFlash \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/third_party/mcuboot/boot/bootutil/include \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/third_party/mcuboot/boot/bootutil/src \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/third_party/mcuboot/ext \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/third_party/mcuboot/ext/mbedtls-asn1/include \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/third_party/mcuboot/boot/ti/source/mcuboot_app \
    -I$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/ti/common/ecdsa_lpf3 \
    --debug \
    --silent \
    -e \
    --aeabi \
    --thumb \
    --diag_suppress=Pa050 \
    --cpu=Cortex-M0+ \
    --vla

LFLAGS += --silent \
    -L$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source \
    -L$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/kernel/nortos \
    -L$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/ti/devices/cc23x0r5 \
    -L$COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR$/source/ti/devices/cc23x0r5/inc \
    -fti_utils_build_linker.cmd.genlibs \
    "$(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/ecc/lib/iar/m0p/ecc.a" \
    --config ../mcuboot_lpf3.icf \
    --map "$(NAME).map" \
    --semihosting=iar_breakpoint \
    --cpu=Cortex-M0+

all: $(NAME).out

.INTERMEDIATE: syscfg
$(SYSCFG_FILES): syscfg
	@ echo generation complete

syscfg: ../mcuboot.syscfg
	@ echo Generating configuration files...
	@ $(SYSCFG_CMD_STUB) --output $(@D) $<

define C_RULE
$(basename $(notdir $(1))).obj: $(1) $(SYSCFG_H_FILES)
	@ echo Building $$@
	@ $(CC) $(CFLAGS) $$< -o $$@
endef

$(foreach c_file,$(SYSCFG_C_FILES),$(eval $(call C_RULE,$(c_file))))

mcuboot_config_led_debug.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/ti/common/cc26xx/debug/led_debug.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

mcuboot_app.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/ti/source/mcuboot_app/mcuboot_app.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

keys.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/ti/source/mcuboot_app/keys.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

flash_map_backend_flash_map_backend.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/ti/source/mcuboot_app/flash_map_backend/flash_map_backend.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

flash_map_backend_ext_flash.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/ti/common/flash/no_rtos/extFlash/ext_flash.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_security_cnt.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/ti/source/mcuboot_app/security_cnt.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_boot_record.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/boot_record.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_image_ed25519.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/image_ed25519.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_bootutil_misc.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/bootutil_misc.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_image_rsa.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/image_rsa.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_image_validate.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/image_validate.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_bootutil_public.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/bootutil_public.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_loader.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/loader.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_caps.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/caps.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_swap_misc.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/swap_misc.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_encrypted.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/encrypted.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_swap_move.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/swap_move.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_fault_injection_hardening.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/fault_injection_hardening.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_fault_injection_hardening_delay_rng_mbedtls.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/fault_injection_hardening_delay_rng_mbedtls.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_swap_scratch.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/swap_scratch.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_image_ec.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/image_ec.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_tlv.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/tlv.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

bootutil_src_image_ec256.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/boot/bootutil/src/image_ec256.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

mbedtls-asn1_asn1parse.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/ext/mbedtls-asn1/src/asn1parse.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

mbedtls-asn1_platform_util.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/ext/mbedtls-asn1/src/platform_util.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

ti-crypto_sl_crypto.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/third_party/mcuboot/ext/ti-crypto/sl_crypto.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

ecdsa_lpf3.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/ti/common/ecdsa_lpf3/ecdsa_lpf3.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

flash_map_backend_bsp_spi_lpf3.obj: $(COM_TI_SIMPLELINK_LOWPOWER_F3_SDK_INSTALL_DIR)/source/ti/common/flash/no_rtos/extFlash/bsp_spi_lpf3.c $(SYSCFG_H_FILES)
	@ echo Building $@
	@ $(CC) $(CFLAGS) $< -o $@

$(NAME).out: $(OBJECTS)
	@ echo linking $@
	@ $(LNK)  $(OBJECTS)  $(LFLAGS) -o $(NAME).out

clean:
	@ echo Cleaning...
	@ $(RM) $(OBJECTS) > $(DEVNULL) 2>&1
	@ $(RM) $(NAME).out > $(DEVNULL) 2>&1
	@ $(RM) $(NAME).map > $(DEVNULL) 2>&1
	@ $(RM) $(SYSCFG_FILES)> $(DEVNULL) 2>&1
