The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

mbed 2

This is the mbed 2 library. If you'd like to learn about Mbed OS please see the mbed-os docs.

Committer:
AnnaBridge
Date:
Tue Mar 20 13:30:58 2018 +0000
Revision:
163:e59c8e839560
Child:
168:b9e159c1930a
mbed library. Release version 160

Who changed what in which revision?

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