Configuration of CPU peripherals for the Atmel SAM D10 Xplained Mini board.
More...
Configuration of CPU peripherals for the Atmel SAM D10 Xplained Mini board.
- Author
- Benjamin Valentin benja.nosp@m.min..nosp@m.valen.nosp@m.tin@.nosp@m.ml-pa.nosp@m..com
Definition in file periph_conf.h.
#include <stdint.h>
#include "cpu.h"
#include "periph_cpu.h"
Go to the source code of this file.
|
There are three choices for selection of CORECLOCK:
- usage of the 48 MHz DFLL fed by external oscillator running at 32 kHz
- usage of the PLL fed by the internal 8MHz oscillator divided by 8
- usage of the internal 8MHz oscillator directly, divided by N if needed
The PLL option allows for the usage of a wider frequency range and a more stable clock with less jitter. This is why this option is default.
The target frequency is computed from the PLL multiplier and the PLL divisor. Use the following formula to compute your values:
CORECLOCK = ((PLL_MUL + 1) * 1MHz) / PLL_DIV
NOTE: The PLL circuit does not run with less than 32MHz while the maximum PLL frequency is 96MHz. So PLL_MULL must be between 31 and 95!
The internal Oscillator used directly can lead to a slightly better power efficiency to the cost of a less stable clock. Use this option when you know what you are doing! The actual core frequency is adjusted as follows:
CORECLOCK = 8MHz / DIV
NOTE: A core clock frequency below 1MHz is not recommended
|
#define | CLOCK_USE_PLL (1) |
|
#define | CLOCK_USE_XOSC32_DFLL (0) |
|
#define | GEN2_ULP32K (1) |
|
#define | CLOCK_DIV (1U) |
|
#define | CLOCK_CORECLOCK (8000000 / CLOCK_DIV) |
|
|
#define | RTT_FREQUENCY (32768U) /* in Hz. For changes see `rtt.c` */ |
|
◆ ADC_GAIN_FACTOR_DEFAULT
#define ADC_GAIN_FACTOR_DEFAULT ADC_INPUTCTRL_GAIN_1X |
◆ ADC_NEG_INPUT
#define ADC_NEG_INPUT ADC_INPUTCTRL_MUXNEG_GND |
◆ ADC_NUMOF
◆ ADC_PRESCALER
#define ADC_PRESCALER ADC_CTRLB_PRESCALER_DIV512 |
◆ ADC_REF_DEFAULT
#define ADC_REF_DEFAULT ADC_REFCTRL_REFSEL_INT1V |
◆ CLOCK_CORECLOCK
#define CLOCK_CORECLOCK (8000000 / CLOCK_DIV) |
◆ CLOCK_DIV
◆ CLOCK_USE_PLL
#define CLOCK_USE_PLL (1) |
◆ CLOCK_USE_XOSC32_DFLL
#define CLOCK_USE_XOSC32_DFLL (0) |
◆ DAC_CLOCK
◆ DAC_VREF
#define DAC_VREF DAC_CTRLB_REFSEL_AVCC |
◆ GEN2_ULP32K
◆ I2C_NUMOF
◆ PWM_0_EN
◆ PWM_NUMOF
◆ RTT_FREQUENCY
#define RTT_FREQUENCY (32768U) /* in Hz. For changes see `rtt.c` */ |
◆ SPI_NUMOF
◆ TIMER_0_ISR
#define TIMER_0_ISR isr_tc1 |
◆ TIMER_0_MAX_VALUE
#define TIMER_0_MAX_VALUE 0xffffffff |
◆ TIMER_NUMOF
◆ UART_0_ISR
#define UART_0_ISR isr_sercom0 |
◆ UART_NUMOF
◆ adc_channels
Initial value:= {
}
#define ADC_INPUTCTRL_MUXPOS_PA05
Alias for PIN5.
#define ADC_INPUTCTRL_MUXPOS_PA07
Alias for PIN7.
#define ADC_INPUTCTRL_MUXPOS_PA04
Alias for PIN4.
#define ADC_INPUTCTRL_MUXPOS_PA06
Alias for PIN6.
#define ADC_INPUTCTRL_MUXPOS_PA02
ADC pin aliases.
#define ADC_INPUTCTRL_MUXPOS_PA03
Alias for PIN1.
Definition at line 237 of file periph_conf.h.
◆ i2c_config
Initial value:= {
{
.dev = &(SERCOM2->I2CM),
}
}
#define GPIO_PIN(x, y)
Define a CPU specific GPIO pin generator macro.
@ I2C_SPEED_NORMAL
normal mode: ~100 kbit/s
@ I2C_FLAG_NONE
No flags set.
@ GPIO_MUX_D
select peripheral function D
#define SAM0_GCLK_MAIN
120 MHz main clock
Definition at line 202 of file periph_conf.h.
◆ pwm_config
◆ spi_config
Initial value:= {
{
.dev = &SERCOM1->SPI,
},
}
@ SPI_PAD_MISO_2
use pad 2 for MISO line
@ GPIO_MUX_C
select peripheral function C
@ SPI_PAD_MOSI_0_SCK_3
use pad 0 for MOSI, pad 3 for SCK
Definition at line 180 of file periph_conf.h.
◆ timer_config
Initial value:= {
{
.dev = TC1,
.irq = TC1_IRQn,
.pm_mask = PM_APBCMASK_TC1 | PM_APBCMASK_TC2,
.gclk_ctrl = GCLK_CLKCTRL_ID_TC1_TC2,
.flags = TC_CTRLA_MODE_COUNT32,
},
}
Definition at line 98 of file periph_conf.h.
◆ uart_config
Initial value:= {
{
.dev = &SERCOM0->USART,
},
}
@ UART_PAD_RX_3
select pad 3
@ UART_FLAG_NONE
No flags set.
@ UART_PAD_TX_2
select pad 2
Definition at line 125 of file periph_conf.h.