/* * Copyright (C) 2016 Freie Universität Berlin * 2016-2017 Inria * * This file is subject to the terms and conditions of the GNU Lesser * General Public License v2.1. See the file LICENSE in the top level * directory for more details. */ /** * @ingroup boards_common_arduino-mkr * @{ * * @file * @brief Configuration of CPU peripherals for Arduino MKR boards * * @author Thomas Eichinger * @author Hauke Petersen * @author Peter Kietzmann * @author Alexandre Abadie * @author Bumsik kim */ #ifndef PERIPH_CONF_H #define PERIPH_CONF_H #include "periph_cpu.h" #include "periph_conf_common.h" #ifdef __cplusplus extern "C" { #endif /** * @name UART configuration * @{ */ static const uart_conf_t uart_config[] = { { .dev = &SERCOM5->USART, .rx_pin = GPIO_PIN(PB,23), /* ARDUINO_PIN_13, RX Pin */ .tx_pin = GPIO_PIN(PB,22), /* ARDUINO_PIN_14, TX Pin */ .mux = GPIO_MUX_D, .rx_pad = UART_PAD_RX_3, .tx_pad = UART_PAD_TX_2, .flags = UART_FLAG_NONE, .gclk_src = GCLK_CLKCTRL_GEN_GCLK0 } }; /* interrupt function name mapping */ #define UART_0_ISR isr_sercom5 #define UART_NUMOF ARRAY_SIZE(uart_config) /** @} */ /** * @name SPI configuration * @{ */ static const spi_conf_t spi_config[] = { { .dev = &SERCOM1->SPI, .miso_pin = GPIO_PIN(PA, 19), /* ARDUINO_PIN_8, SERCOM1-MISO */ .mosi_pin = GPIO_PIN(PA, 16), /* ARDUINO_PIN_10, SERCOM1-MOSI */ .clk_pin = GPIO_PIN(PA, 17), /* ARDUINO_PIN_9, SERCOM1-SCK */ .miso_mux = GPIO_MUX_C, .mosi_mux = GPIO_MUX_C, .clk_mux = GPIO_MUX_C, .miso_pad = SPI_PAD_MISO_3, .mosi_pad = SPI_PAD_MOSI_0_SCK_1 }, { .dev = &SERCOM2->SPI, .miso_pin = GPIO_PIN(PA, 15), .mosi_pin = GPIO_PIN(PA, 12), .clk_pin = GPIO_PIN(PA, 13), .miso_mux = GPIO_MUX_C, .mosi_mux = GPIO_MUX_C, .clk_mux = GPIO_MUX_C, .miso_pad = SPI_PAD_MISO_3, .mosi_pad = SPI_PAD_MOSI_0_SCK_1 } }; #define SPI_NUMOF ARRAY_SIZE(spi_config) /** @} */ #ifdef __cplusplus } #endif #endif /* PERIPH_CONF_H */ /** @} */