2020-04-26 12:41:20 +10:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2017 I-SENSE group of ICCS
|
|
|
|
*
|
2020-06-09 23:54:13 +10:00
|
|
|
* SPDX-License-Identifier: MIT
|
2020-04-26 12:41:20 +10:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include <kernel.h>
|
|
|
|
#include <device.h>
|
|
|
|
#include <init.h>
|
|
|
|
#include <drivers/pinmux.h>
|
|
|
|
#include <sys/sys_io.h>
|
|
|
|
|
|
|
|
#include <pinmux/stm32/pinmux_stm32.h>
|
|
|
|
|
|
|
|
/* pin assignments for STM32F3DISCOVERY board */
|
|
|
|
static const struct pin_config pinconf[] = {
|
|
|
|
#ifdef CONFIG_UART_1
|
2020-09-14 12:53:24 +10:00
|
|
|
{STM32_PIN_PC4, STM32F3_PINMUX_FUNC_PC4_USART1_TX},
|
|
|
|
{STM32_PIN_PC5, STM32F3_PINMUX_FUNC_PC5_USART1_RX},
|
2020-06-09 23:54:13 +10:00
|
|
|
#endif /* CONFIG_UART_1 */
|
2020-04-26 12:41:20 +10:00
|
|
|
#ifdef CONFIG_UART_2
|
2020-09-14 12:53:24 +10:00
|
|
|
{STM32_PIN_PA2, STM32F3_PINMUX_FUNC_PA2_USART2_TX},
|
|
|
|
{STM32_PIN_PA3, STM32F3_PINMUX_FUNC_PA3_USART2_RX},
|
2020-06-09 23:54:13 +10:00
|
|
|
#endif /* CONFIG_UART_2 */
|
2020-04-26 12:41:20 +10:00
|
|
|
#ifdef CONFIG_I2C_1
|
2020-09-14 12:53:24 +10:00
|
|
|
{STM32_PIN_PB6, STM32F3_PINMUX_FUNC_PB6_I2C1_SCL},
|
|
|
|
{STM32_PIN_PB7, STM32F3_PINMUX_FUNC_PB7_I2C1_SDA},
|
2020-04-26 12:41:20 +10:00
|
|
|
#endif /* CONFIG_I2C_1 */
|
|
|
|
#ifdef CONFIG_I2C_2
|
2020-09-14 12:53:24 +10:00
|
|
|
{STM32_PIN_PA9, STM32F3_PINMUX_FUNC_PA9_I2C2_SCL},
|
|
|
|
{STM32_PIN_PA10, STM32F3_PINMUX_FUNC_PA10_I2C2_SDA},
|
2020-04-26 12:41:20 +10:00
|
|
|
#endif /* CONFIG_I2C_2 */
|
|
|
|
#ifdef CONFIG_SPI_1
|
|
|
|
#ifdef CONFIG_SPI_STM32_USE_HW_SS
|
2020-09-14 12:53:24 +10:00
|
|
|
{STM32_PIN_PA4, STM32F3_PINMUX_FUNC_PA4_SPI1_NSS},
|
2020-04-26 12:41:20 +10:00
|
|
|
#endif /* CONFIG_SPI_STM32_USE_HW_SS */
|
2020-09-14 12:53:24 +10:00
|
|
|
{STM32_PIN_PA5, STM32F3_PINMUX_FUNC_PA5_SPI1_SCK},
|
|
|
|
{STM32_PIN_PA6, STM32F3_PINMUX_FUNC_PA6_SPI1_MISO},
|
|
|
|
{STM32_PIN_PA7, STM32F3_PINMUX_FUNC_PA7_SPI1_MOSI},
|
2020-04-26 12:41:20 +10:00
|
|
|
#endif /* CONFIG_SPI_1 */
|
|
|
|
#ifdef CONFIG_SPI_2
|
|
|
|
#ifdef CONFIG_SPI_STM32_USE_HW_SS
|
2020-09-14 12:53:24 +10:00
|
|
|
{STM32_PIN_PB12, STM32F3_PINMUX_FUNC_PB12_SPI2_NSS},
|
2020-04-26 12:41:20 +10:00
|
|
|
#endif /* CONFIG_SPI_STM32_USE_HW_SS */
|
2020-09-14 12:53:24 +10:00
|
|
|
{STM32_PIN_PB13, STM32F3_PINMUX_FUNC_PB13_SPI2_SCK},
|
|
|
|
{STM32_PIN_PB14, STM32F3_PINMUX_FUNC_PB14_SPI2_MISO},
|
|
|
|
{STM32_PIN_PB15, STM32F3_PINMUX_FUNC_PB15_SPI2_MOSI},
|
2020-04-26 12:41:20 +10:00
|
|
|
#endif /* CONFIG_SPI_2 */
|
|
|
|
#ifdef CONFIG_USB_DC_STM32
|
2020-09-14 12:53:24 +10:00
|
|
|
{STM32_PIN_PA11, STM32F3_PINMUX_FUNC_PA11_USB_DM},
|
|
|
|
{STM32_PIN_PA12, STM32F3_PINMUX_FUNC_PA12_USB_DP},
|
2020-06-09 23:54:13 +10:00
|
|
|
#endif /* CONFIG_USB_DC_STM32 */
|
2020-04-26 12:41:20 +10:00
|
|
|
#ifdef CONFIG_CAN_1
|
2020-09-14 12:53:24 +10:00
|
|
|
{STM32_PIN_PD0, STM32F3_PINMUX_FUNC_PD0_CAN1_RX},
|
|
|
|
{STM32_PIN_PD1, STM32F3_PINMUX_FUNC_PD1_CAN1_TX},
|
2020-04-26 12:41:20 +10:00
|
|
|
#endif /* CONFIG_CAN_1 */
|
|
|
|
};
|
|
|
|
|
2020-09-14 12:53:24 +10:00
|
|
|
static int pinmux_stm32_init(struct device *port) {
|
|
|
|
ARG_UNUSED(port);
|
2020-04-26 12:41:20 +10:00
|
|
|
|
2020-09-14 12:53:24 +10:00
|
|
|
stm32_setup_pins(pinconf, ARRAY_SIZE(pinconf));
|
2020-04-26 12:41:20 +10:00
|
|
|
|
2020-09-14 12:53:24 +10:00
|
|
|
return 0;
|
2020-04-26 12:41:20 +10:00
|
|
|
}
|
|
|
|
|
2020-09-14 12:53:24 +10:00
|
|
|
SYS_INIT(pinmux_stm32_init, PRE_KERNEL_1, CONFIG_PINMUX_STM32_DEVICE_INITIALIZATION_PRIORITY);
|