/* * Copyright (C) 2014 Freie Universität Berlin, Hinnerk van Bruinehsen * 2016 Laurent Navet * 2018 Matthew Blue * * 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. */ /* * @ingroup boards_mega-xplained * @brief Support for the Mega Xplained board. * @{ * * @file * @brief Board specific definitions for the Mega Xplained board. * * @author Hinnerk van Bruinehsen * @author Laurent Navet * @author Matthew Blue */ #ifndef BOARD_H #define BOARD_H #include "cpu.h" #include "periph_cpu.h" #include "mega-xplained_pinmap.h" #ifdef __cplusplus extern "C" { #endif /** * @name STDIO configuration * * As the CPU is too slow to handle 115200 baud, we set the default * baudrate to 9600 for this board * @{ */ #ifndef UART_STDIO_BAUDRATE #define UART_STDIO_BAUDRATE (9600U) #endif /** @} */ /** * @brief Use the UART 1 for STDIO on this board */ #define UART_STDIO_DEV (UART_DEV(1)) /** * @name Context swap defines * * Setup to use PD7 which is pin change interrupt 31 (PCINT31) * This emulates a software triggered interrupt * @{ */ #define AVR_CONTEXT_SWAP_INIT do { \ DDRD |= (1 << PD7); \ PCICR |= (1 << PCIE3); \ PCMSK3 |= (1 << PCINT31); \ } while (0) #define AVR_CONTEXT_SWAP_INTERRUPT_VECT PCINT3_vect #define AVR_CONTEXT_SWAP_TRIGGER PORTD ^= (1 << PD7) /** @} */ /** * @name xtimer configuration values * * Xtimer runs at 8MHz / 64 = 125kHz * @{ */ #define XTIMER_DEV (0) #define XTIMER_CHAN (0) #define XTIMER_WIDTH (16) #define XTIMER_HZ (125000UL) #define XTIMER_BACKOFF (40) /** @} */ /** * @name LED pin definitions * @{ */ /* LED0,2 currently unsupported due to lack of GPIO_OD support */ #define LED1_PIN GPIO_PIN(PORT_B, 3) #define LED1_MODE GPIO_OUT #define LED3_PIN GPIO_PIN(PORT_B, 2) #define LED3_MODE GPIO_OUT /** @} */ /** * @name Macros for controlling the on-board LEDs * @{ */ /* LED0,2 currently unsupported due to lack of GPIO_OD support */ #define LED1_ENABLE_PORT DDRB |= LED1_PIN #define LED1_ON PORTB |= LED1_PIN #define LED1_OFF PORTB &= ~LED1_PIN #define LED1_TOGGLE PORTB ^= LED1_PIN #define LED3_ENABLE_PORT DDRB |= LED3_PIN #define LED3_ON PORTB |= LED3_PIN #define LED3_OFF PORTB &= ~LED3_PIN #define LED3_TOGGLE PORTB ^= LED3_PIN /** @} */ /** * @name Button pin configuration * @{ */ #define BTN0_PIN GPIO_PIN(PORT_B, 0) #define BTN0_MODE GPIO_IN #define BTN1_PIN GPIO_PIN(PORT_B, 1) #define BTN1_MODE GPIO_IN /* BTN2 currently unsupported due to lack of GPIO_OD support */ /** * @name ADC NTC, light sensor, and filter lines * @{ */ #define NTC_OUTPUT GPIO_PIN(PORT_A, 5) #define LIGHT_SENSOR_OUTPUT GPIO_PIN(PORT_A, 6) #define FILTER_OUTPUT GPIO_PIN(PORT_A, 7) /** @} */ /** * @brief Initialize board specific hardware, including clock, LEDs and std-IO */ void board_init(void); #ifdef __cplusplus } #endif #endif /* BOARD_H */ /** @} */