Subversion Repositories DashDisplay

Rev

Rev 2 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
2 mjames 1
/**
2
  ******************************************************************************
3
  * @file    stm32f1xx_hal_gpio.h
4
  * @author  MCD Application Team
5 mjames 5
  * @version V1.0.4
6
  * @date    29-April-2016
2 mjames 7
  * @brief   Header file of GPIO HAL module.
8
  ******************************************************************************
9
  * @attention
10
  *
5 mjames 11
  * <h2><center>&copy; COPYRIGHT(c) 2016 STMicroelectronics</center></h2>
2 mjames 12
  *
13
  * Redistribution and use in source and binary forms, with or without modification,
14
  * are permitted provided that the following conditions are met:
15
  *   1. Redistributions of source code must retain the above copyright notice,
16
  *      this list of conditions and the following disclaimer.
17
  *   2. Redistributions in binary form must reproduce the above copyright notice,
18
  *      this list of conditions and the following disclaimer in the documentation
19
  *      and/or other materials provided with the distribution.
20
  *   3. Neither the name of STMicroelectronics nor the names of its contributors
21
  *      may be used to endorse or promote products derived from this software
22
  *      without specific prior written permission.
23
  *
24
  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
25
  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26
  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
27
  * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
28
  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29
  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
30
  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
31
  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
32
  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
33
  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34
  *
35
  ******************************************************************************
36
  */
37
 
38
/* Define to prevent recursive inclusion -------------------------------------*/
39
#ifndef __STM32F1xx_HAL_GPIO_H
40
#define __STM32F1xx_HAL_GPIO_H
41
 
42
#ifdef __cplusplus
43
 extern "C" {
44
#endif
45
 
46
/* Includes ------------------------------------------------------------------*/
47
#include "stm32f1xx_hal_def.h"
48
 
49
/** @addtogroup STM32F1xx_HAL_Driver
50
  * @{
51
  */
52
 
53
/** @addtogroup GPIO
54
  * @{
55
  */
56
 
57
/* Exported types ------------------------------------------------------------*/
58
/** @defgroup GPIO_Exported_Types GPIO Exported Types
59
  * @{
60
  */
61
 
62
/**
63
  * @brief   GPIO Init structure definition  
64
  */
65
typedef struct
66
{
67
  uint32_t Pin;       /*!< Specifies the GPIO pins to be configured.
68
                           This parameter can be any value of @ref GPIO_pins_define */
69
 
70
  uint32_t Mode;      /*!< Specifies the operating mode for the selected pins.
71
                           This parameter can be a value of @ref GPIO_mode_define */
72
 
73
  uint32_t Pull;      /*!< Specifies the Pull-up or Pull-Down activation for the selected pins.
74
                           This parameter can be a value of @ref GPIO_pull_define */
75
 
76
  uint32_t Speed;     /*!< Specifies the speed for the selected pins.
77
                           This parameter can be a value of @ref GPIO_speed_define */
78
}GPIO_InitTypeDef;
79
 
80
/**
81
  * @brief  GPIO Bit SET and Bit RESET enumeration
82
  */
83
typedef enum
84
{
85
  GPIO_PIN_RESET = 0,
86
  GPIO_PIN_SET
87
}GPIO_PinState;
88
 
89
/**
90
  * @}
91
  */
92
 
93
 
94
/* Exported constants --------------------------------------------------------*/
95
 
96
/** @defgroup GPIO_Exported_Constants GPIO Exported Constants
97
  * @{
98
  */
99
 
100
/** @defgroup GPIO_pins_define GPIO pins define
101
  * @{
102
  */
103
#define GPIO_PIN_0                 ((uint16_t)0x0001)  /* Pin 0 selected    */
104
#define GPIO_PIN_1                 ((uint16_t)0x0002)  /* Pin 1 selected    */
105
#define GPIO_PIN_2                 ((uint16_t)0x0004)  /* Pin 2 selected    */
106
#define GPIO_PIN_3                 ((uint16_t)0x0008)  /* Pin 3 selected    */
107
#define GPIO_PIN_4                 ((uint16_t)0x0010)  /* Pin 4 selected    */
108
#define GPIO_PIN_5                 ((uint16_t)0x0020)  /* Pin 5 selected    */
109
#define GPIO_PIN_6                 ((uint16_t)0x0040)  /* Pin 6 selected    */
110
#define GPIO_PIN_7                 ((uint16_t)0x0080)  /* Pin 7 selected    */
111
#define GPIO_PIN_8                 ((uint16_t)0x0100)  /* Pin 8 selected    */
112
#define GPIO_PIN_9                 ((uint16_t)0x0200)  /* Pin 9 selected    */
113
#define GPIO_PIN_10                ((uint16_t)0x0400)  /* Pin 10 selected   */
114
#define GPIO_PIN_11                ((uint16_t)0x0800)  /* Pin 11 selected   */
115
#define GPIO_PIN_12                ((uint16_t)0x1000)  /* Pin 12 selected   */
116
#define GPIO_PIN_13                ((uint16_t)0x2000)  /* Pin 13 selected   */
117
#define GPIO_PIN_14                ((uint16_t)0x4000)  /* Pin 14 selected   */
118
#define GPIO_PIN_15                ((uint16_t)0x8000)  /* Pin 15 selected   */
119
#define GPIO_PIN_All               ((uint16_t)0xFFFF)  /* All pins selected */
120
 
121
#define GPIO_PIN_MASK              ((uint32_t)0x0000FFFF) /* PIN mask for assert test */
122
/**
123
  * @}
124
  */
125
 
126
 
127
/** @defgroup GPIO_mode_define GPIO mode define
128
  * @brief GPIO Configuration Mode
129
  *        Elements values convention: 0xX0yz00YZ
130
  *           - X  : GPIO mode or EXTI Mode
131
  *           - y  : External IT or Event trigger detection
132
  *           - z  : IO configuration on External IT or Event
133
  *           - Y  : Output type (Push Pull or Open Drain)
134
  *           - Z  : IO Direction mode (Input, Output, Alternate or Analog)
135
  * @{
136
  */
137
#define  GPIO_MODE_INPUT                        ((uint32_t)0x00000000)   /*!< Input Floating Mode                   */
138
#define  GPIO_MODE_OUTPUT_PP                    ((uint32_t)0x00000001)   /*!< Output Push Pull Mode                 */
139
#define  GPIO_MODE_OUTPUT_OD                    ((uint32_t)0x00000011)   /*!< Output Open Drain Mode                */
140
#define  GPIO_MODE_AF_PP                        ((uint32_t)0x00000002)   /*!< Alternate Function Push Pull Mode     */
141
#define  GPIO_MODE_AF_OD                        ((uint32_t)0x00000012)   /*!< Alternate Function Open Drain Mode    */
142
#define  GPIO_MODE_AF_INPUT                     GPIO_MODE_INPUT          /*!< Alternate Function Input Mode         */
143
 
144
#define  GPIO_MODE_ANALOG                       ((uint32_t)0x00000003)   /*!< Analog Mode  */
145
 
146
#define  GPIO_MODE_IT_RISING                    ((uint32_t)0x10110000)   /*!< External Interrupt Mode with Rising edge trigger detection          */
147
#define  GPIO_MODE_IT_FALLING                   ((uint32_t)0x10210000)   /*!< External Interrupt Mode with Falling edge trigger detection         */
148
#define  GPIO_MODE_IT_RISING_FALLING            ((uint32_t)0x10310000)   /*!< External Interrupt Mode with Rising/Falling edge trigger detection  */
149
 
150
#define  GPIO_MODE_EVT_RISING                   ((uint32_t)0x10120000)   /*!< External Event Mode with Rising edge trigger detection               */
151
#define  GPIO_MODE_EVT_FALLING                  ((uint32_t)0x10220000)   /*!< External Event Mode with Falling edge trigger detection              */
152
#define  GPIO_MODE_EVT_RISING_FALLING           ((uint32_t)0x10320000)   /*!< External Event Mode with Rising/Falling edge trigger detection       */
153
 
154
/**
155
  * @}
156
  */
157
 
158
 
159
/** @defgroup GPIO_speed_define GPIO speed define
160
  * @brief GPIO Output Maximum frequency
161
  * @{
162
  */  
5 mjames 163
#define  GPIO_SPEED_FREQ_LOW              (GPIO_CRL_MODE0_1) /*!< Low speed */
164
#define  GPIO_SPEED_FREQ_MEDIUM           (GPIO_CRL_MODE0_0) /*!< Medium speed */
165
#define  GPIO_SPEED_FREQ_HIGH             (GPIO_CRL_MODE0)   /*!< High speed */
2 mjames 166
 
167
/**
168
  * @}
169
  */
170
 
171
 
172
 /** @defgroup GPIO_pull_define GPIO pull define
173
   * @brief GPIO Pull-Up or Pull-Down Activation
174
   * @{
175
   */  
176
#define  GPIO_NOPULL        ((uint32_t)0x00000000)   /*!< No Pull-up or Pull-down activation  */
177
#define  GPIO_PULLUP        ((uint32_t)0x00000001)   /*!< Pull-up activation                  */
178
#define  GPIO_PULLDOWN      ((uint32_t)0x00000002)   /*!< Pull-down activation                */
179
 
180
/**
181
  * @}
182
  */
183
 
184
/**
185
  * @}
186
  */
187
 
188
 
189
/* Private macros --------------------------------------------------------*/
190
/** @addtogroup GPIO_Private_Macros
191
  * @{
192
  */
193
 
194
#define IS_GPIO_PIN_ACTION(ACTION) (((ACTION) == GPIO_PIN_RESET) || ((ACTION) == GPIO_PIN_SET))
195
 
196
#define IS_GPIO_PIN(PIN)           (((PIN) & GPIO_PIN_MASK ) != (uint32_t)0x00)
197
 
198
#define IS_GPIO_PULL(PULL) (((PULL) == GPIO_NOPULL) || ((PULL) == GPIO_PULLUP) || \
199
                            ((PULL) == GPIO_PULLDOWN))
200
 
5 mjames 201
#define IS_GPIO_SPEED(SPEED) (((SPEED) == GPIO_SPEED_FREQ_LOW) || \
202
                              ((SPEED) == GPIO_SPEED_FREQ_MEDIUM) || ((SPEED) == GPIO_SPEED_FREQ_HIGH))
2 mjames 203
 
204
#define IS_GPIO_MODE(MODE) (((MODE) == GPIO_MODE_INPUT)              ||\
205
                            ((MODE) == GPIO_MODE_OUTPUT_PP)          ||\
206
                            ((MODE) == GPIO_MODE_OUTPUT_OD)          ||\
207
                            ((MODE) == GPIO_MODE_AF_PP)              ||\
208
                            ((MODE) == GPIO_MODE_AF_OD)              ||\
209
                            ((MODE) == GPIO_MODE_IT_RISING)          ||\
210
                            ((MODE) == GPIO_MODE_IT_FALLING)         ||\
211
                            ((MODE) == GPIO_MODE_IT_RISING_FALLING)  ||\
212
                            ((MODE) == GPIO_MODE_EVT_RISING)         ||\
213
                            ((MODE) == GPIO_MODE_EVT_FALLING)        ||\
214
                            ((MODE) == GPIO_MODE_EVT_RISING_FALLING) ||\
215
                            ((MODE) == GPIO_MODE_ANALOG))
216
 
217
/**
218
  * @}
219
  */
220
 
221
 
222
/* Exported macro ------------------------------------------------------------*/
223
/** @defgroup GPIO_Exported_Macros GPIO Exported Macros
224
  * @{
225
  */
226
 
227
/**
228
  * @brief  Checks whether the specified EXTI line flag is set or not.
229
  * @param  __EXTI_LINE__: specifies the EXTI line flag to check.
230
  *         This parameter can be GPIO_PIN_x where x can be(0..15)
231
  * @retval The new state of __EXTI_LINE__ (SET or RESET).
232
  */
233
#define __HAL_GPIO_EXTI_GET_FLAG(__EXTI_LINE__) (EXTI->PR & (__EXTI_LINE__))   
234
 
235
/**
236
  * @brief  Clears the EXTI's line pending flags.
237
  * @param  __EXTI_LINE__: specifies the EXTI lines flags to clear.
238
  *         This parameter can be any combination of GPIO_PIN_x where x can be (0..15)
239
  * @retval None
240
  */
241
#define __HAL_GPIO_EXTI_CLEAR_FLAG(__EXTI_LINE__) (EXTI->PR = (__EXTI_LINE__))
242
 
243
/**
244
  * @brief  Checks whether the specified EXTI line is asserted or not.
245
  * @param  __EXTI_LINE__: specifies the EXTI line to check.
246
  *          This parameter can be GPIO_PIN_x where x can be(0..15)
247
  * @retval The new state of __EXTI_LINE__ (SET or RESET).
248
  */
249
#define __HAL_GPIO_EXTI_GET_IT(__EXTI_LINE__) (EXTI->PR & (__EXTI_LINE__))   
250
 
251
/**
252
  * @brief  Clears the EXTI's line pending bits.
253
  * @param  __EXTI_LINE__: specifies the EXTI lines to clear.
254
  *          This parameter can be any combination of GPIO_PIN_x where x can be (0..15)
255
  * @retval None
256
  */
257
#define __HAL_GPIO_EXTI_CLEAR_IT(__EXTI_LINE__) (EXTI->PR = (__EXTI_LINE__))
258
 
259
/**
260
  * @brief  Generates a Software interrupt on selected EXTI line.
261
  * @param  __EXTI_LINE__: specifies the EXTI line to check.
262
  *          This parameter can be GPIO_PIN_x where x can be(0..15)
263
  * @retval None
264
  */
265
#define __HAL_GPIO_EXTI_GENERATE_SWIT(__EXTI_LINE__) (EXTI->SWIER |= (__EXTI_LINE__))
266
 
267
/* Include GPIO HAL Extension module */
268
#include "stm32f1xx_hal_gpio_ex.h"
269
 
270
/**
271
  * @}
272
  */
273
 
274
 
275
 
276
/* Exported functions --------------------------------------------------------*/
277
/* Initialization and de-initialization functions *******************************/
278
/** @addtogroup GPIO_Exported_Functions
279
  * @{
280
  */
281
 
282
/** @addtogroup GPIO_Exported_Functions_Group1
283
  * @{
284
  */
285
void  HAL_GPIO_Init(GPIO_TypeDef  *GPIOx, GPIO_InitTypeDef *GPIO_Init);
286
void  HAL_GPIO_DeInit(GPIO_TypeDef  *GPIOx, uint32_t GPIO_Pin);
287
/**
288
  * @}
289
  */
290
 
291
/* IO operation functions *******************************************************/
292
/** @addtogroup GPIO_Exported_Functions_Group2
293
  * @{
294
  */
295
GPIO_PinState HAL_GPIO_ReadPin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);
296
void          HAL_GPIO_WritePin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinState);
297
void          HAL_GPIO_TogglePin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);
298
HAL_StatusTypeDef HAL_GPIO_LockPin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin);
299
void          HAL_GPIO_EXTI_IRQHandler(uint16_t GPIO_Pin);
300
void          HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin);
301
/**
302
  * @}
303
  */
304
 
305
/**
306
  * @}
307
  */
308
 
309
/**
310
  * @}
311
  */
312
 
313
/**
314
  * @}
315
  */
316
 
317
 
318
#ifdef __cplusplus
319
}
320
#endif
321
 
322
#endif /* __STM32F1xx_HAL_GPIO_H */
323
 
324
/************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/