mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
Alexandre Abadie
e089b1eb02
It must be evaluated in `cortexm_common` without a shell context. The `K` is correctly handled by both the linker and `cortexm_common`. Co-authored-by: Gaëtan Harter <gaetan.harter@fu-berlin.de>
55 lines
1.8 KiB
Makefile
55 lines
1.8 KiB
Makefile
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
|
|
|
|
# Add search path for linker scripts
|
|
LINKFLAGS += -L$(RIOTCPU)/$(CPU)/ldscripts
|
|
|
|
# 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)))
|
|
# 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
|
|
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) \
|
|
#
|
|
|
|
LINKFLAGS += $(LINKFLAGPREFIX)--defsym=_rom_start_addr=$(ROM_START_ADDR)
|
|
LINKFLAGS += $(LINKFLAGPREFIX)--defsym=_ram_base_addr=$(RAM_BASE_ADDR)
|
|
LINKFLAGS += $(LINKFLAGPREFIX)--defsym=_ram_start_addr=$(RAM_START_ADDR)
|
|
LINKFLAGS += $(LINKFLAGPREFIX)--defsym=_rom_length=$(ROM_LEN)
|
|
LINKFLAGS += $(LINKFLAGPREFIX)--defsym=_ram_length=$(RAM_LEN)
|
|
|
|
# add the CPU specific flash configuration field for the linker
|
|
export UNDEF += $(BINDIR)/cpu/fcfield.o
|
|
|
|
# include common periph drivers
|
|
USEMODULE += periph_common
|
|
|
|
# select kinetis periph drivers
|
|
ifeq (EA,$(KINETIS_SERIES))
|
|
USEMODULE += periph_ics
|
|
else
|
|
USEMODULE += periph_mcg
|
|
endif
|
|
USEMODULE += periph_wdog
|
|
|
|
# Define a recipe to build the watchdog disable binary, used when flashing
|
|
$(RIOTCPU)/$(CPU)/dist/wdog-disable.bin: $(RIOTCPU)/$(CPU)/dist/wdog-disable.s
|
|
$(Q)$(MAKE) -C $(RIOTCPU)/$(CPU)/dist/ $(notdir $@)
|
|
|
|
include $(RIOTMAKE)/arch/cortexm.inc.mk
|