2019-03-05 15:49:29 +01:00
|
|
|
/*
|
|
|
|
* 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
|
|
|
|
/** @} */
|
|
|
|
|
2019-09-30 19:55:29 +02:00
|
|
|
/**
|
|
|
|
* @name Antenna selection configuration
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2019-10-01 17:04:59 +02:00
|
|
|
/** 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.
|
|
|
|
*/
|
2019-09-30 19:55:29 +02:00
|
|
|
#define VCTL1_PIN GPIO_PIN(0, 24)
|
2019-10-01 17:04:59 +02:00
|
|
|
/** 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.
|
|
|
|
*/
|
2019-09-30 19:55:29 +02:00
|
|
|
#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
|
|
|
|
|
|
|
|
/** @} */
|
|
|
|
|
2019-03-05 15:49:29 +01:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* BOARD_H */
|
|
|
|
/** @} */
|