2017-10-27 01:04:54 +02:00
|
|
|
ifeq (,$(KINETIS_SERIES))
|
|
|
|
# Parse parameters from CPU_MODEL using the kinetis-info.mk script in the same
|
|
|
|
# directory as this Makefile.
|
|
|
|
include $(dir $(abspath $(lastword $(MAKEFILE_LIST))))/kinetis-info.mk
|
|
|
|
endif
|
|
|
|
|
2019-06-06 11:58:58 +02:00
|
|
|
# "The Vector table must be naturally aligned to a power of two whose alignment
|
|
|
|
# value is greater than or equal to number of Exceptions supported x 4"
|
2019-05-28 15:54:06 +02:00
|
|
|
# CPU_IRQ_NUMOF for KWxD and KxF boards is < 102+16 so (81*4 bytes = 472 bytes ~= 0x200)
|
2019-06-06 11:58:58 +02:00
|
|
|
# RIOTBOOT_HDR_LEN can be set to 0x200
|
2019-05-28 15:54:06 +02:00
|
|
|
ifneq (,$(filter FK DW,$(KINETIS_CORE)$(KINETIS_SERIES)))
|
2019-06-06 11:58:58 +02:00
|
|
|
RIOTBOOT_HDR_LEN ?= 0x200
|
|
|
|
endif
|
|
|
|
|
2019-05-28 15:54:06 +02:00
|
|
|
# Slot size is determined by "((total_flash_size - RIOTBOOT_LEN) / 2)".
|
|
|
|
# If RIOTBOOT_LEN uses an uneven number of flashpages, the remainder of the
|
|
|
|
# flash cannot be divided by two slots while staying FLASHPAGE_SIZE aligned.
|
|
|
|
ifeq (K, $(KINETIS_SERIES))
|
|
|
|
RIOTBOOT_LEN ?= 0x2000
|
|
|
|
endif
|
|
|
|
|
2015-02-05 15:34:51 +01:00
|
|
|
# Add search path for linker scripts
|
2017-10-27 01:26:26 +02:00
|
|
|
LINKFLAGS += -L$(RIOTCPU)/$(CPU)/ldscripts
|
2015-02-09 13:50:37 +01:00
|
|
|
|
2017-10-27 01:05:33 +02:00
|
|
|
# Use generic linker script for all Kinetis based CPUs
|
|
|
|
LINKER_SCRIPT = kinetis.ld
|
|
|
|
|
|
|
|
ROM_START_ADDR = 0x00000000
|
|
|
|
RAM_BASE_ADDR = 0x20000000
|
|
|
|
RAM_START_ADDR = $$(($(RAM_BASE_ADDR)-($(KINETIS_SRAM_L_SIZE) * 1024)))
|
2019-03-23 06:55:08 +01:00
|
|
|
# Define ROM_LEN with a non arithmetic value as it must be
|
|
|
|
# evaluated in `cortexm_common` without a shell context
|
|
|
|
# The `K` is correctly handled by both the linker and `cortexm_common`.
|
|
|
|
ROM_LEN = $(KINETIS_ROMSIZE)K
|
2017-10-27 01:05:33 +02:00
|
|
|
RAM_LEN = $$(($(KINETIS_RAMSIZE) * 1024))
|
|
|
|
|
|
|
|
CFLAGS += \
|
|
|
|
-DKINETIS_CORE_$(KINETIS_CORE) \
|
|
|
|
-DKINETIS_SERIES_$(KINETIS_SERIES) \
|
|
|
|
-DKINETIS_FAMILY=$(KINETIS_FAMILY) \
|
|
|
|
-DKINETIS_SUBFAMILY=$(KINETIS_SUBFAMILY) \
|
|
|
|
-DKINETIS_ROMSIZE=$(KINETIS_ROMSIZE) \
|
|
|
|
#
|
|
|
|
|
2017-10-27 01:26:26 +02:00
|
|
|
# add the CPU specific flash configuration field for the linker
|
|
|
|
export UNDEF += $(BINDIR)/cpu/fcfield.o
|
2017-10-16 15:53:15 +02:00
|
|
|
|
2017-09-09 15:04:37 +02:00
|
|
|
# select kinetis periph drivers
|
2018-07-31 18:08:07 +02:00
|
|
|
ifeq (EA,$(KINETIS_SERIES))
|
|
|
|
USEMODULE += periph_ics
|
|
|
|
else
|
2017-09-09 15:04:37 +02:00
|
|
|
USEMODULE += periph_mcg
|
2018-07-31 18:08:07 +02:00
|
|
|
endif
|
2017-09-09 15:04:37 +02:00
|
|
|
USEMODULE += periph_wdog
|
2017-01-09 22:55:53 +01:00
|
|
|
|
2017-10-27 01:26:26 +02:00
|
|
|
include $(RIOTMAKE)/arch/cortexm.inc.mk
|