9c961571a2
The CMSIS module glue code was part of arch/ directory. Move it to modules/cmsis, and provide a single entry point for it: cmsis_core.h. This entry header will include the right CMSIS header (M or A/R). To make this change possible, CMSIS module Kconfig/CMake are declared as external, allowing us to add a new Zephyr include directory. All files including CMSIS have been updated. Signed-off-by: Gerard Marull-Paretas <gerard.marull@nordicsemi.no>
72 lines
1.5 KiB
C
72 lines
1.5 KiB
C
/*
|
|
* Copyright (c) 2020 Antmicro <www.antmicro.com>
|
|
*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
#include <zephyr/kernel.h>
|
|
#include <zephyr/init.h>
|
|
#include <soc.h>
|
|
#include <soc_pinmap.h>
|
|
#include <cmsis_core.h>
|
|
|
|
void eos_s3_lock_enable(void)
|
|
{
|
|
MISC_CTRL->LOCK_KEY_CTRL = MISC_LOCK_KEY;
|
|
}
|
|
|
|
void eos_s3_lock_disable(void)
|
|
{
|
|
MISC_CTRL->LOCK_KEY_CTRL = 1;
|
|
}
|
|
|
|
static void eos_s3_cru_init(void)
|
|
{
|
|
/* Set desired frequency */
|
|
AIP->OSC_CTRL_0 |= AIP_OSC_CTRL_EN;
|
|
AIP->OSC_CTRL_0 &= ~AIP_OSC_CTRL_FRE_SEL;
|
|
OSC_SET_FREQ_INC(CONFIG_SYS_CLOCK_HW_CYCLES_PER_SEC);
|
|
|
|
while (!OSC_CLK_LOCKED()) {
|
|
;
|
|
}
|
|
|
|
/* Enable all clocks for every domain */
|
|
CRU->CLK_DIVIDER_CLK_GATING = (CLK_DIVIDER_A_CG | CLK_DIVIDER_B_CG
|
|
| CLK_DIVIDER_C_CG | CLK_DIVIDER_D_CG | CLK_DIVIDER_F_CG
|
|
| CLK_DIVIDER_G_CG | CLK_DIVIDER_H_CG | CLK_DIVIDER_I_CG
|
|
| CLK_DIVIDER_J_CG);
|
|
|
|
/* Turn off divisor for A0 domain */
|
|
CRU->CLK_CTRL_A_0 = 0;
|
|
|
|
/* Enable UART, WDT and TIMER peripherals */
|
|
CRU->C11_CLK_GATE = C11_CLK_GATE_PATH_0_ON;
|
|
|
|
/* Set divider for domain C11 to ~ 5.12MHz */
|
|
CRU->CLK_CTRL_D_0 = (CLK_CTRL_CLK_DIVIDER_ENABLE |
|
|
CLK_CTRL_CLK_DIVIDER_RATIO_12);
|
|
}
|
|
|
|
|
|
|
|
static int eos_s3_init(void)
|
|
{
|
|
/* Clocks setup */
|
|
eos_s3_lock_enable();
|
|
eos_s3_cru_init();
|
|
eos_s3_lock_disable();
|
|
|
|
SCnSCB->ACTLR |= SCnSCB_ACTLR_DISDEFWBUF_Msk;
|
|
|
|
/* Clear all interrupts */
|
|
INTR_CTRL->OTHER_INTR = 0xFFFFFF;
|
|
|
|
/* Enable UART interrupt */
|
|
INTR_CTRL->OTHER_INTR_EN_M4 = UART_INTR_EN_M4;
|
|
|
|
return 0;
|
|
}
|
|
|
|
SYS_INIT(eos_s3_init, PRE_KERNEL_1, 0);
|