Configuration of CPU peripherals for the Serpente board.  
More...
Configuration of CPU peripherals for the Serpente board. 
- Author
- Benjamin Valentin benpi.nosp@m.cco@.nosp@m.googl.nosp@m.emai.nosp@m.l.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.
|  | 
| For selection of the used CORECLOCK, we have implemented two choices: 
usage of the PLL fed by the internal 8MHz oscillator divided by 8usage 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 we use this option as 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_PLL_MUL   (47U)               /* must be >= 31 & <= 95 */ | 
|  | 
| #define | CLOCK_PLL_DIV   (1U)                /* adjust to your needs */ | 
|  | 
| #define | CLOCK_CORECLOCK   (((CLOCK_PLL_MUL + 1) * 1000000U) / CLOCK_PLL_DIV) | 
|  | 
|  | 
| #define | TIMER_0_MAX_VALUE   0xffff | 
|  | 
| #define | TIMER_0_ISR   isr_tc3 | 
|  | 
| #define | TIMER_1_ISR   isr_tc4 | 
|  | 
| #define | TIMER_NUMOF   ARRAY_SIZE(timer_config) | 
|  | 
| static const tc32_conf_t | timer_config [] | 
|  | 
|  | 
| #define | RTT_FREQUENCY   (32768U)    /* in Hz. For changes see `rtt.c` */ | 
|  | 
|  | 
| #define | ADC_PRESCALER   ADC_CTRLB_PRESCALER_DIV512 | 
|  | 
| #define | ADC_NEG_INPUT   ADC_INPUTCTRL_MUXNEG_GND | 
|  | 
| #define | ADC_GAIN_FACTOR_DEFAULT   ADC_INPUTCTRL_GAIN_1X | 
|  | 
| #define | ADC_REF_DEFAULT   ADC_REFCTRL_REFSEL_INT1V | 
|  | 
| #define | ADC_NUMOF   ARRAY_SIZE(adc_channels) | 
|  | 
| static const adc_conf_chan_t | adc_channels [] | 
|  | 
◆ adc_channels
Initial value:= {
    
}
#define ADC_INPUTCTRL_MUXPOS_PA05
Alias for PIN5.
#define ADC_INPUTCTRL_MUXPOS_PA08
Alias for PIN16.
#define ADC_INPUTCTRL_MUXPOS_PA09
Alias for PIN17.
#define ADC_INPUTCTRL_MUXPOS_PA07
Alias for PIN7.
#define ADC_INPUTCTRL_MUXPOS_PA04
Alias for PIN4.
#define ADC_INPUTCTRL_MUXPOS_PA06
Alias for PIN6.
Definition at line 267 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 234 of file periph_conf.h.
 
 
◆ pwm_chan0_config
Initial value:= {
    
}
@ GPIO_MUX_E
select peripheral function E
@ GPIO_MUX_F
select peripheral function F
Definition at line 156 of file periph_conf.h.
 
 
◆ pwm_chan1_config
◆ pwm_config
Initial value:= {
 
 
 
 
}
#define ARRAY_SIZE(a)
Calculate the number of elements in a static array.
#define TCC_CONFIG(tim)
Static initializer for TCC timer configuration.
Definition at line 175 of file periph_conf.h.
 
 
◆ sam_usbdev_config
Initial value:= {
    {
        .device = &USB->DEVICE,
    }
}
@ GPIO_MUX_G
select peripheral function G
Definition at line 284 of file periph_conf.h.
 
 
◆ timer_config
Initial value:= {
    {   
        .dev            = TC3,
        .irq            = TC3_IRQn,
        .pm_mask        = PM_APBCMASK_TC3,
        .gclk_ctrl      = GCLK_CLKCTRL_ID_TCC2_TC3,
 
 
 
 
        .flags          = TC_CTRLA_MODE_COUNT16,
    },
    {   
        .dev            = TC4,
        .irq            = TC4_IRQn,
        .pm_mask        = PM_APBCMASK_TC4 | PM_APBCMASK_TC5,
        .gclk_ctrl      = GCLK_CLKCTRL_ID_TC4_TC5,
 
 
 
 
        .flags          = TC_CTRLA_MODE_COUNT32,
    }
}
@ SAM0_GCLK_1MHZ
1 MHz clock for xTimer
Definition at line 77 of file periph_conf.h.
 
 
◆ uart_config
Initial value:= {
    {
        .dev      = &SERCOM2->USART,
    },
    {
        .dev      = &SERCOM0->USART,
    }
}
@ UART_PAD_RX_1
select pad 1
@ UART_FLAG_NONE
No flags set.
@ UART_PAD_TX_0
select pad 0
Definition at line 117 of file periph_conf.h.