apm32f4xx_gpio.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. /*!
  2. * @file apm32f4xx_gpio.h
  3. *
  4. * @brief This file provides all the GPIO firmware functions
  5. *
  6. * @version V1.0.2
  7. *
  8. * @date 2022-06-23
  9. *
  10. * @attention
  11. *
  12. * Copyright (C) 2021-2022 Geehy Semiconductor
  13. *
  14. * You may not use this file except in compliance with the
  15. * GEEHY COPYRIGHT NOTICE (GEEHY SOFTWARE PACKAGE LICENSE).
  16. *
  17. * The program is only for reference, which is distributed in the hope
  18. * that it will be usefull and instructional for customers to develop
  19. * their software. Unless required by applicable law or agreed to in
  20. * writing, the program is distributed on an "AS IS" BASIS, WITHOUT
  21. * ANY WARRANTY OR CONDITIONS OF ANY KIND, either express or implied.
  22. * See the GEEHY SOFTWARE PACKAGE LICENSE for the governing permissions
  23. * and limitations under the License.
  24. */
  25. /* Define to prevent recursive inclusion */
  26. #ifndef __APM32F4XX_GPIO_H
  27. #define __APM32F4XX_GPIO_H
  28. #ifdef __cplusplus
  29. extern "C" {
  30. #endif
  31. /* Includes */
  32. #include "apm32f4xx.h"
  33. /** @addtogroup APM32F4xx_StdPeriphDriver
  34. @{
  35. */
  36. /** @addtogroup GPIO_Driver
  37. @{
  38. */
  39. /** @defgroup GPIO_Enumerations
  40. @{
  41. */
  42. /**
  43. * @brief GPIO Configuration Mode enumeration
  44. */
  45. typedef enum
  46. {
  47. GPIO_MODE_IN = 0x00, /*!< GPIO Input Mode */
  48. GPIO_MODE_OUT = 0x01, /*!< GPIO Output Mode */
  49. GPIO_MODE_AF = 0x02, /*!< GPIO Alternate function Mode */
  50. GPIO_MODE_AN = 0x03 /*!< GPIO Analog Mode */
  51. } GPIO_MODE_T;
  52. /**
  53. * @brief GPIO Output type enumeration
  54. */
  55. typedef enum
  56. {
  57. GPIO_OTYPE_PP = 0x00, /*!< GPIO push-pull mode */
  58. GPIO_OTYPE_OD = 0x01 /*!< GPIO open drain mode */
  59. } GPIO_OTYPE_T;
  60. /**
  61. * @brief GPIO Output Maximum frequency enumeration
  62. */
  63. typedef enum
  64. {
  65. GPIO_SPEED_2MHz = 0x00, /*!< Low speed */
  66. GPIO_SPEED_25MHz = 0x01, /*!< Medium speed */
  67. GPIO_SPEED_50MHz = 0x02, /*!< Fast speed */
  68. GPIO_SPEED_100MHz = 0x03 /*!< High speed */
  69. } GPIO_SPEED_T;
  70. /**
  71. * @brief GPIO Configuration PullUp PullDown enumeration
  72. */
  73. typedef enum
  74. {
  75. GPIO_PUPD_NOPULL = 0x00, /*!< GPIO no pull mode */
  76. GPIO_PUPD_UP = 0x01, /*!< GPIO pull-up mode */
  77. GPIO_PUPD_DOWN = 0x02 /*!< GPIO pull-down mode */
  78. } GPIO_PUPD_T;
  79. /**
  80. * @brief GPIO Pins
  81. */
  82. typedef enum
  83. {
  84. GPIO_PIN_0 = ((uint16_t)BIT0), /*!< GPIO pin 0 selected */
  85. GPIO_PIN_1 = ((uint16_t)BIT1), /*!< GPIO pin 1 selected */
  86. GPIO_PIN_2 = ((uint16_t)BIT2), /*!< GPIO pin 2 selected */
  87. GPIO_PIN_3 = ((uint16_t)BIT3), /*!< GPIO pin 3 selected */
  88. GPIO_PIN_4 = ((uint16_t)BIT4), /*!< GPIO pin 4 selected */
  89. GPIO_PIN_5 = ((uint16_t)BIT5), /*!< GPIO pin 5 selected */
  90. GPIO_PIN_6 = ((uint16_t)BIT6), /*!< GPIO pin 6 selected */
  91. GPIO_PIN_7 = ((uint16_t)BIT7), /*!< GPIO pin 7 selected */
  92. GPIO_PIN_8 = ((uint16_t)BIT8), /*!< GPIO pin 8 selected */
  93. GPIO_PIN_9 = ((uint16_t)BIT9), /*!< GPIO pin 9 selected */
  94. GPIO_PIN_10 = ((uint16_t)BIT10), /*!< GPIO pin 10 selected */
  95. GPIO_PIN_11 = ((uint16_t)BIT11), /*!< GPIO pin 11 selected */
  96. GPIO_PIN_12 = ((uint16_t)BIT12), /*!< GPIO pin 12 selected */
  97. GPIO_PIN_13 = ((uint16_t)BIT13), /*!< GPIO pin 13 selected */
  98. GPIO_PIN_14 = ((uint16_t)BIT14), /*!< GPIO pin 14 selected */
  99. GPIO_PIN_15 = ((uint16_t)BIT15), /*!< GPIO pin 15 selected */
  100. GPIO_PIN_ALL = ((uint32_t)0XFFFF), /*!< GPIO all pins selected */
  101. } GPIO_PIN_T;
  102. /**
  103. * @brief GPIO Pin sources
  104. */
  105. typedef enum
  106. {
  107. GPIO_PIN_SOURCE_0, /*!< GPIO pin source 0 */
  108. GPIO_PIN_SOURCE_1, /*!< GPIO pin source 1 */
  109. GPIO_PIN_SOURCE_2, /*!< GPIO pin source 2 */
  110. GPIO_PIN_SOURCE_3, /*!< GPIO pin source 3 */
  111. GPIO_PIN_SOURCE_4, /*!< GPIO pin source 4 */
  112. GPIO_PIN_SOURCE_5, /*!< GPIO pin source 5 */
  113. GPIO_PIN_SOURCE_6, /*!< GPIO pin source 6 */
  114. GPIO_PIN_SOURCE_7, /*!< GPIO pin source 7 */
  115. GPIO_PIN_SOURCE_8, /*!< GPIO pin source 8 */
  116. GPIO_PIN_SOURCE_9, /*!< GPIO pin source 9 */
  117. GPIO_PIN_SOURCE_10, /*!< GPIO pin source 10 */
  118. GPIO_PIN_SOURCE_11, /*!< GPIO pin source 11 */
  119. GPIO_PIN_SOURCE_12, /*!< GPIO pin source 12 */
  120. GPIO_PIN_SOURCE_13, /*!< GPIO pin source 13 */
  121. GPIO_PIN_SOURCE_14, /*!< GPIO pin source 14 */
  122. GPIO_PIN_SOURCE_15, /*!< GPIO pin source 15 */
  123. } GPIO_PIN_SOURCE_T;
  124. /**
  125. * @brief GPIO Alternat function selection
  126. */
  127. typedef enum
  128. {
  129. GPIO_AF_RTC_50Hz = 0x00, /*!< RTC_50Hz Alternate Function mapping */
  130. GPIO_AF_MCO = 0x00, /*!< MCO (MCO1 and MCO2) Alternate Function mapping */
  131. GPIO_AF_TAMPER = 0x00, /*!< TAMPER (TAMPER_1 and TAMPER_2) Alternate Function mapping */
  132. GPIO_AF_SWJ = 0x00, /*!< SWJ (SWD and JTAG) Alternate Function mapping */
  133. GPIO_AF_TRACE = 0x00, /*!< TRACE Alternate Function mapping */
  134. GPIO_AF_TMR1 = 0x01, /*!< TMR1 Alternate Function mapping */
  135. GPIO_AF_TMR2 = 0x01, /*!< TMR2 Alternate Function mapping */
  136. GPIO_AF_LPTMR = 0x01, /*!< LPTMR Alternate Function mapping */
  137. GPIO_AF_TMR3 = 0x02, /*!< TMR3 Alternate Function mapping */
  138. GPIO_AF_TMR4 = 0x02, /*!< TMR4 Alternate Function mapping */
  139. GPIO_AF_TMR5 = 0x02, /*!< TMR5 Alternate Function mapping */
  140. GPIO_AF_TMR8 = 0x03, /*!< TMR8 Alternate Function mapping */
  141. GPIO_AF_TMR9 = 0x03, /*!< TMR9 Alternate Function mapping */
  142. GPIO_AF_TMR10 = 0x03, /*!< TMR10 Alternate Function mapping */
  143. GPIO_AF_TMR11 = 0x03, /*!< TMR11 Alternate Function mapping */
  144. GPIO_AF_I2C1 = 0x04, /*!< I2C1 Alternate Function mapping */
  145. GPIO_AF_I2C2 = 0x04, /*!< I2C2 Alternate Function mapping */
  146. GPIO_AF_I2C3 = 0x04, /*!< I2C3 Alternate Function mapping */
  147. GPIO_AF_FMPI2C = 0x04, /*!< FMPI2C Alternate Function mapping */
  148. GPIO_AF_SPI1 = 0x05, /*!< SPI1/I2S1 Alternate Function mapping */
  149. GPIO_AF_SPI2 = 0x05, /*!< SPI2/I2S2 Alternate Function mapping */
  150. GPIO_AF5_SPI3 = 0x05, /*!< SPI3/I2S3 Alternate Function mapping */
  151. GPIO_AF_SPI4 = 0x05, /*!< SPI4/I2S4 Alternate Function mapping */
  152. GPIO_AF_SPI5 = 0x05, /*!< SPI5 Alternate Function mapping */
  153. GPIO_AF_SPI6 = 0x05, /*!< SPI6 Alternate Function mapping */
  154. GPIO_AF_SPI3 = 0x06, /*!< SPI3/I2S3 Alternate Function mapping */
  155. GPIO_AF6_SPI1 = 0x06, /*!< SPI1 Alternate Function mapping */
  156. GPIO_AF6_SPI2 = 0x06, /*!< SPI2 Alternate Function mapping */
  157. GPIO_AF6_SPI4 = 0x06, /*!< SPI4 Alternate Function mapping */
  158. GPIO_AF6_SPI5 = 0x06, /*!< SPI5 Alternate Function mapping */
  159. GPIO_AF_SAI1 = 0x06, /*!< SAI1 Alternate Function mapping */
  160. GPIO_AF_I2S2ext = 0x06, /*!< I2S2ext_SD Alternate Function mapping */
  161. GPIO_AF_USART1 = 0x07, /*!< USART1 Alternate Function mapping */
  162. GPIO_AF_USART2 = 0x07, /*!< USART2 Alternate Function mapping */
  163. GPIO_AF_USART3 = 0x07, /*!< USART3 Alternate Function mapping */
  164. GPIO_AF7_SPI3 = 0x07, /*!< SPI3/I2S3ext Alternate Function mapping */
  165. GPIO_AF_UART4 = 0x08, /*!< UART4 Alternate Function mapping */
  166. GPIO_AF_UART5 = 0x08, /*!< UART5 Alternate Function mapping */
  167. GPIO_AF_USART6 = 0x08, /*!< USART6 Alternate Function mapping */
  168. GPIO_AF_UART7 = 0x08, /*!< UART7 Alternate Function mapping */
  169. GPIO_AF_UART8 = 0x08, /*!< UART8 Alternate Function mapping */
  170. GPIO_AF8_USART3 = 0x08, /*!< USART3 Alternate Function mapping */
  171. GPIO_AF8_CAN1 = 0x08, /*!< CAN1 Alternate Function mapping */
  172. GPIO_AF_CAN1 = 0x09, /*!< CAN1 Alternate Function mapping */
  173. GPIO_AF_CAN2 = 0x09, /*!< CAN2 Alternate Function mapping */
  174. GPIO_AF_TMR12 = 0x09, /*!< TMR12 Alternate Function mapping */
  175. GPIO_AF_TMR13 = 0x09, /*!< TMR13 Alternate Function mapping */
  176. GPIO_AF_TMR14 = 0x09, /*!< TMR14 Alternate Function mapping */
  177. GPIO_AF9_I2C2 = 0x09, /*!< I2C2 Alternate Function mapping */
  178. GPIO_AF9_I2C3 = 0x09, /*!< I2C3 Alternate Function mapping */
  179. GPIO_AF_OTG_FS = 0x0A, /*!< OTG_FS Alternate Function mapping */
  180. GPIO_AF_OTG_HS = 0x0A, /*!< OTG_HS Alternate Function mapping */
  181. GPIO_AF_ETH = 0x0B, /*!< ETHERNET Alternate Function mapping */
  182. GPIO_AF_FSMC = 0x0C, /*!< FSMC Alternate Function mapping */
  183. GPIO_AF_OTG_HS_FS = 0x0C, /*!< OTG HS configured in FS, Alternate Function mapping */
  184. GPIO_AF_SDIO = 0x0C, /*!< SDIO Alternate Function mapping */
  185. GPIO_AF_DCMI = 0x0D, /*!< DCMI Alternate Function mapping */
  186. GPIO_AF14_RNG = 0x0E, /*!< RNG Alternate Function mapping */
  187. GPIO_AF_EVENTOUT = 0x0F, /*!< EVENTOUT Alternate Function mapping */
  188. } GPIO_AF_T;
  189. /**@} end of group GPIO_Enumerations*/
  190. /** @addtogroup GPIO_Macros Macros
  191. @{
  192. */
  193. #define GPIO_Mode_AIN GPIO_Mode_AN
  194. #define GPIO_AF_I2S3ext GPIO_AF7_SPI3
  195. #define GPIO_AF_OTG1_FS GPIO_AF_OTG_FS
  196. #define GPIO_AF_OTG2_HS GPIO_AF_OTG_HS
  197. #define GPIO_AF_OTG2_FS GPIO_AF_OTG_HS_FS
  198. /**@} end of group GPIO_Macros*/
  199. /** @addtogroup GPIO_Structure Data Structure
  200. @{
  201. */
  202. /**
  203. * @brief GPIO Init structure definition
  204. */
  205. typedef struct
  206. {
  207. uint16_t pin; //!< Specifies the GPIO pins to be configured.
  208. GPIO_MODE_T mode; //!< Specifies the operating mode for the selected pins.
  209. GPIO_SPEED_T speed; //!< Specifies the speed for the selected pins.
  210. GPIO_OTYPE_T otype; //!< Specifies the operating output type for the selected pins.
  211. GPIO_PUPD_T pupd; //!< Specifies the operating Pull-up/Pull down for the selected pins.
  212. } GPIO_Config_T;
  213. /**@} end of group GPIO_Structure*/
  214. /** @defgroup GPIO_Functions
  215. @{
  216. */
  217. /* Reset and common Configuration */
  218. void GPIO_Reset(GPIO_T* port);
  219. void GPIO_Config(GPIO_T* port, GPIO_Config_T* gpioConfig);
  220. void GPIO_ConfigStructInit(GPIO_Config_T* gpioConfig);
  221. /* GPIO Read functions */
  222. uint8_t GPIO_ReadInputBit(GPIO_T* port, uint16_t pin);
  223. uint8_t GPIO_ReadOutputBit(GPIO_T* port, uint16_t pin);
  224. uint16_t GPIO_ReadInputPort(GPIO_T* port);
  225. uint16_t GPIO_ReadOutputPort(GPIO_T* port);
  226. /* GPIO Write functions */
  227. void GPIO_SetBit(GPIO_T* port, uint16_t pin);
  228. void GPIO_ResetBit(GPIO_T* port, uint16_t pin);
  229. void GPIO_WriteBitValue(GPIO_T* port, uint16_t pin, uint8_t bitVal);
  230. void GPIO_WriteOutputPort(GPIO_T* port, uint16_t portValue);
  231. /* GPIO Other functions */
  232. void GPIO_ToggleBit(GPIO_T* port, uint16_t pin);
  233. void GPIO_ConfigPinLock(GPIO_T* port, uint16_t pin);
  234. void GPIO_ConfigPinAF(GPIO_T* port, GPIO_PIN_SOURCE_T gpioPinSource, GPIO_AF_T gpioAf);
  235. #ifdef __cplusplus
  236. }
  237. #endif
  238. #endif /*__APM32F4XX_GPIO_H */
  239. /**@} end of group GPIO_Enumerations */
  240. /**@} end of group GPIO_Driver */
  241. /**@} end of group APM32F4xx_StdPeriphDriver */