mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
Kaspar Schleiser
a134693918
our implementation of stm32f1 uses two 16bit timers to emulate one 32bit timer. This commit makes the timer maximum value definitions match the timers.
323 lines
12 KiB
C
323 lines
12 KiB
C
/*
|
|
* 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.
|
|
*/
|
|
|
|
/**
|
|
* @ingroup boards_iot-lab_M3
|
|
* @{
|
|
*
|
|
* @file
|
|
* @brief Peripheral MCU configuration for the iot-lab_M3 board
|
|
*
|
|
* @author Thomas Eichinger <thomas.eichinger@fu-berlin.de>
|
|
* @author Hauke Petersen <hauke.petersen@fu-berlin.de>
|
|
*/
|
|
|
|
#ifndef PERIPH_CONF_H_
|
|
#define PERIPH_CONF_H_
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @name Clock system configuration
|
|
* @{
|
|
**/
|
|
#define CLOCK_HSE (16000000U) /* frequency of external oscillator */
|
|
#define CLOCK_CORECLOCK (72000000U) /* targeted core clock frequency */
|
|
/* configuration of PLL prescaler and multiply values */
|
|
/* CORECLOCK := HSE / PLL_HSE_DIV * PLL_HSE_MUL */
|
|
#define CLOCK_PLL_HSE_DIV RCC_CFGR_PLLXTPRE_HSE_Div2
|
|
#define CLOCK_PLL_HSE_MUL RCC_CFGR_PLLMULL9
|
|
/* configuration of peripheral bus clock prescalers */
|
|
#define CLOCK_AHB_DIV RCC_CFGR_HPRE_DIV1 /* AHB clock -> 72MHz */
|
|
#define CLOCK_APB2_DIV RCC_CFGR_PPRE2_DIV1 /* APB2 clock -> 72MHz */
|
|
#define CLOCK_APB1_DIV RCC_CFGR_PPRE1_DIV2 /* APB1 clock -> 36MHz */
|
|
/* configuration of flash access cycles */
|
|
#define CLOCK_FLASH_LATENCY FLASH_ACR_LATENCY_2
|
|
/** @} */
|
|
|
|
/**
|
|
* @brief Timer configuration
|
|
* @{
|
|
*/
|
|
#define TIMER_NUMOF (2U)
|
|
#define TIMER_0_EN 1
|
|
#define TIMER_1_EN 1
|
|
|
|
/* Timer 0 configuration */
|
|
#define TIMER_0_DEV_0 TIM2
|
|
#define TIMER_0_DEV_1 TIM3
|
|
#define TIMER_0_CHANNELS 4
|
|
#define TIMER_0_PRESCALER (72U)
|
|
#define TIMER_0_MAX_VALUE (0xffffffff)
|
|
#define TIMER_0_CLKEN() (RCC->APB1ENR |= (RCC_APB1ENR_TIM2EN | RCC_APB1ENR_TIM3EN))
|
|
#define TIMER_0_ISR_0 isr_tim2
|
|
#define TIMER_0_ISR_1 isr_tim3
|
|
#define TIMER_0_IRQ_CHAN_0 TIM2_IRQn
|
|
#define TIMER_0_IRQ_CHAN_1 TIM3_IRQn
|
|
#define TIMER_0_IRQ_PRIO 1
|
|
#define TIMER_0_TRIG_SEL TIM_SMCR_TS_0
|
|
|
|
/* Timer 1 configuration */
|
|
#define TIMER_1_DEV_0 TIM4
|
|
#define TIMER_1_DEV_1 TIM5
|
|
#define TIMER_1_CHANNELS 4
|
|
#define TIMER_1_PRESCALER (72U)
|
|
#define TIMER_1_MAX_VALUE (0xffffffff)
|
|
#define TIMER_1_CLKEN() (RCC->APB1ENR |= (RCC_APB1ENR_TIM4EN | RCC_APB1ENR_TIM5EN))
|
|
#define TIMER_1_ISR_0 isr_tim4
|
|
#define TIMER_1_ISR_1 isr_tim5
|
|
#define TIMER_1_IRQ_CHAN_0 TIM4_IRQn
|
|
#define TIMER_1_IRQ_CHAN_1 TIM5_IRQn
|
|
#define TIMER_1_IRQ_PRIO 1
|
|
#define TIMER_1_TRIG_SEL TIM_SMCR_TS_1
|
|
/** @} */
|
|
|
|
/**
|
|
* @brief UART configuration
|
|
*/
|
|
#define UART_NUMOF (1U)
|
|
#define UART_0_EN 1
|
|
#define UART_1_EN 0
|
|
#define UART_IRQ_PRIO 1
|
|
|
|
/* UART 0 device configuration */
|
|
#define UART_0_DEV USART1
|
|
#define UART_0_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_USART1EN)
|
|
#define UART_0_IRQ USART1_IRQn
|
|
#define UART_0_ISR isr_usart1
|
|
#define UART_0_BUS_FREQ 72000000
|
|
/* UART 0 pin configuration */
|
|
#define UART_0_PORT GPIOA
|
|
#define UART_0_PORT_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPAEN)
|
|
#define UART_0_RX_PIN 10
|
|
#define UART_0_TX_PIN 9
|
|
#define UART_0_AF 0
|
|
|
|
/* UART 1 device configuration */
|
|
#define UART_1_DEV USART2
|
|
#define UART_1_CLKEN() (RCC->APB1ENR |= RCC_APB1ENR_USART2EN)
|
|
#define UART_1_IRQ USART2_IRQn
|
|
#define UART_1_ISR isr_usart2
|
|
#define UART_1_BUS_FREQ 36000000
|
|
/* UART 1 pin configuration */
|
|
#define UART_1_PORT GPIOA
|
|
#define UART_1_PORT_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPAEN)
|
|
#define UART_1_RX_PIN 3
|
|
#define UART_1_TX_PIN 2
|
|
#define UART_1_AF 1
|
|
|
|
/**
|
|
* @brief GPIO configuration
|
|
*/
|
|
#define GPIO_0_EN 1
|
|
#define GPIO_1_EN 1
|
|
#define GPIO_2_EN 1
|
|
#define GPIO_3_EN 1
|
|
#define GPIO_4_EN 1
|
|
#define GPIO_5_EN 1
|
|
#define GPIO_6_EN 1
|
|
#define GPIO_7_EN 1
|
|
#define GPIO_8_EN 1
|
|
#define GPIO_9_EN 1
|
|
#define GPIO_10_EN 1
|
|
#define GPIO_11_EN 1
|
|
#define GPIO_12_EN 1
|
|
#define GPIO_13_EN 1
|
|
#define GPIO_14_EN 1
|
|
#define GPIO_15_EN 1
|
|
#define GPIO_IRQ_PRIO 1
|
|
|
|
/**
|
|
* @brief IRQ config
|
|
*
|
|
* These defines are used for the backmapping in the matching interrupt
|
|
* service routines to call the correct callbacks.
|
|
* GPIO_IRQ_x where x matches the value defined by GPIO_y_PIN
|
|
*/
|
|
#define GPIO_IRQ_0 GPIO_4
|
|
#define GPIO_IRQ_1 GPIO_6
|
|
#define GPIO_IRQ_2 GPIO_7
|
|
#define GPIO_IRQ_3 GPIO_0
|
|
#define GPIO_IRQ_4 GPIO_12
|
|
#define GPIO_IRQ_5 GPIO_3
|
|
#define GPIO_IRQ_6 GPIO_9
|
|
#define GPIO_IRQ_9 GPIO_10
|
|
#define GPIO_IRQ_11 GPIO_8
|
|
#define GPIO_IRQ_12 GPIO_5
|
|
|
|
/* GPIO channel 0 config */
|
|
#define GPIO_0_PORT GPIOA /* user pin 1 */
|
|
#define GPIO_0_PIN 3
|
|
#define GPIO_0_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPAEN)
|
|
#define GPIO_0_EXTI_CFG() (AFIO->EXTICR[0] |= AFIO_EXTICR1_EXTI3_PA)
|
|
#define GPIO_0_IRQ EXTI3_IRQn
|
|
/* GPIO channel 1 config */
|
|
#define GPIO_1_PORT GPIOB /* user pin 2 */
|
|
#define GPIO_1_PIN 9
|
|
#define GPIO_1_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPBEN)
|
|
#define GPIO_1_EXTI_CFG() (AFIO->EXTICR[2] |= AFIO_EXTICR3_EXTI9_PB)
|
|
#define GPIO_1_IRQ EXTI9_5_IRQn
|
|
/* GPIO channel 2 config */
|
|
#define GPIO_2_PORT GPIOC /* user pin 3, DO NOT USE AS EXTI */
|
|
#define GPIO_2_PIN 11
|
|
#define GPIO_2_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPCEN)
|
|
#define GPIO_2_EXTI_CFG() (AFIO->EXTICR[2] |= AFIO_EXTICR3_EXTI11_PC)
|
|
#define GPIO_2_IRQ EXTI15_10_IRQn
|
|
/* GPIO channel 3 config */
|
|
#define GPIO_3_PORT GPIOC /* l3g4200d: int1 */
|
|
#define GPIO_3_PIN 5
|
|
#define GPIO_3_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPCEN)
|
|
#define GPIO_3_EXTI_CFG() (AFIO->EXTICR[1] |= AFIO_EXTICR2_EXTI5_PC)
|
|
#define GPIO_3_IRQ EXTI9_5_IRQn
|
|
/* GPIO channel 4 config */
|
|
#define GPIO_4_PORT GPIOC /* l3g4200d: int2/drdy */
|
|
#define GPIO_4_PIN 0
|
|
#define GPIO_4_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPCEN)
|
|
#define GPIO_4_EXTI_CFG() (AFIO->EXTICR[0] |= AFIO_EXTICR1_EXTI0_PC)
|
|
#define GPIO_4_IRQ EXTI0_IRQn
|
|
/* GPIO channel 5 config */
|
|
#define GPIO_5_PORT GPIOB /* lsm303dlhc: int1 */
|
|
#define GPIO_5_PIN 12
|
|
#define GPIO_5_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPBEN)
|
|
#define GPIO_5_EXTI_CFG() (AFIO->EXTICR[3] |= AFIO_EXTICR4_EXTI12_PB)
|
|
#define GPIO_5_IRQ EXTI15_10_IRQn
|
|
/* GPIO channel 6 config */
|
|
#define GPIO_6_PORT GPIOB /* lsm303dlhc: int2 */
|
|
#define GPIO_6_PIN 1
|
|
#define GPIO_6_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPBEN)
|
|
#define GPIO_6_EXTI_CFG() (AFIO->EXTICR[0] |= AFIO_EXTICR1_EXTI1_PB)
|
|
#define GPIO_6_IRQ EXTI1_IRQn
|
|
/* GPIO channel 7 config */
|
|
#define GPIO_7_PORT GPIOB /* lsm303dlhc: drdy */
|
|
#define GPIO_7_PIN 2
|
|
#define GPIO_7_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPBEN)
|
|
#define GPIO_7_EXTI_CFG() (AFIO->EXTICR[0] |= AFIO_EXTICR1_EXTI2_PB)
|
|
#define GPIO_7_IRQ EXTI2_IRQn
|
|
/* GPIO channel 8 config */
|
|
#define GPIO_8_PORT GPIOA /* flash: cs */
|
|
#define GPIO_8_PIN 11
|
|
#define GPIO_8_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPAEN)
|
|
#define GPIO_8_EXTI_CFG() (AFIO->EXTICR[2] |= AFIO_EXTICR3_EXTI11_PA)
|
|
#define GPIO_8_IRQ EXTI15_10_IRQn
|
|
/* GPIO channel 9 config */
|
|
#define GPIO_9_PORT GPIOC /* flash: write */
|
|
#define GPIO_9_PIN 6
|
|
#define GPIO_9_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPCEN)
|
|
#define GPIO_9_EXTI_CFG() (AFIO->EXTICR[1] |= AFIO_EXTICR2_EXTI6_PC)
|
|
#define GPIO_9_IRQ EXTI9_5_IRQn
|
|
/* GPIO channel 10 config */
|
|
#define GPIO_10_PORT GPIOC /* flash: hold */
|
|
#define GPIO_10_PIN 9
|
|
#define GPIO_10_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPCEN)
|
|
#define GPIO_10_EXTI_CFG() (AFIO->EXTICR[2] |= AFIO_EXTICR3_EXTI9_PC)
|
|
#define GPIO_10_IRQ EXTI9_5_IRQn
|
|
/* GPIO channel 11 config */
|
|
#define GPIO_11_PORT GPIOA /* radio: cs */
|
|
#define GPIO_11_PIN 4
|
|
#define GPIO_11_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPAEN)
|
|
#define GPIO_11_EXTI_CFG() (AFIO->EXTICR[1] |= AFIO_EXTICR2_EXTI4_PA)
|
|
#define GPIO_11_IRQ EXTI4_IRQn
|
|
/* GPIO channel 12 config */
|
|
#define GPIO_12_PORT GPIOC /* radio: int */
|
|
#define GPIO_12_PIN 4
|
|
#define GPIO_12_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPCEN)
|
|
#define GPIO_12_EXTI_CFG() (AFIO->EXTICR[1] |= AFIO_EXTICR2_EXTI4_PC)
|
|
#define GPIO_12_IRQ EXTI4_IRQn
|
|
/* GPIO channel 13 config */
|
|
#define GPIO_13_PORT GPIOC /* radio: reset */
|
|
#define GPIO_13_PIN 1
|
|
#define GPIO_13_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPCEN)
|
|
#define GPIO_13_EXTI_CFG() (AFIO->EXTICR[0] |= AFIO_EXTICR1_EXTI1_PC)
|
|
#define GPIO_13_IRQ EXTI1_IRQn
|
|
/* GPIO channel 14 config */
|
|
#define GPIO_14_PORT GPIOA /* radio: sleep */
|
|
#define GPIO_14_PIN 2
|
|
#define GPIO_14_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPAEN)
|
|
#define GPIO_14_EXTI_CFG() (AFIO->EXTICR[0] |= AFIO_EXTICR1_EXTI2_PA)
|
|
#define GPIO_14_IRQ EXTI2_IRQn
|
|
/* GPIO channel 14 config */
|
|
#define GPIO_15_PORT GPIOC /* battery feedback */
|
|
#define GPIO_15_PIN 13
|
|
#define GPIO_15_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPCEN)
|
|
#define GPIO_15_EXTI_CFG() (AFIO->EXTICR[3] |= AFIO_EXTICR4_EXTI13_PC)
|
|
#define GPIO_15_IRQ EXTI15_10_IRQn
|
|
|
|
/**
|
|
* @brief SPI configuration
|
|
* @{
|
|
*/
|
|
#define SPI_NUMOF (1U)
|
|
#define SPI_0_EN 1
|
|
|
|
/* SPI 0 device configuration */
|
|
#define SPI_0_DEV SPI1
|
|
#define SPI_0_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_SPI1EN)
|
|
#define SPI_0_CLKDIS() (RCC->APB2ENR &= ~(RCC_APB2ENR_SPI1EN))
|
|
#define SPI_0_BUS_DIV 1 /* 1 -> SPI runs with full CPU clock, 0 -> half CPU clock */
|
|
/* SPI 0 pin configuration */
|
|
#define SPI_0_CLK_PORT GPIOA
|
|
#define SPI_0_CLK_PIN 5
|
|
#define SPI_0_CLK_PORT_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPAEN)
|
|
#define SPI_0_MOSI_PORT GPIOA
|
|
#define SPI_0_MOSI_PIN 7
|
|
#define SPI_0_MOSI_PORT_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPAEN)
|
|
#define SPI_0_MISO_PORT GPIOA
|
|
#define SPI_0_MISO_PIN 6
|
|
#define SPI_0_MISO_PORT_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPAEN)
|
|
/** @} */
|
|
|
|
/**
|
|
* @name Real time counter configuration
|
|
* @{
|
|
*/
|
|
#define RTT_NUMOF (1U)
|
|
#define RTT_IRQ_PRIO 1
|
|
|
|
#define RTT_DEV RTC
|
|
#define RTT_IRQ RTC_IRQn
|
|
#define RTT_ISR isr_rtc
|
|
#define RTT_MAX_VALUE (0xffffffff)
|
|
#define RTT_FREQUENCY (1) /* in Hz */
|
|
#define RTT_PRESCALER (0x7fff) /* run with 1 Hz */
|
|
/** @} */
|
|
|
|
/**
|
|
* @name I2C configuration
|
|
* @{
|
|
*/
|
|
#define I2C_NUMOF (1U)
|
|
#define I2C_0_EN 1
|
|
#define I2C_IRQ_PRIO 1
|
|
#define I2C_APBCLK (36000000U)
|
|
|
|
/* I2C 0 device configuration */
|
|
#define I2C_0_DEV I2C1
|
|
#define I2C_0_CLKEN() (RCC->APB1ENR |= RCC_APB1ENR_I2C1EN)
|
|
#define I2C_0_CLKDIS() (RCC->APB1ENR &= ~(RCC_APB1ENR_I2C1EN))
|
|
#define I2C_0_EVT_IRQ I2C1_EV_IRQn
|
|
#define I2C_0_EVT_ISR isr_i2c1_ev
|
|
#define I2C_0_ERR_IRQ I2C1_ER_IRQn
|
|
#define I2C_0_ERR_ISR isr_i2c1_er
|
|
/* I2C 0 pin configuration */
|
|
#define I2C_0_SCL_PORT GPIOB
|
|
#define I2C_0_SCL_PIN 6
|
|
#define I2C_0_SCL_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPBEN)
|
|
#define I2C_0_SDA_PORT GPIOB
|
|
#define I2C_0_SDA_PIN 7
|
|
#define I2C_0_SDA_CLKEN() (RCC->APB2ENR |= RCC_APB2ENR_IOPBEN)
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* PERIPH_CONF_H_ */
|
|
/** @} */
|