1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

cpu/samd21: avoid the use of bitfield

Signed-off-by: Dylan Laduranty <dylan.laduranty@mesotic.com>
This commit is contained in:
Dylan Laduranty 2024-05-30 12:01:24 +02:00
parent 251ea7f75a
commit 16f6a4bb93

View File

@ -130,10 +130,8 @@ static void clk_init(void)
#if CLOCK_8MHZ #if CLOCK_8MHZ
/* configure internal 8MHz oscillator to run without prescaler */ /* configure internal 8MHz oscillator to run without prescaler */
SYSCTRL->OSC8M.bit.PRESC = 0; SYSCTRL->OSC8M.reg &= ~(SYSCTRL_OSC8M_PRESC_Msk);
SYSCTRL->OSC8M.bit.ONDEMAND = 1; SYSCTRL->OSC8M.reg |= (SYSCTRL_OSC8M_ONDEMAND | SYSCTRL_OSC8M_ENABLE);
SYSCTRL->OSC8M.bit.RUNSTDBY = 0;
SYSCTRL->OSC8M.bit.ENABLE = 1;
while (!(SYSCTRL->PCLKSR.reg & SYSCTRL_PCLKSR_OSC8MRDY)) {} while (!(SYSCTRL->PCLKSR.reg & SYSCTRL_PCLKSR_OSC8MRDY)) {}
#endif #endif
@ -144,7 +142,7 @@ static void clk_init(void)
SYSCTRL_XOSC32K_STARTUP(XOSC32_STARTUP_TIME) | SYSCTRL_XOSC32K_STARTUP(XOSC32_STARTUP_TIME) |
SYSCTRL_XOSC32K_RUNSTDBY; SYSCTRL_XOSC32K_RUNSTDBY;
/* Enable XOSC32 with Separate Call */ /* Enable XOSC32 with Separate Call */
SYSCTRL->XOSC32K.bit.ENABLE = 1; SYSCTRL->XOSC32K.reg |= SYSCTRL_XOSC32K_ENABLE;
#endif #endif
/* reset the GCLK module so it is in a known state */ /* reset the GCLK module so it is in a known state */
@ -202,7 +200,7 @@ static void clk_init(void)
while (GCLK->STATUS.reg & GCLK_STATUS_SYNCBUSY) {} while (GCLK->STATUS.reg & GCLK_STATUS_SYNCBUSY) {}
/* Disable ONDEMAND mode while writing configurations */ /* Disable ONDEMAND mode while writing configurations */
SYSCTRL->DFLLCTRL.bit.ONDEMAND = 0; SYSCTRL->DFLLCTRL.reg &= ~(SYSCTRL_DFLLCTRL_ONDEMAND);
while ((SYSCTRL->PCLKSR.reg & SYSCTRL_PCLKSR_DFLLRDY) == 0) { while ((SYSCTRL->PCLKSR.reg & SYSCTRL_PCLKSR_DFLLRDY) == 0) {
/* Wait for DFLL sync */ /* Wait for DFLL sync */
} }
@ -221,7 +219,7 @@ static void clk_init(void)
/* Wait for DFLL sync */ /* Wait for DFLL sync */
} }
SYSCTRL->DFLLCTRL.bit.ENABLE = 1; SYSCTRL->DFLLCTRL.reg |= SYSCTRL_DFLLCTRL_ENABLE;
uint32_t mask = SYSCTRL_PCLKSR_DFLLRDY | uint32_t mask = SYSCTRL_PCLKSR_DFLLRDY |
SYSCTRL_PCLKSR_DFLLLCKF | SYSCTRL_PCLKSR_DFLLLCKF |
SYSCTRL_PCLKSR_DFLLLCKC; SYSCTRL_PCLKSR_DFLLLCKC;
@ -237,7 +235,7 @@ static void clk_init(void)
| GCLK_CLKCTRL_GEN(SAM0_GCLK_MAIN); | GCLK_CLKCTRL_GEN(SAM0_GCLK_MAIN);
while (GCLK->STATUS.reg & GCLK_STATUS_SYNCBUSY) {} while (GCLK->STATUS.reg & GCLK_STATUS_SYNCBUSY) {}
SYSCTRL->DFLLCTRL.bit.ONDEMAND = 1; SYSCTRL->DFLLCTRL.reg |= SYSCTRL_DFLLCTRL_ONDEMAND;
while ((SYSCTRL->PCLKSR.reg & SYSCTRL_PCLKSR_DFLLRDY) == 0) { while ((SYSCTRL->PCLKSR.reg & SYSCTRL_PCLKSR_DFLLRDY) == 0) {
/* Wait for DFLL sync */ /* Wait for DFLL sync */
} }
@ -265,14 +263,14 @@ static void clk_init(void)
/* redirect all peripherals to a disabled clock generator (7) by default */ /* redirect all peripherals to a disabled clock generator (7) by default */
for (unsigned i = 0x3; i <= GCLK_CLKCTRL_ID_Msk; i++) { for (unsigned i = 0x3; i <= GCLK_CLKCTRL_ID_Msk; i++) {
GCLK->CLKCTRL.reg = GCLK_CLKCTRL_ID(i) | GCLK_CLKCTRL_GEN(SAM0_GCLK_DISABLED); GCLK->CLKCTRL.reg = GCLK_CLKCTRL_ID(i) | GCLK_CLKCTRL_GEN(SAM0_GCLK_DISABLED);
while (GCLK->STATUS.bit.SYNCBUSY) {} while (GCLK->STATUS.reg & GCLK_STATUS_SYNCBUSY) {}
} }
} }
void cpu_init(void) void cpu_init(void)
{ {
/* disable the watchdog timer */ /* disable the watchdog timer */
WDT->CTRL.bit.ENABLE = 0; WDT->CTRL.reg = 0;
/* initialize the Cortex-M core */ /* initialize the Cortex-M core */
cortexm_init(); cortexm_init();
/* Initialise clock sources and generic clocks */ /* Initialise clock sources and generic clocks */