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

166 lines
4.2 KiB
C
Raw Normal View History

2014-06-11 14:59:24 +02:00
/*
* Copyright (C) 2014-2015 Freie Universität Berlin
2014-06-11 14:59:24 +02:00
*
* This file is subject to the terms and conditions of the GNU Lesser General
2014-07-03 10:36:46 +02:00
* Public License v2.1. See the file LICENSE in the top level directory for more
2014-06-11 14:59:24 +02:00
* details.
*/
/**
2015-08-19 20:59:06 +02:00
* @defgroup boards_iotlab-m3 IoT-LAB M3 open node
2014-06-11 14:59:24 +02:00
* @ingroup boards
2015-08-19 20:59:06 +02:00
* @brief Board specific files for the iotlab-m3 board.
2014-06-11 14:59:24 +02:00
* @{
*
* @file
2015-08-19 20:59:06 +02:00
* @brief Board specific definitions for the iotlab-m3 board.
2014-06-11 14:59:24 +02:00
*
* @author Alaeddine Weslati <alaeddine.weslati@inria.fr>
* @author Thomas Eichinger <thomas.eichinger@fu-berlin.de>
* @author Oliver Hahm <oliver.hahm@inria.fr>
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
*/
#ifndef BOARD_H_
#define BOARD_H_
#include <stdint.h>
#include "cpu.h"
#include "periph_conf.h"
2014-06-11 14:59:24 +02:00
#ifdef __cplusplus
extern "C" {
#endif
2014-06-11 14:59:24 +02:00
/**
* @name Define the nominal CPU core clock in this board
2014-06-11 14:59:24 +02:00
*/
#define F_CPU CLOCK_CORECLOCK
2014-06-11 14:59:24 +02:00
/**
* @name Define the UART to be used as stdio, its baudrate, and the size of
* receiving ringbuffer
2014-06-11 14:59:24 +02:00
* @{
*/
#define STDIO UART_0
#ifndef STDIO_BAUDRATE
# define STDIO_BAUDRATE (500000U)
#endif
#define STDIO_RX_BUFSIZE (64U)
2014-06-11 14:59:24 +02:00
/** @} */
/**
* @name Define the interface to the AT86RF231 radio
*
* {spi bus, spi speed, cs pin, int pin, reset pin, sleep pin}
*/
#define AT86RF2XX_PARAMS_BOARD {.spi = SPI_0, \
.spi_speed = SPI_SPEED_5MHZ, \
.cs_pin = GPIO_PIN(PORT_A, 4), \
.int_pin = GPIO_PIN(PORT_C, 4), \
.sleep_pin = GPIO_PIN(PORT_A, 2), \
.reset_pin = GPIO_PIN(PORT_C, 1)}
/**
* @name Define the interface for the connected flash memory
* @{
*/
#define EXTFLASH_SPI SPI_1
2015-09-15 11:45:21 +02:00
#define EXTFLASH_CS GPIO_PIN(PORT_A,11)
#define EXTFLASH_WRITE GPIO_PIN(PORT_C,6)
#define EXTFLASH_HOLD GPIO_PIN(PORT_C,9)
/** @} */
/**
* @name Define the interface to the ISL29020 light sensor
* @{
*/
#define ISL29020_I2C I2C_0
#define ISL29020_ADDR 0x44
/** @} */
/**
* @name Define the interface to the LPS331AP pressure sensor
* @{
*/
#define LPS331AP_I2C I2C_0
#define LPS331AP_ADDR 0x5c
/** @} */
/**
* @name Define the interface for the L3G4200D gyroscope
* @{
*/
#define L3G4200D_I2C I2C_0
#define L3G4200D_ADDR 0x68
2015-09-15 11:45:21 +02:00
#define L3G4200D_DRDY GPIO_PIN(PORT_C,0)
#define L3G4200D_INT GPIO_PIN(PORT_C,5)
/** @} */
/**
* @name Define the interface to the LSM303DLHC accelerometer and magnetometer
* @{
*/
#define LSM303DLHC_I2C I2C_0
#define LSM303DLHC_ACC_ADDR (0x19)
#define LSM303DLHC_MAG_ADDR (0x1e)
2015-09-15 11:45:21 +02:00
#define LSM303DLHC_INT1 GPIO_PIN(PORT_B,12)
#define LSM303DLHC_INT2 GPIO_PIN(PORT_B,1)
#define LSM303DLHC_DRDY GPIO_PIN(PORT_B,2)
/** @} */
2014-06-11 14:59:24 +02:00
/**
* @name LED pin definitions
* @{
*/
2014-07-03 10:36:46 +02:00
#define LED_RED_PORT (GPIOD)
#define LED_RED_PIN (2)
2015-09-15 11:45:21 +02:00
#define LED_RED_GPIO GPIO_PIN(PORT_D,2)
2014-07-03 10:36:46 +02:00
#define LED_GREEN_PORT (GPIOB)
#define LED_GREEN_PIN (5)
2015-09-15 11:45:21 +02:00
#define LED_GREEN_GPIO GPIO_PIN(PORT_B,5)
2014-07-03 10:36:46 +02:00
#define LED_ORANGE_PORT (GPIOC)
#define LED_ORANGE_PIN (10)
2015-09-15 11:45:21 +02:00
#define LED_ORANGE_GPIO GPIO_PIN(PORT_C,10)
2014-06-11 14:59:24 +02:00
/** @} */
/**
* @name Macros for controlling the on-board LEDs.
* @{
*/
2014-07-03 10:36:46 +02:00
#define LED_RED_ON (LED_RED_PORT->ODR &= ~(1<<LED_RED_PIN))
#define LED_RED_OFF (LED_RED_PORT->ODR |= (1<<LED_RED_PIN))
#define LED_RED_TOGGLE (LED_RED_PORT->ODR ^= (1<<LED_RED_PIN))
2014-06-11 14:59:24 +02:00
2014-07-03 10:36:46 +02:00
#define LED_GREEN_ON (LED_GREEN_PORT->ODR &= ~(1<<LED_GREEN_PIN))
#define LED_GREEN_OFF (LED_GREEN_PORT->ODR |= (1<<LED_GREEN_PIN))
#define LED_GREEN_TOGGLE (LED_GREEN_PORT->ODR ^= (1<<LED_GREEN_PIN))
2014-06-11 14:59:24 +02:00
2014-07-03 10:36:46 +02:00
#define LED_ORANGE_ON (LED_ORANGE_PORT->ODR &= ~(1<<LED_ORANGE_PIN))
#define LED_ORANGE_OFF (LED_ORANGE_PORT->ODR |= (1<<LED_ORANGE_PIN))
#define LED_ORANGE_TOGGLE (LED_ORANGE_PORT->ODR ^= (1<<LED_ORANGE_PIN))
2014-06-11 14:59:24 +02:00
/** @} */
/**
* @name xtimer tuning values
* @{
*/
#define XTIMER_OVERHEAD 6
#define XTIMER_SHOOT_EARLY 3
/** @} */
2014-06-11 14:59:24 +02:00
/**
* @brief Initialize board specific hardware, including clock, LEDs and std-IO
*/
void board_init(void);
#ifdef __cplusplus
}
#endif
2014-06-11 14:59:24 +02:00
#endif /* BOARD_H_ */
/** @} */