1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 12:52:44 +01:00
RIOT/boards/sltb001a/include/board.h

223 lines
4.6 KiB
C
Raw Normal View History

/*
2020-10-27 00:03:23 +01:00
* Copyright (C) 2015-2020 Freie Universität Berlin
*
* 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.
*/
/**
2018-07-26 11:59:14 +02:00
* @ingroup boards_sltb001a
* @{
*
* @file
* @brief Board specific definitions for the SLTB001A starter kit
*
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
* @author Bas Stottelaar <basstottelaar@gmail.com>
*/
#ifndef BOARD_H
#define BOARD_H
#include "cpu.h"
#include "periph_conf.h"
#include "periph/adc.h"
#include "periph/gpio.h"
#include "periph/spi.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @name Xtimer configuration
*
* The timer runs at 250 kHz to increase accuracy, or at 32.768 kHz if
* LETIMER is used.
* @{
*/
#if IS_ACTIVE(CONFIG_EFM32_XTIMER_USE_LETIMER)
#define XTIMER_DEV (TIMER_DEV(1))
#define XTIMER_HZ (32768UL)
#define XTIMER_WIDTH (16)
#else
#define XTIMER_DEV (TIMER_DEV(0))
#define XTIMER_HZ (250000UL)
#define XTIMER_WIDTH (16)
#endif
#define XTIMER_CHAN (0)
/** @} */
/**
* @name Push button pin definitions
* @{
*/
#define PB0_PIN GPIO_PIN(PD, 14)
#define PB1_PIN GPIO_PIN(PD, 15)
/** @} */
/**
* @name LED pin definitions
* @{
*/
#define LED0_PIN GPIO_PIN(PD, 12)
#define LED1_PIN GPIO_PIN(PD, 11)
/** @} */
/**
* @name Macros for controlling the on-board LEDs
* @{
*/
#define LED0_ON gpio_set(LED0_PIN)
#define LED0_OFF gpio_clear(LED0_PIN)
#define LED0_TOGGLE gpio_toggle(LED0_PIN)
#define LED1_ON gpio_set(LED1_PIN)
#define LED1_OFF gpio_clear(LED1_PIN)
#define LED1_TOGGLE gpio_toggle(LED1_PIN)
/** @} */
/**
* @name Core temperature sensor configuration
*
* Connection to the on-chip temperature sensor.
* @{
*/
#define CORETEMP_ADC ADC_LINE(0)
/** @} */
/**
* @name Environmental sensors configuration
*
* Pin for enabling environmental sensors (BMP280, Si1133, Si7021, Si7210).
* @{
*/
#define ENV_SENSE_PIC_ADDR (0x01)
#define ENV_SENSE_PIC_BIT (0)
/** @} */
/**
* @name Pressure sensor configuration
*
* Connection to the on-board pressure sensor (BMP280).
* @{
*/
#define BMP280_I2C I2C_DEV(0)
#define BMX280_PARAM_I2C_DEV BMP280_I2C
/** @} */
/**
* @name Air quality/gas sensor configuration
*
* Connection to the on-board air quality/gas sensor (CCS811).
* @{
*/
2020-06-28 22:42:32 +02:00
#define CCS811_I2C I2C_DEV(0)
#define CCS811_PIC_ADDR (0x03)
#define CCS811_PIC_EN_BIT (0x00)
#define CCS811_PIC_WAKE_BIT (0x01)
#define CCS811_PARAM_I2C_DEV CCS811_I2C
/** @} */
/**
* @name IMU sensor configuration
*
* Connection to the on-board IMU sensor (ICM-20648).
* @{
*/
#ifndef ICM20648_ENABLED
2020-11-03 13:10:05 +01:00
#define ICM20648_ENABLED 0
#endif
#define ICM20648_SPI SPI_DEV(0)
#define ICM20648_PIC_ADDR (0x00)
#define ICM20648_PIC_EN_BIT (0x00)
/** @} */
/**
* @name Power and Interrupt controller
*
* Pin for communication with the Power and Interrupt Controller.
* @{
*/
#define PIC_INT_WAKE_PIN GPIO_PIN(PD, 10)
#define PIC_I2C I2C_DEV(0)
#define PIC_I2C_ADDR (0x48)
/** @} */
/**
* @name RGB leds configuration
*
* There are four RGB leds on the board.
* @{
*/
#ifndef RGB_LED1_ENABLED
2020-11-03 13:10:05 +01:00
#define RGB_LED1_ENABLED 1
#endif
#ifndef RGB_LED2_ENABLED
2020-11-03 13:10:05 +01:00
#define RGB_LED2_ENABLED 1
#endif
#ifndef RGB_LED3_ENABLED
2020-11-03 13:10:05 +01:00
#define RGB_LED3_ENABLED 1
#endif
#ifndef RGB_LED4_ENABLED
2020-11-03 13:10:05 +01:00
#define RGB_LED4_ENABLED 1
#endif
#define RGB_LED_ADDR (0x04)
#define RGB_LED_EN_BIT (0x00)
#define RGB_LED1_EN_BIT (0x07)
#define RGB_LED2_EN_BIT (0x06)
#define RGB_LED3_EN_BIT (0x05)
#define RGB_LED4_EN_BIT (0x04)
/** @} */
/**
* @name UV/Ambient sensor configuration
*
* Connection to the on-board UV/ambient light sensor (Si1133).
* @{
*/
#ifndef SI1133_ENABLED
2020-11-03 13:10:05 +01:00
#define SI1133_ENABLED 0
#endif
#define SI1133_I2C I2C_DEV(0)
/** @} */
/**
* @name Temperature sensor configuration
*
* Connection to the on-board temperature/humidity sensor (Si7021).
* @{
*/
#define SI7021_I2C I2C_DEV(0)
#define SI70XX_PARAM_I2C_DEV SI7021_I2C
/** @} */
/**
* @name Hall-effect sensor configuration
*
* Connection to the on-board hall-effect sensor (Si7210). Available on
* Rev. A02 boards only.
* @{
*/
#ifndef SI7210_ENABLED
2020-11-03 13:10:05 +01:00
#define SI7210_ENABLED 0
#endif
#define SI7210_I2C I2C_DEV(0)
/** @} */
/**
* @brief Initialize the board (GPIO, sensors, clocks).
*/
void board_init(void);
#ifdef __cplusplus
}
#endif
#endif /* BOARD_H */
/** @} */