mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
cpu/samd5x/cpu.c: reformat code
This formats the code to improve readability and apply the coding convention. This is a whitespace only change that will not change generated binaries.
This commit is contained in:
parent
0cea359db6
commit
20e218680c
113
cpu/samd5x/cpu.c
113
cpu/samd5x/cpu.c
@ -24,75 +24,75 @@
|
|||||||
#include "macros/units.h"
|
#include "macros/units.h"
|
||||||
#include "periph_conf.h"
|
#include "periph_conf.h"
|
||||||
#include "periph/init.h"
|
#include "periph/init.h"
|
||||||
#include "stdio_base.h"
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* An external inductor needs to be present on the board,
|
* An external inductor needs to be present on the board,
|
||||||
* so the feature can only be enabled by the board configuration.
|
* so the feature can only be enabled by the board configuration.
|
||||||
*/
|
*/
|
||||||
#ifndef USE_VREG_BUCK
|
#ifndef USE_VREG_BUCK
|
||||||
#define USE_VREG_BUCK (0)
|
# define USE_VREG_BUCK (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if CLOCK_CORECLOCK == 0
|
#if CLOCK_CORECLOCK == 0
|
||||||
#error Please select CLOCK_CORECLOCK
|
# error Please select CLOCK_CORECLOCK
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if EXTERNAL_OSC32_SOURCE && ULTRA_LOW_POWER_INTERNAL_OSC_SOURCE
|
#if EXTERNAL_OSC32_SOURCE && ULTRA_LOW_POWER_INTERNAL_OSC_SOURCE
|
||||||
#error Select EITHER external 32kHz oscillator OR internal 32kHz Oscillator
|
# error Select EITHER external 32kHz oscillator OR internal 32kHz Oscillator
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef XOSC0_FREQUENCY
|
#ifndef XOSC0_FREQUENCY
|
||||||
#define XOSC0_FREQUENCY (0)
|
# define XOSC0_FREQUENCY (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef XOSC1_FREQUENCY
|
#ifndef XOSC1_FREQUENCY
|
||||||
#define XOSC1_FREQUENCY (0)
|
# define XOSC1_FREQUENCY (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define GCLK_SOURCE_ACTIVE_XOSC (XOSC0_FREQUENCY ? GCLK_SOURCE_XOSC0 : GCLK_SOURCE_XOSC1)
|
#define GCLK_SOURCE_ACTIVE_XOSC \
|
||||||
|
(XOSC0_FREQUENCY ? GCLK_SOURCE_XOSC0 : GCLK_SOURCE_XOSC1)
|
||||||
|
|
||||||
#if USE_XOSC_ONLY /* don't use fast internal oscillators */
|
#if USE_XOSC_ONLY /* don't use fast internal oscillators */
|
||||||
|
|
||||||
#if (XOSC0_FREQUENCY == 0) && (XOSC1_FREQUENCY == 0)
|
# if (XOSC0_FREQUENCY == 0) && (XOSC1_FREQUENCY == 0)
|
||||||
#error Configuration error: no external oscillator frequency defined
|
# error Configuration error: no external oscillator frequency defined
|
||||||
#endif
|
# endif
|
||||||
|
|
||||||
#if (CLOCK_CORECLOCK > SAM0_XOSC_FREQ_HZ)
|
# if (CLOCK_CORECLOCK > SAM0_XOSC_FREQ_HZ)
|
||||||
#error When using an external oscillator for the main clock, the CPU frequency can't exceed it's frequency.
|
# error When using an external oscillator for the main clock, the CPU frequency can't exceed it's frequency.
|
||||||
#endif
|
# endif
|
||||||
|
|
||||||
#define USE_DPLL 0
|
# define USE_DPLL 0
|
||||||
#define USE_DFLL 0
|
# define USE_DFLL 0
|
||||||
#define USE_XOSC 1
|
# define USE_XOSC 1
|
||||||
|
|
||||||
#ifndef GCLK_TIMER_HZ
|
# ifndef GCLK_TIMER_HZ
|
||||||
#define GCLK_TIMER_HZ MHZ(4)
|
# define GCLK_TIMER_HZ MHZ(4)
|
||||||
#endif
|
# endif
|
||||||
|
|
||||||
#else /* !USE_XOSC_ONLY */
|
#else /* !USE_XOSC_ONLY */
|
||||||
|
|
||||||
/* Main clock > 48 MHz -> use DPLL, otherwise use DFLL */
|
/* Main clock > 48 MHz -> use DPLL, otherwise use DFLL */
|
||||||
#define USE_DPLL (CLOCK_CORECLOCK > SAM0_DFLL_FREQ_HZ)
|
# define USE_DPLL (CLOCK_CORECLOCK > SAM0_DFLL_FREQ_HZ)
|
||||||
#define USE_DFLL 1
|
# define USE_DFLL 1
|
||||||
#define USE_XOSC 0
|
# define USE_XOSC 0
|
||||||
|
|
||||||
#ifndef GCLK_TIMER_HZ
|
# ifndef GCLK_TIMER_HZ
|
||||||
#define GCLK_TIMER_HZ MHZ(8)
|
# define GCLK_TIMER_HZ MHZ(8)
|
||||||
#endif
|
# endif
|
||||||
|
|
||||||
#endif /* USE_XOSC_ONLY */
|
#endif /* USE_XOSC_ONLY */
|
||||||
|
|
||||||
#if (CLOCK_CORECLOCK <= SAM0_DFLL_FREQ_HZ) && (SAM0_DFLL_FREQ_HZ % CLOCK_CORECLOCK)
|
#if (CLOCK_CORECLOCK <= SAM0_DFLL_FREQ_HZ) && (SAM0_DFLL_FREQ_HZ % CLOCK_CORECLOCK)
|
||||||
#error For frequencies <= 48 MHz, CLOCK_CORECLOCK must be a divider of 48 MHz
|
# error For frequencies <= 48 MHz, CLOCK_CORECLOCK must be a divider of 48 MHz
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* If the CPU clock is lower than the minimal DPLL Freq
|
/* If the CPU clock is lower than the minimal DPLL Freq
|
||||||
set fDPLL = 2 * CLOCK_CORECLOCK */
|
set fDPLL = 2 * CLOCK_CORECLOCK */
|
||||||
#if USE_DPLL && (CLOCK_CORECLOCK < SAM0_DPLL_FREQ_MIN_HZ)
|
#if USE_DPLL && (CLOCK_CORECLOCK < SAM0_DPLL_FREQ_MIN_HZ)
|
||||||
#define DPLL_DIV 2
|
# define DPLL_DIV 2
|
||||||
#else
|
#else
|
||||||
#define DPLL_DIV 1
|
# define DPLL_DIV 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static void xosc32k_init(void)
|
static void xosc32k_init(void)
|
||||||
@ -117,8 +117,8 @@ static void xosc_init(uint8_t idx)
|
|||||||
uint32_t freq;
|
uint32_t freq;
|
||||||
|
|
||||||
if (!USE_XOSC ||
|
if (!USE_XOSC ||
|
||||||
(idx == 0 && XOSC0_FREQUENCY == 0) ||
|
(idx == 0 && XOSC0_FREQUENCY == 0) ||
|
||||||
(idx == 1 && XOSC1_FREQUENCY == 0)) {
|
(idx == 1 && XOSC1_FREQUENCY == 0)) {
|
||||||
OSCCTRL->XOSCCTRL[idx].reg = 0;
|
OSCCTRL->XOSCCTRL[idx].reg = 0;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -127,7 +127,8 @@ static void xosc_init(uint8_t idx)
|
|||||||
|
|
||||||
if (idx == 0) {
|
if (idx == 0) {
|
||||||
freq = XOSC0_FREQUENCY;
|
freq = XOSC0_FREQUENCY;
|
||||||
} else if (idx == 1) {
|
}
|
||||||
|
else if (idx == 1) {
|
||||||
freq = XOSC1_FREQUENCY;
|
freq = XOSC1_FREQUENCY;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -143,17 +144,20 @@ static void xosc_init(uint8_t idx)
|
|||||||
reg |= OSCCTRL_XOSCCTRL_STARTUP(9)
|
reg |= OSCCTRL_XOSCCTRL_STARTUP(9)
|
||||||
| OSCCTRL_XOSCCTRL_IMULT(3)
|
| OSCCTRL_XOSCCTRL_IMULT(3)
|
||||||
| OSCCTRL_XOSCCTRL_IPTAT(2);
|
| OSCCTRL_XOSCCTRL_IPTAT(2);
|
||||||
} else if (freq <= MHZ(16)) {
|
}
|
||||||
|
else if (freq <= MHZ(16)) {
|
||||||
/* 62000 cycles @ 16MHz = 3875 µs */
|
/* 62000 cycles @ 16MHz = 3875 µs */
|
||||||
reg |= OSCCTRL_XOSCCTRL_STARTUP(7)
|
reg |= OSCCTRL_XOSCCTRL_STARTUP(7)
|
||||||
| OSCCTRL_XOSCCTRL_IMULT(4)
|
| OSCCTRL_XOSCCTRL_IMULT(4)
|
||||||
| OSCCTRL_XOSCCTRL_IPTAT(3);
|
| OSCCTRL_XOSCCTRL_IPTAT(3);
|
||||||
} else if (freq <= MHZ(24)) {
|
}
|
||||||
|
else if (freq <= MHZ(24)) {
|
||||||
/* 68500 cycles @ 24MHz = 2854 µs */
|
/* 68500 cycles @ 24MHz = 2854 µs */
|
||||||
reg |= OSCCTRL_XOSCCTRL_STARTUP(7)
|
reg |= OSCCTRL_XOSCCTRL_STARTUP(7)
|
||||||
| OSCCTRL_XOSCCTRL_IMULT(5)
|
| OSCCTRL_XOSCCTRL_IMULT(5)
|
||||||
| OSCCTRL_XOSCCTRL_IPTAT(3);
|
| OSCCTRL_XOSCCTRL_IPTAT(3);
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
/* 38500 cycles @ 48MHz = 802 µs */
|
/* 38500 cycles @ 48MHz = 802 µs */
|
||||||
reg |= OSCCTRL_XOSCCTRL_STARTUP(5)
|
reg |= OSCCTRL_XOSCCTRL_STARTUP(5)
|
||||||
| OSCCTRL_XOSCCTRL_IMULT(6)
|
| OSCCTRL_XOSCCTRL_IMULT(6)
|
||||||
@ -168,9 +172,9 @@ static void dfll_init(void)
|
|||||||
{
|
{
|
||||||
uint32_t reg = OSCCTRL_DFLLCTRLB_QLDIS
|
uint32_t reg = OSCCTRL_DFLLCTRLB_QLDIS
|
||||||
#ifdef OSCCTRL_DFLLCTRLB_WAITLOCK
|
#ifdef OSCCTRL_DFLLCTRLB_WAITLOCK
|
||||||
| OSCCTRL_DFLLCTRLB_WAITLOCK
|
| OSCCTRL_DFLLCTRLB_WAITLOCK
|
||||||
#endif
|
#endif
|
||||||
;
|
;
|
||||||
|
|
||||||
/* workaround for Errata 2.8.3 DFLLVAL.FINE Value When DFLL48M Re-enabled */
|
/* workaround for Errata 2.8.3 DFLLVAL.FINE Value When DFLL48M Re-enabled */
|
||||||
OSCCTRL->DFLLMUL.reg = 0; /* Write new DFLLMULL configuration */
|
OSCCTRL->DFLLMUL.reg = 0; /* Write new DFLLMULL configuration */
|
||||||
@ -217,13 +221,18 @@ static void fdpll_init_nolock(uint8_t idx, uint32_t f_cpu, uint8_t flags)
|
|||||||
while (OSCCTRL->Dpll[idx].DPLLSYNCBUSY.reg) {}
|
while (OSCCTRL->Dpll[idx].DPLLSYNCBUSY.reg) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void fdpll_lock(uint8_t idx) {
|
static void fdpll_lock(uint8_t idx)
|
||||||
|
{
|
||||||
const uint32_t flags = (OSCCTRL_DPLLSTATUS_CLKRDY | OSCCTRL_DPLLSTATUS_LOCK);
|
const uint32_t flags = (OSCCTRL_DPLLSTATUS_CLKRDY | OSCCTRL_DPLLSTATUS_LOCK);
|
||||||
while (!((OSCCTRL->Dpll[idx].DPLLSTATUS.reg & flags) == flags)) {}
|
while (!((OSCCTRL->Dpll[idx].DPLLSTATUS.reg & flags) == flags)) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void gclk_connect(uint8_t id, uint8_t src, uint32_t flags) {
|
static void gclk_connect(uint8_t id, uint8_t src, uint32_t flags)
|
||||||
GCLK->GENCTRL[id].reg = GCLK_GENCTRL_SRC(src) | GCLK_GENCTRL_GENEN | flags | GCLK_GENCTRL_IDC;
|
{
|
||||||
|
GCLK->GENCTRL[id].reg = GCLK_GENCTRL_SRC(src)
|
||||||
|
| GCLK_GENCTRL_GENEN
|
||||||
|
| flags
|
||||||
|
| GCLK_GENCTRL_IDC;
|
||||||
while (GCLK->SYNCBUSY.reg & GCLK_SYNCBUSY_GENCTRL(id)) {}
|
while (GCLK->SYNCBUSY.reg & GCLK_SYNCBUSY_GENCTRL(id)) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -238,11 +247,13 @@ void sam0_gclk_enable(uint8_t id)
|
|||||||
gclk_connect(SAM0_GCLK_TIMER,
|
gclk_connect(SAM0_GCLK_TIMER,
|
||||||
GCLK_SOURCE_DPLL0,
|
GCLK_SOURCE_DPLL0,
|
||||||
GCLK_GENCTRL_DIV(DPLL_DIV * CLOCK_CORECLOCK / GCLK_TIMER_HZ));
|
GCLK_GENCTRL_DIV(DPLL_DIV * CLOCK_CORECLOCK / GCLK_TIMER_HZ));
|
||||||
} else if (USE_DFLL) {
|
}
|
||||||
|
else if (USE_DFLL) {
|
||||||
gclk_connect(SAM0_GCLK_TIMER,
|
gclk_connect(SAM0_GCLK_TIMER,
|
||||||
GCLK_SOURCE_DFLL,
|
GCLK_SOURCE_DFLL,
|
||||||
GCLK_GENCTRL_DIV(SAM0_DFLL_FREQ_HZ / GCLK_TIMER_HZ));
|
GCLK_GENCTRL_DIV(SAM0_DFLL_FREQ_HZ / GCLK_TIMER_HZ));
|
||||||
} else if (USE_XOSC) {
|
}
|
||||||
|
else if (USE_XOSC) {
|
||||||
gclk_connect(SAM0_GCLK_TIMER,
|
gclk_connect(SAM0_GCLK_TIMER,
|
||||||
GCLK_SOURCE_ACTIVE_XOSC,
|
GCLK_SOURCE_ACTIVE_XOSC,
|
||||||
GCLK_GENCTRL_DIV(SAM0_XOSC_FREQ_HZ / GCLK_TIMER_HZ));
|
GCLK_GENCTRL_DIV(SAM0_XOSC_FREQ_HZ / GCLK_TIMER_HZ));
|
||||||
@ -251,7 +262,8 @@ void sam0_gclk_enable(uint8_t id)
|
|||||||
case SAM0_GCLK_PERIPH:
|
case SAM0_GCLK_PERIPH:
|
||||||
if (USE_DFLL) {
|
if (USE_DFLL) {
|
||||||
gclk_connect(SAM0_GCLK_PERIPH, GCLK_SOURCE_DFLL, 0);
|
gclk_connect(SAM0_GCLK_PERIPH, GCLK_SOURCE_DFLL, 0);
|
||||||
} else if (USE_XOSC) {
|
}
|
||||||
|
else if (USE_XOSC) {
|
||||||
gclk_connect(SAM0_GCLK_PERIPH, GCLK_SOURCE_ACTIVE_XOSC, 0);
|
gclk_connect(SAM0_GCLK_PERIPH, GCLK_SOURCE_ACTIVE_XOSC, 0);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -275,9 +287,11 @@ uint32_t sam0_gclk_freq(uint8_t id)
|
|||||||
case SAM0_GCLK_PERIPH:
|
case SAM0_GCLK_PERIPH:
|
||||||
if (USE_DFLL) {
|
if (USE_DFLL) {
|
||||||
return SAM0_DFLL_FREQ_HZ;
|
return SAM0_DFLL_FREQ_HZ;
|
||||||
} else if (USE_XOSC) {
|
}
|
||||||
|
else if (USE_XOSC) {
|
||||||
return SAM0_XOSC_FREQ_HZ;
|
return SAM0_XOSC_FREQ_HZ;
|
||||||
} else {
|
}
|
||||||
|
else {
|
||||||
assert(0);
|
assert(0);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -290,7 +304,7 @@ uint32_t sam0_gclk_freq(uint8_t id)
|
|||||||
|
|
||||||
void cpu_pm_cb_enter(int deep)
|
void cpu_pm_cb_enter(int deep)
|
||||||
{
|
{
|
||||||
(void) deep;
|
(void)deep;
|
||||||
/* will be called before entering sleep */
|
/* will be called before entering sleep */
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -355,7 +369,8 @@ void cpu_init(void)
|
|||||||
xosc32k_init();
|
xosc32k_init();
|
||||||
if (EXTERNAL_OSC32_SOURCE) {
|
if (EXTERNAL_OSC32_SOURCE) {
|
||||||
gclk_connect(SAM0_GCLK_32KHZ, GCLK_SOURCE_XOSC32K, 0);
|
gclk_connect(SAM0_GCLK_32KHZ, GCLK_SOURCE_XOSC32K, 0);
|
||||||
} else if (ULTRA_LOW_POWER_INTERNAL_OSC_SOURCE) {
|
}
|
||||||
|
else if (ULTRA_LOW_POWER_INTERNAL_OSC_SOURCE) {
|
||||||
gclk_connect(SAM0_GCLK_32KHZ, GCLK_SOURCE_OSCULP32K, 0);
|
gclk_connect(SAM0_GCLK_32KHZ, GCLK_SOURCE_OSCULP32K, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -368,10 +383,12 @@ void cpu_init(void)
|
|||||||
gclk_connect(SAM0_GCLK_MAIN, GCLK_SOURCE_DPLL0,
|
gclk_connect(SAM0_GCLK_MAIN, GCLK_SOURCE_DPLL0,
|
||||||
GCLK_GENCTRL_DIV(DPLL_DIV));
|
GCLK_GENCTRL_DIV(DPLL_DIV));
|
||||||
fdpll_lock(0);
|
fdpll_lock(0);
|
||||||
} else if (USE_DFLL) {
|
}
|
||||||
|
else if (USE_DFLL) {
|
||||||
gclk_connect(SAM0_GCLK_MAIN, GCLK_SOURCE_DFLL,
|
gclk_connect(SAM0_GCLK_MAIN, GCLK_SOURCE_DFLL,
|
||||||
GCLK_GENCTRL_DIV(SAM0_DFLL_FREQ_HZ / CLOCK_CORECLOCK));
|
GCLK_GENCTRL_DIV(SAM0_DFLL_FREQ_HZ / CLOCK_CORECLOCK));
|
||||||
} else if (USE_XOSC) {
|
}
|
||||||
|
else if (USE_XOSC) {
|
||||||
gclk_connect(SAM0_GCLK_MAIN, GCLK_SOURCE_ACTIVE_XOSC,
|
gclk_connect(SAM0_GCLK_MAIN, GCLK_SOURCE_ACTIVE_XOSC,
|
||||||
GCLK_GENCTRL_DIV(SAM0_XOSC_FREQ_HZ / CLOCK_CORECLOCK));
|
GCLK_GENCTRL_DIV(SAM0_XOSC_FREQ_HZ / CLOCK_CORECLOCK));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user