1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 11:32:45 +01:00
RIOT/cpu/kinetis/cpu.c

53 lines
1.2 KiB
C
Raw Normal View History

/*
* Copyright (C) 2017 SKF AB
*
* 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_kinetis
* @{
*
* @file
* @brief Kinetis CPU initialization
*
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
* @}
*/
#include "cpu.h"
2023-01-02 18:08:35 +01:00
#include "kernel_init.h"
#include "periph/init.h"
#include "stdio_base.h"
2018-06-30 19:12:47 +02:00
#ifdef MODULE_PERIPH_MCG
#include "mcg.h"
2018-06-30 19:12:47 +02:00
#endif
/**
* @brief Initialize the CPU, set IRQ priorities
*/
void cpu_init(void)
{
/* initialize the Cortex-M core */
cortexm_init();
#ifdef SMC
/* Clear LLS protection */
/* Clear VLPS, VLPW, VLPR protection */
/* Note: This register can only be written once after each reset, so we must
* enable all power modes that we wish to use. */
SMC->PMPROT |= SMC_PMPROT_ALLS_MASK | SMC_PMPROT_AVLP_MASK;
#endif
2018-06-30 19:12:47 +02:00
#ifdef MODULE_PERIPH_MCG
/* initialize the CPU clocking provided by the MCG module */
kinetis_mcg_init();
2018-06-30 19:12:47 +02:00
#endif
/* initialize stdio prior to periph_init() to allow use of DEBUG() there */
2023-01-02 18:08:35 +01:00
early_init();
/* trigger static peripheral initialization */
periph_init();
}