2019-08-01 20:47:31 +02:00
|
|
|
# Nordic Semiconductor nRF53 MCU line
|
|
|
|
|
|
|
|
# Copyright (c) 2019 Nordic Semiconductor ASA
|
|
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
2021-09-14 13:11:52 +02:00
|
|
|
if SOC_SERIES_NRF53X
|
2019-08-01 20:47:31 +02:00
|
|
|
config SOC_NRF5340_CPUAPP
|
|
|
|
bool
|
|
|
|
select CPU_HAS_NRF_IDAU
|
|
|
|
select CPU_HAS_FPU
|
|
|
|
select ARMV8_M_DSP
|
|
|
|
select HAS_HW_NRF_CC312
|
2021-09-27 17:11:06 +02:00
|
|
|
select HAS_HW_NRF_COMP
|
2019-08-01 20:47:31 +02:00
|
|
|
select HAS_HW_NRF_CLOCK
|
2021-11-09 17:58:49 +01:00
|
|
|
select HAS_HW_NRF_DCNF
|
2019-08-01 20:47:31 +02:00
|
|
|
select HAS_HW_NRF_DPPIC
|
|
|
|
select HAS_HW_NRF_EGU0
|
|
|
|
select HAS_HW_NRF_EGU1
|
|
|
|
select HAS_HW_NRF_EGU2
|
|
|
|
select HAS_HW_NRF_EGU3
|
|
|
|
select HAS_HW_NRF_EGU4
|
|
|
|
select HAS_HW_NRF_EGU5
|
|
|
|
select HAS_HW_NRF_GPIO0
|
|
|
|
select HAS_HW_NRF_GPIO1
|
|
|
|
select HAS_HW_NRF_GPIOTE
|
|
|
|
select HAS_HW_NRF_I2S
|
|
|
|
select HAS_HW_NRF_IPC
|
2021-06-16 10:04:30 +02:00
|
|
|
select HAS_HW_NRF_KMU
|
2021-09-27 17:11:06 +02:00
|
|
|
select HAS_HW_NRF_LPCOMP
|
2021-11-09 17:58:49 +01:00
|
|
|
select HAS_HW_NRF_MUTEX
|
2019-12-16 12:09:57 +01:00
|
|
|
select HAS_HW_NRF_NFCT
|
2020-03-11 11:46:48 +01:00
|
|
|
select HAS_HW_NRF_NVMC_PE
|
2021-11-09 17:58:49 +01:00
|
|
|
select HAS_HW_NRF_OSCILLATORS
|
2019-08-01 20:47:31 +02:00
|
|
|
select HAS_HW_NRF_PDM
|
|
|
|
select HAS_HW_NRF_POWER
|
|
|
|
select HAS_HW_NRF_PWM0
|
|
|
|
select HAS_HW_NRF_PWM1
|
|
|
|
select HAS_HW_NRF_PWM2
|
2020-01-24 16:22:50 +01:00
|
|
|
select HAS_HW_NRF_PWM3
|
2021-02-12 15:44:06 +01:00
|
|
|
select HAS_HW_NRF_QDEC0
|
|
|
|
select HAS_HW_NRF_QDEC1
|
2020-10-21 08:45:15 +02:00
|
|
|
select HAS_HW_NRF_QSPI
|
2021-11-09 17:58:49 +01:00
|
|
|
select HAS_HW_NRF_REGULATORS
|
|
|
|
select HAS_HW_NRF_RESET
|
2019-08-01 20:47:31 +02:00
|
|
|
select HAS_HW_NRF_RTC0
|
|
|
|
select HAS_HW_NRF_RTC1
|
|
|
|
select HAS_HW_NRF_SAADC
|
|
|
|
select HAS_HW_NRF_SPIM0
|
|
|
|
select HAS_HW_NRF_SPIM1
|
|
|
|
select HAS_HW_NRF_SPIM2
|
2020-01-24 16:22:50 +01:00
|
|
|
select HAS_HW_NRF_SPIM3
|
|
|
|
select HAS_HW_NRF_SPIM4
|
2019-08-01 20:47:31 +02:00
|
|
|
select HAS_HW_NRF_SPIS0
|
|
|
|
select HAS_HW_NRF_SPIS1
|
2020-01-24 16:22:50 +01:00
|
|
|
select HAS_HW_NRF_SPIS2
|
|
|
|
select HAS_HW_NRF_SPIS3
|
2019-08-01 20:47:31 +02:00
|
|
|
select HAS_HW_NRF_SPU
|
|
|
|
select HAS_HW_NRF_TIMER0
|
|
|
|
select HAS_HW_NRF_TIMER1
|
|
|
|
select HAS_HW_NRF_TIMER2
|
|
|
|
select HAS_HW_NRF_TWIM0
|
|
|
|
select HAS_HW_NRF_TWIM1
|
2020-01-24 16:22:50 +01:00
|
|
|
select HAS_HW_NRF_TWIM2
|
|
|
|
select HAS_HW_NRF_TWIM3
|
2019-08-01 20:47:31 +02:00
|
|
|
select HAS_HW_NRF_TWIS0
|
|
|
|
select HAS_HW_NRF_TWIS1
|
2020-01-24 16:22:50 +01:00
|
|
|
select HAS_HW_NRF_TWIS2
|
|
|
|
select HAS_HW_NRF_TWIS3
|
2019-08-01 20:47:31 +02:00
|
|
|
select HAS_HW_NRF_UARTE0
|
|
|
|
select HAS_HW_NRF_UARTE1
|
2020-01-24 16:22:50 +01:00
|
|
|
select HAS_HW_NRF_UARTE2
|
|
|
|
select HAS_HW_NRF_UARTE3
|
|
|
|
select HAS_HW_NRF_USBD
|
|
|
|
select HAS_HW_NRF_USBREG
|
2021-11-09 17:58:49 +01:00
|
|
|
select HAS_HW_NRF_VMC
|
2020-01-24 16:22:50 +01:00
|
|
|
select HAS_HW_NRF_WDT0
|
|
|
|
select HAS_HW_NRF_WDT1
|
2019-08-01 20:47:31 +02:00
|
|
|
|
2019-08-07 10:52:32 +02:00
|
|
|
config SOC_NRF5340_CPUNET
|
|
|
|
bool
|
2020-01-15 11:16:13 +01:00
|
|
|
select HAS_HW_NRF_ACL
|
2019-08-07 10:52:32 +02:00
|
|
|
select HAS_HW_NRF_CLOCK
|
2020-09-15 16:45:38 +02:00
|
|
|
select HAS_HW_NRF_CCM
|
|
|
|
select HAS_HW_NRF_CCM_LFLEN_8BIT
|
2019-08-07 10:52:32 +02:00
|
|
|
select HAS_HW_NRF_DPPIC
|
2021-09-27 17:11:06 +02:00
|
|
|
select HAS_HW_NRF_ECB
|
2019-08-07 10:52:32 +02:00
|
|
|
select HAS_HW_NRF_EGU0
|
|
|
|
select HAS_HW_NRF_GPIO0
|
|
|
|
select HAS_HW_NRF_GPIO1
|
|
|
|
select HAS_HW_NRF_GPIOTE
|
|
|
|
select HAS_HW_NRF_IPC
|
2020-03-11 11:46:48 +01:00
|
|
|
select HAS_HW_NRF_NVMC_PE
|
2019-08-07 10:52:32 +02:00
|
|
|
select HAS_HW_NRF_POWER
|
2020-09-15 16:45:38 +02:00
|
|
|
select HAS_HW_NRF_RADIO_BLE_2M
|
2019-08-07 10:52:32 +02:00
|
|
|
select HAS_HW_NRF_RADIO_BLE_CODED
|
|
|
|
select HAS_HW_NRF_RADIO_IEEE802154
|
|
|
|
select HAS_HW_NRF_RNG
|
|
|
|
select HAS_HW_NRF_RTC0
|
|
|
|
select HAS_HW_NRF_RTC1
|
|
|
|
select HAS_HW_NRF_SPIM0
|
|
|
|
select HAS_HW_NRF_SPIS0
|
2021-09-27 17:11:06 +02:00
|
|
|
select HAS_HW_NRF_SWI0
|
|
|
|
select HAS_HW_NRF_SWI1
|
|
|
|
select HAS_HW_NRF_SWI2
|
|
|
|
select HAS_HW_NRF_SWI3
|
2019-08-07 10:52:32 +02:00
|
|
|
select HAS_HW_NRF_TEMP
|
|
|
|
select HAS_HW_NRF_TIMER0
|
|
|
|
select HAS_HW_NRF_TIMER1
|
|
|
|
select HAS_HW_NRF_TIMER2
|
|
|
|
select HAS_HW_NRF_TWIM0
|
|
|
|
select HAS_HW_NRF_TWIS0
|
|
|
|
select HAS_HW_NRF_UARTE0
|
|
|
|
select HAS_HW_NRF_WDT
|
2021-10-27 13:47:57 +02:00
|
|
|
select HAS_NO_PM
|
2019-08-07 10:52:32 +02:00
|
|
|
|
2019-08-01 20:47:31 +02:00
|
|
|
choice
|
|
|
|
prompt "nRF53x MCU Selection"
|
|
|
|
|
|
|
|
config SOC_NRF5340_CPUAPP_QKAA
|
|
|
|
bool "NRF5340_CPUAPP_QKAA"
|
|
|
|
select SOC_NRF5340_CPUAPP
|
|
|
|
|
2019-08-07 10:52:32 +02:00
|
|
|
config SOC_NRF5340_CPUNET_QKAA
|
|
|
|
bool "NRF5340_CPUNET_QKAA"
|
|
|
|
select SOC_NRF5340_CPUNET
|
|
|
|
|
2019-08-01 20:47:31 +02:00
|
|
|
endchoice
|
|
|
|
|
2019-11-12 07:09:42 +01:00
|
|
|
|
|
|
|
if SOC_NRF5340_CPUAPP
|
|
|
|
|
|
|
|
config SOC_DCDC_NRF53X_APP
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
Enable nRF53 series System on Chip Application MCU DC/DC converter.
|
|
|
|
|
|
|
|
config SOC_DCDC_NRF53X_NET
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
Enable nRF53 series System on Chip Network MCU DC/DC converter.
|
|
|
|
|
|
|
|
config SOC_DCDC_NRF53X_HV
|
|
|
|
bool
|
|
|
|
help
|
|
|
|
Enable nRF53 series System on Chip High Voltage DC/DC converter.
|
|
|
|
|
2021-06-02 10:24:19 +02:00
|
|
|
if !TRUSTED_EXECUTION_NONSECURE
|
|
|
|
|
2020-11-10 15:51:40 +01:00
|
|
|
config SOC_ENABLE_LFXO
|
|
|
|
bool "Enable LFXO"
|
|
|
|
default y
|
|
|
|
help
|
|
|
|
Enable the low-frequency oscillator (LFXO) functionality on XL1 and
|
|
|
|
XL2 pins.
|
|
|
|
This option must be enabled if either application or network core is
|
|
|
|
to use the LFXO. Otherwise, XL1 and XL2 pins will behave as regular
|
|
|
|
GPIOs.
|
|
|
|
|
2021-06-02 10:24:19 +02:00
|
|
|
choice SOC_LFXO_LOAD_CAPACITANCE
|
|
|
|
prompt "LFXO load capacitance"
|
|
|
|
depends on SOC_ENABLE_LFXO
|
2021-06-04 15:52:42 +02:00
|
|
|
default SOC_LFXO_CAP_INT_7PF
|
2021-06-02 10:24:19 +02:00
|
|
|
|
|
|
|
config SOC_LFXO_CAP_EXTERNAL
|
|
|
|
bool "Use external load capacitors"
|
|
|
|
|
|
|
|
config SOC_LFXO_CAP_INT_6PF
|
|
|
|
bool "6 pF internal load capacitance"
|
|
|
|
|
|
|
|
config SOC_LFXO_CAP_INT_7PF
|
|
|
|
bool "7 pF internal load capacitance"
|
|
|
|
|
|
|
|
config SOC_LFXO_CAP_INT_9PF
|
|
|
|
bool "9 pF internal load capacitance"
|
|
|
|
|
|
|
|
endchoice
|
|
|
|
|
|
|
|
choice SOC_HFXO_LOAD_CAPACITANCE
|
|
|
|
prompt "HFXO load capacitance"
|
2021-06-16 13:32:05 +02:00
|
|
|
default SOC_HFXO_CAP_DEFAULT
|
|
|
|
|
|
|
|
config SOC_HFXO_CAP_DEFAULT
|
|
|
|
bool "SoC default"
|
|
|
|
help
|
|
|
|
When this option is used, the SoC initialization routine does not
|
|
|
|
touch the XOSC32MCAPS register value, so the default setting for
|
|
|
|
the SoC is in effect. Please note that this may not necessarily be
|
|
|
|
the reset value (0) for the register, as the register can be set
|
|
|
|
during the device trimming in the SystemInit() function.
|
2021-06-02 10:24:19 +02:00
|
|
|
|
|
|
|
config SOC_HFXO_CAP_EXTERNAL
|
|
|
|
bool "Use external load capacitors"
|
|
|
|
|
|
|
|
config SOC_HFXO_CAP_INTERNAL
|
|
|
|
bool "Use internal load capacitors"
|
|
|
|
|
|
|
|
endchoice
|
|
|
|
|
|
|
|
config SOC_HFXO_CAP_INT_VALUE_X2
|
|
|
|
int "Doubled value of HFXO internal load capacitors (in pF)"
|
|
|
|
depends on SOC_HFXO_CAP_INTERNAL
|
|
|
|
range 14 40
|
|
|
|
help
|
|
|
|
Internal capacitors ranging from 7.0 pF to 20.0 pF in 0.5 pF steps
|
|
|
|
can be enabled on pins XC1 and XC2. This option specifies doubled
|
|
|
|
capacitance value for the two capacitors. Set it to 14 to get 7.0 pF
|
|
|
|
for each capacitor, 15 to get 7.5 pF, and so on.
|
|
|
|
|
|
|
|
endif # !TRUSTED_EXECUTION_NONSECURE
|
|
|
|
|
2019-11-12 07:09:42 +01:00
|
|
|
endif # SOC_NRF5340_CPUAPP
|
|
|
|
|
|
|
|
|
2019-08-01 20:47:31 +02:00
|
|
|
config NRF_ENABLE_CACHE
|
|
|
|
bool "Enable cache"
|
2019-08-07 10:52:32 +02:00
|
|
|
depends on (SOC_NRF5340_CPUAPP && !TRUSTED_EXECUTION_NONSECURE) \
|
|
|
|
|| SOC_NRF5340_CPUNET
|
2019-08-01 20:47:31 +02:00
|
|
|
default y
|
|
|
|
help
|
|
|
|
Instruction and Data cache is available on nRF5340 CPUAPP
|
|
|
|
(Application MCU). It may only be accessed by Secure code.
|
|
|
|
|
|
|
|
Instruction cache only (I-Cache) is available in nRF5340
|
|
|
|
CPUNET (Network MCU).
|
2021-09-14 13:11:52 +02:00
|
|
|
|
2021-09-09 15:44:14 +02:00
|
|
|
config NRF53_SYNC_RTC
|
|
|
|
bool "Enable RTC clock synchronization"
|
|
|
|
default y if LOG && !LOG_MODE_MINIMAL
|
|
|
|
depends on NRF_RTC_TIMER
|
|
|
|
select NRFX_DPPI
|
|
|
|
select IPM if !MBOX
|
|
|
|
|
|
|
|
if NRF53_SYNC_RTC
|
|
|
|
|
|
|
|
module = SYNC_RTC
|
|
|
|
module-str = Synchronized RTC
|
|
|
|
source "subsys/logging/Kconfig.template.log_config"
|
|
|
|
|
|
|
|
config NRF_RTC_TIMER_USER_CHAN_COUNT
|
|
|
|
default 1
|
|
|
|
|
|
|
|
config NRF53_SYNC_RTC_LOG_TIMESTAMP
|
|
|
|
bool "Use Synchronized RTC for logging timestamp"
|
|
|
|
default y
|
|
|
|
|
|
|
|
config NRF53_SYNC_RTC_IPM_OUT
|
|
|
|
int "IPM channel from APP to NET"
|
|
|
|
range 0 15
|
|
|
|
default 7 if SOC_NRF5340_CPUAPP
|
|
|
|
default 8
|
|
|
|
|
|
|
|
config NRF53_SYNC_RTC_IPM_IN
|
|
|
|
int "IPM channel from APP to NET"
|
|
|
|
range 0 15
|
|
|
|
default 8 if SOC_NRF5340_CPUAPP
|
|
|
|
default 7
|
|
|
|
|
|
|
|
ipm_num = 0
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 1
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 2
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 3
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 4
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 5
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 6
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 7
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 8
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 9
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 10
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 11
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 12
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 13
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 14
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
ipm_num = 15
|
|
|
|
rsource "Kconfig.sync_rtc_ipm"
|
|
|
|
|
|
|
|
endif # NRF53_SYNC_RTC
|
|
|
|
endif # SOC_SERIES_NRF53X
|