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
|
|
|
* @ingroup boards_spark-core
|
2014-09-17 15:08:57 +02:00
|
|
|
* @{
|
|
|
|
*
|
2015-02-12 13:54:34 +01:00
|
|
|
* @file
|
2014-09-17 15:08:57 +02:00
|
|
|
* @brief Board specific implementations for the spark-core board
|
|
|
|
*
|
|
|
|
* @author Christian Mehlis <mehlis@inf.fu-berlin.de>
|
|
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
|
|
*
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "board.h"
|
2016-03-11 18:04:26 +01:00
|
|
|
#include "periph/gpio.h"
|
2014-09-17 15:08:57 +02:00
|
|
|
|
|
|
|
void board_init(void)
|
|
|
|
{
|
2016-03-11 18:04:26 +01:00
|
|
|
/* initialize the boards LEDs */
|
2016-03-17 14:54:05 +01:00
|
|
|
gpio_init(LED0_PIN, GPIO_OUT);
|
|
|
|
gpio_init(LED1_PIN, GPIO_OUT);
|
|
|
|
gpio_init(LED2_PIN, GPIO_OUT);
|
|
|
|
gpio_init(LED3_PIN, GPIO_OUT);
|
2016-03-11 18:04:26 +01:00
|
|
|
gpio_set(LED0_PIN);
|
|
|
|
gpio_set(LED1_PIN);
|
|
|
|
gpio_set(LED2_PIN);
|
|
|
|
gpio_set(LED3_PIN);
|
|
|
|
|
2014-09-17 15:08:57 +02:00
|
|
|
/* initialize the CPU */
|
|
|
|
cpu_init();
|
|
|
|
/* disable systick interrupt, set by the spark bootloader */
|
|
|
|
SysTick->CTRL = 0;
|
|
|
|
/* signal to spark bootloader: do not enable IWDG! set Stop Mode Flag! */
|
|
|
|
BKP->DR9 = 0xAFFF;
|
|
|
|
/* configure the RIOT vector table location to internal flash + spark bootloader offset */
|
|
|
|
SCB->VTOR = LOCATION_VTABLE;
|
|
|
|
}
|