/* * Copyright (C) 2014-2015 Freie Universität Berlin * * 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. */ /** * @defgroup boards_iotlab-m3 IoT-LAB M3 open node * @ingroup boards * @brief Board specific files for the iotlab-m3 board. * @{ * * @file * @brief Board specific definitions for the iotlab-m3 board. * * @author Alaeddine Weslati * @author Thomas Eichinger * @author Oliver Hahm * @author Hauke Petersen */ #ifndef BOARD_COMMON_H #define BOARD_COMMON_H #include #include "cpu.h" #include "periph_conf.h" #include "periph_conf_common.h" #ifdef __cplusplus extern "C" { #endif /** * @name Set the default baudrate to 500K for this board * @{ */ #ifndef UART_STDIO_BAUDRATE # define UART_STDIO_BAUDRATE (500000U) #endif /** @} */ /** * @name Tell the xtimer that we use a 16-bit peripheral timer */ #define XTIMER_WIDTH (16) /** * @name Define the interface to the AT86RF231 radio * * {spi bus, spi speed, cs pin, int pin, reset pin, sleep pin} */ #define AT86RF2XX_PARAMS_BOARD {.spi = SPI_DEV(0), \ .spi_clk = SPI_CLK_5MHZ, \ .cs_pin = GPIO_PIN(PORT_A, 4), \ .int_pin = GPIO_PIN(PORT_C, 4), \ .sleep_pin = GPIO_PIN(PORT_A, 2), \ .reset_pin = GPIO_PIN(PORT_C, 1)} /** * @brief LED pin definitions and handlers * @{ */ #define LED0_PIN GPIO_PIN(PORT_D, 2) #define LED1_PIN GPIO_PIN(PORT_B, 5) #define LED2_PIN GPIO_PIN(PORT_C, 10) #define LED0_MASK (1 << 2) #define LED1_MASK (1 << 5) #define LED2_MASK (1 << 10) #define LED0_ON (GPIOD->ODR &= ~LED0_MASK) #define LED0_OFF (GPIOD->ODR |= LED0_MASK) #define LED0_TOGGLE (GPIOD->ODR ^= LED0_MASK) #define LED1_ON (GPIOB->ODR &= ~LED1_MASK) #define LED1_OFF (GPIOB->ODR |= LED1_MASK) #define LED1_TOGGLE (GPIOB->ODR ^= LED1_MASK) #define LED2_ON (GPIOC->ODR &= ~LED2_MASK) #define LED2_OFF (GPIOC->ODR |= LED2_MASK) #define LED2_TOGGLE (GPIOC->ODR ^= LED2_MASK) /** @} */ /** * @name xtimer tuning values * @{ */ #define XTIMER_OVERHEAD 6 #define XTIMER_SHOOT_EARLY 3 /** @} */ /** * @brief Initialize board specific hardware, including clock, LEDs and std-IO */ void board_init(void); #ifdef __cplusplus } #endif #endif /* BOARD_COMMON_H */ /** @} */