/* * Copyright (C) 2018 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_particle-mesh * @{ * * @file * @brief Common board specific configuration for the Particle Mesh * * @author Alexandre Abadie */ #ifndef BOARD_H #define BOARD_H #include "cpu.h" #include "board_common.h" #ifdef __cplusplus extern "C" { #endif /** * @name LED pin configuration * @{ */ #define LED0_PIN GPIO_PIN(0, 13) #define LED1_PIN GPIO_PIN(0, 14) #define LED2_PIN GPIO_PIN(0, 15) #define LED_PORT (NRF_P0) #define LED0_MASK (1 << 13) #define LED1_MASK (1 << 14) #define LED2_MASK (1 << 15) #define LED_MASK (LED0_MASK | LED1_MASK | LED2_MASK) #define LED0_ON (LED_PORT->OUTCLR = LED0_MASK) #define LED0_OFF (LED_PORT->OUTSET = LED0_MASK) #define LED0_TOGGLE (LED_PORT->OUT ^= LED0_MASK) #define LED1_ON (LED_PORT->OUTCLR = LED1_MASK) #define LED1_OFF (LED_PORT->OUTSET = LED1_MASK) #define LED1_TOGGLE (LED_PORT->OUT ^= LED1_MASK) #define LED2_ON (LED_PORT->OUTCLR = LED2_MASK) #define LED2_OFF (LED_PORT->OUTSET = LED2_MASK) #define LED2_TOGGLE (LED_PORT->OUT ^= LED2_MASK) /** @} */ /** * @name Button pin configuration * @{ */ #define BTN0_PIN GPIO_PIN(0, 11) #define BTN0_MODE GPIO_IN_PU /** @} */ /** * @name Antenna selection configuration * @{ */ #ifdef BOARD_PARTICLE_XENON #define VCTL1_PIN GPIO_PIN(0, 24) #define VCTL2_PIN GPIO_PIN(0, 25) #endif #ifdef BOARD_PARTICLE_ARGON #define VCTL1_PIN GPIO_PIN(0, 25) #define VCTL2_PIN GPIO_PIN(0, 2) #endif #ifdef BOARD_PARTICLE_BORON #define VCTL1_PIN GPIO_PIN(0, 7) #endif /** @} */ #ifdef __cplusplus } #endif #endif /* BOARD_H */ /** @} */