/* * Copyright (C) 2014 Freie Universität Berlin * Copyright (C) 2018 HAW Hamburg * * 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_openmote-b * @{ * * @file * @brief Board specific definitions for the OpenMote-B board * * @author Hauke Petersen * @author Kevin Weiss */ #ifndef BOARD_H #define BOARD_H #include "cpu.h" #include "periph/gpio.h" #include "cc2538_eui_primary.h" #ifdef __cplusplus extern "C" { #endif /** * @name LED pin definitions and handlers * @{ */ #define LED0_PIN GPIO_PIN(2, 4) #define LED1_PIN GPIO_PIN(2, 7) #define LED2_PIN GPIO_PIN(2, 6) #define LED3_PIN GPIO_PIN(2, 5) #define BTN0_PIN GPIO_PIN(3, 5) #define BTN0_MODE GPIO_IN #define RF24_SWITCH_CC2538_PIN GPIO_PIN(3, 4) /**< PD4 -- CC2538 */ #define RF24_SWITCH_AT86RF215_PIN GPIO_PIN(3, 3) /**< PD3 -- AT86RF215 */ #define LED_PORT GPIO_C #define LED0_MASK (1 << 4) #define LED1_MASK (1 << 7) #define LED2_MASK (1 << 6) #define LED3_MASK (1 << 5) #define RF_SWITCH_PORT GPIO_D #define RF24_SWITCH_CC2538_MASK (1 << 4) #define RF24_SWITCH_AT86RF215_MASK (1 << 3) #define LED0_ON (LED_PORT->DATA &= ~LED0_MASK) #define LED0_OFF (LED_PORT->DATA |= LED0_MASK) #define LED0_TOGGLE (LED_PORT->DATA ^= LED0_MASK) #define LED1_ON (LED_PORT->DATA &= ~LED1_MASK) #define LED1_OFF (LED_PORT->DATA |= LED1_MASK) #define LED1_TOGGLE (LED_PORT->DATA ^= LED1_MASK) #define LED2_ON (LED_PORT->DATA &= ~LED2_MASK) #define LED2_OFF (LED_PORT->DATA |= LED2_MASK) #define LED2_TOGGLE (LED_PORT->DATA ^= LED2_MASK) #define LED3_ON (LED_PORT->DATA &= ~LED3_MASK) #define LED3_OFF (LED_PORT->DATA |= LED3_MASK) #define LED3_TOGGLE (LED_PORT->DATA ^= LED3_MASK) #define RF24_SWITCH_CC2538_ON (RF_SWITCH_PORT->DATA &= ~RF24_SWITCH_CC2538_MASK) #define RF24_SWITCH_CC2538_OFF (RF_SWITCH_PORT->DATA |= RF24_SWITCH_CC2538_MASK) #define RF24_SWITCH_CC2538_TOGGLE (RF_SWITCH_PORT->DATA ^= RF24_SWITCH_CC2538_MASK) #define RF24_SWITCH_AT86RF215_ON (RF_SWITCH_PORT->DATA &= ~RF24_SWITCH_AT86RF215_MASK) #define RF24_SWITCH_AT86RF215_OFF (RF_SWITCH_PORT->DATA |= RF24_SWITCH_AT86RF215_MASK) #define RF24_SWITCH_AT86RF215_TOGGLE (RF_SWITCH_PORT->DATA ^= RF24_SWITCH_AT86RF215_MASK) /** @} */ /** * @name RF CORE observable signals settings * @{ */ #define CONFIG_CC2538_RF_OBS_SIG_0_PCX 5 /* PC5 */ #define CONFIG_CC2538_RF_OBS_SIG_1_PCX 6 /* PC6 */ #define CONFIG_CC2538_RF_OBS_SIG_2_PCX 7 /* PC7 */ /** @} */ /** * @name OpenWSN leds configuration * @{ */ #define OPENWSN_LEDPIN_ERROR LED0_PIN #define OPENWSN_LEDPIN_SYNC LED1_PIN #define OPENWSN_LEDPIN_RADIO LED3_PIN #define OPENWSN_LEDPIN_DEBUG LED2_PIN /** @} */ /** * @name OpenWSN debugpins configuration * * @note This configuration mimics the one done in OpenWSN-fw for the * same platform * @{ */ #define OPENWSN_DEBUGPIN_FRAME GPIO_PIN(0, 7) /* A7 */ #define OPENWSN_DEBUGPIN_ISR GPIO_PIN(2, 3) /* C3 */ #define OPENWSN_DEBUGPIN_SLOT GPIO_PIN(1, 3) /* B3 */ #define OPENWSN_DEBUGPIN_FSM GPIO_PIN(1, 2) /* B2 */ #define OPENWSN_DEBUGPIN_TASK GPIO_PIN(1, 1) /* B1 */ #define OPENWSN_DEBUGPIN_RADIO GPIO_PIN(1, 0) /* B0 */ /** * @name AT86RF215 configuration * @{ */ #define AT86RF215_PARAM_SPI SPI_DEV(0) #define AT86RF215_PARAM_CS GPIO_PIN(0, 3) /* A3 */ #define AT86RF215_PARAM_INT GPIO_PIN(3, 0) /* D0 */ #define AT86RF215_PARAM_RESET GPIO_PIN(3, 1) /* D1 */ /** @} */ /** * @name xtimer configuration * @{ */ #define XTIMER_WIDTH (16) #define XTIMER_BACKOFF (50) #define XTIMER_ISR_BACKOFF (40) /** @} */ /** * @name Flash Customer Configuration Area (CCA) parameters * @{ */ #ifndef UPDATE_CCA #define UPDATE_CCA (1) #endif #define CCA_BACKDOOR_ENABLE (1) #define CCA_BACKDOOR_PORT_A_PIN (6) /**< BSL_BOOT Pin */ #define CCA_BACKDOOR_ACTIVE_LEVEL (0) /**< Active low */ #define BOOT_PIN GPIO_PIN(0, CCA_BACKDOOR_PORT_A_PIN) /**< BSL_BOOT Pin */ /** @} */ /** * @brief Initialize board specific hardware, including clock, LEDs and std-IO */ void board_init(void); #ifdef __cplusplus } /* end extern "C" */ #endif #endif /* BOARD_H */ /** @} */