/* * Copyright (C) 2016 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_common_nucleo STM Nucleo common * @ingroup boards_common * @brief Shared files and configuration for all STM Nucleo boards. * @{ * * @file * @brief Common pin definitions and board configuration options * * @author Hauke Petersen * @author Sebastian Meiling */ #ifndef BOARD_COMMON_H #define BOARD_COMMON_H #include "cpu.h" #include "periph_conf.h" #include "arduino_pinmap.h" #ifdef __cplusplus extern "C" { #endif /** * @brief LED pin definitions and handlers * @{ */ #ifdef CPU_MODEL_STM32F302R8 #define LED0_PORT GPIOB #define LED0_PIN GPIO_PIN(PORT_B, 13) #define LED0_MASK (1 << 13) #else #define LED0_PORT GPIOA #define LED0_PIN GPIO_PIN(PORT_A, 5) #define LED0_MASK (1 << 5) #endif #define LED0_ON (LED0_PORT->BSRR = LED0_MASK) #define LED0_OFF (LED0_PORT->BSRR = (LED0_MASK << 16)) #define LED0_TOGGLE (LED0_PORT->ODR ^= LED0_MASK) /** @} */ /** * @brief User button * @{ */ #define BTN0_PIN GPIO_PIN(PORT_C, 13) #define BTN0_MODE GPIO_IN_PU /** @} */ /** * @brief Initialize board specific hardware, including clock, LEDs and std-IO */ void board_init(void); #ifdef __cplusplus } #endif #endif /* BOARD_COMMON_H */ /** @} */