/** ****************************************************************************** * @file stm32f4xx_hal_gpio.h * @author MCD Application Team * @brief Header file of GPIO HAL module. ****************************************************************************** * @attention * * Copyright (c) 2017 STMicroelectronics. * All rights reserved. * * This software is licensed under terms that can be found in the LICENSE file * in the root directory of this software component. * If no LICENSE file comes with this software, it is provided AS-IS. * ****************************************************************************** *//* ... *//* Define to prevent recursive inclusion -------------------------------------*/#ifndef__STM32F4xx_HAL_GPIO_H#define__STM32F4xx_HAL_GPIO_H#ifdef__cplusplusextern"C"{#endif/* Includes ------------------------------------------------------------------*/#include"stm32f4xx_hal_def.h"/** @addtogroup STM32F4xx_HAL_Driver * @{ *//* ... *//** @addtogroup GPIO * @{ *//* ... */Includes/* Exported types ------------------------------------------------------------*//** @defgroup GPIO_Exported_Types GPIO Exported Types * @{ *//* ... *//** * @brief GPIO Init structure definition *//* ... */typedefstruct{uint32_tPin;/*!< Specifies the GPIO pins to be configured. This parameter can be any value of @ref GPIO_pins_define *//* ... */uint32_tMode;/*!< Specifies the operating mode for the selected pins. This parameter can be a value of @ref GPIO_mode_define *//* ... */uint32_tPull;/*!< Specifies the Pull-up or Pull-Down activation for the selected pins. This parameter can be a value of @ref GPIO_pull_define *//* ... */uint32_tSpeed;/*!< Specifies the speed for the selected pins. This parameter can be a value of @ref GPIO_speed_define *//* ... */uint32_tAlternate;/*!< Peripheral to be connected to the selected pins. This parameter can be a value of @ref GPIO_Alternate_function_selection *//* ... */...}GPIO_InitTypeDef;/** * @brief GPIO Bit SET and Bit RESET enumeration *//* ... */typedefenum{GPIO_PIN_RESET=0,GPIO_PIN_SET...}GPIO_PinState;/** * @} *//* ... */Exported types/* Exported constants --------------------------------------------------------*//** @defgroup GPIO_Exported_Constants GPIO Exported Constants * @{ *//* ... *//** @defgroup GPIO_pins_define GPIO pins define * @{ *//* ... */#defineGPIO_PIN_0((uint16_t)0x0001)/* Pin 0 selected */#defineGPIO_PIN_1((uint16_t)0x0002)/* Pin 1 selected */#defineGPIO_PIN_2((uint16_t)0x0004)/* Pin 2 selected */#defineGPIO_PIN_3((uint16_t)0x0008)/* Pin 3 selected */#defineGPIO_PIN_4((uint16_t)0x0010)/* Pin 4 selected */#defineGPIO_PIN_5((uint16_t)0x0020)/* Pin 5 selected */#defineGPIO_PIN_6((uint16_t)0x0040)/* Pin 6 selected */#defineGPIO_PIN_7((uint16_t)0x0080)/* Pin 7 selected */#defineGPIO_PIN_8((uint16_t)0x0100)/* Pin 8 selected */#defineGPIO_PIN_9((uint16_t)0x0200)/* Pin 9 selected */#defineGPIO_PIN_10((uint16_t)0x0400)/* Pin 10 selected */#defineGPIO_PIN_11((uint16_t)0x0800)/* Pin 11 selected */#defineGPIO_PIN_12((uint16_t)0x1000)/* Pin 12 selected */#defineGPIO_PIN_13((uint16_t)0x2000)/* Pin 13 selected */#defineGPIO_PIN_14((uint16_t)0x4000)/* Pin 14 selected */#defineGPIO_PIN_15((uint16_t)0x8000)/* Pin 15 selected */#defineGPIO_PIN_All((uint16_t)0xFFFF)/* All pins selected */#defineGPIO_PIN_MASK0x0000FFFFU/* PIN mask for assert test *//** * @} *//* ... *//** @defgroup GPIO_mode_define GPIO mode define * @brief GPIO Configuration Mode * Elements values convention: 0x00WX00YZ * - W : EXTI trigger detection on 3 bits * - X : EXTI mode (IT or Event) on 2 bits * - Y : Output type (Push Pull or Open Drain) on 1 bit * - Z : GPIO mode (Input, Output, Alternate or Analog) on 2 bits * @{ *//* ... */#defineGPIO_MODE_INPUTMODE_INPUT/*!< Input Floating Mode */#defineGPIO_MODE_OUTPUT_PP(MODE_OUTPUT|OUTPUT_PP)/*!< Output Push Pull Mode */#defineGPIO_MODE_OUTPUT_OD(MODE_OUTPUT|OUTPUT_OD)/*!< Output Open Drain Mode */#defineGPIO_MODE_AF_PP(MODE_AF|OUTPUT_PP)/*!< Alternate Function Push Pull Mode */#defineGPIO_MODE_AF_OD(MODE_AF|OUTPUT_OD)/*!< Alternate Function Open Drain Mode */#defineGPIO_MODE_ANALOGMODE_ANALOG/*!< Analog Mode */#defineGPIO_MODE_IT_RISING(MODE_INPUT|EXTI_IT|TRIGGER_RISING)/*!< External Interrupt Mode with Rising edge trigger detection */#defineGPIO_MODE_IT_FALLING(MODE_INPUT|EXTI_IT|TRIGGER_FALLING)/*!< External Interrupt Mode with Falling edge trigger detection */#defineGPIO_MODE_IT_RISING_FALLING(MODE_INPUT|EXTI_IT|TRIGGER_RISING|TRIGGER_FALLING)/*!< External Interrupt Mode with Rising/Falling edge trigger detection */#defineGPIO_MODE_EVT_RISING(MODE_INPUT|EXTI_EVT|TRIGGER_RISING)/*!< External Event Mode with Rising edge trigger detection */#defineGPIO_MODE_EVT_FALLING(MODE_INPUT|EXTI_EVT|TRIGGER_FALLING)/*!< External Event Mode with Falling edge trigger detection */#defineGPIO_MODE_EVT_RISING_FALLING(MODE_INPUT|EXTI_EVT|TRIGGER_RISING|TRIGGER_FALLING)/*!< External Event Mode with Rising/Falling edge trigger detection *//** * @} *//* ... *//** @defgroup GPIO_speed_define GPIO speed define * @brief GPIO Output Maximum frequency * @{ *//* ... */#defineGPIO_SPEED_FREQ_LOW0x00000000U/*!< IO works at 2 MHz, please refer to the product datasheet */#defineGPIO_SPEED_FREQ_MEDIUM0x00000001U/*!< range 12,5 MHz to 50 MHz, please refer to the product datasheet */#defineGPIO_SPEED_FREQ_HIGH0x00000002U/*!< range 25 MHz to 100 MHz, please refer to the product datasheet */#defineGPIO_SPEED_FREQ_VERY_HIGH0x00000003U/*!< range 50 MHz to 200 MHz, please refer to the product datasheet *//** * @} *//* ... *//** @defgroup GPIO_pull_define GPIO pull define * @brief GPIO Pull-Up or Pull-Down Activation * @{ *//* ... */#defineGPIO_NOPULL0x00000000U/*!< No Pull-up or Pull-down activation */#defineGPIO_PULLUP0x00000001U/*!< Pull-up activation */#defineGPIO_PULLDOWN0x00000002U/*!< Pull-down activation *//** * @} *//* ... *//** * @} *//* ... *//* Exported macro ------------------------------------------------------------*//** @defgroup GPIO_Exported_Macros GPIO Exported Macros * @{ *//* ... *//** * @brief Checks whether the specified EXTI line flag is set or not. * @param __EXTI_LINE__ specifies the EXTI line flag to check. * This parameter can be GPIO_PIN_x where x can be(0..15) * @retval The new state of __EXTI_LINE__ (SET or RESET). *//* ... */#define__HAL_GPIO_EXTI_GET_FLAG(__EXTI_LINE__)(EXTI->PR&(__EXTI_LINE__))/** * @brief Clears the EXTI's line pending flags. * @param __EXTI_LINE__ specifies the EXTI lines flags to clear. * This parameter can be any combination of GPIO_PIN_x where x can be (0..15) * @retval None *//* ... */#define__HAL_GPIO_EXTI_CLEAR_FLAG(__EXTI_LINE__)(EXTI->PR=(__EXTI_LINE__))/** * @brief Checks whether the specified EXTI line is asserted or not. * @param __EXTI_LINE__ specifies the EXTI line to check. * This parameter can be GPIO_PIN_x where x can be(0..15) * @retval The new state of __EXTI_LINE__ (SET or RESET). *//* ... */#define__HAL_GPIO_EXTI_GET_IT(__EXTI_LINE__)(EXTI->PR&(__EXTI_LINE__))/** * @brief Clears the EXTI's line pending bits. * @param __EXTI_LINE__ specifies the EXTI lines to clear. * This parameter can be any combination of GPIO_PIN_x where x can be (0..15) * @retval None *//* ... */#define__HAL_GPIO_EXTI_CLEAR_IT(__EXTI_LINE__)(EXTI->PR=(__EXTI_LINE__))/** * @brief Generates a Software interrupt on selected EXTI line. * @param __EXTI_LINE__ specifies the EXTI line to check. * This parameter can be GPIO_PIN_x where x can be(0..15) * @retval None *//* ... */#define__HAL_GPIO_EXTI_GENERATE_SWIT(__EXTI_LINE__)(EXTI->SWIER|=(__EXTI_LINE__))42 defines/** * @} *//* ... *//* Include GPIO HAL Extension module */#include"stm32f4xx_hal_gpio_ex.h"/* Exported functions --------------------------------------------------------*//** @addtogroup GPIO_Exported_Functions * @{ *//* ... *//** @addtogroup GPIO_Exported_Functions_Group1 * @{ *//* ... *//* Initialization and de-initialization functions *****************************/voidHAL_GPIO_Init(GPIO_TypeDef*GPIOx,GPIO_InitTypeDef*GPIO_Init);voidHAL_GPIO_DeInit(GPIO_TypeDef*GPIOx,uint32_tGPIO_Pin);/** * @} *//* ... *//** @addtogroup GPIO_Exported_Functions_Group2 * @{ *//* ... *//* IO operation functions *****************************************************/GPIO_PinStateHAL_GPIO_ReadPin(GPIO_TypeDef*GPIOx,uint16_tGPIO_Pin);voidHAL_GPIO_WritePin(GPIO_TypeDef*GPIOx,uint16_tGPIO_Pin,GPIO_PinStatePinState);voidHAL_GPIO_TogglePin(GPIO_TypeDef*GPIOx,uint16_tGPIO_Pin);HAL_StatusTypeDefHAL_GPIO_LockPin(GPIO_TypeDef*GPIOx,uint16_tGPIO_Pin);voidHAL_GPIO_EXTI_IRQHandler(uint16_tGPIO_Pin);voidHAL_GPIO_EXTI_Callback(uint16_tGPIO_Pin);/** * @} *//* ... *//** * @} *//* ... */Exported functions/* Private types -------------------------------------------------------------*//* Private variables ---------------------------------------------------------*//* Private constants ---------------------------------------------------------*//** @defgroup GPIO_Private_Constants GPIO Private Constants * @{ *//* ... */#defineGPIO_MODE_Pos0U#defineGPIO_MODE(0x3UL<<GPIO_MODE_Pos)#defineMODE_INPUT(0x0UL<<GPIO_MODE_Pos)#defineMODE_OUTPUT(0x1UL<<GPIO_MODE_Pos)#defineMODE_AF(0x2UL<<GPIO_MODE_Pos)#defineMODE_ANALOG(0x3UL<<GPIO_MODE_Pos)#defineOUTPUT_TYPE_Pos4U#defineOUTPUT_TYPE(0x1UL<<OUTPUT_TYPE_Pos)#defineOUTPUT_PP(0x0UL<<OUTPUT_TYPE_Pos)#defineOUTPUT_OD(0x1UL<<OUTPUT_TYPE_Pos)#defineEXTI_MODE_Pos16U#defineEXTI_MODE(0x3UL<<EXTI_MODE_Pos)#defineEXTI_IT(0x1UL<<EXTI_MODE_Pos)#defineEXTI_EVT(0x2UL<<EXTI_MODE_Pos)#defineTRIGGER_MODE_Pos20U#defineTRIGGER_MODE(0x7UL<<TRIGGER_MODE_Pos)#defineTRIGGER_RISING(0x1UL<<TRIGGER_MODE_Pos)#defineTRIGGER_FALLING(0x2UL<<TRIGGER_MODE_Pos)/** * @} *//* ... *//* Private macros ------------------------------------------------------------*//** @defgroup GPIO_Private_Macros GPIO Private Macros * @{ *//* ... */#defineIS_GPIO_PIN_ACTION(ACTION)(((ACTION)==GPIO_PIN_RESET)||((ACTION)==GPIO_PIN_SET))#defineIS_GPIO_PIN(PIN)(((((uint32_t)PIN)&GPIO_PIN_MASK)!=0x00U)&&((((uint32_t)PIN)&~GPIO_PIN_MASK)==0x00U))#defineIS_GPIO_MODE(MODE)(((MODE)==GPIO_MODE_INPUT)||\((MODE)==GPIO_MODE_OUTPUT_PP)||\((MODE)==GPIO_MODE_OUTPUT_OD)||\((MODE)==GPIO_MODE_AF_PP)||\((MODE)==GPIO_MODE_AF_OD)||\((MODE)==GPIO_MODE_IT_RISING)||\((MODE)==GPIO_MODE_IT_FALLING)||\((MODE)==GPIO_MODE_IT_RISING_FALLING)||\((MODE)==GPIO_MODE_EVT_RISING)||\((MODE)==GPIO_MODE_EVT_FALLING)||\((MODE)==GPIO_MODE_EVT_RISING_FALLING)||\((MODE)==GPIO_MODE_ANALOG))...#defineIS_GPIO_SPEED(SPEED)(((SPEED)==GPIO_SPEED_FREQ_LOW)||((SPEED)==GPIO_SPEED_FREQ_MEDIUM)||\((SPEED)==GPIO_SPEED_FREQ_HIGH)||((SPEED)==GPIO_SPEED_FREQ_VERY_HIGH))...#defineIS_GPIO_PULL(PULL)(((PULL)==GPIO_NOPULL)||((PULL)==GPIO_PULLUP)||\((PULL)==GPIO_PULLDOWN))...23 defines/** * @} *//* ... *//* Private functions ---------------------------------------------------------*//** @defgroup GPIO_Private_Functions GPIO Private Functions * @{ *//* ... *//** * @} *//* ... *//** * @} *//* ... *//** * @} *//* ... */#ifdef__cplusplus}extern "C" { ... }#endif/* ... */#endif/* __STM32F4xx_HAL_GPIO_H */
Details
Show: from
Types: Columns:
All items filtered out
All items filtered out
This file uses the notable symbols shown below. Click anywhere in the file to view more details.