/* * Copyright (C) 2014 Eistec AB * * 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. */ /** * @defgroup board_mulle Eistec Mulle * @ingroup boards * @brief Board specific files for Eistec Mulle IoT boards * @{ * * @file * @brief Board specific definitions for the Eistec Mulle IoT board * * @author Joakim NohlgÄrd */ #ifndef BOARD_H_ #define BOARD_H_ #include "cpu.h" #include "periph_conf.h" #include "mulle-nvram.h" /* Use the on board RTC 32kHz clock for LPTMR clocking. */ #undef LPTIMER_CLKSRC /** @brief Clock source for the LPTMR module */ #define LPTIMER_CLKSRC LPTIMER_CLKSRC_ERCLK32K /** Disable hardware watchdog, for debugging purposes, don't use this on production builds. */ #define DISABLE_WDOG 1 /** * @name Define UART device and baudrate for stdio * @{ */ #define STDIO UART_0 #define STDIO_BAUDRATE (115200U) #define STDIO_RX_BUFSIZE (64U) /** @} */ /** * @name LEDs configuration * @{ */ #define LED_RED_PORT PTC #define LED_RED_PIN 15 #define LED_RED_GPIO GPIO_PIN(PORT_C, LED_RED_PIN) #define LED_YELLOW_PORT PTC #define LED_YELLOW_PIN 14 #define LED_YELLOW_GPIO GPIO_PIN(PORT_C, LED_YELLOW_PIN) #define LED_GREEN_PORT PTC #define LED_GREEN_PIN 13 #define LED_GREEN_GPIO GPIO_PIN(PORT_C, LED_GREEN_PIN) /** @} */ /** * @name Macros for controlling the on-board LEDs. * @{ */ #define LED_RED_ON (BITBAND_REG32(LED_RED_PORT->PSOR, LED_RED_PIN) = 1) #define LED_RED_OFF (BITBAND_REG32(LED_RED_PORT->PCOR, LED_RED_PIN) = 1) #define LED_RED_TOGGLE (BITBAND_REG32(LED_RED_PORT->PTOR, LED_RED_PIN) = 1) #define LED_YELLOW_ON (BITBAND_REG32(LED_YELLOW_PORT->PSOR, LED_YELLOW_PIN) = 1) #define LED_YELLOW_OFF (BITBAND_REG32(LED_YELLOW_PORT->PCOR, LED_YELLOW_PIN) = 1) #define LED_YELLOW_TOGGLE (BITBAND_REG32(LED_YELLOW_PORT->PTOR, LED_YELLOW_PIN) = 1) #define LED_GREEN_ON (BITBAND_REG32(LED_GREEN_PORT->PSOR, LED_GREEN_PIN) = 1) #define LED_GREEN_OFF (BITBAND_REG32(LED_GREEN_PORT->PCOR, LED_GREEN_PIN) = 1) #define LED_GREEN_TOGGLE (BITBAND_REG32(LED_GREEN_PORT->PTOR, LED_GREEN_PIN) = 1) /** @} */ #ifdef __cplusplus extern "C" { #endif /** * @brief Initialize board specific hardware, including clock, LEDs and std-IO */ void board_init(void); #ifdef __cplusplus } #endif /** * @name Define the interface to the AT86RF212B radio * @{ */ #define AT86RF231_SPI SPI_0 #define AT86RF231_CS GPIO_PIN(PORT_D, 4) #define AT86RF231_INT GPIO_PIN(PORT_B, 9) /** @todo work around missing RESET pin on Mulle v0.6x */ #define AT86RF231_RESET GPIO_PIN(PORT_C, 12) #define AT86RF231_SLEEP GPIO_PIN(PORT_E, 6) #define AT86RF231_SPI_CLK SPI_SPEED_5MHZ /** @} */ /** * @name LIS3DH configuration * @{ */ #define LIS3DH_INT1 GPIO_PIN(PORT_C, 18) #define LIS3DH_INT2 GPIO_PIN(PORT_C, 17) #define LIS3DH_CS GPIO_PIN(PORT_D, 0) #define LIS3DH_SPI SPI_2 /** @} */ /** * @name Mulle power control configuration */ /** @{ */ #define MULLE_POWER_AVDD GPIO_PIN(PORT_B, 17) /**< AVDD enable pin */ #define MULLE_POWER_VPERIPH GPIO_PIN(PORT_D, 7) /**< VPERIPH enable pin */ #define MULLE_POWER_VSEC GPIO_PIN(PORT_B, 16) /**< VSEC enable pin */ /** @} */ /** * @name Mulle NVRAM hardware configuration */ /** @{ */ /** FRAM SPI bus, SPI_2 in RIOT is mapped to hardware bus SPI0, see periph_conf.h */ #define MULLE_NVRAM_SPI_DEV SPI_2 #define MULLE_NVRAM_SPI_CS GPIO_PIN(PORT_D, 6) /**< FRAM CS pin */ #define MULLE_NVRAM_CAPACITY 512 /**< FRAM size, in bytes */ #define MULLE_NVRAM_SPI_ADDRESS_COUNT 1 /**< FRAM addressing size, in bytes */ /** @} */ /** * @name K60 clock dividers */ /** @{ */ /** * System clock divider setting, the actual hardware register value, see reference manual for details. */ #define CONFIG_CLOCK_K60_SYS_DIV 0x00 /** * Bus clock divider setting, the actual hardware register value, see reference manual for details */ #define CONFIG_CLOCK_K60_BUS_DIV 0x01 /** * Flexbus clock divider setting, the actual hardware register value, see reference manual for details */ #define CONFIG_CLOCK_K60_FB_DIV 0x01 /** * Flash clock divider setting, the actual hardware register value, see reference manual for details */ #define CONFIG_CLOCK_K60_FLASH_DIV 0x03 /** @} */ #endif /* BOARD_H_ */ /** @} */