/* * Copyright (c) 2016 Nordic Semiconductor ASA * * SPDX-License-Identifier: Apache-2.0 */ /** * @file * @brief System/hardware module for Nordic Semiconductor nRF52 family processor * * This module provides routines to initialize and support board-level hardware * for the Nordic Semiconductor nRF52 family processor. */ #include #include #include #include #include #include #ifdef CONFIG_RUNTIME_NMI extern void z_arm_nmi_init(void); #define NMI_INIT() z_arm_nmi_init() #else #define NMI_INIT() #endif #if defined(CONFIG_SOC_NRF52805) #include #elif defined(CONFIG_SOC_NRF52810) #include #elif defined(CONFIG_SOC_NRF52811) #include #elif defined(CONFIG_SOC_NRF52820) #include #elif defined(CONFIG_SOC_NRF52832) #include #elif defined(CONFIG_SOC_NRF52833) #include #elif defined(CONFIG_SOC_NRF52840) #include #else #error "Unknown SoC." #endif #define LOG_LEVEL CONFIG_SOC_LOG_LEVEL LOG_MODULE_REGISTER(soc); /* Overrides the weak ARM implementation: Set general purpose retention register and reboot */ void sys_arch_reboot(int type) { nrf_power_gpregret_set(NRF_POWER, (uint8_t)type); NVIC_SystemReset(); } static int nordicsemi_nrf52_init(const struct device *arg) { uint32_t key; ARG_UNUSED(arg); key = irq_lock(); #ifdef CONFIG_NRF_ENABLE_ICACHE /* Enable the instruction cache */ NRF_NVMC->ICACHECNF = NVMC_ICACHECNF_CACHEEN_Msk; #endif #if defined(CONFIG_SOC_DCDC_NRF52X) nrf_power_dcdcen_set(NRF_POWER, true); #endif /* Install default handler that simply resets the CPU * if configured in the kernel, NOP otherwise */ NMI_INIT(); irq_unlock(key); return 0; } void arch_busy_wait(uint32_t time_us) { nrfx_coredep_delay_us(time_us); } SYS_INIT(nordicsemi_nrf52_init, PRE_KERNEL_1, 0);