22 #include "periph_cpu.h"
32 #ifndef CLOCK_CORECLOCK
33 #define CLOCK_CORECLOCK MHZ(120)
41 #define EXTERNAL_OSC32_SOURCE 1
42 #define ULTRA_LOW_POWER_INTERNAL_OSC_SOURCE 0
49 #define USE_VREG_BUCK (1)
59 .mclk = &MCLK->APBAMASK.reg,
60 .mclk_mask = MCLK_APBAMASK_TC0 | MCLK_APBAMASK_TC1,
61 .gclk_id = TC0_GCLK_ID,
63 .flags = TC_CTRLA_MODE_COUNT32,
68 .mclk = &MCLK->APBBMASK.reg,
69 .mclk_mask = MCLK_APBBMASK_TC2 | MCLK_APBBMASK_TC3,
70 .gclk_id = TC2_GCLK_ID,
72 .flags = TC_CTRLA_MODE_COUNT32,
77 #define TIMER_0_CHANNELS 2
78 #define TIMER_0_ISR isr_tc0
81 #define TIMER_1_CHANNELS 2
82 #define TIMER_1_ISR isr_tc2
84 #define TIMER_NUMOF ARRAY_SIZE(timer_config)
108 #define ISR_CAN0 isr_can0
111 #define ISR_CAN1 isr_can1
114 #define CAN_NUMOF ARRAY_SIZE(candev_conf)
123 .
dev = &SERCOM5->USART,
133 .dev = &SERCOM4->USART,
136 #ifdef MODULE_PERIPH_UART_HW_FC
142 #ifdef MODULE_PERIPH_UART_HW_FC
151 .dev = &SERCOM0->USART,
154 #ifdef MODULE_PERIPH_UART_HW_FC
160 #ifdef MODULE_PERIPH_UART_HW_FC
169 .dev = &SERCOM3->USART,
181 #define UART_0_ISR isr_sercom5_2
182 #define UART_0_ISR_TX isr_sercom5_0
184 #define UART_1_ISR isr_sercom4_2
185 #define UART_1_ISR_TX isr_sercom4_0
187 #define UART_2_ISR isr_sercom0_2
188 #define UART_2_ISR_TX isr_sercom0_0
190 #define UART_3_ISR isr_sercom3_2
191 #define UART_3_ISR_TX isr_sercom3_0
193 #define UART_NUMOF ARRAY_SIZE(uart_config)
215 .chan = pwm_chan0_config,
222 #define PWM_NUMOF ARRAY_SIZE(pwm_config)
231 .
dev = &SERCOM1->SPI,
241 #ifdef MODULE_PERIPH_DMA
242 .tx_trigger = SERCOM1_DMAC_ID_TX,
243 .rx_trigger = SERCOM1_DMAC_ID_RX,
249 #define SPI_NUMOF ARRAY_SIZE(spi_config)
258 .
dev = &SERCOM2->I2CM,
268 #define I2C_NUMOF ARRAY_SIZE(i2c_config)
275 #ifndef RTT_FREQUENCY
276 #define RTT_FREQUENCY (32768U)
291 .device = &USB->DEVICE,
303 #define ADC_GCLK_SRC SAM0_GCLK_PERIPH
304 #define ADC_PRESCALER ADC_CTRLA_PRESCALER_DIV8
306 #define ADC_NEG_INPUT ADC_INPUTCTRL_MUXNEG(0x18u)
307 #define ADC_REF_DEFAULT ADC_REFCTRL_REFSEL_INTVCC1
328 #define ADC_NUMOF ARRAY_SIZE(adc_channels)
336 #define DAC_CLOCK SAM0_GCLK_TIMER
340 #define DAC_VREF DAC_CTRLB_REFSEL_VREFPU
#define GPIO_PIN(x, y)
Define a CPU specific GPIO pin generator macro.
static const uart_conf_t uart_config[]
UART configuration.
static const spi_conf_t spi_config[]
SPI configuration.
static const i2c_conf_t i2c_config[]
I2C configuration.
static const timer_conf_t timer_config[]
All timers on board.
static const pwm_conf_t pwm_config[]
Actual PWM configuration.
#define ARRAY_SIZE(a)
Calculate the number of elements in a static array.
static const gpio_t adc_channels[]
Static array with declared ADC channels.
@ I2C_SPEED_NORMAL
normal mode: ~100 kbit/s
@ UART_PAD_RX_1
select pad 1
@ I2C_FLAG_NONE
No flags set.
@ SPI_PAD_MISO_3
use pad 3 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_H
select peripheral function H
@ GPIO_MUX_C
select peripheral function C
@ GPIO_MUX_F
select peripheral function F
@ SPI_PAD_MOSI_0_SCK_1
use pad 0 for MOSI, pad 1 for SCK
#define ADC0_INPUTCTRL_MUXPOS_PA04
Alias for AIN4.
#define ADC0_INPUTCTRL_MUXPOS_PA07
Alias for AIN7.
#define ADC0_INPUTCTRL_MUXPOS_PA10
Alias for AIN10.
#define ADC1_INPUTCTRL_MUXPOS_PB05
Alias for AIN7.
#define ADC1_INPUTCTRL_MUXPOS_PB04
Alias for AIN6.
#define ADC0_INPUTCTRL_MUXPOS_PB01
Alias for AIN13.
#define ADC0_INPUTCTRL_MUXPOS_PB03
Alias for AIN15.
#define ADC0_INPUTCTRL_MUXPOS_PB08
Alias for AIN2.
#define ADC0_INPUTCTRL_MUXPOS_PA11
Alias for AIN11.
#define ADC0_INPUTCTRL_MUXPOS_PB00
Alias for AIN12.
#define ADC1_INPUTCTRL_MUXPOS_PB07
Alias for AIN9.
#define ADC0_INPUTCTRL_MUXPOS_PA03
Alias for AIN1.
#define ADC0_INPUTCTRL_MUXPOS_PB09
Alias for AIN3.
#define ADC0_INPUTCTRL_MUXPOS_PA02
ADC pin aliases.
#define SAM0_GCLK_PERIPH
12-48 MHz (DFLL) clock
#define ADC1_INPUTCTRL_MUXPOS_PB06
Alias for AIN8.
@ SAM0_GCLK_TIMER
4/8MHz clock for timers
@ SAM0_GCLK_48MHZ
48MHz clock
ADC Channel Configuration.
ESP CAN device configuration.
Linux candev configuration.
I2C configuration structure.
TWI_t * dev
Pointer to hardware module registers.
PWM channel configuration data structure.
PWM device configuration.
tc_tcc_cfg_t tim
timer configuration
USB peripheral parameters.
SPI device configuration.
SPI_t * dev
pointer to the used SPI device
Timer device configuration.
TC0_t * dev
Pointer to the used as Timer device.
UART device configuration.
USART_t * dev
pointer to the used UART device