24#include "periph_cpu.h"
62#define CLOCK_USE_PLL (1)
63#define CLOCK_USE_XOSC32_DFLL (0)
71#define GEN2_ULP32K (0)
75#define CLOCK_PLL_MUL (47U)
76#define CLOCK_PLL_DIV (1U)
78#define CLOCK_CORECLOCK (((CLOCK_PLL_MUL + 1) * 1000000U) / CLOCK_PLL_DIV)
79#elif CLOCK_USE_XOSC32_DFLL
81#define CLOCK_CORECLOCK (48000000U)
82#define CLOCK_XOSC32K (32768UL)
88#define CLOCK_CORECLOCK (8000000 / CLOCK_DIV)
100 .pm_mask = PM_APBCMASK_TC3,
101 .gclk_ctrl = GCLK_CLKCTRL_ID_TCC2_TC3,
102#if CLOCK_USE_PLL || CLOCK_USE_XOSC32_DFLL
107 .flags = TC_CTRLA_MODE_COUNT16,
112 .pm_mask = PM_APBCMASK_TC4 | PM_APBCMASK_TC5,
113 .gclk_ctrl = GCLK_CLKCTRL_ID_TC4_TC5,
114#if CLOCK_USE_PLL || CLOCK_USE_XOSC32_DFLL
119 .flags = TC_CTRLA_MODE_COUNT32,
123#define TIMER_0_MAX_VALUE 0xffff
126#define TIMER_0_ISR isr_tc3
127#define TIMER_1_ISR isr_tc4
129#define TIMER_NUMOF ARRAY_SIZE(timer_config)
138 .dev = &SERCOM0->USART,
141#ifdef MODULE_PERIPH_UART_HW_FC
147#ifdef MODULE_PERIPH_UART_HW_FC
156 .dev = &SERCOM5->USART,
159#ifdef MODULE_PERIPH_UART_HW_FC
165#ifdef MODULE_PERIPH_UART_HW_FC
176#define UART_0_ISR isr_sercom0
177#define UART_1_ISR isr_sercom5
179#define UART_NUMOF ARRAY_SIZE(uart_config)
212 .chan = pwm_chan0_config,
220 .chan = pwm_chan1_config,
228#define PWM_NUMOF ARRAY_SIZE(pwm_config)
237 .dev = &SERCOM4->SPI,
247#ifdef MODULE_PERIPH_DMA
248 .tx_trigger = SERCOM4_DMAC_ID_TX,
249 .rx_trigger = SERCOM4_DMAC_ID_RX,
253 .dev = &SERCOM5->SPI,
263#ifdef MODULE_PERIPH_DMA
264 .tx_trigger = SERCOM5_DMAC_ID_TX,
265 .rx_trigger = SERCOM5_DMAC_ID_RX,
270#define SPI_NUMOF ARRAY_SIZE(spi_config)
279 .dev = &(SERCOM3->I2CM),
288#define I2C_NUMOF ARRAY_SIZE(i2c_config)
296#define RTT_FREQUENCY (32768U)
298#define RTT_MIN_OFFSET (10U)
307#define ADC_PRESCALER ADC_CTRLB_PRESCALER_DIV512
309#define ADC_NEG_INPUT ADC_INPUTCTRL_MUXNEG_GND
310#define ADC_GAIN_FACTOR_DEFAULT ADC_INPUTCTRL_GAIN_1X
311#define ADC_REF_DEFAULT ADC_REFCTRL_REFSEL_INT1V
319#define ADC_NUMOF ARRAY_SIZE(adc_channels)
331 .device = &USB->DEVICE,
#define GPIO_PIN(x, y)
Define a CPU specific GPIO pin generator macro.
@ I2C_SPEED_NORMAL
normal mode: ~100 kbit/s
#define ARRAY_SIZE(a)
Calculate the number of elements in a static array.
@ UART_PAD_RX_1
select pad 1
@ I2C_FLAG_NONE
No flags set.
@ SPI_PAD_MISO_0
use pad 0 for MISO line
@ UART_FLAG_NONE
No flags set.
@ UART_PAD_TX_0_RTS_2_CTS_3
TX is pad 0, on top RTS on pad 2 and CTS on pad 3.
@ UART_PAD_TX_0
select pad 0
#define TCC_CONFIG(tim)
Static initializer for TCC timer configuration.
@ GPIO_MUX_E
select peripheral function E
@ GPIO_MUX_D
select peripheral function D
@ GPIO_MUX_G
select peripheral function G
@ GPIO_MUX_F
select peripheral function F
@ SPI_PAD_MOSI_2_SCK_3
use pad 2 for MOSI, pad 3 for SCK
#define ADC_INPUTCTRL_MUXPOS_PA07
Alias for PIN7.
@ SAM0_GCLK_1MHZ
1 MHz clock for xTimer
#define ADC_INPUTCTRL_MUXPOS_PA06
Alias for PIN6.
#define SAM0_GCLK_MAIN
120 MHz main clock
ADC Channel Configuration.
I2C configuration structure.
PWM channel configuration data structure.
PWM device configuration.
USB peripheral parameters.
SPI device configuration.
Timer device configuration.
UART device configuration.