2021-06-01 21:31:30 +02:00
|
|
|
/*
|
|
|
|
* 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"
|
2023-01-02 18:08:35 +01:00
|
|
|
#include "kernel_init.h"
|
2021-06-01 21:31:30 +02:00
|
|
|
#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
|
2023-04-25 21:06:34 +02:00
|
|
|
| RESETS_RESET_pads_bank0_Msk
|
2021-06-01 21:31:30 +02:00
|
|
|
| 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);
|
|
|
|
}
|
2023-04-25 21:06:34 +02:00
|
|
|
|
|
|
|
/* Configure USB PLL to deliver 48MHz needed by ADC */
|
|
|
|
if (IS_USED(MODULE_PERIPH_ADC)) {
|
|
|
|
pll_start_usb(PLL_USB_REF_DIV, PLL_USB_VCO_FEEDBACK_SCALE,
|
|
|
|
PLL_USB_POSTDIV1, PLL_USB_POSTDIV2);
|
|
|
|
clock_adc_configure(CLOCKS_CLK_ADC_CTRL_AUXSRC_clksrc_pll_usb);
|
|
|
|
}
|
2021-06-01 21:31:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
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 */
|
2023-01-02 18:08:35 +01:00
|
|
|
early_init();
|
2021-06-01 21:31:30 +02:00
|
|
|
|
|
|
|
DEBUG_PUTS("[rpx0xx] GPOUT0 (GPIO pin 21) is clocked from XOSC (typically 12 MHz)");
|
|
|
|
|
|
|
|
/* trigger static peripheral initialization */
|
|
|
|
periph_init();
|
|
|
|
}
|