/* * Copyright (c) 2017 Linaro Limited * * SPDX-License-Identifier: Apache-2.0 */ #ifndef ZEPHYR_INCLUDE_DT_BINDINGS_PINCTRL_STM32_PINCTRL_H_ #define ZEPHYR_INCLUDE_DT_BINDINGS_PINCTRL_STM32_PINCTRL_H_ #include /* Adapted from Linux: include/dt-bindings/pinctrl/stm32-pinfunc.h */ /** * @brief Pin modes */ #define STM32_AF0 0x0 #define STM32_AF1 0x1 #define STM32_AF2 0x2 #define STM32_AF3 0x3 #define STM32_AF4 0x4 #define STM32_AF5 0x5 #define STM32_AF6 0x6 #define STM32_AF7 0x7 #define STM32_AF8 0x8 #define STM32_AF9 0x9 #define STM32_AF10 0xa #define STM32_AF11 0xb #define STM32_AF12 0xc #define STM32_AF13 0xd #define STM32_AF14 0xe #define STM32_AF15 0xf #define STM32_ANALOG 0x10 /** * @brief Macro to generate pinmux int using port, pin number and mode arguments * This is taken from Linux equivalent st,stm32f429-pinctrl binding */ #define PIN_NO(port, line) (((port) - 'A') * 0x10 + (line)) #define STM32_PINMUX(port, line, mode) (((PIN_NO(port, line)) << 8) | (STM32_ ## mode)) /** * @brief PIN configuration bitfield * * Pin configuration is coded with the following * fields * Alternate Functions [ 0 : 3 ] * GPIO Mode [ 4 : 5 ] * GPIO Output type [ 6 ] * GPIO Speed [ 7 : 8 ] * GPIO PUPD config [ 9 : 10 ] * * Applicable to STM32F3, STM32F4, STM32L4 series */ /* Alternate functions */ #define STM32_FUNC_ALT_0 0 #define STM32_FUNC_ALT_1 1 #define STM32_FUNC_ALT_2 2 #define STM32_FUNC_ALT_3 3 #define STM32_FUNC_ALT_4 4 #define STM32_FUNC_ALT_5 5 #define STM32_FUNC_ALT_6 6 #define STM32_FUNC_ALT_7 7 #define STM32_FUNC_ALT_8 8 #define STM32_FUNC_ALT_9 9 #define STM32_FUNC_ALT_10 10 #define STM32_FUNC_ALT_11 11 #define STM32_FUNC_ALT_12 12 #define STM32_FUNC_ALT_13 13 #define STM32_FUNC_ALT_14 14 #define STM32_FUNC_ALT_15 15 #define STM32_AFR_MASK 0xF #define STM32_AFR_SHIFT 0 /* GPIO Mode */ #define STM32_MODER_INPUT_MODE (0x0<