1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-17 22:32:44 +01:00
RIOT/cpu/nrf9160/cpu.c

58 lines
1.2 KiB
C
Raw Normal View History

2021-07-14 18:19:27 +02:00
/*
* Copyright (C) 2021 Mesotic SAS
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @ingroup cpu_nrf9160
* @{
*
* @file
* @brief Implementation of the CPU initialization
*
* @author Dylan Laduranty <dylan.laduranty@mesotic.com>
*
* @}
*/
#include "cpu.h"
2023-01-02 18:08:35 +01:00
#include "kernel_init.h"
2021-07-14 18:19:27 +02:00
#include "nrf_clock.h"
#include "periph_conf.h"
#include "periph/init.h"
#include "stdio_base.h"
/**
* @brief LFCLK Clock selection configuration guard
*/
#if ((CLOCK_LFCLK != CLOCK_LFCLKSRC_SRC_LFRC) && \
(CLOCK_LFCLK != CLOCK_LFCLKSRC_SRC_LFXO))
#error "LFCLK init: CLOCK_LFCLK has invalid value"
#endif
2021-07-14 18:19:27 +02:00
/**
* @brief Initialize the CPU, set IRQ priorities
*/
void cpu_init(void)
{
/* initialize hf clock */
clock_init_hf();
#ifdef NVMC_ICACHECNF_CACHEEN_Msk
/* enable instruction cache */
NRF_NVMC_S->ICACHECNF = (NVMC_ICACHECNF_CACHEEN_Msk);
#endif
/* call cortexm default initialization */
cortexm_init();
/* initialize stdio prior to periph_init() to allow use of DEBUG() there */
2023-01-02 18:08:35 +01:00
early_init();
2021-07-14 18:19:27 +02:00
/* trigger static peripheral initialization */
periph_init();
}