mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
99 lines
3.3 KiB
C
99 lines
3.3 KiB
C
|
/*
|
||
|
* Copyright (C) 2021 Mesotic SAS
|
||
|
*
|
||
|
* 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_nrf9160dk
|
||
|
* @{
|
||
|
*
|
||
|
* @file
|
||
|
* @brief Board configuration for the nrf9160dk board
|
||
|
*
|
||
|
* @author Dylan Laduranty <dylan.laduranty@mesotic.com>
|
||
|
*/
|
||
|
|
||
|
#ifndef BOARD_H
|
||
|
#define BOARD_H
|
||
|
|
||
|
#include "cpu.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @name Clock configuration
|
||
|
*
|
||
|
* @note The LTE modem will only work with the high accuracy RC oscillator
|
||
|
*
|
||
|
* @{
|
||
|
*/
|
||
|
#define CLOCK_HFCLK (32U) /**< set to 0: internal RC oscillator
|
||
|
* 32: 32MHz crystal */
|
||
|
#define CLOCK_LFCLK (3) /**< set to 0: internal RC oscillator
|
||
|
* 3: High Accuracy oscillator */
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @name LED pin configuration
|
||
|
* @{
|
||
|
*/
|
||
|
#define LED0_PIN GPIO_PIN(0, 2) /**< LED0 pin definition */
|
||
|
#define LED1_PIN GPIO_PIN(0, 3) /**< LED1 pin definition */
|
||
|
#define LED2_PIN GPIO_PIN(0, 4) /**< LED2 pin definition */
|
||
|
#define LED3_PIN GPIO_PIN(0, 5) /**< LED3 pin definition */
|
||
|
|
||
|
#define LED0_MASK (1 << 2) /**< LED0 PORT bitmask */
|
||
|
#define LED1_MASK (1 << 3) /**< LED1 PORT bitmask */
|
||
|
#define LED2_MASK (1 << 4) /**< LED2 PORT bitmask */
|
||
|
#define LED3_MASK (1 << 5) /**< LED3 PORT bitmask */
|
||
|
|
||
|
#define LED_PORT (NRF_P0_S) /**< Default LED PORT */
|
||
|
|
||
|
#define LED0_ON (LED_PORT->OUTCLR = LED0_MASK) /**< LED0 ON macro */
|
||
|
#define LED0_OFF (LED_PORT->OUTSET = LED0_MASK) /**< LED0 OFF macro */
|
||
|
#define LED0_TOGGLE (LED_PORT->OUT ^= LED0_MASK) /**< LED0 toggle macro */
|
||
|
|
||
|
#define LED1_ON (LED_PORT->OUTCLR = LED1_MASK) /**< LED1 ON macro */
|
||
|
#define LED1_OFF (LED_PORT->OUTSET = LED1_MASK) /**< LED1 OFF macro */
|
||
|
#define LED1_TOGGLE (LED_PORT->OUT ^= LED1_MASK) /**< LED1 toggle macro */
|
||
|
|
||
|
#define LED2_ON (LED_PORT->OUTCLR = LED2_MASK) /**< LED2 ON macro */
|
||
|
#define LED2_OFF (LED_PORT->OUTSET = LED2_MASK) /**< LED2 OFF macro */
|
||
|
#define LED2_TOGGLE (LED_PORT->OUT ^= LED2_MASK) /**< LED2 toggle macro */
|
||
|
|
||
|
#define LED3_ON (LED_PORT->OUTCLR = LED3_MASK) /**< LED3 ON macro */
|
||
|
#define LED3_OFF (LED_PORT->OUTSET = LED3_MASK) /**< LED3 OFF macro */
|
||
|
#define LED3_TOGGLE (LED_PORT->OUT ^= LED3_MASK) /**< LED3 toggle macro */
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @name Button pin configuration
|
||
|
* @{
|
||
|
*/
|
||
|
#define BTN0_PIN GPIO_PIN(0, 6) /**< BTN0 pin definition */
|
||
|
#define BTN0_MODE GPIO_IN /**< BTN0 default mode */
|
||
|
#define BTN1_PIN GPIO_PIN(0, 7) /**< BTN1 pin definition */
|
||
|
#define BTN1_MODE GPIO_IN /**< BTN1 default mode */
|
||
|
#define BTN2_PIN GPIO_PIN(0, 8) /**< BTN2 pin definition */
|
||
|
#define BTN2_MODE GPIO_IN /**< BTN2 default mode */
|
||
|
#define BTN3_PIN GPIO_PIN(0, 9) /**< BTN3 pin definition */
|
||
|
#define BTN3_MODE GPIO_IN /**< BTN3 default mode */
|
||
|
/** @} */
|
||
|
|
||
|
/**
|
||
|
* @brief Initialize the platform
|
||
|
*/
|
||
|
void board_init(void);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* BOARD_H */
|
||
|
/** @} */
|