/* * Copyright (c) 2023 Nuvoton Technology Corporation. * * SPDX-License-Identifier: Apache-2.0 */ #include #include /* Hardware and starter kit includes. */ #include void soc_reset_hook(void) { SystemInit(); /* Unlock protected registers */ SYS_UnlockReg(); /* Release I/O hold status */ CLK->IOPDCTL = 1; /* * ------------------- * Init System Clock * ------------------- */ #if DT_NODE_HAS_PROP(DT_NODELABEL(scc), hxt) /* Enable/disable 4~24 MHz external crystal oscillator (HXT) */ if (DT_ENUM_IDX(DT_NODELABEL(scc), hxt) == NUMAKER_SCC_CLKSW_ENABLE) { CLK_EnableXtalRC(CLK_PWRCTL_HXTEN_Msk); /* Wait for HXT clock ready */ CLK_WaitClockReady(CLK_STATUS_HXTSTB_Msk); } else if (DT_ENUM_IDX(DT_NODELABEL(scc), hxt) == NUMAKER_SCC_CLKSW_DISABLE) { CLK_DisableXtalRC(CLK_PWRCTL_HXTEN_Msk); } #endif #if DT_NODE_HAS_PROP(DT_NODELABEL(scc), lxt) /* Enable/disable 32.768 kHz low-speed external crystal oscillator (LXT) */ if (DT_ENUM_IDX(DT_NODELABEL(scc), lxt) == NUMAKER_SCC_CLKSW_ENABLE) { CLK_EnableXtalRC(CLK_PWRCTL_LXTEN_Msk); /* Wait for LXT clock ready */ CLK_WaitClockReady(CLK_STATUS_LXTSTB_Msk); } else if (DT_ENUM_IDX(DT_NODELABEL(scc), lxt) == NUMAKER_SCC_CLKSW_DISABLE) { CLK_DisableXtalRC(CLK_PWRCTL_LXTEN_Msk); } #endif /* Enable 12 MHz high-speed internal RC oscillator (HIRC) */ CLK_EnableXtalRC(CLK_PWRCTL_HIRCEN_Msk); /* Wait for HIRC clock ready */ CLK_WaitClockReady(CLK_STATUS_HIRCSTB_Msk); /* Enable 10 KHz low-speed internal RC oscillator (LIRC) */ CLK_EnableXtalRC(CLK_PWRCTL_LIRCEN_Msk); /* Wait for LIRC clock ready */ CLK_WaitClockReady(CLK_STATUS_LIRCSTB_Msk); #if DT_NODE_HAS_PROP(DT_NODELABEL(scc), hirc48m) /* Enable/disable 48 MHz high-speed internal RC oscillator (HIRC48M) */ if (DT_ENUM_IDX(DT_NODELABEL(scc), hirc48m) == NUMAKER_SCC_CLKSW_ENABLE) { CLK_EnableXtalRC(CLK_PWRCTL_HIRC48MEN_Msk); /* Wait for HIRC48M clock ready */ CLK_WaitClockReady(CLK_STATUS_HIRC48MSTB_Msk); } else if (DT_ENUM_IDX(DT_NODELABEL(scc), hirc48m) == NUMAKER_SCC_CLKSW_DISABLE) { CLK_DisableXtalRC(CLK_PWRCTL_HIRC48MEN_Msk); } #endif #if DT_NODE_HAS_PROP(DT_NODELABEL(scc), clk_pclkdiv) /* Set CLK_PCLKDIV register on request */ CLK->PCLKDIV = DT_PROP(DT_NODELABEL(scc), clk_pclkdiv); #endif #if DT_NODE_HAS_PROP(DT_NODELABEL(scc), core_clock) /* Set core clock (HCLK) on request */ CLK_SetCoreClock(DT_PROP(DT_NODELABEL(scc), core_clock)); #endif /* * Update System Core Clock * User can use SystemCoreClockUpdate() to calculate SystemCoreClock. */ SystemCoreClockUpdate(); /* Lock protected registers */ SYS_LockReg(); }