| /* |
| * Copyright (c) 2016 Linaro Limited. |
| * Copyright (c) 2019 Centaur Analytics, Inc |
| * |
| * SPDX-License-Identifier: Apache-2.0 |
| */ |
| |
| #ifndef ZEPHYR_DRIVERS_PINMUX_STM32_PINMUX_STM32F4_H_ |
| #define ZEPHYR_DRIVERS_PINMUX_STM32_PINMUX_STM32F4_H_ |
| |
| /** |
| * @file Header for STM32F4 pin multiplexing helper |
| */ |
| |
| /* |
| * Note: |
| * The SPIx_SCK pin speed must be set to VERY_HIGH to avoid last data bit |
| * corruption which is a known issue of STM32F4 SPI peripheral (see errata |
| * sheets). |
| */ |
| |
| /* Port A */ |
| #define STM32F4_PINMUX_FUNC_PA0_PWM2_CH1 \ |
| (STM32_PINMUX_ALT_FUNC_1 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA0_USART2_CTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA0_UART4_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA0_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PA0_ADC123_IN0 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PA1_I2S4_SD \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA1_USART2_RTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA1_UART4_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PA1_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PA1_ADC123_IN1 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PA2_USART2_TX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA2_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PA2_ADC123_IN2 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PA3_USART2_RX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PA3_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PA3_ADC123_IN3 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PA4_SPI1_NSS \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA4_I2S1_WS \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PA4_I2S3_WS \ |
| (STM32_PINMUX_ALT_FUNC_6 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PA4_ADC12_IN4 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PA5_SPI1_SCK \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PA5_I2S1_CK \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PA5_ADC12_IN5 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PA6_SPI1_MISO \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUPDR_PULL_DOWN) |
| #define STM32F4_PINMUX_FUNC_PA6_ADC12_IN6 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PA7_SPI1_MOSI \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUPDR_PULL_DOWN) |
| #define STM32F4_PINMUX_FUNC_PA7_I2S1_SD \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PA7_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PA7_ADC12_IN7 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PA8_MCO \ |
| (STM32_PINMUX_ALT_FUNC_0 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PA8_I2C3_SCL \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA8_UART7_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PA9_USART1_TX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PA10_USART1_RX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PA11_USART1_CTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA11_USART6_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA11_CAN1_RX \ |
| (STM32_PINMUX_ALT_FUNC_9 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA11_UART4_RX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PA11_OTG_FS_DM \ |
| (STM32_PINMUX_ALT_FUNC_10 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PA12_USART1_RTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA12_USART6_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PA12_CAN1_TX \ |
| (STM32_PINMUX_ALT_FUNC_9 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PA12_UART4_TX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA12_OTG_FS_DP \ |
| (STM32_PINMUX_ALT_FUNC_10 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PA15_USART1_TX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PA15_UART7_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| |
| /* Port B */ |
| #define STM32F4_PINMUX_FUNC_PB0_I2S5_CK \ |
| (STM32_PINMUX_ALT_FUNC_6 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PB0_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PB0_ADC12_IN8 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PB1_ADC12_IN9 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PB3_I2S3_CK \ |
| (STM32_PINMUX_ALT_FUNC_6 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PB3_USART1_RX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB3_UART7_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB3_I2C2_SDA \ |
| (STM32_PINMUX_ALT_FUNC_9 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB1_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PB3_SPI1_SCK \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| |
| #define STM32F4_PINMUX_FUNC_PB4_PWM3_CH1 \ |
| (STM32_PINMUX_ALT_FUNC_2 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB4_UART7_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB4_I2C3_SDA \ |
| (STM32_PINMUX_ALT_FUNC_9 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB4_SPI1_MISO \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUPDR_PULL_DOWN) |
| |
| #define STM32F4_PINMUX_FUNC_PB5_I2S3_SD \ |
| (STM32_PINMUX_ALT_FUNC_6 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB5_UART5_RX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB5_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PB5_SPI1_MOSI \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUPDR_PULL_DOWN) |
| |
| #define STM32F4_PINMUX_FUNC_PB6_PWM4_CH1 \ |
| (STM32_PINMUX_ALT_FUNC_2 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB6_I2C1_SCL \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB6_USART1_TX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB6_UART5_TX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PB7_PWM4_CH2 \ |
| (STM32_PINMUX_ALT_FUNC_2 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB7_I2C1_SDA \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB7_USART1_RX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PB8_PWM4_CH3 \ |
| (STM32_PINMUX_ALT_FUNC_2 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB8_I2C1_SCL \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB8_I2S5_SD \ |
| (STM32_PINMUX_ALT_FUNC_6 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB8_CAN1_RX \ |
| (STM32_PINMUX_ALT_FUNC_9 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB8_UART5_RX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB8_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PB9_PWM4_CH4 \ |
| (STM32_PINMUX_ALT_FUNC_2 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB9_I2C1_SDA \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB9_I2C2_SDA \ |
| (STM32_PINMUX_ALT_FUNC_9 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB9_CAN1_TX \ |
| (STM32_PINMUX_ALT_FUNC_9 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB9_UART5_TX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB9_SPI2_NSS \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PB10_I2C2_SCL \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB10_USART3_TX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB10_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PB11_I2C2_SDA \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB11_USART3_RX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB11_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PB12_SPI2_NSS \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB12_I2S2_WS \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB12_I2S4_WS \ |
| (STM32_PINMUX_ALT_FUNC_6 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB12_UART5_RX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB12_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PB13_SPI2_SCK \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PB13_I2S2_CK \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PB13_I2S4_CK \ |
| (STM32_PINMUX_ALT_FUNC_6 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PB13_USART3_CTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB13_UART5_TX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB13_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PB14_SPI2_MISO \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUPDR_PULL_DOWN) |
| #define STM32F4_PINMUX_FUNC_PB14_USART3_RTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PB14_OTG_HS_DM \ |
| (STM32_PINMUX_ALT_FUNC_12 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PB15_SPI2_MOSI \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUPDR_PULL_DOWN) |
| #define STM32F4_PINMUX_FUNC_PB15_I2S2_SD \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PB15_OTG_HS_DP \ |
| (STM32_PINMUX_ALT_FUNC_12 | STM32_PUSHPULL_NOPULL) |
| |
| /* Port C */ |
| #define STM32F4_PINMUX_FUNC_PC0_ADC123_IN10 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PC1_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PC1_I2S2_SD \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PC1_ADC123_IN11 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PC2_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PC2_ADC123_IN12 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PC3_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PC3_ADC123_IN13 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PC4_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PC4_ADC12_IN14 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PC5_USART3_RX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PC5_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PC5_ADC12_IN15 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PC6_PWM3_CH1 \ |
| (STM32_PINMUX_ALT_FUNC_2 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PC6_USART6_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PC7_PWM3_CH2 \ |
| (STM32_PINMUX_ALT_FUNC_2 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PC7_USART6_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PC7_I2S2_CK \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PC8_PWM3_CH3 \ |
| (STM32_PINMUX_ALT_FUNC_2 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PC8_UART5_RTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PC9_MCO2 \ |
| (STM32_PINMUX_ALT_FUNC_0 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| #define STM32F4_PINMUX_FUNC_PC9_PWM3_CH4 \ |
| (STM32_PINMUX_ALT_FUNC_2 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PC9_I2C3_SDA \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PC9_UART5_CTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PC10_USART3_TX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PC10_UART4_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PC11_USART3_RX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PC11_UART4_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PC12_UART5_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PC12_I2C2_SDA \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_PUSHPULL_PULLUP) |
| |
| /* Port D */ |
| #define STM32F4_PINMUX_FUNC_PD0_CAN1_RX \ |
| (STM32_PINMUX_ALT_FUNC_9 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PD0_UART4_RX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PD1_CAN1_TX \ |
| (STM32_PINMUX_ALT_FUNC_9 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PD2_UART5_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PD3_USART2_CTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PD3_SPI2_SCK \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PD4_USART2_RTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PD5_USART2_TX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PD6_USART2_RX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PD8_USART3_TX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PD9_USART3_RX \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PD10_UART4_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PD11_USART3_CTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PD12_USART3_RTS \ |
| (STM32_PINMUX_ALT_FUNC_7 | STM32_OPENDRAIN_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PD14_PWM4_CH3 \ |
| (STM32_PINMUX_ALT_FUNC_2 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PD14_UART9_RX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PD15_PWM4_CH4 \ |
| (STM32_PINMUX_ALT_FUNC_2 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PD15_UART9_TX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_PULLUP) |
| |
| /* Port E */ |
| #define STM32F4_PINMUX_FUNC_PE0_UART8_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PE1_UART8_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PE2_UART10_RX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PE2_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PE3_UART10_TX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PE4_I2S5_WS \ |
| (STM32_PINMUX_ALT_FUNC_6 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PE5_PWM9_CH1 \ |
| (STM32_PINMUX_ALT_FUNC_3 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PE6_PWM9_CH2 \ |
| (STM32_PINMUX_ALT_FUNC_3 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PE7_UART7_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PE8_UART7_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PE13_PWM1_CH3 \ |
| (STM32_PINMUX_ALT_FUNC_1 | STM32_PUSHPULL_PULLUP) |
| |
| /* Port F */ |
| #define STM32F4_PINMUX_FUNC_PF0_I2C2_SDA \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PF1_I2C2_SCL \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PF3_ADC3_IN9 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PF4_ADC3_IN14 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PF5_ADC3_IN15 \ |
| STM32_MODER_ANALOG_MODE |
| |
| #define STM32F4_PINMUX_FUNC_PF6_UART7_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PF6_ADC3_IN4 \ |
| STM32_MODER_ANALOG_MODE |
| #define STM32F4_PINMUX_FUNC_PF6_SPI5_MASTER_NSS \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PF7_UART7_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PF7_ADC3_IN5 \ |
| STM32_MODER_ANALOG_MODE |
| #define STM32F4_PINMUX_FUNC_PF7_SPI5_MASTER_SCK \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PF8_UART8_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PF8_ADC3_IN6 \ |
| STM32_MODER_ANALOG_MODE |
| #define STM32F4_PINMUX_FUNC_PF8_SPI5_MASTER_MISO \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUPDR_PULL_DOWN) |
| |
| #define STM32F4_PINMUX_FUNC_PF9_UART8_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PF9_ADC3_IN7 \ |
| STM32_MODER_ANALOG_MODE |
| #define STM32F4_PINMUX_FUNC_PF9_SPI5_MASTER_MOSI \ |
| (STM32_PINMUX_ALT_FUNC_5 | STM32_PUPDR_PULL_DOWN) |
| |
| #define STM32F4_PINMUX_FUNC_PF10_ADC3_IN8 \ |
| STM32_MODER_ANALOG_MODE |
| |
| /* Port G */ |
| #define STM32F4_PINMUX_FUNC_PG0_UART9_RX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PG1_UART9_TX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PG9_USART6_RX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_NOPULL) |
| |
| #define STM32F4_PINMUX_FUNC_PG8_USART6_RTS \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PG8_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PG11_UART10_RX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL) |
| #define STM32F4_PINMUX_FUNC_PG11_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PG12_USART6_RTS \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PG12_UART10_TX \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PG13_USART6_CTS \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PG13_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PG14_USART6_TX \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_PUSHPULL_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PG14_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PG15_USART6_CTS \ |
| (STM32_PINMUX_ALT_FUNC_8 | STM32_OPENDRAIN_PULLUP) |
| /* Port H */ |
| #define STM32F4_PINMUX_FUNC_PH2_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PH3_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PH4_I2C2_SCL \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PH5_I2C2_SDA \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PH7_I2C3_SCL \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| #define STM32F4_PINMUX_FUNC_PH7_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #define STM32F4_PINMUX_FUNC_PH8_I2C3_SDA \ |
| (STM32_PINMUX_ALT_FUNC_4 | STM32_OPENDRAIN_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PH13_CAN1_TX \ |
| (STM32_PINMUX_ALT_FUNC_9 | STM32_PUSHPULL_NOPULL) |
| |
| /* Port I */ |
| #define STM32F4_PINMUX_FUNC_PI9_CAN1_RX \ |
| (STM32_PINMUX_ALT_FUNC_9 | STM32_PUSHPULL_PULLUP) |
| |
| #define STM32F4_PINMUX_FUNC_PI10_ETH \ |
| (STM32_PINMUX_ALT_FUNC_11 | STM32_PUSHPULL_NOPULL | \ |
| STM32_OSPEEDR_VERY_HIGH_SPEED) |
| |
| #endif /* ZEPHYR_DRIVERS_PINMUX_STM32_PINMUX_STM32F4_H_ */ |