1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/cpu/kinetis/kinetis-info.mk
2018-01-17 18:13:59 +01:00

149 lines
5.5 KiB
Makefile

# Split the part number into qualification, family, subfamily, core, memory, temperature, package, speed
KINETIS_INFO := $(shell printf '%s' '$(CPU_MODEL)' | tr 'a-z' 'A-Z' | sed -E -e 's/^(M|K|S9)K([ELMSVW]?|EA)([0-9]?)([0-9]?)([A-Z])([NX]?)([0-9][0-9M]?[0-9]?)([ABZ]?)(.*)$$/\1 \2 \3 \4 \5 \6 \7 \8:\9/' -e 's/^([^ ]*) /\1 K /' -e 's/^([^:]*):([CMV])(..)([0-9]*).*$$/\1 \2 \3 \4/' -e 's/ / _ /g' -e 's/ / _ /g')
export KINETIS_QUALIFICATION := $(word 1, $(KINETIS_INFO))
export KINETIS_SERIES := $(word 2, $(KINETIS_INFO))
export KINETIS_FAMILY := $(word 3, $(KINETIS_INFO))
export KINETIS_SUBFAMILY := $(word 4, $(KINETIS_INFO))
# Core type, D = Cortex-M4, F = Cortex-M4/M7 w/ FPU, Z = Cortex-M0
export KINETIS_CORE := $(word 5, $(KINETIS_INFO))
# FlexRAM (X) or not (N), does not apply to all families
export KINETIS_FLEXMEM := $(word 6, $(KINETIS_INFO))
# ROM size, KiB
export KINETIS_ROMSIZE := $(word 7, $(KINETIS_INFO))
# some special cases for ROM size, refactor when there are too many special cases
ifeq ($(KINETIS_ROMSIZE), 1M0)
export KINETIS_ROMSIZE = 1024
else ifeq ($(KINETIS_ROMSIZE), 1M2)
export KINETIS_ROMSIZE = 1280
else ifeq ($(KINETIS_ROMSIZE), 2M0)
export KINETIS_ROMSIZE = 2048
endif
# Mask set revision, only some parts, see data sheet for details
export KINETIS_MASKREV := $(word 8, $(KINETIS_INFO))
# Temperature range, C = -40--+85, V = -40--+105, M = -40--+125
export KINETIS_TEMPRANGE := $(word 9, $(KINETIS_INFO))
# Chip package code
export KINETIS_PACKAGE := $(word 10, $(KINETIS_INFO))
# Maximum speed, MHz/10, max speed is usually 48 MHz if this number is missing
export KINETIS_SPEED := $(word 11, $(KINETIS_INFO))
ifeq ($(KINETIS_CORE), Z)
# Cortex-M0+
export CPU_ARCH = cortex-m0plus
export CPU_FAMILY = klx
else ifeq ($(KINETIS_CORE), D)
# Cortex-M4
export CPU_ARCH = cortex-m4
export CPU_FAMILY = kx
else ifeq ($(KINETIS_CORE), F)
# Cortex-M4F or Cortex-M7
# TODO: Add floating point support
export CPU_ARCH = cortex-m4
export CPU_FAMILY = kx
endif
# RAM sizes are a bit arbitrary, but are usually dependent on ROM size and core speed.
# KINETIS_RAMSIZE is used inside a $(( )) shell arithmetic block, so it is OK to
# use mathematical expressions here.
# This block is not complete, but it does cover all the CPUs supported by RIOT, and then some.
ifeq ($(KINETIS_SERIES),K)
# A majority of the models have this ratio of SRAM_L vs total SRAM size
KINETIS_SRAM_L_SIZE = $(KINETIS_RAMSIZE)/2
ifeq ($(KINETIS_ROMSIZE),2048)
ifeq ($(firstword $(sort $(KINETIS_SUBFAMILY) 7)),7)
# subfamily >= 7
# OCRAM in K27, K28 is not mapped here.
KINETIS_RAMSIZE = 512
else
KINETIS_RAMSIZE = 256
endif
else ifeq ($(KINETIS_ROMSIZE),1024)
ifeq ($(firstword $(sort $(KINETIS_SUBFAMILY) 3)),3)
# subfamily >= 3
KINETIS_RAMSIZE = 256
else
KINETIS_RAMSIZE = 128
endif
else ifeq ($(KINETIS_ROMSIZE),512)
ifeq ($(KINETIS_SPEED),5)
KINETIS_RAMSIZE = 64
else ifeq ($(KINETIS_SUBFAMILY),4)
KINETIS_RAMSIZE = 192
else
KINETIS_RAMSIZE = 128
endif
else ifeq ($(KINETIS_ROMSIZE),256)
ifeq ($(KINETIS_SPEED),5)
KINETIS_RAMSIZE = 32
else ifeq ($(KINETIS_SPEED),15)
KINETIS_RAMSIZE = 256
else ifeq ($(KINETIS_FAMILY)$(KINETIS_SUBFAMILY),22)
KINETIS_RAMSIZE = 48
else ifeq ($(KINETIS_FAMILY)$(KINETIS_SUBFAMILY),24)
KINETIS_RAMSIZE = 256
else ifeq ($(KINETIS_FAMILY)$(KINETIS_SUBFAMILY),20)
KINETIS_RAMSIZE = 64
endif
else ifeq ($(KINETIS_ROMSIZE),128)
ifeq ($(KINETIS_FAMILY),0)
KINETIS_RAMSIZE = 16
else ifeq ($(KINETIS_SUBFAMILY)$(KINETIS_SPEED),05)
KINETIS_RAMSIZE = 16
else ifeq ($(KINETIS_CORE),F)
KINETIS_RAMSIZE = 24
KINETIS_SRAM_L_SIZE = 8
else
KINETIS_RAMSIZE = 32
endif
else ifeq ($(KINETIS_ROMSIZE),64)
KINETIS_RAMSIZE = 16
endif
ifneq (,$(filter $(KINETIS_RAMSIZE),192 256))
# There seems to be a cap on SRAM_L at 64 kB across the whole K series
KINETIS_SRAM_L_SIZE = 64
endif
else ifeq ($(KINETIS_SERIES),W)
KINETIS_RAMSIZE = $(KINETIS_ROMSIZE)/8
ifeq ($(KINETIS_CORE),D)
KINETIS_SRAM_L_SIZE = $(KINETIS_RAMSIZE)/2
else ifeq ($(KINETIS_FAMILY),0)
# 01Z
KINETIS_SRAM_L_SIZE = 4
else ifeq ($(KINETIS_SUBFAMILY),0)
# 20Z, 30Z, 40Z
KINETIS_SRAM_L_SIZE = 4
else ifeq ($(KINETIS_SUBFAMILY),1)
# 21Z, 31Z, 41Z
KINETIS_RAMSIZE = $(KINETIS_ROMSIZE)/4
KINETIS_SRAM_L_SIZE = $(KINETIS_RAMSIZE)/4
else
# TODO: KW35/36
$(error Unknown Kinetis W)
endif
endif
export KINETIS_RAMSIZE
export KINETIS_SRAM_L_SIZE
# Some debug output to use in case things are not being correctly detected
ifeq ($(KINETIS_INFO_DEBUG),1)
$(info Kinetis CPU info: $(KINETIS_INFO))
$(info Qualification: $(KINETIS_QUALIFICATION))
$(info Core: $(KINETIS_CORE))
$(info Series: $(KINETIS_SERIES))
$(info Family: $(KINETIS_FAMILY))
$(info Subfamily: $(KINETIS_SUBFAMILY))
$(info ROM size: $(KINETIS_ROMSIZE))
$(info RAM size: $(shell printf '%-4s (%s)' $$(($(KINETIS_RAMSIZE))) '$(KINETIS_RAMSIZE)'))
$(info SRAM_L: $(shell printf '%-4s (%s)' $$(($(KINETIS_SRAM_L_SIZE))) '$(KINETIS_SRAM_L_SIZE)'))
$(info Max speed: $(KINETIS_SPEED))
$(info Temperature range: $(KINETIS_TEMPRANGE))
$(info Revision: $(KINETIS_MASKREV))
$(info Package code: $(KINETIS_PACKAGE))
endif
ifeq (,$(KINETIS_RAMSIZE))
$(error Unknown Kinetis RAM size, update kinetis-info.mk with your CPU)
endif