2017-05-01 11:46:37 +02:00
|
|
|
/*
|
2017-04-27 15:42:22 +02:00
|
|
|
* Copyright (C) 2017 SKF AB
|
2017-05-01 11:46:37 +02:00
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2017-10-27 01:26:26 +02:00
|
|
|
* @ingroup cpu_kinetis
|
2017-05-01 11:46:37 +02:00
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
2017-04-27 15:42:22 +02:00
|
|
|
* @brief Kinetis CPU initialization
|
2017-05-01 11:46:37 +02:00
|
|
|
*
|
|
|
|
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "cpu.h"
|
|
|
|
#include "periph/init.h"
|
2018-06-30 19:12:47 +02:00
|
|
|
#ifdef MODULE_PERIPH_MCG
|
2017-04-27 15:42:22 +02:00
|
|
|
#include "mcg.h"
|
2018-06-30 19:12:47 +02:00
|
|
|
#endif
|
2017-05-01 11:46:37 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize the CPU, set IRQ priorities
|
|
|
|
*/
|
|
|
|
void cpu_init(void)
|
|
|
|
{
|
|
|
|
/* initialize the Cortex-M core */
|
|
|
|
cortexm_init();
|
2018-07-31 18:08:07 +02:00
|
|
|
#ifdef SMC
|
2017-04-27 15:42:22 +02:00
|
|
|
/* 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;
|
2018-07-31 18:08:07 +02:00
|
|
|
#endif
|
2018-06-30 19:12:47 +02:00
|
|
|
#ifdef MODULE_PERIPH_MCG
|
2017-04-27 15:42:22 +02:00
|
|
|
/* initialize the CPU clocking provided by the MCG module */
|
|
|
|
kinetis_mcg_init();
|
2018-06-30 19:12:47 +02:00
|
|
|
#endif
|
2017-05-01 11:46:37 +02:00
|
|
|
/* trigger static peripheral initialization */
|
|
|
|
periph_init();
|
|
|
|
}
|