mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
d37adee32d
There is no hardware limitation for custom boards based on STM32 to uses SPI bus with signals coming from different PORT and alternate functions. This patch allow alternate's function definition per pin basis, thus enable the support of SPI bus signals routed on differents PORT. Signed-off-by: Yannick Gicquel <ygicquel@gmail.com>
191 lines
4.8 KiB
C
191 lines
4.8 KiB
C
/*
|
|
* Copyright (C) 2016 Inria
|
|
*
|
|
* 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_nucleo-f411re
|
|
* @{
|
|
*
|
|
* @file
|
|
* @name Peripheral MCU configuration for the nucleo-f411re board
|
|
*
|
|
* @author Alexandre Abadie <alexandre.abadie@inria.fr>
|
|
*/
|
|
|
|
#ifndef PERIPH_CONF_H
|
|
#define PERIPH_CONF_H
|
|
|
|
#include "periph_cpu.h"
|
|
#include "f4/cfg_clock_96_8_1.h"
|
|
#include "cfg_i2c1_pb8_pb9.h"
|
|
#include "cfg_timer_tim5.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @name UART configuration
|
|
* @{
|
|
*/
|
|
static const uart_conf_t uart_config[] = {
|
|
{
|
|
.dev = USART2,
|
|
.rcc_mask = RCC_APB1ENR_USART2EN,
|
|
.rx_pin = GPIO_PIN(PORT_A,3),
|
|
.tx_pin = GPIO_PIN(PORT_A,2),
|
|
.rx_af = GPIO_AF7,
|
|
.tx_af = GPIO_AF7,
|
|
.bus = APB1,
|
|
.irqn = USART2_IRQn,
|
|
#ifdef UART_USE_DMA
|
|
.dma_stream = 6,
|
|
.dma_chan = 4
|
|
#endif
|
|
},
|
|
{
|
|
.dev = USART1,
|
|
.rcc_mask = RCC_APB2ENR_USART1EN,
|
|
.rx_pin = GPIO_PIN(PORT_A, 10),
|
|
.tx_pin = GPIO_PIN(PORT_A, 9),
|
|
.rx_af = GPIO_AF7,
|
|
.tx_af = GPIO_AF7,
|
|
.bus = APB2,
|
|
.irqn = USART1_IRQn,
|
|
#ifdef UART_USE_DMA
|
|
.dma_stream = 6,
|
|
.dma_chan = 3
|
|
#endif
|
|
},
|
|
{
|
|
.dev = USART6,
|
|
.rcc_mask = RCC_APB2ENR_USART6EN,
|
|
.rx_pin = GPIO_PIN(PORT_A, 12),
|
|
.tx_pin = GPIO_PIN(PORT_A, 11),
|
|
.rx_af = GPIO_AF8,
|
|
.tx_af = GPIO_AF8,
|
|
.bus = APB2,
|
|
.irqn = USART6_IRQn,
|
|
#ifdef UART_USE_DMA
|
|
.dma_stream = 6,
|
|
.dma_chan = 2
|
|
#endif
|
|
}
|
|
};
|
|
|
|
/* assign ISR vector names */
|
|
#define UART_0_ISR isr_usart2
|
|
#define UART_0_DMA_ISR isr_dma1_stream6
|
|
#define UART_1_ISR isr_usart1
|
|
#define UART_1_DMA_ISR isr_dma1_stream6
|
|
#define UART_2_ISR isr_usart6
|
|
#define UART_2_DMA_ISR isr_dma1_stream6
|
|
|
|
/* deduct number of defined UART interfaces */
|
|
#define UART_NUMOF ARRAY_SIZE(uart_config)
|
|
/** @} */
|
|
|
|
/** @name PWM configuration
|
|
* @{
|
|
*/
|
|
static const pwm_conf_t pwm_config[] = {
|
|
{
|
|
.dev = TIM2,
|
|
.rcc_mask = RCC_APB1ENR_TIM2EN,
|
|
.chan = { { .pin = GPIO_PIN(PORT_A, 15) , .cc_chan = 0 },
|
|
{ .pin = GPIO_PIN(PORT_B, 3) /* D3 */, .cc_chan = 1 },
|
|
{ .pin = GPIO_PIN(PORT_B, 10) /* D6 */, .cc_chan = 2 },
|
|
{ .pin = GPIO_UNDEF, .cc_chan = 0 } },
|
|
.af = GPIO_AF1,
|
|
.bus = APB1
|
|
},
|
|
{
|
|
.dev = TIM3,
|
|
.rcc_mask = RCC_APB1ENR_TIM3EN,
|
|
.chan = { { .pin = GPIO_PIN(PORT_B, 4) /* D5 */, .cc_chan = 0 },
|
|
{ .pin = GPIO_PIN(PORT_C, 7) /* D9 */, .cc_chan = 1 },
|
|
{ .pin = GPIO_PIN(PORT_C, 8), .cc_chan = 2 },
|
|
{ .pin = GPIO_PIN(PORT_C, 9), .cc_chan = 3 } },
|
|
.af = GPIO_AF2,
|
|
.bus = APB1
|
|
},
|
|
};
|
|
|
|
#define PWM_NUMOF ARRAY_SIZE(pwm_config)
|
|
/** @} */
|
|
|
|
/**
|
|
* @name SPI configuration
|
|
*
|
|
* @note The spi_divtable is auto-generated from
|
|
* `cpu/stm32_common/dist/spi_divtable/spi_divtable.c`
|
|
* @{
|
|
*/
|
|
static const uint8_t spi_divtable[2][5] = {
|
|
{ /* for APB1 @ 48000000Hz */
|
|
7, /* -> 187500Hz */
|
|
6, /* -> 375000Hz */
|
|
5, /* -> 750000Hz */
|
|
2, /* -> 6000000Hz */
|
|
1 /* -> 12000000Hz */
|
|
},
|
|
{ /* for APB2 @ 96000000Hz */
|
|
7, /* -> 375000Hz */
|
|
7, /* -> 375000Hz */
|
|
6, /* -> 750000Hz */
|
|
3, /* -> 6000000Hz */
|
|
2 /* -> 12000000Hz */
|
|
}
|
|
};
|
|
|
|
static const spi_conf_t spi_config[] = {
|
|
{
|
|
.dev = SPI1,
|
|
.mosi_pin = GPIO_PIN(PORT_A, 7),
|
|
.miso_pin = GPIO_PIN(PORT_A, 6),
|
|
.sclk_pin = GPIO_PIN(PORT_A, 5),
|
|
.cs_pin = GPIO_PIN(PORT_A, 4),
|
|
.mosi_af = GPIO_AF5,
|
|
.miso_af = GPIO_AF5,
|
|
.sclk_af = GPIO_AF5,
|
|
.cs_af = GPIO_AF5,
|
|
.rccmask = RCC_APB2ENR_SPI1EN,
|
|
.apbbus = APB2
|
|
}
|
|
};
|
|
|
|
#define SPI_NUMOF ARRAY_SIZE(spi_config)
|
|
/** @} */
|
|
|
|
/**
|
|
* @name ADC configuration
|
|
*
|
|
* Note that we do not configure all ADC channels,
|
|
* and not in the STM32F411 order. Instead, we
|
|
* just define 6 ADC channels, for the Nucleo
|
|
* Arduino header pins A0-A5
|
|
*
|
|
* @{
|
|
*/
|
|
#define ADC_NUMOF (6U)
|
|
#define ADC_CONFIG { \
|
|
{GPIO_PIN(PORT_A, 0), 0, 0}, \
|
|
{GPIO_PIN(PORT_A, 1), 0, 1}, \
|
|
{GPIO_PIN(PORT_A, 4), 0, 4}, \
|
|
{GPIO_PIN(PORT_B, 0), 0, 8}, \
|
|
{GPIO_PIN(PORT_C, 1), 0, 11}, \
|
|
{GPIO_PIN(PORT_C, 0), 0, 10}, \
|
|
}
|
|
/** @} */
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* PERIPH_CONF_H */
|
|
/** @} */
|