1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/cpu/rpx0xx/cpu.c
Marian Buschsieweke ea56dfc3ff
cpu/rpx0xx: add support for the RP2040 MCU
Co-authored-by: Fabian Hüßler <fabian.huessler@st.ovgu.de>
2021-07-14 12:41:20 +02:00

97 lines
3.1 KiB
C

/*
* Copyright (C) 2021 Otto-von-Guericke Universität Magdeburg
*
* 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_rpx0xx
* @{
*
* @file
* @brief Implementation of the CPU initialization
*
* @author Fabian Hüßler <fabian.huessler@ovgu.de>
*
* @}
*/
#include "cpu.h"
#include "macros/units.h"
#include "periph/init.h"
#include "periph_cpu.h"
#include "io_reg.h"
#include "stdio_base.h"
#include "vendor/RP2040.h"
#define ENABLE_DEBUG 0
#include "debug.h"
static void _cpu_reset(void)
{
/* 2.14 subsystem resets */
uint32_t rst;
/* Reset hardware components except for critical ones */
rst = RESETS_RESET_MASK
& ~(RESETS_RESET_usbctrl_Msk
| RESETS_RESET_syscfg_Msk
| RESETS_RESET_pll_usb_Msk
| RESETS_RESET_pll_sys_Msk
| RESETS_RESET_pads_qspi_Msk
| RESETS_RESET_io_qspi_Msk);
periph_reset(rst);
/* Assert that reset has completed except for those components which
are not clocked by clk_ref or clk_sys */
rst = RESETS_RESET_MASK
& ~(RESETS_RESET_usbctrl_Msk
| RESETS_RESET_uart1_Msk
| RESETS_RESET_uart0_Msk
| RESETS_RESET_spi1_Msk
| RESETS_RESET_spi0_Msk
| RESETS_RESET_rtc_Msk
| RESETS_RESET_adc_Msk);
periph_reset_done(rst);
/* power the reference clock from its default source: the ROSC */
clock_ref_configure_source(MHZ(12), MHZ(12), CLOCKS_CLK_REF_CTRL_SRC_rosc_clksrc_ph);
/* power the system clock from its default source: the reference clock */
clock_sys_configure_source(MHZ(12), MHZ(12), CLOCKS_CLK_SYS_CTRL_SRC_clk_ref);
/* start XOSC, typically running at 12 MHz */
xosc_start(CLOCK_XOSC);
/* reset system PLL */
pll_reset_sys();
/* start the system PLL (typically takes the 12 MHz XOSC to generate 125 MHz) */
pll_start_sys(PLL_SYS_REF_DIV, PLL_SYS_VCO_FEEDBACK_SCALE, PLL_SYS_POSTDIV1, PLL_SYS_POSTDIV2);
/* configure reference clock to run from XOSC (typically 12 MHz) */
clock_ref_configure_source(CLOCK_XOSC, CLOCK_XOSC,
CLOCKS_CLK_REF_CTRL_SRC_xosc_clksrc);
/* configure system clock output */
clock_sys_configure_aux_source(CLOCK_CORECLOCK, CLOCK_CORECLOCK,
CLOCKS_CLK_SYS_CTRL_AUXSRC_clksrc_pll_sys);
/* configure the peripheral clock to run from the system clock */
clock_periph_configure(CLOCK_PERIPH_SOURCE);
if (IS_USED(ENABLE_DEBUG)) {
/* check clk_ref with logic analyzer */
clock_gpout0_configure(CLOCK_XOSC, CLOCK_XOSC,
CLOCKS_CLK_GPOUT0_CTRL_AUXSRC_clk_ref);
}
}
void cpu_init(void)
{
/* initialize the Cortex-M core */
cortexm_init();
_cpu_reset();
/* initialize stdio prior to periph_init() to allow use of DEBUG() there */
stdio_init();
DEBUG_PUTS("[rpx0xx] GPOUT0 (GPIO pin 21) is clocked from XOSC (typically 12 MHz)");
/* trigger static peripheral initialization */
periph_init();
}