2014-09-17 15:08:57 +02:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2014 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.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2015-02-12 13:54:34 +01:00
|
|
|
* @defgroup boards_spark-core Spark-Core
|
2014-09-17 15:08:57 +02:00
|
|
|
* @ingroup boards
|
|
|
|
* @brief Board specific files for the spark-core board.
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file
|
|
|
|
* @brief Board specific definitions for the spark-core board.
|
|
|
|
*
|
|
|
|
* @author Christian Mehlis <mehlis@inf.fu-berlin.de>
|
|
|
|
*/
|
|
|
|
|
2017-01-18 13:00:05 +01:00
|
|
|
#ifndef BOARD_H
|
|
|
|
#define BOARD_H
|
2014-09-17 15:08:57 +02:00
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
#include "cpu.h"
|
|
|
|
#include "periph_conf.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name Define the location of the RIOT image in flash
|
|
|
|
*/
|
|
|
|
#define LOCATION_VTABLE (0x08005000)
|
|
|
|
|
2016-03-01 14:10:15 +01:00
|
|
|
/**
|
|
|
|
* @name Tell the xtimer that we use a 16-bit peripheral timer
|
|
|
|
*/
|
2016-05-06 22:10:52 +02:00
|
|
|
#define XTIMER_WIDTH (16)
|
2016-03-01 14:10:15 +01:00
|
|
|
|
2014-09-17 15:08:57 +02:00
|
|
|
/**
|
2016-03-11 18:04:26 +01:00
|
|
|
* @brief Macros for controlling the on-board LEDs
|
2014-09-17 15:08:57 +02:00
|
|
|
* @{
|
|
|
|
*/
|
2016-03-11 18:04:26 +01:00
|
|
|
#define LED0_PIN GPIO_PIN(PORT_A, 9)
|
|
|
|
#define LED1_PIN GPIO_PIN(PORT_A, 10)
|
|
|
|
#define LED2_PIN GPIO_PIN(PORT_A, 8)
|
|
|
|
#define LED3_PIN GPIO_PIN(PORT_A, 13)
|
|
|
|
|
2014-09-17 15:08:57 +02:00
|
|
|
#define LED_PORT (GPIOA)
|
2016-03-11 18:04:26 +01:00
|
|
|
#define LED0_MASK (1 << 9)
|
|
|
|
#define LED1_MASK (1 << 10)
|
|
|
|
#define LED2_MASK (1 << 8)
|
|
|
|
#define LED3_MASK (1 << 13)
|
2014-09-17 15:08:57 +02:00
|
|
|
|
2016-03-11 18:04:26 +01:00
|
|
|
#define LED0_ON (LED_PORT->BRR = LED0_MASK)
|
|
|
|
#define LED0_OFF (LED_PORT->BSRR = LED0_MASK)
|
|
|
|
#define LED0_TOGGLE (LED_PORT->ODR ^= LED0_MASK)
|
|
|
|
|
|
|
|
#define LED1_ON (LED_PORT->BRR = LED1_MASK)
|
|
|
|
#define LED1_OFF (LED_PORT->BSRR = LED1_MASK)
|
|
|
|
#define LED1_TOGGLE (LED_PORT->ODR ^= LED1_MASK)
|
|
|
|
|
|
|
|
#define LED2_ON (LED_PORT->BRR = LED2_MASK)
|
|
|
|
#define LED2_OFF (LED_PORT->BSRR = LED2_MASK)
|
|
|
|
#define LED2_TOGGLE (LED_PORT->ODR ^= LED2_MASK)
|
|
|
|
|
|
|
|
#define LED3_ON (LED_PORT->BRR = LED3_MASK)
|
|
|
|
#define LED3_OFF (LED_PORT->BSRR = LED3_MASK)
|
|
|
|
#define LED3_TOGGLE (LED_PORT->ODR ^= LED3_MASK)
|
2014-09-17 15:08:57 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name User button configuration
|
|
|
|
*/
|
2015-09-15 11:45:21 +02:00
|
|
|
#define BUTTON1 GPIO_PIN(PORT_B,2)
|
2014-09-17 15:08:57 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @name CC3000 pin configuration
|
|
|
|
* @{
|
|
|
|
*/
|
2016-11-08 18:28:32 +01:00
|
|
|
#define CC3000_SPI SPI_DEV(0)
|
2015-09-15 11:45:21 +02:00
|
|
|
#define CC3000_CS GPIO_PIN(PORT_B,12)
|
|
|
|
#define CC3000_EN GPIO_PIN(PORT_B,8)
|
|
|
|
#define CC3000_INT GPIO_PIN(PORT_B,11)
|
2014-09-17 15:08:57 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @name EXTFLASH pin configuration
|
|
|
|
* @{
|
|
|
|
*/
|
2016-11-08 18:28:32 +01:00
|
|
|
#define EXTFLASH_SPI SPI_DEV(0)
|
2015-09-15 11:45:21 +02:00
|
|
|
#define EXTFLASH GPIO_PIN(PORT_B,9)
|
2014-09-17 15:08:57 +02:00
|
|
|
/** @} */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize board specific hardware, including clock, LEDs and std-IO
|
|
|
|
*/
|
|
|
|
void board_init(void);
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
} /* end extern "C" */
|
|
|
|
#endif
|
|
|
|
|
2017-01-18 13:00:05 +01:00
|
|
|
#endif /* BOARD_H */
|
2014-09-17 15:08:57 +02:00
|
|
|
/** @} */
|