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:
Thu Nov 08 11:45:42 2018 +0000
Revision:
171:3a7713b1edbc
Parent:
TARGET_DISCO_F303VC/TARGET_STM/TARGET_STM32F3/device/stm32f3xx_hal_gpio_ex.h@168:b9e159c1930a
mbed library. Release version 164

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