Frederick Huang / mbed-STM32L452

Dependents:   STM32L452_Nucleo_ticker

Fork of mbed-dev by mbed official

Committer:
Frederick_H
Date:
Fri Dec 15 08:17:23 2017 +0000
Revision:
182:59ec31722650
Parent:
157:ff67d9f36b67
Modify hal_tick.h of TARGET_STM32L476xG

Who changed what in which revision?

UserRevisionLine numberNew contents of line
<> 144:ef7eb2e8f9f7 1 /**
<> 144:ef7eb2e8f9f7 2 ******************************************************************************
<> 144:ef7eb2e8f9f7 3 * @file stm32f3xx_hal_gpio_ex.h
<> 144:ef7eb2e8f9f7 4 * @author MCD Application Team
<> 157:ff67d9f36b67 5 * @version V1.4.0
<> 157:ff67d9f36b67 6 * @date 16-December-2016
<> 144:ef7eb2e8f9f7 7 * @brief Header file of GPIO HAL Extended module.
<> 144:ef7eb2e8f9f7 8 ******************************************************************************
<> 144:ef7eb2e8f9f7 9 * @attention
<> 144:ef7eb2e8f9f7 10 *
<> 144:ef7eb2e8f9f7 11 * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
<> 144:ef7eb2e8f9f7 12 *
<> 144:ef7eb2e8f9f7 13 * Redistribution and use in source and binary forms, with or without modification,
<> 144:ef7eb2e8f9f7 14 * are permitted provided that the following conditions are met:
<> 144:ef7eb2e8f9f7 15 * 1. Redistributions of source code must retain the above copyright notice,
<> 144:ef7eb2e8f9f7 16 * this list of conditions and the following disclaimer.
<> 144:ef7eb2e8f9f7 17 * 2. Redistributions in binary form must reproduce the above copyright notice,
<> 144:ef7eb2e8f9f7 18 * this list of conditions and the following disclaimer in the documentation
<> 144:ef7eb2e8f9f7 19 * and/or other materials provided with the distribution.
<> 144:ef7eb2e8f9f7 20 * 3. Neither the name of STMicroelectronics nor the names of its contributors
<> 144:ef7eb2e8f9f7 21 * may be used to endorse or promote products derived from this software
<> 144:ef7eb2e8f9f7 22 * without specific prior written permission.
<> 144:ef7eb2e8f9f7 23 *
<> 144:ef7eb2e8f9f7 24 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
<> 144:ef7eb2e8f9f7 25 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
<> 144:ef7eb2e8f9f7 26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
<> 144:ef7eb2e8f9f7 27 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
<> 144:ef7eb2e8f9f7 28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
<> 144:ef7eb2e8f9f7 29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
<> 144:ef7eb2e8f9f7 30 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
<> 144:ef7eb2e8f9f7 31 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
<> 144:ef7eb2e8f9f7 32 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
<> 144:ef7eb2e8f9f7 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
<> 144:ef7eb2e8f9f7 34 *
<> 144:ef7eb2e8f9f7 35 ******************************************************************************
<> 144:ef7eb2e8f9f7 36 */
<> 144:ef7eb2e8f9f7 37
<> 144:ef7eb2e8f9f7 38 /* Define to prevent recursive inclusion -------------------------------------*/
<> 144:ef7eb2e8f9f7 39 #ifndef __STM32F3xx_HAL_GPIO_EX_H
<> 144:ef7eb2e8f9f7 40 #define __STM32F3xx_HAL_GPIO_EX_H
<> 144:ef7eb2e8f9f7 41
<> 144:ef7eb2e8f9f7 42 #ifdef __cplusplus
<> 144:ef7eb2e8f9f7 43 extern "C" {
<> 144:ef7eb2e8f9f7 44 #endif
<> 144:ef7eb2e8f9f7 45
<> 144:ef7eb2e8f9f7 46 /* Includes ------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 47 #include "stm32f3xx_hal_def.h"
<> 144:ef7eb2e8f9f7 48
<> 144:ef7eb2e8f9f7 49 /** @addtogroup STM32F3xx_HAL_Driver
<> 144:ef7eb2e8f9f7 50 * @{
<> 144:ef7eb2e8f9f7 51 */
<> 144:ef7eb2e8f9f7 52
<> 144:ef7eb2e8f9f7 53 /** @defgroup GPIOEx GPIOEx
<> 144:ef7eb2e8f9f7 54 * @brief GPIO Extended HAL module driver
<> 144:ef7eb2e8f9f7 55 * @{
<> 144:ef7eb2e8f9f7 56 */
<> 144:ef7eb2e8f9f7 57
<> 144:ef7eb2e8f9f7 58 /* Exported types ------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 59 /* Exported constants --------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 60 /** @defgroup GPIOEx_Exported_Constants GPIOEx Exported Constants
<> 144:ef7eb2e8f9f7 61 * @{
<> 144:ef7eb2e8f9f7 62 */
<> 144:ef7eb2e8f9f7 63
<> 144:ef7eb2e8f9f7 64 /** @defgroup GPIOEx_Alternate_function_selection GPIOEx Alternate function selection
<> 144:ef7eb2e8f9f7 65 * @{
<> 144:ef7eb2e8f9f7 66 */
<> 144:ef7eb2e8f9f7 67
<> 144:ef7eb2e8f9f7 68 #if defined (STM32F302xC)
<> 144:ef7eb2e8f9f7 69 /*---------------------------------- STM32F302xC ------------------------------*/
<> 144:ef7eb2e8f9f7 70 /**
<> 144:ef7eb2e8f9f7 71 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 72 */
<> 157:ff67d9f36b67 73 #define GPIO_AF0_RTC_50Hz ((uint8_t)0x00U) /* RTC_50Hz Alternate Function mapping */
<> 157:ff67d9f36b67 74 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 75 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 76 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 77 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 78
<> 144:ef7eb2e8f9f7 79 /**
<> 144:ef7eb2e8f9f7 80 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 81 */
<> 157:ff67d9f36b67 82 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 83 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 84 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 85 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 86 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 87 /**
<> 144:ef7eb2e8f9f7 88 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 89 */
<> 157:ff67d9f36b67 90 #define GPIO_AF2_TIM1 ((uint8_t)0x02U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 91 #define GPIO_AF2_TIM2 ((uint8_t)0x02U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 92 #define GPIO_AF2_TIM3 ((uint8_t)0x02U) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 93 #define GPIO_AF2_TIM4 ((uint8_t)0x02U) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 94 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 95 #define GPIO_AF2_COMP1 ((uint8_t)0x02U) /* COMP1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 96 /**
<> 144:ef7eb2e8f9f7 97 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 98 */
<> 157:ff67d9f36b67 99 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 157:ff67d9f36b67 100 #define GPIO_AF3_TIM15 ((uint8_t)0x03U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 101
<> 144:ef7eb2e8f9f7 102 /**
<> 144:ef7eb2e8f9f7 103 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 104 */
<> 157:ff67d9f36b67 105 #define GPIO_AF4_TIM1 ((uint8_t)0x04U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 106 #define GPIO_AF4_TIM16 ((uint8_t)0x04U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 107 #define GPIO_AF4_TIM17 ((uint8_t)0x04U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 108 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 109 #define GPIO_AF4_I2C2 ((uint8_t)0x04U) /* I2C2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 110
<> 144:ef7eb2e8f9f7 111 /**
<> 144:ef7eb2e8f9f7 112 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 113 */
<> 157:ff67d9f36b67 114 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1/I2S1 Alternate Function mapping */
<> 157:ff67d9f36b67 115 #define GPIO_AF5_SPI2 ((uint8_t)0x05U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 116 #define GPIO_AF5_SPI3 ((uint8_t)0x05U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 117 #define GPIO_AF5_I2S ((uint8_t)0x05U) /* I2S Alternate Function mapping */
<> 157:ff67d9f36b67 118 #define GPIO_AF5_I2S2ext ((uint8_t)0x05U) /* I2S2ext Alternate Function mapping */
<> 157:ff67d9f36b67 119 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 120 #define GPIO_AF5_UART4 ((uint8_t)0x05U) /* UART4 Alternate Function mapping */
<> 157:ff67d9f36b67 121 #define GPIO_AF5_UART5 ((uint8_t)0x05U) /* UART5 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 122 /**
<> 144:ef7eb2e8f9f7 123 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 124 */
<> 157:ff67d9f36b67 125 #define GPIO_AF6_SPI2 ((uint8_t)0x06U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 126 #define GPIO_AF6_SPI3 ((uint8_t)0x06U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 127 #define GPIO_AF6_I2S3ext ((uint8_t)0x06U) /* I2S3ext Alternate Function mapping */
<> 157:ff67d9f36b67 128 #define GPIO_AF6_TIM1 ((uint8_t)0x06U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 129 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 130
<> 144:ef7eb2e8f9f7 131 /**
<> 144:ef7eb2e8f9f7 132 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 133 */
<> 157:ff67d9f36b67 134 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 135 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 136 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 137 #define GPIO_AF7_COMP6 ((uint8_t)0x07U) /* COMP6 Alternate Function mapping */
<> 157:ff67d9f36b67 138 #define GPIO_AF7_CAN ((uint8_t)0x07U) /* CAN Alternate Function mapping */
<> 144:ef7eb2e8f9f7 139
<> 144:ef7eb2e8f9f7 140 /**
<> 144:ef7eb2e8f9f7 141 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 142 */
<> 157:ff67d9f36b67 143 #define GPIO_AF8_COMP1 ((uint8_t)0x08U) /* COMP1 Alternate Function mapping */
<> 157:ff67d9f36b67 144 #define GPIO_AF8_COMP2 ((uint8_t)0x08U) /* COMP2 Alternate Function mapping */
<> 157:ff67d9f36b67 145 #define GPIO_AF8_COMP4 ((uint8_t)0x08U) /* COMP4 Alternate Function mapping */
<> 157:ff67d9f36b67 146 #define GPIO_AF8_COMP6 ((uint8_t)0x08U) /* COMP6 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 147
<> 144:ef7eb2e8f9f7 148 /**
<> 144:ef7eb2e8f9f7 149 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 150 */
<> 157:ff67d9f36b67 151 #define GPIO_AF9_CAN ((uint8_t)0x09U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 152 #define GPIO_AF9_TIM1 ((uint8_t)0x09U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 153 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 154
<> 144:ef7eb2e8f9f7 155 /**
<> 144:ef7eb2e8f9f7 156 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 157 */
<> 157:ff67d9f36b67 158 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 159 #define GPIO_AF10_TIM3 ((uint8_t)0xAU) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 160 #define GPIO_AF10_TIM4 ((uint8_t)0xAU) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 161 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 162 /**
<> 144:ef7eb2e8f9f7 163 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 164 */
<> 157:ff67d9f36b67 165 #define GPIO_AF11_TIM1 ((uint8_t)0x0BU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 166
<> 144:ef7eb2e8f9f7 167 /**
<> 144:ef7eb2e8f9f7 168 * @brief AF 12 selection
<> 144:ef7eb2e8f9f7 169 */
<> 157:ff67d9f36b67 170 #define GPIO_AF12_TIM1 ((uint8_t)0xCU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 171
<> 144:ef7eb2e8f9f7 172 /**
<> 144:ef7eb2e8f9f7 173 * @brief AF 14 selection
<> 144:ef7eb2e8f9f7 174 */
<> 144:ef7eb2e8f9f7 175
<> 157:ff67d9f36b67 176 #define GPIO_AF14_USB ((uint8_t)0x0EU) /* USB Alternate Function mapping */
<> 144:ef7eb2e8f9f7 177 /**
<> 144:ef7eb2e8f9f7 178 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 179 */
<> 157:ff67d9f36b67 180 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 181
<> 157:ff67d9f36b67 182 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0CU) || ((AF) == (uint8_t)0x0EU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 183 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 184 #endif /* STM32F302xC */
<> 144:ef7eb2e8f9f7 185
<> 144:ef7eb2e8f9f7 186 #if defined (STM32F303xC)
<> 144:ef7eb2e8f9f7 187 /*---------------------------------- STM32F303xC ------------------------------*/
<> 144:ef7eb2e8f9f7 188 /**
<> 144:ef7eb2e8f9f7 189 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 190 */
<> 157:ff67d9f36b67 191 #define GPIO_AF0_RTC_50Hz ((uint8_t)0x00U) /* RTC_50Hz Alternate Function mapping */
<> 157:ff67d9f36b67 192 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 193 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 194 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 195 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 196
<> 144:ef7eb2e8f9f7 197 /**
<> 144:ef7eb2e8f9f7 198 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 199 */
<> 157:ff67d9f36b67 200 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 201 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 202 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 203 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 204 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 205 /**
<> 144:ef7eb2e8f9f7 206 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 207 */
<> 157:ff67d9f36b67 208 #define GPIO_AF2_TIM1 ((uint8_t)0x02U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 209 #define GPIO_AF2_TIM2 ((uint8_t)0x02U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 210 #define GPIO_AF2_TIM3 ((uint8_t)0x02U) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 211 #define GPIO_AF2_TIM4 ((uint8_t)0x02U) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 212 #define GPIO_AF2_TIM8 ((uint8_t)0x02U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 213 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 214 #define GPIO_AF2_COMP1 ((uint8_t)0x02U) /* COMP1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 215 /**
<> 144:ef7eb2e8f9f7 216 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 217 */
<> 157:ff67d9f36b67 218 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 157:ff67d9f36b67 219 #define GPIO_AF3_TIM8 ((uint8_t)0x03U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 220 #define GPIO_AF3_COMP7 ((uint8_t)0x03U) /* COMP7 Alternate Function mapping */
<> 157:ff67d9f36b67 221 #define GPIO_AF3_TIM15 ((uint8_t)0x03U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 222
<> 144:ef7eb2e8f9f7 223 /**
<> 144:ef7eb2e8f9f7 224 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 225 */
<> 157:ff67d9f36b67 226 #define GPIO_AF4_TIM1 ((uint8_t)0x04U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 227 #define GPIO_AF4_TIM8 ((uint8_t)0x04U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 228 #define GPIO_AF4_TIM16 ((uint8_t)0x04U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 229 #define GPIO_AF4_TIM17 ((uint8_t)0x04U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 230 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 231 #define GPIO_AF4_I2C2 ((uint8_t)0x04U) /* I2C2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 232
<> 144:ef7eb2e8f9f7 233 /**
<> 144:ef7eb2e8f9f7 234 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 235 */
<> 157:ff67d9f36b67 236 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1/I2S1 Alternate Function mapping */
<> 157:ff67d9f36b67 237 #define GPIO_AF5_SPI2 ((uint8_t)0x05U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 238 #define GPIO_AF5_SPI3 ((uint8_t)0x05U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 239 #define GPIO_AF5_I2S ((uint8_t)0x05U) /* I2S Alternate Function mapping */
<> 157:ff67d9f36b67 240 #define GPIO_AF5_I2S2ext ((uint8_t)0x05U) /* I2S2ext Alternate Function mapping */
<> 157:ff67d9f36b67 241 #define GPIO_AF5_TIM8 ((uint8_t)0x05U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 242 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 243 #define GPIO_AF5_UART4 ((uint8_t)0x05U) /* UART4 Alternate Function mapping */
<> 157:ff67d9f36b67 244 #define GPIO_AF5_UART5 ((uint8_t)0x05U) /* UART5 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 245 /**
<> 144:ef7eb2e8f9f7 246 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 247 */
<> 157:ff67d9f36b67 248 #define GPIO_AF6_SPI2 ((uint8_t)0x06U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 249 #define GPIO_AF6_SPI3 ((uint8_t)0x06U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 250 #define GPIO_AF6_I2S3ext ((uint8_t)0x06U) /* I2S3ext Alternate Function mapping */
<> 157:ff67d9f36b67 251 #define GPIO_AF6_TIM1 ((uint8_t)0x06U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 252 #define GPIO_AF6_TIM8 ((uint8_t)0x06U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 253 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 254
<> 144:ef7eb2e8f9f7 255 /**
<> 144:ef7eb2e8f9f7 256 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 257 */
<> 157:ff67d9f36b67 258 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 259 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 260 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 261 #define GPIO_AF7_COMP3 ((uint8_t)0x07U) /* COMP3 Alternate Function mapping */
<> 157:ff67d9f36b67 262 #define GPIO_AF7_COMP5 ((uint8_t)0x07U) /* COMP5 Alternate Function mapping */
<> 157:ff67d9f36b67 263 #define GPIO_AF7_COMP6 ((uint8_t)0x07U) /* COMP6 Alternate Function mapping */
<> 157:ff67d9f36b67 264 #define GPIO_AF7_CAN ((uint8_t)0x07U) /* CAN Alternate Function mapping */
<> 144:ef7eb2e8f9f7 265
<> 144:ef7eb2e8f9f7 266 /**
<> 144:ef7eb2e8f9f7 267 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 268 */
<> 157:ff67d9f36b67 269 #define GPIO_AF8_COMP1 ((uint8_t)0x08U) /* COMP1 Alternate Function mapping */
<> 157:ff67d9f36b67 270 #define GPIO_AF8_COMP2 ((uint8_t)0x08U) /* COMP2 Alternate Function mapping */
<> 157:ff67d9f36b67 271 #define GPIO_AF8_COMP3 ((uint8_t)0x08U) /* COMP3 Alternate Function mapping */
<> 157:ff67d9f36b67 272 #define GPIO_AF8_COMP4 ((uint8_t)0x08U) /* COMP4 Alternate Function mapping */
<> 157:ff67d9f36b67 273 #define GPIO_AF8_COMP5 ((uint8_t)0x08U) /* COMP5 Alternate Function mapping */
<> 157:ff67d9f36b67 274 #define GPIO_AF8_COMP6 ((uint8_t)0x08U) /* COMP6 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 275
<> 144:ef7eb2e8f9f7 276 /**
<> 144:ef7eb2e8f9f7 277 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 278 */
<> 157:ff67d9f36b67 279 #define GPIO_AF9_CAN ((uint8_t)0x09U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 280 #define GPIO_AF9_TIM1 ((uint8_t)0x09U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 281 #define GPIO_AF9_TIM8 ((uint8_t)0x09U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 282 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 283
<> 144:ef7eb2e8f9f7 284 /**
<> 144:ef7eb2e8f9f7 285 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 286 */
<> 157:ff67d9f36b67 287 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 288 #define GPIO_AF10_TIM3 ((uint8_t)0xAU) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 289 #define GPIO_AF10_TIM4 ((uint8_t)0xAU) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 290 #define GPIO_AF10_TIM8 ((uint8_t)0xAU) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 291 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 292 /**
<> 144:ef7eb2e8f9f7 293 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 294 */
<> 157:ff67d9f36b67 295 #define GPIO_AF11_TIM1 ((uint8_t)0x0BU) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 296 #define GPIO_AF11_TIM8 ((uint8_t)0x0BU) /* TIM8 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 297
<> 144:ef7eb2e8f9f7 298 /**
<> 144:ef7eb2e8f9f7 299 * @brief AF 12 selection
<> 144:ef7eb2e8f9f7 300 */
<> 157:ff67d9f36b67 301 #define GPIO_AF12_TIM1 ((uint8_t)0xCU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 302
<> 144:ef7eb2e8f9f7 303 /**
<> 144:ef7eb2e8f9f7 304 * @brief AF 14 selection
<> 144:ef7eb2e8f9f7 305 */
<> 144:ef7eb2e8f9f7 306
<> 157:ff67d9f36b67 307 #define GPIO_AF14_USB ((uint8_t)0x0EU) /* USB Alternate Function mapping */
<> 144:ef7eb2e8f9f7 308 /**
<> 144:ef7eb2e8f9f7 309 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 310 */
<> 157:ff67d9f36b67 311 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 312
<> 157:ff67d9f36b67 313 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0CU) || ((AF) == (uint8_t)0x0EU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 314 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 315 #endif /* STM32F303xC */
<> 144:ef7eb2e8f9f7 316
<> 144:ef7eb2e8f9f7 317 #if defined (STM32F303xE)
<> 144:ef7eb2e8f9f7 318 /*---------------------------------- STM32F303xE ------------------------------*/
<> 144:ef7eb2e8f9f7 319 /**
<> 144:ef7eb2e8f9f7 320 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 321 */
<> 157:ff67d9f36b67 322 #define GPIO_AF0_RTC_50Hz ((uint8_t)0x00U) /* RTC_50Hz Alternate Function mapping */
<> 157:ff67d9f36b67 323 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 324 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 325 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 326 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 327
<> 144:ef7eb2e8f9f7 328 /**
<> 144:ef7eb2e8f9f7 329 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 330 */
<> 157:ff67d9f36b67 331 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 332 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 333 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 334 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 335 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 336
<> 144:ef7eb2e8f9f7 337 /**
<> 144:ef7eb2e8f9f7 338 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 339 */
<> 157:ff67d9f36b67 340 #define GPIO_AF2_TIM1 ((uint8_t)0x02U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 341 #define GPIO_AF2_TIM2 ((uint8_t)0x02U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 342 #define GPIO_AF2_TIM3 ((uint8_t)0x02U) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 343 #define GPIO_AF2_TIM4 ((uint8_t)0x02U) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 344 #define GPIO_AF2_TIM8 ((uint8_t)0x02U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 345 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 346 #define GPIO_AF2_COMP1 ((uint8_t)0x02U) /* COMP1 Alternate Function mapping */
<> 157:ff67d9f36b67 347 #define GPIO_AF2_I2C3 ((uint8_t)0x02U) /* I2C3 Alternate Function mapping */
<> 157:ff67d9f36b67 348 #define GPIO_AF2_TIM20 ((uint8_t)0x02U) /* TIM20 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 349
<> 144:ef7eb2e8f9f7 350 /**
<> 144:ef7eb2e8f9f7 351 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 352 */
<> 157:ff67d9f36b67 353 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 157:ff67d9f36b67 354 #define GPIO_AF3_TIM8 ((uint8_t)0x03U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 355 #define GPIO_AF3_COMP7 ((uint8_t)0x03U) /* COMP7 Alternate Function mapping */
<> 157:ff67d9f36b67 356 #define GPIO_AF3_TIM15 ((uint8_t)0x03U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 357 #define GPIO_AF3_I2C3 ((uint8_t)0x03U) /* I2C3 Alternate Function mapping */
<> 157:ff67d9f36b67 358 #define GPIO_AF3_TIM20 ((uint8_t)0x03U) /* TIM20 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 359
<> 144:ef7eb2e8f9f7 360 /**
<> 144:ef7eb2e8f9f7 361 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 362 */
<> 157:ff67d9f36b67 363 #define GPIO_AF4_TIM1 ((uint8_t)0x04U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 364 #define GPIO_AF4_TIM8 ((uint8_t)0x04U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 365 #define GPIO_AF4_TIM16 ((uint8_t)0x04U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 366 #define GPIO_AF4_TIM17 ((uint8_t)0x04U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 367 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 368 #define GPIO_AF4_I2C2 ((uint8_t)0x04U) /* I2C2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 369
<> 144:ef7eb2e8f9f7 370 /**
<> 144:ef7eb2e8f9f7 371 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 372 */
<> 157:ff67d9f36b67 373 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1 Alternate Function mapping */
<> 157:ff67d9f36b67 374 #define GPIO_AF5_SPI2 ((uint8_t)0x05U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 375 #define GPIO_AF5_SPI3 ((uint8_t)0x05U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 376 #define GPIO_AF5_I2S ((uint8_t)0x05U) /* I2S Alternate Function mapping */
<> 157:ff67d9f36b67 377 #define GPIO_AF5_I2S2ext ((uint8_t)0x05U) /* I2S2ext Alternate Function mapping */
<> 157:ff67d9f36b67 378 #define GPIO_AF5_TIM8 ((uint8_t)0x05U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 379 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 380 #define GPIO_AF5_UART4 ((uint8_t)0x05U) /* UART4 Alternate Function mapping */
<> 157:ff67d9f36b67 381 #define GPIO_AF5_UART5 ((uint8_t)0x05U) /* UART5 Alternate Function mapping */
<> 157:ff67d9f36b67 382 #define GPIO_AF5_SPI4 ((uint8_t)0x05U) /* SPI4 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 383
<> 144:ef7eb2e8f9f7 384 /**
<> 144:ef7eb2e8f9f7 385 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 386 */
<> 157:ff67d9f36b67 387 #define GPIO_AF6_SPI2 ((uint8_t)0x06U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 388 #define GPIO_AF6_SPI3 ((uint8_t)0x06U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 389 #define GPIO_AF6_I2S3ext ((uint8_t)0x06U) /* I2S3ext Alternate Function mapping */
<> 157:ff67d9f36b67 390 #define GPIO_AF6_TIM1 ((uint8_t)0x06U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 391 #define GPIO_AF6_TIM8 ((uint8_t)0x06U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 392 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 393 #define GPIO_AF6_TIM20 ((uint8_t)0x06U) /* TIM20 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 394
<> 144:ef7eb2e8f9f7 395 /**
<> 144:ef7eb2e8f9f7 396 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 397 */
<> 157:ff67d9f36b67 398 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 399 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 400 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 401 #define GPIO_AF7_COMP3 ((uint8_t)0x07U) /* COMP3 Alternate Function mapping */
<> 157:ff67d9f36b67 402 #define GPIO_AF7_COMP5 ((uint8_t)0x07U) /* COMP5 Alternate Function mapping */
<> 157:ff67d9f36b67 403 #define GPIO_AF7_COMP6 ((uint8_t)0x07U) /* COMP6 Alternate Function mapping */
<> 157:ff67d9f36b67 404 #define GPIO_AF7_CAN ((uint8_t)0x07U) /* CAN Alternate Function mapping */
<> 144:ef7eb2e8f9f7 405
<> 144:ef7eb2e8f9f7 406 /**
<> 144:ef7eb2e8f9f7 407 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 408 */
<> 157:ff67d9f36b67 409 #define GPIO_AF8_COMP1 ((uint8_t)0x08U) /* COMP1 Alternate Function mapping */
<> 157:ff67d9f36b67 410 #define GPIO_AF8_COMP2 ((uint8_t)0x08U) /* COMP2 Alternate Function mapping */
<> 157:ff67d9f36b67 411 #define GPIO_AF8_COMP3 ((uint8_t)0x08U) /* COMP3 Alternate Function mapping */
<> 157:ff67d9f36b67 412 #define GPIO_AF8_COMP4 ((uint8_t)0x08U) /* COMP4 Alternate Function mapping */
<> 157:ff67d9f36b67 413 #define GPIO_AF8_COMP5 ((uint8_t)0x08U) /* COMP5 Alternate Function mapping */
<> 157:ff67d9f36b67 414 #define GPIO_AF8_COMP6 ((uint8_t)0x08U) /* COMP6 Alternate Function mapping */
<> 157:ff67d9f36b67 415 #define GPIO_AF8_I2C3 ((uint8_t)0x08U) /* I2C3 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 416
<> 144:ef7eb2e8f9f7 417 /**
<> 144:ef7eb2e8f9f7 418 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 419 */
<> 157:ff67d9f36b67 420 #define GPIO_AF9_CAN ((uint8_t)0x09U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 421 #define GPIO_AF9_TIM1 ((uint8_t)0x09U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 422 #define GPIO_AF9_TIM8 ((uint8_t)0x09U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 423 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 424
<> 144:ef7eb2e8f9f7 425 /**
<> 144:ef7eb2e8f9f7 426 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 427 */
<> 157:ff67d9f36b67 428 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 429 #define GPIO_AF10_TIM3 ((uint8_t)0xAU) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 430 #define GPIO_AF10_TIM4 ((uint8_t)0xAU) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 431 #define GPIO_AF10_TIM8 ((uint8_t)0xAU) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 432 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 433 /**
<> 144:ef7eb2e8f9f7 434 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 435 */
<> 157:ff67d9f36b67 436 #define GPIO_AF11_TIM1 ((uint8_t)0x0BU) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 437 #define GPIO_AF11_TIM8 ((uint8_t)0x0BU) /* TIM8 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 438
<> 144:ef7eb2e8f9f7 439 /**
<> 144:ef7eb2e8f9f7 440 * @brief AF 12 selection
<> 144:ef7eb2e8f9f7 441 */
<> 157:ff67d9f36b67 442 #define GPIO_AF12_TIM1 ((uint8_t)0xCU) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 443 #define GPIO_AF12_FMC ((uint8_t)0xCU) /* FMC Alternate Function mapping */
<> 157:ff67d9f36b67 444 #define GPIO_AF12_SDIO ((uint8_t)0xCU) /* SDIO Alternate Function mapping */
<> 144:ef7eb2e8f9f7 445
<> 144:ef7eb2e8f9f7 446 /**
<> 144:ef7eb2e8f9f7 447 * @brief AF 14 selection
<> 144:ef7eb2e8f9f7 448 */
<> 157:ff67d9f36b67 449 #define GPIO_AF14_USB ((uint8_t)0x0EU) /* USB Alternate Function mapping */
<> 144:ef7eb2e8f9f7 450
<> 144:ef7eb2e8f9f7 451 /**
<> 144:ef7eb2e8f9f7 452 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 453 */
<> 157:ff67d9f36b67 454 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 455
<> 157:ff67d9f36b67 456 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0CU) || ((AF) == (uint8_t)0x0EU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 457 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 458 #endif /* STM32F303xE */
<> 144:ef7eb2e8f9f7 459
<> 144:ef7eb2e8f9f7 460 #if defined (STM32F302xE)
<> 144:ef7eb2e8f9f7 461 /*---------------------------------- STM32F302xE ------------------------------*/
<> 144:ef7eb2e8f9f7 462 /**
<> 144:ef7eb2e8f9f7 463 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 464 */
<> 157:ff67d9f36b67 465 #define GPIO_AF0_RTC_50Hz ((uint8_t)0x00U) /* RTC_50Hz Alternate Function mapping */
<> 157:ff67d9f36b67 466 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 467 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 468 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 469 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 470
<> 144:ef7eb2e8f9f7 471 /**
<> 144:ef7eb2e8f9f7 472 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 473 */
<> 157:ff67d9f36b67 474 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 475 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 476 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 477 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 478 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 479
<> 144:ef7eb2e8f9f7 480 /**
<> 144:ef7eb2e8f9f7 481 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 482 */
<> 157:ff67d9f36b67 483 #define GPIO_AF2_TIM1 ((uint8_t)0x02U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 484 #define GPIO_AF2_TIM2 ((uint8_t)0x02U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 485 #define GPIO_AF2_TIM3 ((uint8_t)0x02U) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 486 #define GPIO_AF2_TIM4 ((uint8_t)0x02U) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 487 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 488 #define GPIO_AF2_COMP1 ((uint8_t)0x02U) /* COMP1 Alternate Function mapping */
<> 157:ff67d9f36b67 489 #define GPIO_AF2_I2C3 ((uint8_t)0x02U) /* I2C3 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 490
<> 144:ef7eb2e8f9f7 491 /**
<> 144:ef7eb2e8f9f7 492 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 493 */
<> 157:ff67d9f36b67 494 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 157:ff67d9f36b67 495 #define GPIO_AF3_TIM15 ((uint8_t)0x03U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 496 #define GPIO_AF3_I2C3 ((uint8_t)0x03U) /* I2C3 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 497
<> 144:ef7eb2e8f9f7 498 /**
<> 144:ef7eb2e8f9f7 499 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 500 */
<> 157:ff67d9f36b67 501 #define GPIO_AF4_TIM1 ((uint8_t)0x04U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 502 #define GPIO_AF4_TIM16 ((uint8_t)0x04U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 503 #define GPIO_AF4_TIM17 ((uint8_t)0x04U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 504 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 505 #define GPIO_AF4_I2C2 ((uint8_t)0x04U) /* I2C2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 506
<> 144:ef7eb2e8f9f7 507 /**
<> 144:ef7eb2e8f9f7 508 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 509 */
<> 157:ff67d9f36b67 510 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1 Alternate Function mapping */
<> 157:ff67d9f36b67 511 #define GPIO_AF5_SPI2 ((uint8_t)0x05U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 512 #define GPIO_AF5_SPI3 ((uint8_t)0x05U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 513 #define GPIO_AF5_I2S ((uint8_t)0x05U) /* I2S Alternate Function mapping */
<> 157:ff67d9f36b67 514 #define GPIO_AF5_I2S2ext ((uint8_t)0x05U) /* I2S2ext Alternate Function mapping */
<> 157:ff67d9f36b67 515 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 516 #define GPIO_AF5_UART4 ((uint8_t)0x05U) /* UART4 Alternate Function mapping */
<> 157:ff67d9f36b67 517 #define GPIO_AF5_UART5 ((uint8_t)0x05U) /* UART5 Alternate Function mapping */
<> 157:ff67d9f36b67 518 #define GPIO_AF5_SPI4 ((uint8_t)0x05U) /* SPI4 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 519
<> 144:ef7eb2e8f9f7 520 /**
<> 144:ef7eb2e8f9f7 521 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 522 */
<> 157:ff67d9f36b67 523 #define GPIO_AF6_SPI2 ((uint8_t)0x06U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 524 #define GPIO_AF6_SPI3 ((uint8_t)0x06U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 525 #define GPIO_AF6_I2S3ext ((uint8_t)0x06U) /* I2S3ext Alternate Function mapping */
<> 157:ff67d9f36b67 526 #define GPIO_AF6_TIM1 ((uint8_t)0x06U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 527 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 528
<> 144:ef7eb2e8f9f7 529 /**
<> 144:ef7eb2e8f9f7 530 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 531 */
<> 157:ff67d9f36b67 532 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 533 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 534 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 535 #define GPIO_AF7_COMP6 ((uint8_t)0x07U) /* COMP6 Alternate Function mapping */
<> 157:ff67d9f36b67 536 #define GPIO_AF7_CAN ((uint8_t)0x07U) /* CAN Alternate Function mapping */
<> 144:ef7eb2e8f9f7 537
<> 144:ef7eb2e8f9f7 538 /**
<> 144:ef7eb2e8f9f7 539 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 540 */
<> 157:ff67d9f36b67 541 #define GPIO_AF8_COMP1 ((uint8_t)0x08U) /* COMP1 Alternate Function mapping */
<> 157:ff67d9f36b67 542 #define GPIO_AF8_COMP2 ((uint8_t)0x08U) /* COMP2 Alternate Function mapping */
<> 157:ff67d9f36b67 543 #define GPIO_AF8_COMP4 ((uint8_t)0x08U) /* COMP4 Alternate Function mapping */
<> 157:ff67d9f36b67 544 #define GPIO_AF8_COMP6 ((uint8_t)0x08U) /* COMP6 Alternate Function mapping */
<> 157:ff67d9f36b67 545 #define GPIO_AF8_I2C3 ((uint8_t)0x08U) /* I2C3 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 546
<> 144:ef7eb2e8f9f7 547 /**
<> 144:ef7eb2e8f9f7 548 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 549 */
<> 157:ff67d9f36b67 550 #define GPIO_AF9_CAN ((uint8_t)0x09U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 551 #define GPIO_AF9_TIM1 ((uint8_t)0x09U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 552 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 553
<> 144:ef7eb2e8f9f7 554 /**
<> 144:ef7eb2e8f9f7 555 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 556 */
<> 157:ff67d9f36b67 557 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 558 #define GPIO_AF10_TIM3 ((uint8_t)0xAU) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 559 #define GPIO_AF10_TIM4 ((uint8_t)0xAU) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 560 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 561 /**
<> 144:ef7eb2e8f9f7 562 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 563 */
<> 157:ff67d9f36b67 564 #define GPIO_AF11_TIM1 ((uint8_t)0x0BU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 565
<> 144:ef7eb2e8f9f7 566 /**
<> 144:ef7eb2e8f9f7 567 * @brief AF 12 selection
<> 144:ef7eb2e8f9f7 568 */
<> 157:ff67d9f36b67 569 #define GPIO_AF12_TIM1 ((uint8_t)0xCU) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 570 #define GPIO_AF12_FMC ((uint8_t)0xCU) /* FMC Alternate Function mapping */
<> 157:ff67d9f36b67 571 #define GPIO_AF12_SDIO ((uint8_t)0xCU) /* SDIO Alternate Function mapping */
<> 144:ef7eb2e8f9f7 572
<> 144:ef7eb2e8f9f7 573 /**
<> 144:ef7eb2e8f9f7 574 * @brief AF 14 selection
<> 144:ef7eb2e8f9f7 575 */
<> 157:ff67d9f36b67 576 #define GPIO_AF14_USB ((uint8_t)0x0EU) /* USB Alternate Function mapping */
<> 144:ef7eb2e8f9f7 577
<> 144:ef7eb2e8f9f7 578 /**
<> 144:ef7eb2e8f9f7 579 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 580 */
<> 157:ff67d9f36b67 581 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 582
<> 157:ff67d9f36b67 583 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0CU) || ((AF) == (uint8_t)0x0EU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 584 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 585 #endif /* STM32F302xE */
<> 144:ef7eb2e8f9f7 586
<> 144:ef7eb2e8f9f7 587 #if defined (STM32F398xx)
<> 144:ef7eb2e8f9f7 588 /*---------------------------------- STM32F398xx ------------------------------*/
<> 144:ef7eb2e8f9f7 589 /**
<> 144:ef7eb2e8f9f7 590 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 591 */
<> 157:ff67d9f36b67 592 #define GPIO_AF0_RTC_50Hz ((uint8_t)0x00U) /* RTC_50Hz Alternate Function mapping */
<> 157:ff67d9f36b67 593 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 594 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 595 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 596 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 597
<> 144:ef7eb2e8f9f7 598 /**
<> 144:ef7eb2e8f9f7 599 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 600 */
<> 157:ff67d9f36b67 601 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 602 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 603 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 604 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 605 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 606
<> 144:ef7eb2e8f9f7 607 /**
<> 144:ef7eb2e8f9f7 608 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 609 */
<> 157:ff67d9f36b67 610 #define GPIO_AF2_TIM1 ((uint8_t)0x02U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 611 #define GPIO_AF2_TIM2 ((uint8_t)0x02U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 612 #define GPIO_AF2_TIM3 ((uint8_t)0x02U) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 613 #define GPIO_AF2_TIM4 ((uint8_t)0x02U) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 614 #define GPIO_AF2_TIM8 ((uint8_t)0x02U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 615 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 616 #define GPIO_AF2_COMP1 ((uint8_t)0x02U) /* COMP1 Alternate Function mapping */
<> 157:ff67d9f36b67 617 #define GPIO_AF2_I2C3 ((uint8_t)0x02U) /* I2C3 Alternate Function mapping */
<> 157:ff67d9f36b67 618 #define GPIO_AF2_TIM20 ((uint8_t)0x02U) /* TIM20 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 619
<> 144:ef7eb2e8f9f7 620 /**
<> 144:ef7eb2e8f9f7 621 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 622 */
<> 157:ff67d9f36b67 623 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 157:ff67d9f36b67 624 #define GPIO_AF3_TIM8 ((uint8_t)0x03U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 625 #define GPIO_AF3_COMP7 ((uint8_t)0x03U) /* COMP7 Alternate Function mapping */
<> 157:ff67d9f36b67 626 #define GPIO_AF3_TIM15 ((uint8_t)0x03U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 627 #define GPIO_AF3_I2C3 ((uint8_t)0x03U) /* I2C3 Alternate Function mapping */
<> 157:ff67d9f36b67 628 #define GPIO_AF3_TIM20 ((uint8_t)0x03U) /* TIM20 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 629
<> 144:ef7eb2e8f9f7 630 /**
<> 144:ef7eb2e8f9f7 631 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 632 */
<> 157:ff67d9f36b67 633 #define GPIO_AF4_TIM1 ((uint8_t)0x04U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 634 #define GPIO_AF4_TIM8 ((uint8_t)0x04U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 635 #define GPIO_AF4_TIM16 ((uint8_t)0x04U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 636 #define GPIO_AF4_TIM17 ((uint8_t)0x04U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 637 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 638 #define GPIO_AF4_I2C2 ((uint8_t)0x04U) /* I2C2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 639
<> 144:ef7eb2e8f9f7 640 /**
<> 144:ef7eb2e8f9f7 641 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 642 */
<> 157:ff67d9f36b67 643 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1 Alternate Function mapping */
<> 157:ff67d9f36b67 644 #define GPIO_AF5_SPI2 ((uint8_t)0x05U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 645 #define GPIO_AF5_SPI3 ((uint8_t)0x05U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 646 #define GPIO_AF5_I2S ((uint8_t)0x05U) /* I2S Alternate Function mapping */
<> 157:ff67d9f36b67 647 #define GPIO_AF5_I2S2ext ((uint8_t)0x05U) /* I2S2ext Alternate Function mapping */
<> 157:ff67d9f36b67 648 #define GPIO_AF5_TIM8 ((uint8_t)0x05U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 649 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 650 #define GPIO_AF5_UART4 ((uint8_t)0x05U) /* UART4 Alternate Function mapping */
<> 157:ff67d9f36b67 651 #define GPIO_AF5_UART5 ((uint8_t)0x05U) /* UART5 Alternate Function mapping */
<> 157:ff67d9f36b67 652 #define GPIO_AF5_SPI4 ((uint8_t)0x05U) /* SPI4 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 653
<> 144:ef7eb2e8f9f7 654 /**
<> 144:ef7eb2e8f9f7 655 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 656 */
<> 157:ff67d9f36b67 657 #define GPIO_AF6_SPI2 ((uint8_t)0x06U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 658 #define GPIO_AF6_SPI3 ((uint8_t)0x06U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 659 #define GPIO_AF6_I2S3ext ((uint8_t)0x06U) /* I2S3ext Alternate Function mapping */
<> 157:ff67d9f36b67 660 #define GPIO_AF6_TIM1 ((uint8_t)0x06U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 661 #define GPIO_AF6_TIM8 ((uint8_t)0x06U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 662 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 663 #define GPIO_AF6_TIM20 ((uint8_t)0x06U) /* TIM20 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 664
<> 144:ef7eb2e8f9f7 665 /**
<> 144:ef7eb2e8f9f7 666 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 667 */
<> 157:ff67d9f36b67 668 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 669 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 670 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 671 #define GPIO_AF7_COMP3 ((uint8_t)0x07U) /* COMP3 Alternate Function mapping */
<> 157:ff67d9f36b67 672 #define GPIO_AF7_COMP5 ((uint8_t)0x07U) /* COMP5 Alternate Function mapping */
<> 157:ff67d9f36b67 673 #define GPIO_AF7_COMP6 ((uint8_t)0x07U) /* COMP6 Alternate Function mapping */
<> 157:ff67d9f36b67 674 #define GPIO_AF7_CAN ((uint8_t)0x07U) /* CAN Alternate Function mapping */
<> 144:ef7eb2e8f9f7 675
<> 144:ef7eb2e8f9f7 676 /**
<> 144:ef7eb2e8f9f7 677 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 678 */
<> 157:ff67d9f36b67 679 #define GPIO_AF8_COMP1 ((uint8_t)0x08U) /* COMP1 Alternate Function mapping */
<> 157:ff67d9f36b67 680 #define GPIO_AF8_COMP2 ((uint8_t)0x08U) /* COMP2 Alternate Function mapping */
<> 157:ff67d9f36b67 681 #define GPIO_AF8_COMP3 ((uint8_t)0x08U) /* COMP3 Alternate Function mapping */
<> 157:ff67d9f36b67 682 #define GPIO_AF8_COMP4 ((uint8_t)0x08U) /* COMP4 Alternate Function mapping */
<> 157:ff67d9f36b67 683 #define GPIO_AF8_COMP5 ((uint8_t)0x08U) /* COMP5 Alternate Function mapping */
<> 157:ff67d9f36b67 684 #define GPIO_AF8_COMP6 ((uint8_t)0x08U) /* COMP6 Alternate Function mapping */
<> 157:ff67d9f36b67 685 #define GPIO_AF8_I2C3 ((uint8_t)0x08U) /* I2C3 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 686
<> 144:ef7eb2e8f9f7 687 /**
<> 144:ef7eb2e8f9f7 688 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 689 */
<> 157:ff67d9f36b67 690 #define GPIO_AF9_CAN ((uint8_t)0x09U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 691 #define GPIO_AF9_TIM1 ((uint8_t)0x09U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 692 #define GPIO_AF9_TIM8 ((uint8_t)0x09U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 693 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 694
<> 144:ef7eb2e8f9f7 695 /**
<> 144:ef7eb2e8f9f7 696 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 697 */
<> 157:ff67d9f36b67 698 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 699 #define GPIO_AF10_TIM3 ((uint8_t)0xAU) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 700 #define GPIO_AF10_TIM4 ((uint8_t)0xAU) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 701 #define GPIO_AF10_TIM8 ((uint8_t)0xAU) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 702 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 703 /**
<> 144:ef7eb2e8f9f7 704 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 705 */
<> 157:ff67d9f36b67 706 #define GPIO_AF11_TIM1 ((uint8_t)0x0BU) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 707 #define GPIO_AF11_TIM8 ((uint8_t)0x0BU) /* TIM8 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 708
<> 144:ef7eb2e8f9f7 709 /**
<> 144:ef7eb2e8f9f7 710 * @brief AF 12 selection
<> 144:ef7eb2e8f9f7 711 */
<> 157:ff67d9f36b67 712 #define GPIO_AF12_TIM1 ((uint8_t)0xCU) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 713 #define GPIO_AF12_FMC ((uint8_t)0xCU) /* FMC Alternate Function mapping */
<> 157:ff67d9f36b67 714 #define GPIO_AF12_SDIO ((uint8_t)0xCU) /* SDIO Alternate Function mapping */
<> 144:ef7eb2e8f9f7 715
<> 144:ef7eb2e8f9f7 716 /**
<> 144:ef7eb2e8f9f7 717 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 718 */
<> 157:ff67d9f36b67 719 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 720
<> 157:ff67d9f36b67 721 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0CU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 722 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 723 #endif /* STM32F398xx */
<> 144:ef7eb2e8f9f7 724
<> 144:ef7eb2e8f9f7 725 #if defined (STM32F358xx)
<> 144:ef7eb2e8f9f7 726 /*---------------------------------- STM32F358xx -------------------------------------------*/
<> 144:ef7eb2e8f9f7 727 /**
<> 144:ef7eb2e8f9f7 728 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 729 */
<> 157:ff67d9f36b67 730 #define GPIO_AF0_RTC_50Hz ((uint8_t)0x00U) /* RTC_50Hz Alternate Function mapping */
<> 157:ff67d9f36b67 731 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 732 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 733 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 734 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 735
<> 144:ef7eb2e8f9f7 736 /**
<> 144:ef7eb2e8f9f7 737 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 738 */
<> 157:ff67d9f36b67 739 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 740 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 741 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 742 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 743 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 744 /**
<> 144:ef7eb2e8f9f7 745 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 746 */
<> 157:ff67d9f36b67 747 #define GPIO_AF2_TIM1 ((uint8_t)0x02U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 748 #define GPIO_AF2_TIM2 ((uint8_t)0x02U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 749 #define GPIO_AF2_TIM3 ((uint8_t)0x02U) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 750 #define GPIO_AF2_TIM4 ((uint8_t)0x02U) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 751 #define GPIO_AF2_TIM8 ((uint8_t)0x02U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 752 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 753 #define GPIO_AF2_COMP1 ((uint8_t)0x02U) /* COMP1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 754 /**
<> 144:ef7eb2e8f9f7 755 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 756 */
<> 157:ff67d9f36b67 757 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 157:ff67d9f36b67 758 #define GPIO_AF3_TIM8 ((uint8_t)0x03U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 759 #define GPIO_AF3_COMP7 ((uint8_t)0x03U) /* COMP7 Alternate Function mapping */
<> 157:ff67d9f36b67 760 #define GPIO_AF3_TIM15 ((uint8_t)0x03U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 761
<> 144:ef7eb2e8f9f7 762 /**
<> 144:ef7eb2e8f9f7 763 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 764 */
<> 157:ff67d9f36b67 765 #define GPIO_AF4_TIM1 ((uint8_t)0x04U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 766 #define GPIO_AF4_TIM8 ((uint8_t)0x04U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 767 #define GPIO_AF4_TIM16 ((uint8_t)0x04U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 768 #define GPIO_AF4_TIM17 ((uint8_t)0x04U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 769 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 770 #define GPIO_AF4_I2C2 ((uint8_t)0x04U) /* I2C2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 771
<> 144:ef7eb2e8f9f7 772 /**
<> 144:ef7eb2e8f9f7 773 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 774 */
<> 157:ff67d9f36b67 775 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1/I2S1 Alternate Function mapping */
<> 157:ff67d9f36b67 776 #define GPIO_AF5_SPI2 ((uint8_t)0x05U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 777 #define GPIO_AF5_SPI3 ((uint8_t)0x05U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 778 #define GPIO_AF5_I2S ((uint8_t)0x05U) /* I2S Alternate Function mapping */
<> 157:ff67d9f36b67 779 #define GPIO_AF5_I2S2ext ((uint8_t)0x05U) /* I2S2ext Alternate Function mapping */
<> 157:ff67d9f36b67 780 #define GPIO_AF5_TIM8 ((uint8_t)0x05U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 781 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 782 #define GPIO_AF5_UART4 ((uint8_t)0x05U) /* UART4 Alternate Function mapping */
<> 157:ff67d9f36b67 783 #define GPIO_AF5_UART5 ((uint8_t)0x05U) /* UART5 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 784 /**
<> 144:ef7eb2e8f9f7 785 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 786 */
<> 157:ff67d9f36b67 787 #define GPIO_AF6_SPI2 ((uint8_t)0x06U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 788 #define GPIO_AF6_SPI3 ((uint8_t)0x06U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 789 #define GPIO_AF6_I2S3ext ((uint8_t)0x06U) /* I2S3ext Alternate Function mapping */
<> 157:ff67d9f36b67 790 #define GPIO_AF6_TIM1 ((uint8_t)0x06U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 791 #define GPIO_AF6_TIM8 ((uint8_t)0x06U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 792 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 793
<> 144:ef7eb2e8f9f7 794 /**
<> 144:ef7eb2e8f9f7 795 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 796 */
<> 157:ff67d9f36b67 797 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 798 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 799 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 800 #define GPIO_AF7_COMP3 ((uint8_t)0x07U) /* COMP3 Alternate Function mapping */
<> 157:ff67d9f36b67 801 #define GPIO_AF7_COMP5 ((uint8_t)0x07U) /* COMP5 Alternate Function mapping */
<> 157:ff67d9f36b67 802 #define GPIO_AF7_COMP6 ((uint8_t)0x07U) /* COMP6 Alternate Function mapping */
<> 157:ff67d9f36b67 803 #define GPIO_AF7_CAN ((uint8_t)0x07U) /* CAN Alternate Function mapping */
<> 144:ef7eb2e8f9f7 804
<> 144:ef7eb2e8f9f7 805 /**
<> 144:ef7eb2e8f9f7 806 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 807 */
<> 157:ff67d9f36b67 808 #define GPIO_AF8_COMP1 ((uint8_t)0x08U) /* COMP1 Alternate Function mapping */
<> 157:ff67d9f36b67 809 #define GPIO_AF8_COMP2 ((uint8_t)0x08U) /* COMP2 Alternate Function mapping */
<> 157:ff67d9f36b67 810 #define GPIO_AF8_COMP3 ((uint8_t)0x08U) /* COMP3 Alternate Function mapping */
<> 157:ff67d9f36b67 811 #define GPIO_AF8_COMP4 ((uint8_t)0x08U) /* COMP4 Alternate Function mapping */
<> 157:ff67d9f36b67 812 #define GPIO_AF8_COMP5 ((uint8_t)0x08U) /* COMP5 Alternate Function mapping */
<> 157:ff67d9f36b67 813 #define GPIO_AF8_COMP6 ((uint8_t)0x08U) /* COMP6 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 814
<> 144:ef7eb2e8f9f7 815 /**
<> 144:ef7eb2e8f9f7 816 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 817 */
<> 157:ff67d9f36b67 818 #define GPIO_AF9_CAN ((uint8_t)0x09U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 819 #define GPIO_AF9_TIM1 ((uint8_t)0x09U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 820 #define GPIO_AF9_TIM8 ((uint8_t)0x09U) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 821 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 822
<> 144:ef7eb2e8f9f7 823 /**
<> 144:ef7eb2e8f9f7 824 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 825 */
<> 157:ff67d9f36b67 826 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 827 #define GPIO_AF10_TIM3 ((uint8_t)0xAU) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 828 #define GPIO_AF10_TIM4 ((uint8_t)0xAU) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 829 #define GPIO_AF10_TIM8 ((uint8_t)0xAU) /* TIM8 Alternate Function mapping */
<> 157:ff67d9f36b67 830 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 831 /**
<> 144:ef7eb2e8f9f7 832 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 833 */
<> 157:ff67d9f36b67 834 #define GPIO_AF11_TIM1 ((uint8_t)0x0BU) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 835 #define GPIO_AF11_TIM8 ((uint8_t)0x0BU) /* TIM8 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 836
<> 144:ef7eb2e8f9f7 837 /**
<> 144:ef7eb2e8f9f7 838 * @brief AF 12 selection
<> 144:ef7eb2e8f9f7 839 */
<> 157:ff67d9f36b67 840 #define GPIO_AF12_TIM1 ((uint8_t)0xCU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 841
<> 144:ef7eb2e8f9f7 842 /**
<> 144:ef7eb2e8f9f7 843 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 844 */
<> 157:ff67d9f36b67 845 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 846
<> 157:ff67d9f36b67 847 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0CU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 848 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 849 #endif /* STM32F358xx */
<> 144:ef7eb2e8f9f7 850
<> 144:ef7eb2e8f9f7 851 #if defined (STM32F373xC)
<> 144:ef7eb2e8f9f7 852 /*---------------------------------- STM32F373xC--------------------------------*/
<> 144:ef7eb2e8f9f7 853 /**
<> 144:ef7eb2e8f9f7 854 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 855 */
<> 157:ff67d9f36b67 856 #define GPIO_AF0_RTC_50Hz ((uint8_t)0x00U) /* RTC_50Hz Alternate Function mapping */
<> 157:ff67d9f36b67 857 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 858 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 859 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 860 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 861
<> 144:ef7eb2e8f9f7 862 /**
<> 144:ef7eb2e8f9f7 863 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 864 */
<> 157:ff67d9f36b67 865 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 866 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 867 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 868 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 869 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 870 /**
<> 144:ef7eb2e8f9f7 871 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 872 */
<> 157:ff67d9f36b67 873 #define GPIO_AF2_TIM3 ((uint8_t)0x02U) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 874 #define GPIO_AF2_TIM4 ((uint8_t)0x02U) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 875 #define GPIO_AF2_TIM5 ((uint8_t)0x02U) /* TIM5 Alternate Function mapping */
<> 157:ff67d9f36b67 876 #define GPIO_AF2_TIM13 ((uint8_t)0x02U) /* TIM13 Alternate Function mapping */
<> 157:ff67d9f36b67 877 #define GPIO_AF2_TIM14 ((uint8_t)0x02U) /* TIM14 Alternate Function mapping */
<> 157:ff67d9f36b67 878 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 879 #define GPIO_AF2_TIM19 ((uint8_t)0x02U) /* TIM19 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 880
<> 144:ef7eb2e8f9f7 881 /**
<> 144:ef7eb2e8f9f7 882 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 883 */
<> 157:ff67d9f36b67 884 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 144:ef7eb2e8f9f7 885 /**
<> 144:ef7eb2e8f9f7 886 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 887 */
<> 157:ff67d9f36b67 888 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 889 #define GPIO_AF4_I2C2 ((uint8_t)0x04U) /* I2C2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 890
<> 144:ef7eb2e8f9f7 891 /**
<> 144:ef7eb2e8f9f7 892 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 893 */
<> 157:ff67d9f36b67 894 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1/I2S1 Alternate Function mapping */
<> 157:ff67d9f36b67 895 #define GPIO_AF5_SPI2 ((uint8_t)0x05U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 896 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 897 /**
<> 144:ef7eb2e8f9f7 898 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 899 */
<> 157:ff67d9f36b67 900 #define GPIO_AF6_SPI1 ((uint8_t)0x06U) /* SPI1/I2S1 Alternate Function mapping */
<> 157:ff67d9f36b67 901 #define GPIO_AF6_SPI3 ((uint8_t)0x06U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 902 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 903 #define GPIO_AF6_CEC ((uint8_t)0x06U) /* CEC Alternate Function mapping */
<> 144:ef7eb2e8f9f7 904 /**
<> 144:ef7eb2e8f9f7 905 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 906 */
<> 157:ff67d9f36b67 907 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 908 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 909 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 910 #define GPIO_AF7_CAN ((uint8_t)0x07U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 911 #define GPIO_AF7_CEC ((uint8_t)0x07U) /* CEC Alternate Function mapping */
<> 144:ef7eb2e8f9f7 912
<> 144:ef7eb2e8f9f7 913 /**
<> 144:ef7eb2e8f9f7 914 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 915 */
<> 157:ff67d9f36b67 916 #define GPIO_AF8_COMP1 ((uint8_t)0x08U) /* COMP1 Alternate Function mapping */
<> 157:ff67d9f36b67 917 #define GPIO_AF8_COMP2 ((uint8_t)0x08U) /* COMP2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 918
<> 144:ef7eb2e8f9f7 919 /**
<> 144:ef7eb2e8f9f7 920 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 921 */
<> 157:ff67d9f36b67 922 #define GPIO_AF9_CAN ((uint8_t)0x09U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 923 #define GPIO_AF9_TIM12 ((uint8_t)0x09U) /* TIM12 Alternate Function mapping */
<> 157:ff67d9f36b67 924 #define GPIO_AF9_TIM13 ((uint8_t)0x09U) /* TIM13 Alternate Function mapping */
<> 157:ff67d9f36b67 925 #define GPIO_AF9_TIM14 ((uint8_t)0x09U) /* TIM14 Alternate Function mapping */
<> 157:ff67d9f36b67 926 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 927 /**
<> 144:ef7eb2e8f9f7 928 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 929 */
<> 157:ff67d9f36b67 930 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 931 #define GPIO_AF10_TIM3 ((uint8_t)0xAU) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 932 #define GPIO_AF10_TIM4 ((uint8_t)0xAU) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 933 #define GPIO_AF10_TIM12 ((uint8_t)0xAU) /* TIM12 Alternate Function mapping */
<> 157:ff67d9f36b67 934 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 935 /**
<> 144:ef7eb2e8f9f7 936 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 937 */
<> 157:ff67d9f36b67 938 #define GPIO_AF11_TIM19 ((uint8_t)0x0BU) /* TIM19 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 939
<> 144:ef7eb2e8f9f7 940
<> 144:ef7eb2e8f9f7 941 /**
<> 144:ef7eb2e8f9f7 942 * @brief AF 14 selection
<> 144:ef7eb2e8f9f7 943 */
<> 157:ff67d9f36b67 944 #define GPIO_AF14_USB ((uint8_t)0x0EU) /* USB Alternate Function mapping */
<> 144:ef7eb2e8f9f7 945
<> 144:ef7eb2e8f9f7 946 /**
<> 144:ef7eb2e8f9f7 947 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 948 */
<> 157:ff67d9f36b67 949 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 950
<> 157:ff67d9f36b67 951 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0BU) || ((AF) == (uint8_t)0x0EU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 952 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 953 #endif /* STM32F373xC */
<> 144:ef7eb2e8f9f7 954
<> 144:ef7eb2e8f9f7 955
<> 144:ef7eb2e8f9f7 956 #if defined (STM32F378xx)
<> 144:ef7eb2e8f9f7 957 /*---------------------------------------- STM32F378xx--------------------------------------*/
<> 144:ef7eb2e8f9f7 958 /**
<> 144:ef7eb2e8f9f7 959 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 960 */
<> 157:ff67d9f36b67 961 #define GPIO_AF0_RTC_50Hz ((uint8_t)0x00U) /* RTC_50Hz Alternate Function mapping */
<> 157:ff67d9f36b67 962 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 963 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 964 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 965 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 966
<> 144:ef7eb2e8f9f7 967 /**
<> 144:ef7eb2e8f9f7 968 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 969 */
<> 157:ff67d9f36b67 970 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 971 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 972 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 973 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 974 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 975 /**
<> 144:ef7eb2e8f9f7 976 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 977 */
<> 157:ff67d9f36b67 978 #define GPIO_AF2_TIM3 ((uint8_t)0x02U) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 979 #define GPIO_AF2_TIM4 ((uint8_t)0x02U) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 980 #define GPIO_AF2_TIM5 ((uint8_t)0x02U) /* TIM5 Alternate Function mapping */
<> 157:ff67d9f36b67 981 #define GPIO_AF2_TIM13 ((uint8_t)0x02U) /* TIM13 Alternate Function mapping */
<> 157:ff67d9f36b67 982 #define GPIO_AF2_TIM14 ((uint8_t)0x02U) /* TIM14 Alternate Function mapping */
<> 157:ff67d9f36b67 983 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 984 #define GPIO_AF2_TIM19 ((uint8_t)0x02U) /* TIM19 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 985
<> 144:ef7eb2e8f9f7 986 /**
<> 144:ef7eb2e8f9f7 987 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 988 */
<> 157:ff67d9f36b67 989 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 144:ef7eb2e8f9f7 990 /**
<> 144:ef7eb2e8f9f7 991 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 992 */
<> 157:ff67d9f36b67 993 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 994 #define GPIO_AF4_I2C2 ((uint8_t)0x04U) /* I2C2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 995
<> 144:ef7eb2e8f9f7 996 /**
<> 144:ef7eb2e8f9f7 997 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 998 */
<> 157:ff67d9f36b67 999 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1/I2S1 Alternate Function mapping */
<> 157:ff67d9f36b67 1000 #define GPIO_AF5_SPI2 ((uint8_t)0x05U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 1001 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1002
<> 144:ef7eb2e8f9f7 1003 /**
<> 144:ef7eb2e8f9f7 1004 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 1005 */
<> 157:ff67d9f36b67 1006 #define GPIO_AF6_SPI1 ((uint8_t)0x06U) /* SPI1/I2S1 Alternate Function mapping */
<> 157:ff67d9f36b67 1007 #define GPIO_AF6_SPI3 ((uint8_t)0x06U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 1008 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 1009 #define GPIO_AF6_CEC ((uint8_t)0x06U) /* CEC Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1010
<> 144:ef7eb2e8f9f7 1011 /**
<> 144:ef7eb2e8f9f7 1012 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 1013 */
<> 157:ff67d9f36b67 1014 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 1015 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 1016 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 1017 #define GPIO_AF7_CAN ((uint8_t)0x07U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 1018 #define GPIO_AF7_CEC ((uint8_t)0x07U) /* CEC Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1019
<> 144:ef7eb2e8f9f7 1020 /**
<> 144:ef7eb2e8f9f7 1021 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 1022 */
<> 157:ff67d9f36b67 1023 #define GPIO_AF8_COMP1 ((uint8_t)0x08U) /* COMP1 Alternate Function mapping */
<> 157:ff67d9f36b67 1024 #define GPIO_AF8_COMP2 ((uint8_t)0x08U) /* COMP2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1025
<> 144:ef7eb2e8f9f7 1026 /**
<> 144:ef7eb2e8f9f7 1027 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 1028 */
<> 157:ff67d9f36b67 1029 #define GPIO_AF9_CAN ((uint8_t)0x09U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 1030 #define GPIO_AF9_TIM12 ((uint8_t)0x09U) /* TIM12 Alternate Function mapping */
<> 157:ff67d9f36b67 1031 #define GPIO_AF9_TIM13 ((uint8_t)0x09U) /* TIM13 Alternate Function mapping */
<> 157:ff67d9f36b67 1032 #define GPIO_AF9_TIM14 ((uint8_t)0x09U) /* TIM14 Alternate Function mapping */
<> 157:ff67d9f36b67 1033 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1034
<> 144:ef7eb2e8f9f7 1035 /**
<> 144:ef7eb2e8f9f7 1036 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 1037 */
<> 157:ff67d9f36b67 1038 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 1039 #define GPIO_AF10_TIM3 ((uint8_t)0xAU) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 1040 #define GPIO_AF10_TIM4 ((uint8_t)0xAU) /* TIM4 Alternate Function mapping */
<> 157:ff67d9f36b67 1041 #define GPIO_AF10_TIM12 ((uint8_t)0xAU) /* TIM12 Alternate Function mapping */
<> 157:ff67d9f36b67 1042 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1043
<> 144:ef7eb2e8f9f7 1044 /**
<> 144:ef7eb2e8f9f7 1045 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 1046 */
<> 157:ff67d9f36b67 1047 #define GPIO_AF11_TIM19 ((uint8_t)0x0BU) /* TIM19 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1048
<> 144:ef7eb2e8f9f7 1049 /**
<> 144:ef7eb2e8f9f7 1050 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 1051 */
<> 157:ff67d9f36b67 1052 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1053
<> 157:ff67d9f36b67 1054 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0BU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 1055 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 1056 #endif /* STM32F378xx */
<> 144:ef7eb2e8f9f7 1057
<> 144:ef7eb2e8f9f7 1058 #if defined (STM32F303x8)
<> 144:ef7eb2e8f9f7 1059 /*---------------------------------- STM32F303x8--------------------------------*/
<> 144:ef7eb2e8f9f7 1060 /**
<> 144:ef7eb2e8f9f7 1061 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 1062 */
<> 157:ff67d9f36b67 1063 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 1064 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 1065 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 1066 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1067
<> 144:ef7eb2e8f9f7 1068 /**
<> 144:ef7eb2e8f9f7 1069 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 1070 */
<> 157:ff67d9f36b67 1071 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 1072 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 1073 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 1074 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 1075 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1076 /**
<> 144:ef7eb2e8f9f7 1077 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 1078 */
<> 157:ff67d9f36b67 1079 #define GPIO_AF2_TIM3 ((uint8_t)0x02U) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 1080 #define GPIO_AF2_TIM1 ((uint8_t)0x02U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1081 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 1082 #define GPIO_AF2_TIM16 ((uint8_t)0x02U) /* TIM16 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1083
<> 144:ef7eb2e8f9f7 1084 /**
<> 144:ef7eb2e8f9f7 1085 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 1086 */
<> 157:ff67d9f36b67 1087 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1088
<> 144:ef7eb2e8f9f7 1089 /**
<> 144:ef7eb2e8f9f7 1090 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 1091 */
<> 157:ff67d9f36b67 1092 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 1093 #define GPIO_AF4_TIM1 ((uint8_t)0x04U) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1094
<> 144:ef7eb2e8f9f7 1095 /**
<> 144:ef7eb2e8f9f7 1096 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 1097 */
<> 157:ff67d9f36b67 1098 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1 Alternate Function mapping */
<> 157:ff67d9f36b67 1099 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1100 /**
<> 144:ef7eb2e8f9f7 1101 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 1102 */
<> 157:ff67d9f36b67 1103 #define GPIO_AF6_TIM1 ((uint8_t)0x06U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1104 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1105
<> 144:ef7eb2e8f9f7 1106 /**
<> 144:ef7eb2e8f9f7 1107 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 1108 */
<> 157:ff67d9f36b67 1109 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 1110 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 1111 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 1112 #define GPIO_AF7_GPCOMP6 ((uint8_t)0x07U) /* GPCOMP6 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1113
<> 144:ef7eb2e8f9f7 1114 /**
<> 144:ef7eb2e8f9f7 1115 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 1116 */
<> 157:ff67d9f36b67 1117 #define GPIO_AF8_GPCOMP2 ((uint8_t)0x08U) /* GPCOMP2 Alternate Function mapping */
<> 157:ff67d9f36b67 1118 #define GPIO_AF8_GPCOMP4 ((uint8_t)0x08U) /* GPCOMP4 Alternate Function mapping */
<> 157:ff67d9f36b67 1119 #define GPIO_AF8_GPCOMP6 ((uint8_t)0x08U) /* GPCOMP6 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1120
<> 144:ef7eb2e8f9f7 1121 /**
<> 144:ef7eb2e8f9f7 1122 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 1123 */
<> 157:ff67d9f36b67 1124 #define GPIO_AF9_CAN ((uint8_t)0x09U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 1125 #define GPIO_AF9_TIM1 ((uint8_t)0x09U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1126 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1127 /**
<> 144:ef7eb2e8f9f7 1128 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 1129 */
<> 157:ff67d9f36b67 1130 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 1131 #define GPIO_AF10_TIM3 ((uint8_t)0xAU) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 1132 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1133
<> 144:ef7eb2e8f9f7 1134 /**
<> 144:ef7eb2e8f9f7 1135 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 1136 */
<> 157:ff67d9f36b67 1137 #define GPIO_AF11_TIM1 ((uint8_t)0x0BU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1138
<> 144:ef7eb2e8f9f7 1139 /**
<> 144:ef7eb2e8f9f7 1140 * @brief AF 12 selection
<> 144:ef7eb2e8f9f7 1141 */
<> 157:ff67d9f36b67 1142 #define GPIO_AF12_TIM1 ((uint8_t)0x0CU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1143
<> 144:ef7eb2e8f9f7 1144 /**
<> 144:ef7eb2e8f9f7 1145 * @brief AF 13 selection
<> 144:ef7eb2e8f9f7 1146 */
<> 157:ff67d9f36b67 1147 #define GPIO_AF13_OPAMP2 ((uint8_t)0x0DU) /* OPAMP2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1148
<> 144:ef7eb2e8f9f7 1149 /**
<> 144:ef7eb2e8f9f7 1150 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 1151 */
<> 157:ff67d9f36b67 1152 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1153
<> 157:ff67d9f36b67 1154 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0DU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 1155 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 1156 #endif /* STM32F303x8 */
<> 144:ef7eb2e8f9f7 1157
<> 144:ef7eb2e8f9f7 1158 #if defined (STM32F334x8) || defined (STM32F328xx)
<> 144:ef7eb2e8f9f7 1159 /*---------------------------------- STM32F334x8/STM32F328xx -------------------------------*/
<> 144:ef7eb2e8f9f7 1160 /**
<> 144:ef7eb2e8f9f7 1161 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 1162 */
<> 157:ff67d9f36b67 1163 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 1164 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 1165 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 1166 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1167
<> 144:ef7eb2e8f9f7 1168 /**
<> 144:ef7eb2e8f9f7 1169 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 1170 */
<> 157:ff67d9f36b67 1171 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 1172 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 1173 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 1174 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 1175 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1176 /**
<> 144:ef7eb2e8f9f7 1177 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 1178 */
<> 157:ff67d9f36b67 1179 #define GPIO_AF2_TIM3 ((uint8_t)0x02U) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 1180 #define GPIO_AF2_TIM1 ((uint8_t)0x02U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1181 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 1182 #define GPIO_AF2_TIM16 ((uint8_t)0x02U) /* TIM16 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1183
<> 144:ef7eb2e8f9f7 1184 /**
<> 144:ef7eb2e8f9f7 1185 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 1186 */
<> 157:ff67d9f36b67 1187 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 157:ff67d9f36b67 1188 #define GPIO_AF3_HRTIM1 ((uint8_t)0x03U) /* HRTIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1189
<> 144:ef7eb2e8f9f7 1190 /**
<> 144:ef7eb2e8f9f7 1191 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 1192 */
<> 157:ff67d9f36b67 1193 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 1194 #define GPIO_AF4_TIM1 ((uint8_t)0x04U) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1195
<> 144:ef7eb2e8f9f7 1196 /**
<> 144:ef7eb2e8f9f7 1197 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 1198 */
<> 157:ff67d9f36b67 1199 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1 Alternate Function mapping */
<> 157:ff67d9f36b67 1200 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1201 /**
<> 144:ef7eb2e8f9f7 1202 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 1203 */
<> 157:ff67d9f36b67 1204 #define GPIO_AF6_TIM1 ((uint8_t)0x06U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1205 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1206
<> 144:ef7eb2e8f9f7 1207 /**
<> 144:ef7eb2e8f9f7 1208 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 1209 */
<> 157:ff67d9f36b67 1210 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 1211 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 1212 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 1213 #define GPIO_AF7_GPCOMP6 ((uint8_t)0x07U) /* GPCOMP6 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1214
<> 144:ef7eb2e8f9f7 1215 /**
<> 144:ef7eb2e8f9f7 1216 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 1217 */
<> 157:ff67d9f36b67 1218 #define GPIO_AF8_GPCOMP2 ((uint8_t)0x08U) /* GPCOMP2 Alternate Function mapping */
<> 157:ff67d9f36b67 1219 #define GPIO_AF8_GPCOMP4 ((uint8_t)0x08U) /* GPCOMP4 Alternate Function mapping */
<> 157:ff67d9f36b67 1220 #define GPIO_AF8_GPCOMP6 ((uint8_t)0x08U) /* GPCOMP6 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1221
<> 144:ef7eb2e8f9f7 1222 /**
<> 144:ef7eb2e8f9f7 1223 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 1224 */
<> 157:ff67d9f36b67 1225 #define GPIO_AF9_CAN ((uint8_t)0x09U) /* CAN Alternate Function mapping */
<> 157:ff67d9f36b67 1226 #define GPIO_AF9_TIM1 ((uint8_t)0x09U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1227 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1228 /**
<> 144:ef7eb2e8f9f7 1229 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 1230 */
<> 157:ff67d9f36b67 1231 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 1232 #define GPIO_AF10_TIM3 ((uint8_t)0xAU) /* TIM3 Alternate Function mapping */
<> 157:ff67d9f36b67 1233 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1234
<> 144:ef7eb2e8f9f7 1235 /**
<> 144:ef7eb2e8f9f7 1236 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 1237 */
<> 157:ff67d9f36b67 1238 #define GPIO_AF11_TIM1 ((uint8_t)0x0BU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1239
<> 144:ef7eb2e8f9f7 1240 /**
<> 144:ef7eb2e8f9f7 1241 * @brief AF 12 selection
<> 144:ef7eb2e8f9f7 1242 */
<> 157:ff67d9f36b67 1243 #define GPIO_AF12_TIM1 ((uint8_t)0x0CU) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1244 #define GPIO_AF12_HRTIM1 ((uint8_t)0x0CU) /* HRTIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1245
<> 144:ef7eb2e8f9f7 1246 /**
<> 144:ef7eb2e8f9f7 1247 * @brief AF 13 selection
<> 144:ef7eb2e8f9f7 1248 */
<> 157:ff67d9f36b67 1249 #define GPIO_AF13_OPAMP2 ((uint8_t)0x0DU) /* OPAMP2 Alternate Function mapping */
<> 157:ff67d9f36b67 1250 #define GPIO_AF13_HRTIM1 ((uint8_t)0x0DU) /* HRTIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1251
<> 144:ef7eb2e8f9f7 1252 /**
<> 144:ef7eb2e8f9f7 1253 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 1254 */
<> 157:ff67d9f36b67 1255 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1256
<> 157:ff67d9f36b67 1257 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0DU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 1258 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 1259 #endif /* STM32F334x8 || STM32F328xx */
<> 144:ef7eb2e8f9f7 1260
<> 144:ef7eb2e8f9f7 1261 #if defined (STM32F301x8) || defined (STM32F318xx)
<> 144:ef7eb2e8f9f7 1262 /*---------------------------------- STM32F301x8 / STM32F318xx ------------------------------------------*/
<> 144:ef7eb2e8f9f7 1263 /**
<> 144:ef7eb2e8f9f7 1264 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 1265 */
<> 157:ff67d9f36b67 1266 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 1267 #define GPIO_AF0_RTC_50Hz ((uint8_t)0x00U) /* RTC Alternate Function mapping */
<> 157:ff67d9f36b67 1268 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 1269 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 1270 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1271
<> 144:ef7eb2e8f9f7 1272 /**
<> 144:ef7eb2e8f9f7 1273 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 1274 */
<> 157:ff67d9f36b67 1275 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 1276 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 1277 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 1278 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 1279 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1280 /**
<> 144:ef7eb2e8f9f7 1281 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 1282 */
<> 157:ff67d9f36b67 1283 #define GPIO_AF2_I2C3 ((uint8_t)0x02U) /* I2C3 Alternate Function mapping */
<> 157:ff67d9f36b67 1284 #define GPIO_AF2_TIM1 ((uint8_t)0x02U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1285 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 1286 #define GPIO_AF2_TIM2 ((uint8_t)0x02U) /* TIM2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1287
<> 144:ef7eb2e8f9f7 1288 /**
<> 144:ef7eb2e8f9f7 1289 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 1290 */
<> 157:ff67d9f36b67 1291 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 157:ff67d9f36b67 1292 #define GPIO_AF3_I2C3 ((uint8_t)0x03U) /* I2C3 Alternate Function mapping */
<> 157:ff67d9f36b67 1293 #define GPIO_AF3_TIM15 ((uint8_t)0x03U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1294
<> 144:ef7eb2e8f9f7 1295 /**
<> 144:ef7eb2e8f9f7 1296 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 1297 */
<> 157:ff67d9f36b67 1298 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 1299 #define GPIO_AF4_I2C2 ((uint8_t)0x04U) /* I2C2 Alternate Function mapping */
<> 157:ff67d9f36b67 1300 #define GPIO_AF4_TIM1 ((uint8_t)0x04U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1301 #define GPIO_AF4_TIM16 ((uint8_t)0x04U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 1302 #define GPIO_AF4_TIM17 ((uint8_t)0x04U) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1303
<> 144:ef7eb2e8f9f7 1304 /**
<> 144:ef7eb2e8f9f7 1305 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 1306 */
<> 157:ff67d9f36b67 1307 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1 Alternate Function mapping */
<> 157:ff67d9f36b67 1308 #define GPIO_AF5_SPI2 ((uint8_t)0x05U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 1309 #define GPIO_AF5_SPI3 ((uint8_t)0x05U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 1310 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1311 /**
<> 144:ef7eb2e8f9f7 1312 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 1313 */
<> 157:ff67d9f36b67 1314 #define GPIO_AF6_TIM1 ((uint8_t)0x06U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1315 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 1316 #define GPIO_AF6_SPI2 ((uint8_t)0x06U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 1317 #define GPIO_AF6_SPI3 ((uint8_t)0x06U) /* SPI3/I2S3 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1318
<> 144:ef7eb2e8f9f7 1319 /**
<> 144:ef7eb2e8f9f7 1320 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 1321 */
<> 157:ff67d9f36b67 1322 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 1323 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 1324 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 1325 #define GPIO_AF7_GPCOMP6 ((uint8_t)0x07U) /* GPCOMP6 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1326
<> 144:ef7eb2e8f9f7 1327 /**
<> 144:ef7eb2e8f9f7 1328 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 1329 */
<> 157:ff67d9f36b67 1330 #define GPIO_AF8_I2C3 ((uint8_t)0x08U) /* I2C3 Alternate Function mapping */
<> 157:ff67d9f36b67 1331 #define GPIO_AF8_GPCOMP2 ((uint8_t)0x08U) /* GPCOMP2 Alternate Function mapping */
<> 157:ff67d9f36b67 1332 #define GPIO_AF8_GPCOMP4 ((uint8_t)0x08U) /* GPCOMP4 Alternate Function mapping */
<> 157:ff67d9f36b67 1333 #define GPIO_AF8_GPCOMP6 ((uint8_t)0x08U) /* GPCOMP6 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1334
<> 144:ef7eb2e8f9f7 1335 /**
<> 144:ef7eb2e8f9f7 1336 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 1337 */
<> 157:ff67d9f36b67 1338 #define GPIO_AF9_TIM1 ((uint8_t)0x09U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1339 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1340
<> 144:ef7eb2e8f9f7 1341 /**
<> 144:ef7eb2e8f9f7 1342 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 1343 */
<> 157:ff67d9f36b67 1344 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 1345 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1346
<> 144:ef7eb2e8f9f7 1347 /**
<> 144:ef7eb2e8f9f7 1348 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 1349 */
<> 157:ff67d9f36b67 1350 #define GPIO_AF11_TIM1 ((uint8_t)0x0BU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1351
<> 144:ef7eb2e8f9f7 1352 /**
<> 144:ef7eb2e8f9f7 1353 * @brief AF 12 selection
<> 144:ef7eb2e8f9f7 1354 */
<> 157:ff67d9f36b67 1355 #define GPIO_AF12_TIM1 ((uint8_t)0x0CU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1356
<> 144:ef7eb2e8f9f7 1357 /**
<> 144:ef7eb2e8f9f7 1358 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 1359 */
<> 157:ff67d9f36b67 1360 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1361
<> 157:ff67d9f36b67 1362 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0CU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 1363 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 1364 #endif /* STM32F301x8 || STM32F318xx */
<> 144:ef7eb2e8f9f7 1365
<> 144:ef7eb2e8f9f7 1366 #if defined (STM32F302x8)
<> 144:ef7eb2e8f9f7 1367 /*---------------------------------- STM32F302x8------------------------------------------*/
<> 144:ef7eb2e8f9f7 1368 /**
<> 144:ef7eb2e8f9f7 1369 * @brief AF 0 selection
<> 144:ef7eb2e8f9f7 1370 */
<> 157:ff67d9f36b67 1371 #define GPIO_AF0_MCO ((uint8_t)0x00U) /* MCO (MCO1 and MCO2) Alternate Function mapping */
<> 157:ff67d9f36b67 1372 #define GPIO_AF0_RTC_50Hz ((uint8_t)0x00U) /* RTC Alternate Function mapping */
<> 157:ff67d9f36b67 1373 #define GPIO_AF0_TAMPER ((uint8_t)0x00U) /* TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
<> 157:ff67d9f36b67 1374 #define GPIO_AF0_SWJ ((uint8_t)0x00U) /* SWJ (SWD and JTAG) Alternate Function mapping */
<> 157:ff67d9f36b67 1375 #define GPIO_AF0_TRACE ((uint8_t)0x00U) /* TRACE Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1376
<> 144:ef7eb2e8f9f7 1377 /**
<> 144:ef7eb2e8f9f7 1378 * @brief AF 1 selection
<> 144:ef7eb2e8f9f7 1379 */
<> 157:ff67d9f36b67 1380 #define GPIO_AF1_TIM2 ((uint8_t)0x01U) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 1381 #define GPIO_AF1_TIM15 ((uint8_t)0x01U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 1382 #define GPIO_AF1_TIM16 ((uint8_t)0x01U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 1383 #define GPIO_AF1_TIM17 ((uint8_t)0x01U) /* TIM17 Alternate Function mapping */
<> 157:ff67d9f36b67 1384 #define GPIO_AF1_EVENTOUT ((uint8_t)0x01U) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1385 /**
<> 144:ef7eb2e8f9f7 1386 * @brief AF 2 selection
<> 144:ef7eb2e8f9f7 1387 */
<> 157:ff67d9f36b67 1388 #define GPIO_AF2_I2C3 ((uint8_t)0x02U) /* I2C3 Alternate Function mapping */
<> 157:ff67d9f36b67 1389 #define GPIO_AF2_TIM1 ((uint8_t)0x02U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1390 #define GPIO_AF2_TIM15 ((uint8_t)0x02U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 1391 #define GPIO_AF2_TIM2 ((uint8_t)0x02U) /* TIM2 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1392
<> 144:ef7eb2e8f9f7 1393 /**
<> 144:ef7eb2e8f9f7 1394 * @brief AF 3 selection
<> 144:ef7eb2e8f9f7 1395 */
<> 157:ff67d9f36b67 1396 #define GPIO_AF3_TSC ((uint8_t)0x03U) /* TSC Alternate Function mapping */
<> 157:ff67d9f36b67 1397 #define GPIO_AF3_I2C3 ((uint8_t)0x03U) /* I2C3 Alternate Function mapping */
<> 157:ff67d9f36b67 1398 #define GPIO_AF3_TIM15 ((uint8_t)0x03U) /* TIM15 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1399
<> 144:ef7eb2e8f9f7 1400 /**
<> 144:ef7eb2e8f9f7 1401 * @brief AF 4 selection
<> 144:ef7eb2e8f9f7 1402 */
<> 157:ff67d9f36b67 1403 #define GPIO_AF4_I2C1 ((uint8_t)0x04U) /* I2C1 Alternate Function mapping */
<> 157:ff67d9f36b67 1404 #define GPIO_AF4_I2C2 ((uint8_t)0x04U) /* I2C2 Alternate Function mapping */
<> 157:ff67d9f36b67 1405 #define GPIO_AF4_TIM1 ((uint8_t)0x04U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1406 #define GPIO_AF4_TIM16 ((uint8_t)0x04U) /* TIM16 Alternate Function mapping */
<> 157:ff67d9f36b67 1407 #define GPIO_AF4_TIM17 ((uint8_t)0x04U) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1408
<> 144:ef7eb2e8f9f7 1409 /**
<> 144:ef7eb2e8f9f7 1410 * @brief AF 5 selection
<> 144:ef7eb2e8f9f7 1411 */
<> 157:ff67d9f36b67 1412 #define GPIO_AF5_SPI1 ((uint8_t)0x05U) /* SPI1 Alternate Function mapping */
<> 157:ff67d9f36b67 1413 #define GPIO_AF5_SPI2 ((uint8_t)0x05U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 1414 #define GPIO_AF5_SPI3 ((uint8_t)0x05U) /* SPI3/I2S3 Alternate Function mapping */
<> 157:ff67d9f36b67 1415 #define GPIO_AF5_IR ((uint8_t)0x05U) /* IR Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1416 /**
<> 144:ef7eb2e8f9f7 1417 * @brief AF 6 selection
<> 144:ef7eb2e8f9f7 1418 */
<> 157:ff67d9f36b67 1419 #define GPIO_AF6_TIM1 ((uint8_t)0x06U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1420 #define GPIO_AF6_IR ((uint8_t)0x06U) /* IR Alternate Function mapping */
<> 157:ff67d9f36b67 1421 #define GPIO_AF6_SPI2 ((uint8_t)0x06U) /* SPI2/I2S2 Alternate Function mapping */
<> 157:ff67d9f36b67 1422 #define GPIO_AF6_SPI3 ((uint8_t)0x06U) /* SPI3/I2S3 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1423
<> 144:ef7eb2e8f9f7 1424 /**
<> 144:ef7eb2e8f9f7 1425 * @brief AF 7 selection
<> 144:ef7eb2e8f9f7 1426 */
<> 157:ff67d9f36b67 1427 #define GPIO_AF7_USART1 ((uint8_t)0x07U) /* USART1 Alternate Function mapping */
<> 157:ff67d9f36b67 1428 #define GPIO_AF7_USART2 ((uint8_t)0x07U) /* USART2 Alternate Function mapping */
<> 157:ff67d9f36b67 1429 #define GPIO_AF7_USART3 ((uint8_t)0x07U) /* USART3 Alternate Function mapping */
<> 157:ff67d9f36b67 1430 #define GPIO_AF7_GPCOMP6 ((uint8_t)0x07U) /* GPCOMP6 Alternate Function mapping */
<> 157:ff67d9f36b67 1431 #define GPIO_AF7_CAN ((uint8_t)0x07U) /* CAN Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1432
<> 144:ef7eb2e8f9f7 1433 /**
<> 144:ef7eb2e8f9f7 1434 * @brief AF 8 selection
<> 144:ef7eb2e8f9f7 1435 */
<> 157:ff67d9f36b67 1436 #define GPIO_AF8_I2C3 ((uint8_t)0x08U) /* I2C3 Alternate Function mapping */
<> 157:ff67d9f36b67 1437 #define GPIO_AF8_GPCOMP2 ((uint8_t)0x08U) /* GPCOMP2 Alternate Function mapping */
<> 157:ff67d9f36b67 1438 #define GPIO_AF8_GPCOMP4 ((uint8_t)0x08U) /* GPCOMP4 Alternate Function mapping */
<> 157:ff67d9f36b67 1439 #define GPIO_AF8_GPCOMP6 ((uint8_t)0x08U) /* GPCOMP6 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1440
<> 144:ef7eb2e8f9f7 1441 /**
<> 144:ef7eb2e8f9f7 1442 * @brief AF 9 selection
<> 144:ef7eb2e8f9f7 1443 */
<> 157:ff67d9f36b67 1444 #define GPIO_AF9_TIM1 ((uint8_t)0x09U) /* TIM1 Alternate Function mapping */
<> 157:ff67d9f36b67 1445 #define GPIO_AF9_TIM15 ((uint8_t)0x09U) /* TIM15 Alternate Function mapping */
<> 157:ff67d9f36b67 1446 #define GPIO_AF9_CAN ((uint8_t)0x09U) /* CAN Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1447
<> 144:ef7eb2e8f9f7 1448 /**
<> 144:ef7eb2e8f9f7 1449 * @brief AF 10 selection
<> 144:ef7eb2e8f9f7 1450 */
<> 157:ff67d9f36b67 1451 #define GPIO_AF10_TIM2 ((uint8_t)0xAU) /* TIM2 Alternate Function mapping */
<> 157:ff67d9f36b67 1452 #define GPIO_AF10_TIM17 ((uint8_t)0xAU) /* TIM17 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1453
<> 144:ef7eb2e8f9f7 1454 /**
<> 144:ef7eb2e8f9f7 1455 * @brief AF 11 selection
<> 144:ef7eb2e8f9f7 1456 */
<> 157:ff67d9f36b67 1457 #define GPIO_AF11_TIM1 ((uint8_t)0x0BU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1458
<> 144:ef7eb2e8f9f7 1459 /**
<> 144:ef7eb2e8f9f7 1460 * @brief AF 12 selection
<> 144:ef7eb2e8f9f7 1461 */
<> 157:ff67d9f36b67 1462 #define GPIO_AF12_TIM1 ((uint8_t)0x0CU) /* TIM1 Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1463
<> 144:ef7eb2e8f9f7 1464 /**
<> 144:ef7eb2e8f9f7 1465 * @brief AF 15 selection
<> 144:ef7eb2e8f9f7 1466 */
<> 157:ff67d9f36b67 1467 #define GPIO_AF15_EVENTOUT ((uint8_t)0x0FU) /* EVENTOUT Alternate Function mapping */
<> 144:ef7eb2e8f9f7 1468
<> 157:ff67d9f36b67 1469 #define IS_GPIO_AF(AF) (((AF) <= (uint8_t)0x0CU) || ((AF) == (uint8_t)0x0FU))
<> 144:ef7eb2e8f9f7 1470 /*------------------------------------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 1471 #endif /* STM32F302x8 */
<> 144:ef7eb2e8f9f7 1472 /**
<> 144:ef7eb2e8f9f7 1473 * @}
<> 144:ef7eb2e8f9f7 1474 */
<> 144:ef7eb2e8f9f7 1475
<> 144:ef7eb2e8f9f7 1476 /**
<> 144:ef7eb2e8f9f7 1477 * @}
<> 144:ef7eb2e8f9f7 1478 */
<> 144:ef7eb2e8f9f7 1479
<> 144:ef7eb2e8f9f7 1480 /* Exported macro ------------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 1481 /** @defgroup GPIOEx_Exported_Macros GPIOEx Exported Macros
<> 144:ef7eb2e8f9f7 1482 * @{
<> 144:ef7eb2e8f9f7 1483 */
<> 144:ef7eb2e8f9f7 1484
<> 144:ef7eb2e8f9f7 1485 /** @defgroup GPIOEx_Get_Port_Index GPIOEx_Get Port Index
<> 144:ef7eb2e8f9f7 1486 * @{
<> 144:ef7eb2e8f9f7 1487 */
<> 144:ef7eb2e8f9f7 1488 #if defined(STM32F303x8) || defined(STM32F334x8) || defined(STM32F328xx) || \
<> 144:ef7eb2e8f9f7 1489 defined(STM32F301x8) || defined(STM32F302x8) || defined(STM32F318xx)
<> 144:ef7eb2e8f9f7 1490 #define GPIO_GET_INDEX(__GPIOx__) (((__GPIOx__) == (GPIOA))? 0U :\
<> 144:ef7eb2e8f9f7 1491 ((__GPIOx__) == (GPIOB))? 1U :\
<> 144:ef7eb2e8f9f7 1492 ((__GPIOx__) == (GPIOC))? 2U :\
<> 144:ef7eb2e8f9f7 1493 ((__GPIOx__) == (GPIOD))? 3U : 5U)
<> 144:ef7eb2e8f9f7 1494 #endif /* STM32F303x8 || STM32F334x8 || STM32F328xx || */
<> 144:ef7eb2e8f9f7 1495 /* STM32F301x8 || STM32F302x8 || STM32F318xx */
<> 144:ef7eb2e8f9f7 1496
<> 144:ef7eb2e8f9f7 1497 #if defined(STM32F302xC) || defined(STM32F303xC) || defined(STM32F358xx) || \
<> 144:ef7eb2e8f9f7 1498 defined(STM32F373xC) || defined(STM32F378xx)
<> 144:ef7eb2e8f9f7 1499 #define GPIO_GET_INDEX(__GPIOx__) (((__GPIOx__) == (GPIOA))? 0U :\
<> 144:ef7eb2e8f9f7 1500 ((__GPIOx__) == (GPIOB))? 1U :\
<> 144:ef7eb2e8f9f7 1501 ((__GPIOx__) == (GPIOC))? 2U :\
<> 144:ef7eb2e8f9f7 1502 ((__GPIOx__) == (GPIOD))? 3U :\
<> 144:ef7eb2e8f9f7 1503 ((__GPIOx__) == (GPIOE))? 4U : 5U)
<> 144:ef7eb2e8f9f7 1504 #endif /* STM32F302xC || STM32F303xC || STM32F358xx || */
<> 144:ef7eb2e8f9f7 1505 /* STM32F373xC || STM32F378xx */
<> 144:ef7eb2e8f9f7 1506
<> 144:ef7eb2e8f9f7 1507 #if defined(STM32F302xE) || defined(STM32F303xE) || defined(STM32F398xx)
<> 144:ef7eb2e8f9f7 1508 #define GPIO_GET_INDEX(__GPIOx__) (((__GPIOx__) == (GPIOA))? 0U :\
<> 144:ef7eb2e8f9f7 1509 ((__GPIOx__) == (GPIOB))? 1U :\
<> 144:ef7eb2e8f9f7 1510 ((__GPIOx__) == (GPIOC))? 2U :\
<> 144:ef7eb2e8f9f7 1511 ((__GPIOx__) == (GPIOD))? 3U :\
<> 144:ef7eb2e8f9f7 1512 ((__GPIOx__) == (GPIOE))? 4U :\
<> 144:ef7eb2e8f9f7 1513 ((__GPIOx__) == (GPIOF))? 5U :\
<> 144:ef7eb2e8f9f7 1514 ((__GPIOx__) == (GPIOG))? 6U : 7U)
<> 144:ef7eb2e8f9f7 1515 #endif /* STM32F302xE || STM32F303xE || STM32F398xx */
<> 144:ef7eb2e8f9f7 1516
<> 144:ef7eb2e8f9f7 1517 /**
<> 144:ef7eb2e8f9f7 1518 * @}
<> 144:ef7eb2e8f9f7 1519 */
<> 144:ef7eb2e8f9f7 1520
<> 144:ef7eb2e8f9f7 1521 /**
<> 144:ef7eb2e8f9f7 1522 * @}
<> 144:ef7eb2e8f9f7 1523 */
<> 144:ef7eb2e8f9f7 1524
<> 144:ef7eb2e8f9f7 1525 /* Exported functions --------------------------------------------------------*/
<> 144:ef7eb2e8f9f7 1526 /**
<> 144:ef7eb2e8f9f7 1527 * @}
<> 144:ef7eb2e8f9f7 1528 */
<> 144:ef7eb2e8f9f7 1529
<> 144:ef7eb2e8f9f7 1530 /**
<> 144:ef7eb2e8f9f7 1531 * @}
<> 144:ef7eb2e8f9f7 1532 */
<> 144:ef7eb2e8f9f7 1533
<> 144:ef7eb2e8f9f7 1534 #ifdef __cplusplus
<> 144:ef7eb2e8f9f7 1535 }
<> 144:ef7eb2e8f9f7 1536 #endif
<> 144:ef7eb2e8f9f7 1537
<> 144:ef7eb2e8f9f7 1538 #endif /* __STM32F3xx_HAL_GPIO_EX_H */
<> 144:ef7eb2e8f9f7 1539
<> 144:ef7eb2e8f9f7 1540 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/