1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-15 17:52:45 +01:00
RIOT/boards/common/particle-mesh/include/board.h
chrysn 9954194ae0 particle boards: Make default antenna selection configurable
The setter function approach makes this switchable at runtime (antenna
diversity?).

Documentation is added both to the board introduction page and the
individual pins and functions.
2019-11-18 13:54:39 +01:00

125 lines
3.1 KiB
C

/*
* 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 <alexandre.abadie@inria.fr>
*/
#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
* @{
*/
/** Choices in antenna outputs for the board's nRF radio
*
* @see board_nrfantenna_select */
enum board_nrfantenna_selection {
/** The board's built-in antenna */
BOARD_NRFANTENNA_BUILTIN,
/** The board's uFL connector */
BOARD_NRFANTENNA_EXTERNAL,
};
/** @brief Antenna output selection
*
* Drive the on-board antenna switch to connect the nRF radio to a given @p
* choice of antenna output.
*
* This can be called to change the antenna selection at runtime; for the
* default configuration that gets set during board initialization, see @ref
* boards_common_particle-mesh.
* */
void board_nrfantenna_select(enum board_nrfantenna_selection choice);
#if defined(BOARD_PARTICLE_XENON) || defined(DOXYGEN)
/** The GPIO pin used to drive the VCTL1 pin of antenna switch
*
* Rather than actuating this directly, consider using the @ref
* board_nrfantenna_select function.
*/
#define VCTL1_PIN GPIO_PIN(0, 24)
/** The GPIO pin used to drive the VCTL2 pin of antenna switch
*
* This definition is left out for boards whose VCTL2 is driven by an inverter
* from VCTL1.
*
* Rather than actuating this directly, consider using the @ref
* board_nrfantenna_select function.
*/
#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 */
/** @} */