2019-05-13 16:08:54 +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.
|
2022-11-24 14:56:21 +01:00
|
|
|
ifneq (,$(filter usbus_dfu tinyusb_dfu,$(USEMODULE)))
|
2020-12-15 17:17:05 +01:00
|
|
|
RIOTBOOT_LEN ?= 0x4000
|
|
|
|
else
|
|
|
|
RIOTBOOT_LEN ?= 0x2000
|
|
|
|
endif
|
2019-05-13 16:08:54 +02:00
|
|
|
|
2017-07-03 14:27:22 +02:00
|
|
|
# Export internal ROM alignment and slot sizes for bootloader support
|
2018-02-06 16:41:48 +01:00
|
|
|
export MCUBOOT_IMAGE_ALIGN = 8
|
|
|
|
export MCUBOOT_SLOT0_SIZE = 0x8000
|
|
|
|
export MCUBOOT_SLOT1_SIZE = 0x3C000
|
|
|
|
export MCUBOOT_SLOT2_SIZE = 0x3C000
|
2017-07-03 14:27:22 +02:00
|
|
|
|
2019-03-07 14:27:45 +01:00
|
|
|
# Set ROM and RAM lengths according to CPU model
|
2020-06-26 16:26:17 +02:00
|
|
|
ifneq (,$(filter nrf52805xxaa nrf52810xxaa nrf52811xxaa,$(CPU_MODEL)))
|
2020-05-03 15:54:32 +02:00
|
|
|
ROM_LEN ?= 0x30000
|
|
|
|
RAM_LEN ?= 0x6000
|
|
|
|
endif
|
2020-06-26 16:26:17 +02:00
|
|
|
ifneq (,$(filter nrf52820xxaa,$(CPU_MODEL)))
|
|
|
|
ROM_LEN ?= 0x40000
|
|
|
|
RAM_LEN ?= 0x8000
|
|
|
|
endif
|
2019-03-07 14:27:45 +01:00
|
|
|
ifneq (,$(filter nrf52832xxaa,$(CPU_MODEL)))
|
|
|
|
ROM_LEN ?= 0x80000
|
|
|
|
RAM_LEN ?= 0x10000
|
|
|
|
endif
|
2020-06-26 16:26:17 +02:00
|
|
|
ifneq (,$(filter nrf52833xxaa,$(CPU_MODEL)))
|
|
|
|
ROM_LEN ?= 0x80000
|
|
|
|
RAM_LEN ?= 0x20000
|
|
|
|
endif
|
2019-03-07 14:27:45 +01:00
|
|
|
ifneq (,$(filter nrf52840xxaa,$(CPU_MODEL)))
|
|
|
|
ROM_LEN ?= 0x100000
|
|
|
|
RAM_LEN ?= 0x40000
|
|
|
|
endif
|
|
|
|
|
2020-06-23 00:29:29 +02:00
|
|
|
VECTORS_O ?= $(BINDIR)/nrf52_vectors/vectors_$(CPU_MODEL).o
|
|
|
|
|
2016-02-07 12:55:42 +01:00
|
|
|
include $(RIOTCPU)/nrf5x_common/Makefile.include
|
2016-01-27 10:47:12 +01:00
|
|
|
include $(RIOTMAKE)/arch/cortexm.inc.mk
|