hc32l196_gpio.h 73 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227
  1. /*******************************************************************************
  2. * Copyright (C) 2018, Huada Semiconductor Co.,Ltd All rights reserved.
  3. *
  4. * This software is owned and published by:
  5. * Huada Semiconductor Co.,Ltd ("HDSC").
  6. *
  7. * BY DOWNLOADING, INSTALLING OR USING THIS SOFTWARE, YOU AGREE TO BE BOUND
  8. * BY ALL THE TERMS AND CONDITIONS OF THIS AGREEMENT.
  9. *
  10. * This software contains source code for use with HDSC
  11. * components. This software is licensed by HDSC to be adapted only
  12. * for use in systems utilizing HDSC components. HDSC shall not be
  13. * responsible for misuse or illegal use of this software for devices not
  14. * supported herein. HDSC is providing this software "AS IS" and will
  15. * not be responsible for issues arising from incorrect user implementation
  16. * of the software.
  17. *
  18. * Disclaimer:
  19. * HDSC MAKES NO WARRANTY, EXPRESS OR IMPLIED, ARISING BY LAW OR OTHERWISE,
  20. * REGARDING THE SOFTWARE (INCLUDING ANY ACOOMPANYING WRITTEN MATERIALS),
  21. * ITS PERFORMANCE OR SUITABILITY FOR YOUR INTENDED USE, INCLUDING,
  22. * WITHOUT LIMITATION, THE IMPLIED WARRANTY OF MERCHANTABILITY, THE IMPLIED
  23. * WARRANTY OF FITNESS FOR A PARTICULAR PURPOSE OR USE, AND THE IMPLIED
  24. * WARRANTY OF NONINFRINGEMENT.
  25. * HDSC SHALL HAVE NO LIABILITY (WHETHER IN CONTRACT, WARRANTY, TORT,
  26. * NEGLIGENCE OR OTHERWISE) FOR ANY DAMAGES WHATSOEVER (INCLUDING, WITHOUT
  27. * LIMITATION, DAMAGES FOR LOSS OF BUSINESS PROFITS, BUSINESS INTERRUPTION,
  28. * LOSS OF BUSINESS INFORMATION, OR OTHER PECUNIARY LOSS) ARISING FROM USE OR
  29. * INABILITY TO USE THE SOFTWARE, INCLUDING, WITHOUT LIMITATION, ANY DIRECT,
  30. * INDIRECT, INCIDENTAL, SPECIAL OR CONSEQUENTIAL DAMAGES OR LOSS OF DATA,
  31. * SAVINGS OR PROFITS,
  32. * EVEN IF Disclaimer HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
  33. * YOU ASSUME ALL RESPONSIBILITIES FOR SELECTION OF THE SOFTWARE TO ACHIEVE YOUR
  34. * INTENDED RESULTS, AND FOR THE INSTALLATION OF, USE OF, AND RESULTS OBTAINED
  35. * FROM, THE SOFTWARE.
  36. *
  37. * This software may be replicated in part or whole for the licensed use,
  38. * with the restriction that this Disclaimer and Copyright notice must be
  39. * included with each copy of this software, whether used in part or whole,
  40. * at all times.
  41. */
  42. /******************************************************************************/
  43. /** \file gpio.h
  44. **
  45. ** GPIO driver
  46. ** @link GPIO Group Some description @endlink
  47. **
  48. ** - 2018-04-18
  49. **
  50. ******************************************************************************/
  51. #ifndef __GPIO_H__
  52. #define __GPIO_H__
  53. /*******************************************************************************
  54. * Include files
  55. ******************************************************************************/
  56. #include "hc32l196_ddl.h"
  57. /* C binding of definitions if building with C++ compiler */
  58. #ifdef __cplusplus
  59. extern "C"
  60. {
  61. #endif
  62. /**
  63. *******************************************************************************
  64. ** \defgroup GpioGroup General Purpose I/O (GPIO)
  65. **
  66. **
  67. ******************************************************************************/
  68. //@{
  69. #define GPIO_GPSZ (0x40u)
  70. /*******************************************************************************
  71. * Global type definitions
  72. ******************************************************************************/
  73. /**
  74. *******************************************************************************
  75. ** \brief GPIO PORT类型定义
  76. ******************************************************************************/
  77. typedef enum en_gpio_port
  78. {
  79. GpioPortA = 0x00u, ///< GPIO PORT A
  80. GpioPortB = 0x40u, ///< GPIO PORT B
  81. GpioPortC = 0x80u, ///< GPIO PORT C
  82. GpioPortD = 0xc0u, ///< GPIO PORT D
  83. GpioPortE = 0x1000u, ///< GPIO PORT E
  84. GpioPortF = 0x1040u, ///< GPIO PORT F
  85. }en_gpio_port_t;
  86. /**
  87. *******************************************************************************
  88. ** \brief GPIO PIN类型定义
  89. ******************************************************************************/
  90. typedef enum en_gpio_pin
  91. {
  92. GpioPin0 = 0u, ///< GPIO PIN0
  93. GpioPin1 = 1u, ///< GPIO PIN1
  94. GpioPin2 = 2u, ///< GPIO PIN2
  95. GpioPin3 = 3u, ///< GPIO PIN3
  96. GpioPin4 = 4u, ///< GPIO PIN4
  97. GpioPin5 = 5u, ///< GPIO PIN5
  98. GpioPin6 = 6u, ///< GPIO PIN6
  99. GpioPin7 = 7u, ///< GPIO PIN7
  100. GpioPin8 = 8u, ///< GPIO PIN8
  101. GpioPin9 = 9u, ///< GPIO PIN9
  102. GpioPin10 = 10u, ///< GPIO PIN10
  103. GpioPin11 = 11u, ///< GPIO PIN11
  104. GpioPin12 = 12u, ///< GPIO PIN12
  105. GpioPin13 = 13u, ///< GPIO PIN13
  106. GpioPin14 = 14u, ///< GPIO PIN14
  107. GpioPin15 = 15u, ///< GPIO PIN15
  108. }en_gpio_pin_t;
  109. /**
  110. *******************************************************************************
  111. ** \brief GPIO 端口复用功能(AF-Alternate function)类型定义
  112. ** \note 具体功能及含义请参考用户手册GPIO复用表或下表
  113. ******************************************************************************/
  114. typedef enum en_gpio_af
  115. {
  116. GpioAf0 = 0u, ///< GPIO功能
  117. GpioAf1 = 1u, ///< GPIO AF1:复用功能1
  118. GpioAf2 = 2u, ///< GPIO AF2:复用功能2
  119. GpioAf3 = 3u, ///< GPIO AF3:复用功能3
  120. GpioAf4 = 4u, ///< GPIO AF4:复用功能4
  121. GpioAf5 = 5u, ///< GPIO AF5:复用功能5
  122. GpioAf6 = 6u, ///< GPIO AF6:复用功能6
  123. GpioAf7 = 7u, ///< GPIO AF7:复用功能7
  124. }en_gpio_af_t;
  125. ///*||======||=============||=============||=============||=============||=============||=============||=============||*///
  126. ///*||PSEL || GpioAf1 || GpioAf2 || GpioAf3 || GpioAf4 || GpioAf5 || GpioAf6 || GpioAf7 ||*///
  127. ///*||======||=============||=============||=============||=============||=============||=============||=============||*///
  128. ///*||PA00 ||UART1_CTS ||LPUART1_TXD ||TIM0_ETR ||VC0_OUT ||TIM1_CHA ||TIM3_ETR ||TIM0_CHA ||*///
  129. ///*||PA01 ||UART1_RTS ||LPUART1_RXD ||TIM0_CHB ||TIM1_ETR ||TIM1_CHB ||HCLK_OUT ||SPI1_MOSI ||*///
  130. ///*||PA02 ||UART1_TXD ||TIM0_CHA ||VC1_OUT ||TIM1_CHA ||TIM2_CHA ||PCLK_OUT ||SPI1_MISO ||*///
  131. ///*||PA03 ||UART1_RXD ||TIM0_GATE ||TIM1_CHB ||TIM2_CHB ||SPI1_CS ||TIM3_CH1A ||TIM5_CHA ||*///
  132. ///*||PA04 ||SPI0_CS ||UART1_TXD ||PCA_CH4 ||TIM2_ETR ||TIM5_CHA ||LVD_OUT ||TIM3_CH2B ||*///
  133. ///*||PA05 ||SPI0_SCK ||TIM0_ETR ||PCA_ECI ||TIM0_CHA ||TIM5_CHB ||XTL_OUT ||XTH_OUT ||*///
  134. ///*||PA06 ||SPI0_MISO ||PCA_CH0 ||TIM3_BK ||TIM1_CHA ||VC0_OUT ||TIM3_GATE ||LPUART0_CTS ||*///
  135. ///*||PA07 ||SPI0_MOSI ||PCA_CH1 ||HCLK_OUT ||TIM3_CH0B ||TIM2_CHA ||VC1_OUT ||TIM4_CHB ||*///
  136. ///*||PA08 ||UART0_TXD ||TIM3_CH0A || || ||TIM1_GATE ||TIM4_CHA ||TIM3_BK ||*///
  137. ///*||PA09 ||UART0_TXD ||TIM3_CH1A ||TIM0_BK ||I2C0_SCL || ||HCLK_OUT ||TIM5_CHA ||*///
  138. ///*||PA10 ||UART0_RXD ||TIM3_CH2A ||TIM2_BK ||I2C0_SDA ||TIM2_GATE ||PCLK_OUT ||TIM6_CHA ||*///
  139. ///*||PA11 ||UART0_CTS ||TIM3_GATE ||I2C1_SCL || ||VC0_OUT ||SPI0_MISO ||TIM4_CHB ||*///
  140. ///*||PA12 ||UART0_RTS ||TIM3_ETR ||I2C1_SDA || ||VC1_OUT ||SPI0_MOSI ||PCNT_S0 ||*///
  141. ///*||PA13 ||IR_OUT ||UART0_RXD ||LVD_OUT ||TIM3_ETR ||RTC_1HZ ||PCNT_S1 ||VC2_OUT ||*///
  142. ///*||PA14 ||UART1_TXD ||UART0_TXD ||TIM3_CH2A ||LVD_OUT ||RCH_OUT ||RCL_OUT ||PLL_OUT ||*///
  143. ///*||PA15 ||SPI0_CS ||UART1_RXD ||LPUART1_RTS ||TIM0_ETR ||TIM0_CHA ||TIM3_CH1A || ||*///
  144. ///*||PB00 ||PCA_CH2 ||TIM3_CH1B ||LPUART0_TXD ||TIM5_CHB ||RCH_OUT ||RCL_OUT ||PLL_OUT ||*///
  145. ///*||PB01 ||PCA_CH3 ||PCLK_OUT ||TIM3_CH2B ||TIM6_CHB ||LPUART0_RTS ||VC2_OUT ||TCLK_OUT  ||*///
  146. ///*||PB02 ||LPTIM_TOG ||PCA_ECI ||LPUART1_TXD ||TIM4_CHA ||TIM1_BK ||TIM0_BK ||TIM2_BK ||*///
  147. ///*||PB03 ||SPI0_SCK ||TIM0_CHB ||TIM1_GATE ||TIM3_CH0A ||LPTIM_GATE ||XTL_OUT ||XTH_OUT ||*///
  148. ///*||PB04 ||SPI0_MISO ||PCA_CH0 ||TIM2_BK ||UART0_CTS ||TIM2_GATE ||TIM3_CH0B ||LPTIM_ETR ||*///
  149. ///*||PB05 ||SPI0_MOSI || ||TIM1_BK ||PCA_CH1 ||LPTIM_GATE ||PCNT_S0 ||UART0_RTS ||*///
  150. ///*||PB06 ||I2C0_SCL ||UART0_TXD ||TIM1_CHB ||TIM0_CHA ||LPTIM_ETR ||TIM3_CH0A ||LPTIM_TOG ||*///
  151. ///*||PB07 ||I2C0_SDA ||UART0_RXD ||TIM2_CHB ||LPUART1_CTS ||TIM0_CHB ||LPTIM_TOGN ||PCNT_S1 ||*///
  152. ///*||PB08 ||I2C0_SCL ||TIM1_CHA || ||TIM2_CHA ||TIM0_GATE ||TIM3_CH2A ||UART0_TXD ||*///
  153. ///*||PB09 ||I2C0_SDA ||IR_OUT ||SPI1_CS ||TIM2_CHA || ||TIM2_CHB ||UART0_RXD ||*///
  154. ///*||PB10 ||I2C1_SCL ||SPI1_SCK ||TIM1_CHA ||LPUART0_TXD ||TIM3_CH1A ||LPUART1_RTS ||UART1_RTS ||*///
  155. ///*||PB11 ||I2C1_SDA ||TIM1_CHB ||LPUART0_RXD ||TIM2_GATE ||TIM6_CHA ||LPUART1_CTS ||UART1_CTS ||*///
  156. ///*||PB12 ||SPI1_CS ||TIM3_BK ||LPUART0_TXD ||TIM0_BK || ||LPUART0_RTS ||TIM6_CHA ||*///
  157. ///*||PB13 ||SPI1_SCK ||I2C1_SCL ||TIM3_CH0B ||LPUART0_CTS ||TIM1_CHA ||TIM1_GATE ||TIM6_CHB ||*///
  158. ///*||PB14 ||SPI1_MISO ||I2C1_SDA ||TIM3_CH1B ||TIM0_CHA ||RTC_1HZ ||LPUART0_RTS ||TIM1_BK ||*///
  159. ///*||PB15 ||SPI1_MOSI ||TIM3_CH2B ||TIM0_CHB ||TIM0_GATE || || ||LPUART1_RXD ||*///
  160. ///*||PC00 ||LPTIM_GATE ||PCNT_S0 ||UART1_CTS ||UART2_RTS || || || ||*///
  161. ///*||PC01 ||LPTIM_TOG ||TIM5_CHB ||UART1_RTS ||PCNT_S0FO || ||UART2_CTS || ||*///
  162. ///*||PC02 ||SPI1_MISO ||LPTIM_TOGN ||PCNT_S1 ||UART2_RXD || || || ||*///
  163. ///*||PC03 ||SPI1_MOSI ||LPTIM_ETR ||LPTIM_TOGN ||PCNT_S1FO ||UART2_TXD || || ||*///
  164. ///*||PC04 ||LPUART0_TXD ||TIM2_ETR ||IR_OUT ||VC2_OUT || || || ||*///
  165. ///*||PC05 ||LPUART0_RXD ||TIM6_CHB ||PCA_CH4 || || || || ||*///
  166. ///*||PC06 ||PCA_CH0 ||TIM4_CHA ||TIM2_CHA ||LPTIM1_GATE || ||UART3_RXD || ||*///
  167. ///*||PC07 ||PCA_CH1 ||TIM5_CHA ||TIM2_CHB ||LPTIM1_ETR || ||UART3_TXD || ||*///
  168. ///*||PC08 ||PCA_CH2 ||TIM6_CHA ||TIM2_ETR ||LPTIM1_TOG || ||UART3_CTS || ||*///
  169. ///*||PC09 ||PCA_CH3 ||TIM4_CHB ||TIM1_ETR ||LPTIM1_TOGN || ||UART3_RTS || ||*///
  170. ///*||PC10 ||LPUART1_TXD ||LPUART0_TXD ||PCA_CH2 || || || || ||*///
  171. ///*||PC11 ||LPUART1_RXD ||LPUART0_RXD ||PCA_CH3 ||PCNT_S0FO || || || ||*///
  172. ///*||PC12 ||LPUART0_TXD ||LPUART1_TXD ||PCA_CH4 ||PCNT_S1FO || || || ||*///
  173. ///*||PC13 || ||RTC_1HZ ||TIM3_CH1B || || || || ||*///
  174. ///*||PC14 || || || || || || || ||*///
  175. ///*||PC15 || || || || || || || ||*///
  176. ///*||PD00 || ||SPI1_CS || || || || || ||*///
  177. ///*||PD01 || ||SPI1_SCK || || || || || ||*///
  178. ///*||PD02 ||PCA_ECI ||LPUART0_RTS ||TIM1_ETR || || || || ||*///
  179. ///*||PD03 ||UART1_CTS ||SPI1_MISO ||LPTIM1_TOG || || || || ||*///
  180. ///*||PD04 ||UART1_RTS ||SPI1_MOSI ||LPTIM1_TOGN || || || || ||*///
  181. ///*||PD05 ||UART1_TXD ||LPTIM1_GATE || || || || || ||*///
  182. ///*||PD06 ||UART1_RXD ||LPTIM1_ETR || || || || || ||*///
  183. ///*||PD07 ||UART1_TXD || || || || || || ||*///
  184. ///*||PD08 ||LPUART0_TXD || || || || || || ||*///
  185. ///*||PD09 ||LPUART0_RXD || || || || || || ||*///
  186. ///*||PD10 ||LPUART0_TXD || || || || || || ||*///
  187. ///*||PD11 ||LPUART0_CTS || || || || || || ||*///
  188. ///*||PD12 ||LPUART0_RTS ||UART2_RTS || || || || || ||*///
  189. ///*||PD13 ||UART2_RXD || || || || || || ||*///
  190. ///*||PD14 ||UART2_TXD || || || || || || ||*///
  191. ///*||PD15 || ||UART2_CTS || || || || || ||*///
  192. ///*||PE00 ||TIM1_CHA || || || || || || ||*///
  193. ///*||PE01 ||TIM2_CHA || || || || || || ||*///
  194. ///*||PE02 ||PCA_ECI || || || || || || ||*///
  195. ///*||PE03 ||PCA_CH0 || || || || || || ||*///
  196. ///*||PE04 ||PCA_CH1 || || || || || || ||*///
  197. ///*||PE05 ||PCA_CH2 || || || || || || ||*///
  198. ///*||PE06 ||PCA_CH3 || || || || || || ||*///
  199. ///*||PE07 ||TIM3_ETR ||LPTIM1_GATE || || || || || ||*///
  200. ///*||PE08 ||TIM3_CH0B ||LPTIM1_ETR || || || || || ||*///
  201. ///*||PE09 ||TIM3_CH0A ||LPTIM1_TOG || || || || || ||*///
  202. ///*||PE10 ||TIM3_CH1B ||LPTIM1_TOGN || || || || || ||*///
  203. ///*||PE11 ||TIM3_CH1A || || || || || || ||*///
  204. ///*||PE12 ||TIM3_CH2B ||SPI0_CS ||UART3_CTS || || || || ||*///
  205. ///*||PE13 ||TIM3_CH2A ||SPI0_SCK ||UART3_RTS || || || || ||*///
  206. ///*||PE14 ||TIM3_CH0B ||SPI0_MISO ||UART3_RXD || || || || ||*///
  207. ///*||PE15 ||TIM3_BK ||SPI0_MOSI ||UART3_TXD || || || || ||*///
  208. ///*||PF00 ||I2C0_SDA || ||UART1_TXD || || || || ||*///
  209. ///*||PF01 ||I2C0_SCL ||TIM4_CHB ||UART1_RXD || || || || ||*///
  210. ///*||PF02 || || || || || || || ||*///
  211. ///*||PF03 || || || || || || || ||*///
  212. ///*||PF04 || || || || || || || ||*///
  213. ///*||PF05 || || || || || || || ||*///
  214. ///*||PF06 ||I2C1_SCL ||LPUART1_CTS ||UART0_CTS || || || || ||*///
  215. ///*||PF07 ||I2C1_SDA ||LPUART1_RTS ||UART0_RTS || || || || ||*///
  216. ///*||PF09 ||TIM0_CHA || || || || || || ||*///
  217. ///*||PF10 ||TIM0_CHB || || || || || || ||*///
  218. ///*||PF11 || || || || || || || ||*///
  219. ///*||======||=============||=============||=============||=============||=============||=============||=============||*///
  220. /**
  221. *******************************************************************************
  222. ** \brief GPIO输入输出配置数据类型定义
  223. ******************************************************************************/
  224. typedef enum en_gpio_dir
  225. {
  226. GpioDirOut = 0u, ///< GPIO 输出
  227. GpioDirIn = 1u, ///< GPIO 输入
  228. }en_gpio_dir_t;
  229. /**
  230. *******************************************************************************
  231. ** \brief GPIO端口上拉配置数据类型定义
  232. ******************************************************************************/
  233. typedef enum en_gpio_pu
  234. {
  235. GpioPuDisable = 0u, ///< GPIO无上拉
  236. GpioPuEnable = 1u, ///< GPIO上拉
  237. }en_gpio_pu_t;
  238. /**
  239. *******************************************************************************
  240. ** \brief GPIO端口下拉配置数据类型定义
  241. ******************************************************************************/
  242. typedef enum en_gpio_pd
  243. {
  244. GpioPdDisable = 0u, ///< GPIO无下拉
  245. GpioPdEnable = 1u, ///< GPIO下拉
  246. }en_gpio_pd_t;
  247. /**
  248. *******************************************************************************
  249. ** \brief GPIO端口输出驱动能力配置数据类型定义
  250. ******************************************************************************/
  251. typedef enum en_gpio_drv
  252. {
  253. GpioDrvH = 0u, ///< GPIO高驱动能力
  254. GpioDrvL = 1u, ///< GPIO低驱动能力
  255. }en_gpio_drv_t;
  256. /**
  257. *******************************************************************************
  258. ** \brief GPIO端口开漏输出控制数据类型定义
  259. ******************************************************************************/
  260. typedef enum en_gpio_od
  261. {
  262. GpioOdDisable = 0u, ///< GPIO开漏输出关闭
  263. GpioOdEnable = 1u, ///< GPIO开漏输出使能
  264. }en_gpio_od_t;
  265. /**
  266. *******************************************************************************
  267. ** \brief GPIO端口输入/输出值寄存器总线控制模式选择
  268. ******************************************************************************/
  269. typedef enum en_gpio_ctrl_mode
  270. {
  271. GpioFastIO = 0u, ///< FAST IO 总线控制模式
  272. GpioAHB = 1u, ///< AHB 总线控制模式
  273. }en_gpio_ctrl_mode_t;
  274. /**
  275. *******************************************************************************
  276. ** \brief GPIO中断触发方式类型定义
  277. ******************************************************************************/
  278. typedef enum en_gpio_irqtype
  279. {
  280. GpioIrqHigh = 0u, ///< GPIO高电平触发
  281. GpioIrqLow = 1u, ///< GPIO低电平触发
  282. GpioIrqRising = 2u, ///< GPIO上升沿触发
  283. GpioIrqFalling = 3u, ///< GPIO下降沿触发
  284. }en_gpio_irqtype_t;
  285. /**
  286. *******************************************************************************
  287. ** \brief GPIO 辅助功能(SF-Secondary Function)端口中断模式类型定义
  288. ******************************************************************************/
  289. typedef enum en_gpio_sf_irqmode
  290. {
  291. GpioSfIrqDpslpMode = 1u, ///< Deep Sleep模式
  292. GpioSfIrqActSlpMode = 0u, ///< Active/Sleep模式
  293. }en_gpio_sf_irqmode_t;
  294. /**
  295. *******************************************************************************
  296. ** \brief GPIO 辅助功能(SF-Secondary Function)HCLK输出门控类型定义
  297. ******************************************************************************/
  298. typedef enum en_gpio_sf_hclkout_g
  299. {
  300. GpioSfHclkOutDisable = 0u, ///< HCLK输出门控关闭
  301. GpioSfHclkOutEnable = 1u, ///< HCLK输出门控使能
  302. }en_gpio_sf_hclkout_g_t;
  303. /**
  304. *******************************************************************************
  305. ** \brief GPIO 辅助功能(SF-Secondary Function)HCLK输出分频选择类型定义
  306. ******************************************************************************/
  307. typedef enum en_gpio_sf_hclkout_div
  308. {
  309. GpioSfHclkOutDiv1 = 0u, ///< HCLK
  310. GpioSfHclkOutDiv2 = 1u, ///< HCLK/2
  311. GpioSfHclkOutDiv4 = 2u, ///< HCLK/4
  312. GpioSfHclkOutDiv8 = 3u, ///< HCLK/8
  313. }en_gpio_sf_hclkout_div_t;
  314. /**
  315. *******************************************************************************
  316. ** \brief GPIO 辅助功能(SF-Secondary Function)PCLK输出门控类型定义
  317. ******************************************************************************/
  318. typedef enum en_gpio_sf_pclkout_g
  319. {
  320. GpioSfPclkOutDisable = 0u, ///< PCLK输出门控关闭
  321. GpioSfPclkOutEnable = 1u, ///< PCLK输出门控使能
  322. }en_gpio_sf_pclkout_g_t;
  323. /**
  324. *******************************************************************************
  325. ** \brief GPIO 辅助功能(SF-Secondary Function)PCLK输出分频选择类型定义
  326. ******************************************************************************/
  327. typedef enum en_gpio_sf_pclkout_div
  328. {
  329. GpioSfPclkOutDiv1 = 0u, ///< PCLK
  330. GpioSfPclkOutDiv2 = 1u, ///< PCLK/2
  331. GpioSfPclkOutDiv4 = 2u, ///< PCLK/4
  332. GpioSfPclkOutDiv8 = 3u, ///< PCLK/8
  333. }en_gpio_sf_pclkout_div_t;
  334. /**
  335. *******************************************************************************
  336. ** \brief GPIO 辅助功能(SF-Secondary Function)IR输出极性选择类型定义
  337. ******************************************************************************/
  338. typedef enum en_gpio_sf_irpol
  339. {
  340. GpioSfIrP = 0u, ///< IR正向输出
  341. GpioSfIrN = 1u, ///< IR反向输出
  342. }en_gpio_sf_irpol_t;
  343. /**
  344. *******************************************************************************
  345. ** \brief GPIO 辅助功能(SF-Secondary Function)SSN通道类型定义
  346. ******************************************************************************/
  347. typedef enum en_gpio_sf_ssnspi
  348. {
  349. GpioSpi0 = 0u, ///< SPI0 SSN
  350. GpioSpi1 = 1u, ///< SPI1 SSN
  351. }en_gpio_sf_ssnspi_t;
  352. /**
  353. *******************************************************************************
  354. ** \brief GPIO 辅助功能(SF-Secondary Function)SSN与外部时钟输入信号源选择类型定义
  355. ******************************************************************************/
  356. typedef enum en_gpio_sf_ssn_extclk
  357. {
  358. GpioSfSsnExtClkH = 0u, ///< 高电平
  359. GpioSfSsnExtClkPA03 = 1u, ///< PA03
  360. GpioSfSsnExtClkPA04 = 2u, ///< PA04
  361. GpioSfSsnExtClkPA06 = 3u, ///< PA06
  362. GpioSfSsnExtClkPA08 = 4u, ///< PA08
  363. GpioSfSsnExtClkPA09 = 5u, ///< PA09
  364. GpioSfSsnExtClkPA12 = 6u, ///< PA12
  365. GpioSfSsnExtClkPA15 = 7u, ///< PA15
  366. GpioSfSsnExtClkPB01 = 8u, ///< PB01
  367. GpioSfSsnExtClkPB02 = 9u, ///< PB02
  368. GpioSfSsnExtClkPB05 = 10u, ///< PB05
  369. GpioSfSsnExtClkPB06 = 11u, ///< PB06
  370. GpioSfSsnExtClkPB09 = 12u, ///< PB09
  371. GpioSfSsnExtClkPB10 = 13u, ///< PB10
  372. GpioSfSsnExtClkPB12 = 14u, ///< PB12
  373. GpioSfSsnExtClkPB14 = 15u, ///< PB14
  374. }en_gpio_sf_ssn_extclk_t;
  375. /**
  376. *******************************************************************************
  377. ** \brief GPIO 辅助功能(SF-Secondary Function)定时器互联功能选择类型定义
  378. ** \note 具体功能及含义请参考用户手册GPIO辅助寄存器描述
  379. ******************************************************************************/
  380. typedef enum en_gpio_sf
  381. {
  382. GpioSf0 = 0u, ///< SF0:PX_SEL的配置功能
  383. GpioSf1 = 1u, ///< SF1:辅助功能1
  384. GpioSf2 = 2u, ///< SF2:辅助功能2
  385. GpioSf3 = 3u, ///< SF3:辅助功能3
  386. GpioSf4 = 4u, ///< SF4:辅助功能4
  387. GpioSf5 = 5u, ///< SF5:辅助功能5
  388. GpioSf6 = 6u, ///< SF6:辅助功能6
  389. GpioSf7 = 7u, ///< SF7:辅助功能7
  390. }en_gpio_sf_t;
  391. /**
  392. *******************************************************************************
  393. ** \brief GPIO 辅助功能(SF-Secondary Function)定时器门控类型选择数据类型定义
  394. ******************************************************************************/
  395. typedef enum en_gpio_sf_tim_g
  396. {
  397. GpioSfTim0G = 0u, ///<Tim0定时器GATE输入选择
  398. GpioSfTim1G = 3u, ///<Tim1定时器GATE输入选择
  399. GpioSfTim2G = 6u, ///<Tim2定时器GATE输入选择
  400. GpioSfTim3G = 9u, ///<Tim3定时器GATE输入选择
  401. GpioSfLpTim0G = 12u, ///<LPTim0定时器GATE输入选择
  402. GpioSfLpTim1G = 38u, ///<LPTim1定时器GATE输入选择
  403. }en_gpio_sf_tim_g_t;
  404. /**
  405. *******************************************************************************
  406. ** \brief GPIO 辅助功能(SF-Secondary Function)定时器ETR类型选择数据类型定义
  407. ******************************************************************************/
  408. typedef enum en_gpio_sf_tim_e
  409. {
  410. GpioSfTim0E = 0u, ///<Tim0定时器ETR输入选择
  411. GpioSfTim1E = 3u, ///<Tim1定时器ETR输入选择
  412. GpioSfTim2E = 6u, ///<Tim2定时器ETR输入选择
  413. GpioSfTim3E = 9u, ///<Tim3定时器ETR输入选择
  414. GpioSfLpTim0E = 12u, ///<LPTim0定时器ETR输入选择
  415. GpioSfLpTim1E = 41u, ///<LPTim1定时器ETR输入选择
  416. }en_gpio_sf_tim_e_t;
  417. /**
  418. *******************************************************************************
  419. ** \brief GPIO 辅助功能(SF-Secondary Function)定时器捕获输入类型选择数据类型定义
  420. ******************************************************************************/
  421. typedef enum en_gpio_sf_tim_c
  422. {
  423. GpioSfTim0CA = 0u, ///<Tim0定时器CHA输入选择
  424. GpioSfTim1CA = 3u, ///<Tim1定时器CHA输入选择
  425. GpioSfTim2CA = 6u, ///<Tim2定时器CHA输入选择
  426. GpioSfTim3CA = 9u, ///<Tim3定时器CH0A输入选择
  427. GpioSfTim3CB = 12u, ///<Tim3定时器CH0B输入选择
  428. }en_gpio_sf_tim_c_t;
  429. /**
  430. *******************************************************************************
  431. ** \brief GPIO 辅助功能(SF-Secondary Function)PCA捕获选择数据类型定义
  432. ******************************************************************************/
  433. typedef enum en_gpio_sf_pca
  434. {
  435. GpioSfPcaCH0 = 0u, ///<PCA_CH0捕获口输入选择
  436. GpioSfPcaECI = 3u, ///<PCA ECI时钟输入选择
  437. }en_gpio_sf_pca_t;
  438. /**
  439. *******************************************************************************
  440. ** \brief GPIO 辅助功能(SF-Secondary Function)PCNT脉冲输入选择数据类型定义
  441. ******************************************************************************/
  442. typedef enum en_gpio_sf_pcnt
  443. {
  444. GpioSfPcntS0 = 0u, ///<PCNT_S0输入选择
  445. GpioSfPcntS1 = 3u, ///<PCNT_S1输入选择
  446. }en_gpio_sf_pcnt_t;
  447. /**
  448. *******************************************************************************
  449. ** \brief GPIO 端口配置结构体定义
  450. ******************************************************************************/
  451. typedef struct
  452. {
  453. boolean_t bOutputVal; ///< 默认端口输出电平
  454. en_gpio_dir_t enDir; ///< 端口方向配置
  455. en_gpio_drv_t enDrv; ///< 端口驱动能力配置
  456. en_gpio_pu_t enPu; ///< 端口上拉配置
  457. en_gpio_pd_t enPd; ///< 端口下拉配置
  458. en_gpio_od_t enOD; ///< 端口开漏输出配置
  459. en_gpio_ctrl_mode_t enCtrlMode; ///< 端口输入/输出值寄存器总线控制模式配置
  460. }stc_gpio_cfg_t;
  461. /*******************************************************************************
  462. * Global definitions——(GPIO 复用功能宏定义)
  463. ******************************************************************************/
  464. ///< GPIO 复用功能宏定义
  465. ///< GpioAf1
  466. #define PA00_UART1_CTS (GpioPortA<<16u|GpioPin0 <<8u|GpioAf1)
  467. #define PA01_UART1_RTS (GpioPortA<<16u|GpioPin1 <<8u|GpioAf1)
  468. #define PA02_UART1_TXD (GpioPortA<<16u|GpioPin2 <<8u|GpioAf1)
  469. #define PA03_UART1_RXD (GpioPortA<<16u|GpioPin3 <<8u|GpioAf1)
  470. #define PA04_SPI0_CS (GpioPortA<<16u|GpioPin4 <<8u|GpioAf1)
  471. #define PA05_SPI0_SCK (GpioPortA<<16u|GpioPin5 <<8u|GpioAf1)
  472. #define PA06_SPI0_MISO (GpioPortA<<16u|GpioPin6 <<8u|GpioAf1)
  473. #define PA07_SPI0_MOSI (GpioPortA<<16u|GpioPin7 <<8u|GpioAf1)
  474. #define PA08_UART0_TXD (GpioPortA<<16u|GpioPin8 <<8u|GpioAf1)
  475. #define PA09_UART0_TXD (GpioPortA<<16u|GpioPin9 <<8u|GpioAf1)
  476. #define PA10_UART0_RXD (GpioPortA<<16u|GpioPin10<<8u|GpioAf1)
  477. #define PA11_UART0_CTS (GpioPortA<<16u|GpioPin11<<8u|GpioAf1)
  478. #define PA12_UART0_RTS (GpioPortA<<16u|GpioPin12<<8u|GpioAf1)
  479. #define PA13_IR_OUT (GpioPortA<<16u|GpioPin13<<8u|GpioAf1)
  480. #define PA14_UART1_TXD (GpioPortA<<16u|GpioPin14<<8u|GpioAf1)
  481. #define PA15_SPI0_CS (GpioPortA<<16u|GpioPin15<<8u|GpioAf1)
  482. #define PB00_PCA_CH2 (GpioPortB<<16u|GpioPin0 <<8u|GpioAf1)
  483. #define PB01_PCA_CH3 (GpioPortB<<16u|GpioPin1 <<8u|GpioAf1)
  484. #define PB02_LPTIM_TOG (GpioPortB<<16u|GpioPin2 <<8u|GpioAf1)
  485. #define PB03_SPI0_SCK (GpioPortB<<16u|GpioPin3 <<8u|GpioAf1)
  486. #define PB04_SPI0_MISO (GpioPortB<<16u|GpioPin4 <<8u|GpioAf1)
  487. #define PB05_SPI0_MOSI (GpioPortB<<16u|GpioPin5 <<8u|GpioAf1)
  488. #define PB06_I2C0_SCL (GpioPortB<<16u|GpioPin6 <<8u|GpioAf1)
  489. #define PB07_I2C0_SDA (GpioPortB<<16u|GpioPin7 <<8u|GpioAf1)
  490. #define PB08_I2C0_SCL (GpioPortB<<16u|GpioPin8 <<8u|GpioAf1)
  491. #define PB09_I2C0_SDA (GpioPortB<<16u|GpioPin9 <<8u|GpioAf1)
  492. #define PB10_I2C1_SCL (GpioPortB<<16u|GpioPin10<<8u|GpioAf1)
  493. #define PB11_I2C1_SDA (GpioPortB<<16u|GpioPin11<<8u|GpioAf1)
  494. #define PB12_SPI1_CS (GpioPortB<<16u|GpioPin12<<8u|GpioAf1)
  495. #define PB13_SPI1_SCK (GpioPortB<<16u|GpioPin13<<8u|GpioAf1)
  496. #define PB14_SPI1_MISO (GpioPortB<<16u|GpioPin14<<8u|GpioAf1)
  497. #define PB15_SPI1_MOSI (GpioPortB<<16u|GpioPin15<<8u|GpioAf1)
  498. #define PC00_LPTIM_GATE (GpioPortC<<16u|GpioPin0 <<8u|GpioAf1)
  499. #define PC01_LPTIM_TOG (GpioPortC<<16u|GpioPin1 <<8u|GpioAf1)
  500. #define PC02_SPI1_MISO (GpioPortC<<16u|GpioPin2 <<8u|GpioAf1)
  501. #define PC03_SPI1_MOSI (GpioPortC<<16u|GpioPin3 <<8u|GpioAf1)
  502. #define PC04_LPUART0_TXD (GpioPortC<<16u|GpioPin4 <<8u|GpioAf1)
  503. #define PC05_LPUART0_RXD (GpioPortC<<16u|GpioPin5 <<8u|GpioAf1)
  504. #define PC06_PCA_CH0 (GpioPortC<<16u|GpioPin6 <<8u|GpioAf1)
  505. #define PC07_PCA_CH1 (GpioPortC<<16u|GpioPin7 <<8u|GpioAf1)
  506. #define PC08_PCA_CH2 (GpioPortC<<16u|GpioPin8 <<8u|GpioAf1)
  507. #define PC09_PCA_CH3 (GpioPortC<<16u|GpioPin9 <<8u|GpioAf1)
  508. #define PC10_LPUART1_TXD (GpioPortC<<16u|GpioPin10<<8u|GpioAf1)
  509. #define PC11_LPUART1_RXD (GpioPortC<<16u|GpioPin11<<8u|GpioAf1)
  510. #define PC12_LPUART0_TXD (GpioPortC<<16u|GpioPin12<<8u|GpioAf1)
  511. #define PC13_1x (GpioPortC<<16u|GpioPin13<<8u|GpioAf1)
  512. #define PC14_1x (GpioPortC<<16u|GpioPin14<<8u|GpioAf1)
  513. #define PC15_1x (GpioPortC<<16u|GpioPin15<<8u|GpioAf1)
  514. #define PD00_1x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf1)
  515. #define PD01_1x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf1)
  516. #define PD02_PCA_ECI (GpioPortD<<16u|GpioPin2 <<8u|GpioAf1)
  517. #define PD03_UART1_CTS (GpioPortD<<16u|GpioPin3 <<8u|GpioAf1)
  518. #define PD04_UART1_RTS (GpioPortD<<16u|GpioPin4 <<8u|GpioAf1)
  519. #define PD05_UART1_TXD (GpioPortD<<16u|GpioPin5 <<8u|GpioAf1)
  520. #define PD06_UART1_RXD (GpioPortD<<16u|GpioPin6 <<8u|GpioAf1)
  521. #define PD07_UART1_TXD (GpioPortD<<16u|GpioPin7 <<8u|GpioAf1)
  522. #define PD08_LPUART0_TXD (GpioPortD<<16u|GpioPin8 <<8u|GpioAf1)
  523. #define PD09_LPUART0_RXD (GpioPortD<<16u|GpioPin9 <<8u|GpioAf1)
  524. #define PD10_LPUART0_TXD (GpioPortD<<16u|GpioPin10<<8u|GpioAf1)
  525. #define PD11_LPUART0_CTS (GpioPortD<<16u|GpioPin11<<8u|GpioAf1)
  526. #define PD12_LPUART0_RTS (GpioPortD<<16u|GpioPin12<<8u|GpioAf1)
  527. #define PD13_UART2_RXD (GpioPortD<<16u|GpioPin13<<8u|GpioAf1)
  528. #define PD14_UART2_TXD (GpioPortD<<16u|GpioPin14<<8u|GpioAf1)
  529. #define PD15_1x (GpioPortD<<16u|GpioPin15<<8u|GpioAf1)
  530. #define PE00_TIM1_CHA (GpioPortE<<16u|GpioPin0 <<8u|GpioAf1)
  531. #define PE01_TIM2_CHA (GpioPortE<<16u|GpioPin1 <<8u|GpioAf1)
  532. #define PE02_PCA_ECI (GpioPortE<<16u|GpioPin2 <<8u|GpioAf1)
  533. #define PE03_PCA_CH0 (GpioPortE<<16u|GpioPin3 <<8u|GpioAf1)
  534. #define PE04_PCA_CH1 (GpioPortE<<16u|GpioPin4 <<8u|GpioAf1)
  535. #define PE05_PCA_CH2 (GpioPortE<<16u|GpioPin5 <<8u|GpioAf1)
  536. #define PE06_PCA_CH3 (GpioPortE<<16u|GpioPin6 <<8u|GpioAf1)
  537. #define PE07_TIM3_ETR (GpioPortE<<16u|GpioPin7 <<8u|GpioAf1)
  538. #define PE08_TIM3_CH0B (GpioPortE<<16u|GpioPin8 <<8u|GpioAf1)
  539. #define PE09_TIM3_CH0A (GpioPortE<<16u|GpioPin9 <<8u|GpioAf1)
  540. #define PE10_TIM3_CH1B (GpioPortE<<16u|GpioPin10<<8u|GpioAf1)
  541. #define PE11_TIM3_CH1A (GpioPortE<<16u|GpioPin11<<8u|GpioAf1)
  542. #define PE12_TIM3_CH2B (GpioPortE<<16u|GpioPin12<<8u|GpioAf1)
  543. #define PE13_TIM3_CH2A (GpioPortE<<16u|GpioPin13<<8u|GpioAf1)
  544. #define PE14_TIM3_CH0B (GpioPortE<<16u|GpioPin14<<8u|GpioAf1)
  545. #define PE15_TIM3_BK (GpioPortE<<16u|GpioPin15<<8u|GpioAf1)
  546. #define PF00_I2C0_SDA (GpioPortF<<16u|GpioPin0 <<8u|GpioAf1)
  547. #define PF01_I2C0_SCL (GpioPortF<<16u|GpioPin1 <<8u|GpioAf1)
  548. #define PF02_1x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf1)
  549. #define PF03_1x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf1)
  550. #define PF04_1x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf1)
  551. #define PF05_1x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf1)
  552. #define PF06_I2C1_SCL (GpioPortF<<16u|GpioPin6 <<8u|GpioAf1)
  553. #define PF07_I2C1_SDA (GpioPortF<<16u|GpioPin7 <<8u|GpioAf1)
  554. #define PF09_TIM0_CHA (GpioPortF<<16u|GpioPin9 <<8u|GpioAf1)
  555. #define PF10_TIM0_CHB (GpioPortF<<16u|GpioPin10<<8u|GpioAf1)
  556. #define PF11_1x (GpioPortF<<16u|GpioPin11<<8u|GpioAf1)
  557. ///< GpioAf2
  558. #define PA00_LPUART1_TXD (GpioPortA<<16u|GpioPin0 <<8u|GpioAf2)
  559. #define PA01_LPUART1_RXD (GpioPortA<<16u|GpioPin1 <<8u|GpioAf2)
  560. #define PA02_TIM0_CHA (GpioPortA<<16u|GpioPin2 <<8u|GpioAf2)
  561. #define PA03_TIM0_GATE (GpioPortA<<16u|GpioPin3 <<8u|GpioAf2)
  562. #define PA04_UART1_TXD (GpioPortA<<16u|GpioPin4 <<8u|GpioAf2)
  563. #define PA05_TIM0_ETR (GpioPortA<<16u|GpioPin5 <<8u|GpioAf2)
  564. #define PA06_PCA_CH0 (GpioPortA<<16u|GpioPin6 <<8u|GpioAf2)
  565. #define PA07_PCA_CH1 (GpioPortA<<16u|GpioPin7 <<8u|GpioAf2)
  566. #define PA08_TIM3_CH0A (GpioPortA<<16u|GpioPin8 <<8u|GpioAf2)
  567. #define PA09_TIM3_CH1A (GpioPortA<<16u|GpioPin9 <<8u|GpioAf2)
  568. #define PA10_TIM3_CH2A (GpioPortA<<16u|GpioPin10<<8u|GpioAf2)
  569. #define PA11_TIM3_GATE (GpioPortA<<16u|GpioPin11<<8u|GpioAf2)
  570. #define PA12_TIM3_ETR (GpioPortA<<16u|GpioPin12<<8u|GpioAf2)
  571. #define PA13_UART0_RXD (GpioPortA<<16u|GpioPin13<<8u|GpioAf2)
  572. #define PA14_UART0_TXD (GpioPortA<<16u|GpioPin14<<8u|GpioAf2)
  573. #define PA15_UART1_RXD (GpioPortA<<16u|GpioPin15<<8u|GpioAf2)
  574. #define PB00_TIM3_CH1B (GpioPortB<<16u|GpioPin0 <<8u|GpioAf2)
  575. #define PB01_PCLK_OUT (GpioPortB<<16u|GpioPin1 <<8u|GpioAf2)
  576. #define PB02_PCA_ECI (GpioPortB<<16u|GpioPin2 <<8u|GpioAf2)
  577. #define PB03_TIM0_CHB (GpioPortB<<16u|GpioPin3 <<8u|GpioAf2)
  578. #define PB04_PCA_CH0 (GpioPortB<<16u|GpioPin4 <<8u|GpioAf2)
  579. #define PB05_2x (GpioPortB<<16u|GpioPin5 <<8u|GpioAf2)
  580. #define PB06_UART0_TXD (GpioPortB<<16u|GpioPin6 <<8u|GpioAf2)
  581. #define PB07_UART0_RXD (GpioPortB<<16u|GpioPin7 <<8u|GpioAf2)
  582. #define PB08_TIM1_CHA (GpioPortB<<16u|GpioPin8 <<8u|GpioAf2)
  583. #define PB09_IR_OUT (GpioPortB<<16u|GpioPin9 <<8u|GpioAf2)
  584. #define PB10_SPI1_SCK (GpioPortB<<16u|GpioPin10<<8u|GpioAf2)
  585. #define PB11_TIM1_CHB (GpioPortB<<16u|GpioPin11<<8u|GpioAf2)
  586. #define PB12_TIM3_BK (GpioPortB<<16u|GpioPin12<<8u|GpioAf2)
  587. #define PB13_I2C1_SCL (GpioPortB<<16u|GpioPin13<<8u|GpioAf2)
  588. #define PB14_I2C1_SDA (GpioPortB<<16u|GpioPin14<<8u|GpioAf2)
  589. #define PB15_TIM3_CH2B (GpioPortB<<16u|GpioPin15<<8u|GpioAf2)
  590. #define PC00_PCNT_S0 (GpioPortC<<16u|GpioPin0 <<8u|GpioAf2)
  591. #define PC01_TIM5_CHB (GpioPortC<<16u|GpioPin1 <<8u|GpioAf2)
  592. #define PC02_LPTIM_TOGN (GpioPortC<<16u|GpioPin2 <<8u|GpioAf2)
  593. #define PC03_LPTIM_ETR (GpioPortC<<16u|GpioPin3 <<8u|GpioAf2)
  594. #define PC04_TIM2_ETR (GpioPortC<<16u|GpioPin4 <<8u|GpioAf2)
  595. #define PC05_TIM6_CHB (GpioPortC<<16u|GpioPin5 <<8u|GpioAf2)
  596. #define PC06_TIM4_CHA (GpioPortC<<16u|GpioPin6 <<8u|GpioAf2)
  597. #define PC07_TIM5_CHA (GpioPortC<<16u|GpioPin7 <<8u|GpioAf2)
  598. #define PC08_TIM6_CHA (GpioPortC<<16u|GpioPin8 <<8u|GpioAf2)
  599. #define PC09_TIM4_CHB (GpioPortC<<16u|GpioPin9 <<8u|GpioAf2)
  600. #define PC10_LPUART0_TXD (GpioPortC<<16u|GpioPin10<<8u|GpioAf2)
  601. #define PC11_LPUART0_RXD (GpioPortC<<16u|GpioPin11<<8u|GpioAf2)
  602. #define PC12_LPUART1_TXD (GpioPortC<<16u|GpioPin12<<8u|GpioAf2)
  603. #define PC13_RTC_1HZ (GpioPortC<<16u|GpioPin13<<8u|GpioAf2)
  604. #define PC14_2x (GpioPortC<<16u|GpioPin14<<8u|GpioAf2)
  605. #define PC15_2x (GpioPortC<<16u|GpioPin15<<8u|GpioAf2)
  606. #define PD00_SPI1_CS (GpioPortD<<16u|GpioPin0 <<8u|GpioAf2)
  607. #define PD01_SPI1_SCK (GpioPortD<<16u|GpioPin1 <<8u|GpioAf2)
  608. #define PD02_LPUART0_RTS (GpioPortD<<16u|GpioPin2 <<8u|GpioAf2)
  609. #define PD03_SPI1_MISO (GpioPortD<<16u|GpioPin3 <<8u|GpioAf2)
  610. #define PD04_SPI1_MOSI (GpioPortD<<16u|GpioPin4 <<8u|GpioAf2)
  611. #define PD05_LPTIM1_GATE (GpioPortD<<16u|GpioPin5 <<8u|GpioAf2)
  612. #define PD06_LPTIM1_ETR (GpioPortD<<16u|GpioPin6 <<8u|GpioAf2)
  613. #define PD07_2x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf2)
  614. #define PD08_2x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf2)
  615. #define PD09_2x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf2)
  616. #define PD10_2x (GpioPortD<<16u|GpioPin10<<8u|GpioAf2)
  617. #define PD11_2x (GpioPortD<<16u|GpioPin11<<8u|GpioAf2)
  618. #define PD12_UART2_RTS (GpioPortD<<16u|GpioPin12<<8u|GpioAf2)
  619. #define PD13_2x (GpioPortD<<16u|GpioPin13<<8u|GpioAf2)
  620. #define PD14_2x (GpioPortD<<16u|GpioPin14<<8u|GpioAf2)
  621. #define PD15_UART2_CTS (GpioPortD<<16u|GpioPin15<<8u|GpioAf2)
  622. #define PE00_2x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf2)
  623. #define PE01_2x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf2)
  624. #define PE02_2x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf2)
  625. #define PE03_2x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf2)
  626. #define PE04_2x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf2)
  627. #define PE05_2x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf2)
  628. #define PE06_2x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf2)
  629. #define PE07_LPTIM1_GATE (GpioPortE<<16u|GpioPin7 <<8u|GpioAf2)
  630. #define PE08_LPTIM1_ETR (GpioPortE<<16u|GpioPin8 <<8u|GpioAf2)
  631. #define PE09_LPTIM1_TOG (GpioPortE<<16u|GpioPin9 <<8u|GpioAf2)
  632. #define PE10_LPTIM1_TOGN (GpioPortE<<16u|GpioPin10<<8u|GpioAf2)
  633. #define PE11_2x (GpioPortE<<16u|GpioPin11<<8u|GpioAf2)
  634. #define PE12_SPI0_CS (GpioPortE<<16u|GpioPin12<<8u|GpioAf2)
  635. #define PE13_SPI0_SCK (GpioPortE<<16u|GpioPin13<<8u|GpioAf2)
  636. #define PE14_SPI0_MISO (GpioPortE<<16u|GpioPin14<<8u|GpioAf2)
  637. #define PE15_SPI0_MOSI (GpioPortE<<16u|GpioPin15<<8u|GpioAf2)
  638. #define PF00_2x (GpioPortF<<16u|GpioPin0 <<8u|GpioAf2)
  639. #define PF01_TIM4_CHB (GpioPortF<<16u|GpioPin1 <<8u|GpioAf2)
  640. #define PF02_2x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf2)
  641. #define PF03_2x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf2)
  642. #define PF04_2x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf2)
  643. #define PF05_2x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf2)
  644. #define PF06_LPUART1_CTS (GpioPortF<<16u|GpioPin6 <<8u|GpioAf2)
  645. #define PF07_LPUART1_RTS (GpioPortF<<16u|GpioPin7 <<8u|GpioAf2)
  646. #define PF09_2x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf2)
  647. #define PF10_2x (GpioPortF<<16u|GpioPin10<<8u|GpioAf2)
  648. #define PF11_2x (GpioPortF<<16u|GpioPin11<<8u|GpioAf2)
  649. ///< GpioAf3
  650. #define PA00_TIM0_ETR (GpioPortA<<16u|GpioPin0 <<8u|GpioAf3)
  651. #define PA01_TIM0_CHB (GpioPortA<<16u|GpioPin1 <<8u|GpioAf3)
  652. #define PA02_VC1_OUT (GpioPortA<<16u|GpioPin2 <<8u|GpioAf3)
  653. #define PA03_TIM1_CHB (GpioPortA<<16u|GpioPin3 <<8u|GpioAf3)
  654. #define PA04_PCA_CH4 (GpioPortA<<16u|GpioPin4 <<8u|GpioAf3)
  655. #define PA05_PCA_ECI (GpioPortA<<16u|GpioPin5 <<8u|GpioAf3)
  656. #define PA06_TIM3_BK (GpioPortA<<16u|GpioPin6 <<8u|GpioAf3)
  657. #define PA07_HCLK_OUT (GpioPortA<<16u|GpioPin7 <<8u|GpioAf3)
  658. #define PA08_3x (GpioPortA<<16u|GpioPin8 <<8u|GpioAf3)
  659. #define PA09_TIM0_BK (GpioPortA<<16u|GpioPin9 <<8u|GpioAf3)
  660. #define PA10_TIM2_BK (GpioPortA<<16u|GpioPin10<<8u|GpioAf3)
  661. #define PA11_I2C1_SCL (GpioPortA<<16u|GpioPin11<<8u|GpioAf3)
  662. #define PA12_I2C1_SDA (GpioPortA<<16u|GpioPin12<<8u|GpioAf3)
  663. #define PA13_LVD_OUT (GpioPortA<<16u|GpioPin13<<8u|GpioAf3)
  664. #define PA14_TIM3_CH2A (GpioPortA<<16u|GpioPin14<<8u|GpioAf3)
  665. #define PA15_LPUART1_RTS (GpioPortA<<16u|GpioPin15<<8u|GpioAf3)
  666. #define PB00_LPUART0_TXD (GpioPortB<<16u|GpioPin0 <<8u|GpioAf3)
  667. #define PB01_TIM3_CH2B (GpioPortB<<16u|GpioPin1 <<8u|GpioAf3)
  668. #define PB02_LPUART1_TXD (GpioPortB<<16u|GpioPin2 <<8u|GpioAf3)
  669. #define PB03_TIM1_GATE (GpioPortB<<16u|GpioPin3 <<8u|GpioAf3)
  670. #define PB04_TIM2_BK (GpioPortB<<16u|GpioPin4 <<8u|GpioAf3)
  671. #define PB05_TIM1_BK (GpioPortB<<16u|GpioPin5 <<8u|GpioAf3)
  672. #define PB06_TIM1_CHB (GpioPortB<<16u|GpioPin6 <<8u|GpioAf3)
  673. #define PB07_TIM2_CHB (GpioPortB<<16u|GpioPin7 <<8u|GpioAf3)
  674. #define PB08_3x (GpioPortB<<16u|GpioPin8 <<8u|GpioAf3)
  675. #define PB09_SPI1_CS (GpioPortB<<16u|GpioPin9 <<8u|GpioAf3)
  676. #define PB10_TIM1_CHA (GpioPortB<<16u|GpioPin10<<8u|GpioAf3)
  677. #define PB11_LPUART0_RXD (GpioPortB<<16u|GpioPin11<<8u|GpioAf3)
  678. #define PB12_LPUART0_TXD (GpioPortB<<16u|GpioPin12<<8u|GpioAf3)
  679. #define PB13_TIM3_CH0B (GpioPortB<<16u|GpioPin13<<8u|GpioAf3)
  680. #define PB14_TIM3_CH1B (GpioPortB<<16u|GpioPin14<<8u|GpioAf3)
  681. #define PB15_TIM0_CHB (GpioPortB<<16u|GpioPin15<<8u|GpioAf3)
  682. #define PC00_UART1_CTS (GpioPortC<<16u|GpioPin0 <<8u|GpioAf3)
  683. #define PC01_UART1_RTS (GpioPortC<<16u|GpioPin1 <<8u|GpioAf3)
  684. #define PC02_PCNT_S1 (GpioPortC<<16u|GpioPin2 <<8u|GpioAf3)
  685. #define PC03_LPTIM_TOGN (GpioPortC<<16u|GpioPin3 <<8u|GpioAf3)
  686. #define PC04_IR_OUT (GpioPortC<<16u|GpioPin4 <<8u|GpioAf3)
  687. #define PC05_PCA_CH4 (GpioPortC<<16u|GpioPin5 <<8u|GpioAf3)
  688. #define PC06_TIM2_CHA (GpioPortC<<16u|GpioPin6 <<8u|GpioAf3)
  689. #define PC07_TIM2_CHB (GpioPortC<<16u|GpioPin7 <<8u|GpioAf3)
  690. #define PC08_TIM2_ETR (GpioPortC<<16u|GpioPin8 <<8u|GpioAf3)
  691. #define PC09_TIM1_ETR (GpioPortC<<16u|GpioPin9 <<8u|GpioAf3)
  692. #define PC10_PCA_CH2 (GpioPortC<<16u|GpioPin10<<8u|GpioAf3)
  693. #define PC11_PCA_CH3 (GpioPortC<<16u|GpioPin11<<8u|GpioAf3)
  694. #define PC12_PCA_CH4 (GpioPortC<<16u|GpioPin12<<8u|GpioAf3)
  695. #define PC13_TIM3_CH1B (GpioPortC<<16u|GpioPin13<<8u|GpioAf3)
  696. #define PC14_3x (GpioPortC<<16u|GpioPin14<<8u|GpioAf3)
  697. #define PC15_3x (GpioPortC<<16u|GpioPin15<<8u|GpioAf3)
  698. #define PD00_3x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf3)
  699. #define PD01_3x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf3)
  700. #define PD02_TIM1_ETR (GpioPortD<<16u|GpioPin2 <<8u|GpioAf3)
  701. #define PD03_LPTIM1_TOG (GpioPortD<<16u|GpioPin3 <<8u|GpioAf3)
  702. #define PD04_LPTIM1_TOGN (GpioPortD<<16u|GpioPin4 <<8u|GpioAf3)
  703. #define PD05_3x (GpioPortD<<16u|GpioPin5 <<8u|GpioAf3)
  704. #define PD06_3x (GpioPortD<<16u|GpioPin6 <<8u|GpioAf3)
  705. #define PD07_3x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf3)
  706. #define PD08_3x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf3)
  707. #define PD09_3x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf3)
  708. #define PD10_3x (GpioPortD<<16u|GpioPin10<<8u|GpioAf3)
  709. #define PD11_3x (GpioPortD<<16u|GpioPin11<<8u|GpioAf3)
  710. #define PD12_3x (GpioPortD<<16u|GpioPin12<<8u|GpioAf3)
  711. #define PD13_3x (GpioPortD<<16u|GpioPin13<<8u|GpioAf3)
  712. #define PD14_3x (GpioPortD<<16u|GpioPin14<<8u|GpioAf3)
  713. #define PD15_3x (GpioPortD<<16u|GpioPin15<<8u|GpioAf3)
  714. #define PE00_3x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf3)
  715. #define PE01_3x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf3)
  716. #define PE02_3x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf3)
  717. #define PE03_3x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf3)
  718. #define PE04_3x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf3)
  719. #define PE05_3x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf3)
  720. #define PE06_3x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf3)
  721. #define PE07_3x (GpioPortE<<16u|GpioPin7 <<8u|GpioAf3)
  722. #define PE08_3x (GpioPortE<<16u|GpioPin8 <<8u|GpioAf3)
  723. #define PE09_3x (GpioPortE<<16u|GpioPin9 <<8u|GpioAf3)
  724. #define PE10_3x (GpioPortE<<16u|GpioPin10<<8u|GpioAf3)
  725. #define PE11_3x (GpioPortE<<16u|GpioPin11<<8u|GpioAf3)
  726. #define PE12_UART3_CTS (GpioPortE<<16u|GpioPin12<<8u|GpioAf3)
  727. #define PE13_UART3_RTS (GpioPortE<<16u|GpioPin13<<8u|GpioAf3)
  728. #define PE14_UART3_RXD (GpioPortE<<16u|GpioPin14<<8u|GpioAf3)
  729. #define PE15_UART3_TXD (GpioPortE<<16u|GpioPin15<<8u|GpioAf3)
  730. #define PF00_UART1_TXD (GpioPortF<<16u|GpioPin0 <<8u|GpioAf3)
  731. #define PF01_UART1_RXD (GpioPortF<<16u|GpioPin1 <<8u|GpioAf3)
  732. #define PF02_3x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf3)
  733. #define PF03_3x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf3)
  734. #define PF04_3x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf3)
  735. #define PF05_3x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf3)
  736. #define PF06_UART0_CTS (GpioPortF<<16u|GpioPin6 <<8u|GpioAf3)
  737. #define PF07_UART0_RTS (GpioPortF<<16u|GpioPin7 <<8u|GpioAf3)
  738. #define PF09_3x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf3)
  739. #define PF10_3x (GpioPortF<<16u|GpioPin10<<8u|GpioAf3)
  740. #define PF11_3x (GpioPortF<<16u|GpioPin11<<8u|GpioAf3)
  741. ///< GpioAf4
  742. #define PA00_VC0_OUT (GpioPortA<<16u|GpioPin0 <<8u|GpioAf4)
  743. #define PA01_TIM1_ETR (GpioPortA<<16u|GpioPin1 <<8u|GpioAf4)
  744. #define PA02_TIM1_CHA (GpioPortA<<16u|GpioPin2 <<8u|GpioAf4)
  745. #define PA03_TIM2_CHB (GpioPortA<<16u|GpioPin3 <<8u|GpioAf4)
  746. #define PA04_TIM2_ETR (GpioPortA<<16u|GpioPin4 <<8u|GpioAf4)
  747. #define PA05_TIM0_CHA (GpioPortA<<16u|GpioPin5 <<8u|GpioAf4)
  748. #define PA06_TIM1_CHA (GpioPortA<<16u|GpioPin6 <<8u|GpioAf4)
  749. #define PA07_TIM3_CH0B (GpioPortA<<16u|GpioPin7 <<8u|GpioAf4)
  750. #define PA08_4x (GpioPortA<<16u|GpioPin8 <<8u|GpioAf4)
  751. #define PA09_I2C0_SCL (GpioPortA<<16u|GpioPin9 <<8u|GpioAf4)
  752. #define PA10_I2C0_SDA (GpioPortA<<16u|GpioPin10<<8u|GpioAf4)
  753. #define PA11_4x (GpioPortA<<16u|GpioPin11<<8u|GpioAf4)
  754. #define PA12_4x (GpioPortA<<16u|GpioPin12<<8u|GpioAf4)
  755. #define PA13_TIM3_ETR (GpioPortA<<16u|GpioPin13<<8u|GpioAf4)
  756. #define PA14_LVD_OUT (GpioPortA<<16u|GpioPin14<<8u|GpioAf4)
  757. #define PA15_TIM0_ETR (GpioPortA<<16u|GpioPin15<<8u|GpioAf4)
  758. #define PB00_TIM5_CHB (GpioPortB<<16u|GpioPin0 <<8u|GpioAf4)
  759. #define PB01_TIM6_CHB (GpioPortB<<16u|GpioPin1 <<8u|GpioAf4)
  760. #define PB02_TIM4_CHA (GpioPortB<<16u|GpioPin2 <<8u|GpioAf4)
  761. #define PB03_TIM3_CH0A (GpioPortB<<16u|GpioPin3 <<8u|GpioAf4)
  762. #define PB04_UART0_CTS (GpioPortB<<16u|GpioPin4 <<8u|GpioAf4)
  763. #define PB05_PCA_CH1 (GpioPortB<<16u|GpioPin5 <<8u|GpioAf4)
  764. #define PB06_TIM0_CHA (GpioPortB<<16u|GpioPin6 <<8u|GpioAf4)
  765. #define PB07_LPUART1_CTS (GpioPortB<<16u|GpioPin7 <<8u|GpioAf4)
  766. #define PB08_TIM2_CHA (GpioPortB<<16u|GpioPin8 <<8u|GpioAf4)
  767. #define PB09_TIM2_CHA (GpioPortB<<16u|GpioPin9 <<8u|GpioAf4)
  768. #define PB10_LPUART0_TXD (GpioPortB<<16u|GpioPin10<<8u|GpioAf4)
  769. #define PB11_TIM2_GATE (GpioPortB<<16u|GpioPin11<<8u|GpioAf4)
  770. #define PB12_TIM0_BK (GpioPortB<<16u|GpioPin12<<8u|GpioAf4)
  771. #define PB13_LPUART0_CTS (GpioPortB<<16u|GpioPin13<<8u|GpioAf4)
  772. #define PB14_TIM0_CHA (GpioPortB<<16u|GpioPin14<<8u|GpioAf4)
  773. #define PB15_TIM0_GATE (GpioPortB<<16u|GpioPin15<<8u|GpioAf4)
  774. #define PC00_UART2_RTS (GpioPortC<<16u|GpioPin0 <<8u|GpioAf4)
  775. #define PC01_PCNT_S0FO (GpioPortC<<16u|GpioPin1 <<8u|GpioAf4)
  776. #define PC02_UART2_RXD (GpioPortC<<16u|GpioPin2 <<8u|GpioAf4)
  777. #define PC03_PCNT_S1FO (GpioPortC<<16u|GpioPin3 <<8u|GpioAf4)
  778. #define PC04_VC2_OUT (GpioPortC<<16u|GpioPin4 <<8u|GpioAf4)
  779. #define PC05_4x (GpioPortC<<16u|GpioPin5 <<8u|GpioAf4)
  780. #define PC06_LPTIM1_GATE (GpioPortC<<16u|GpioPin6 <<8u|GpioAf4)
  781. #define PC07_LPTIM1_ETR (GpioPortC<<16u|GpioPin7 <<8u|GpioAf4)
  782. #define PC08_LPTIM1_TOG (GpioPortC<<16u|GpioPin8 <<8u|GpioAf4)
  783. #define PC09_LPTIM1_TOGN (GpioPortC<<16u|GpioPin9 <<8u|GpioAf4)
  784. #define PC10_4x (GpioPortC<<16u|GpioPin10<<8u|GpioAf4)
  785. #define PC11_PCNT_S0FO (GpioPortC<<16u|GpioPin11<<8u|GpioAf4)
  786. #define PC12_PCNT_S1FO (GpioPortC<<16u|GpioPin12<<8u|GpioAf4)
  787. #define PC13_4x (GpioPortC<<16u|GpioPin13<<8u|GpioAf4)
  788. #define PC14_4x (GpioPortC<<16u|GpioPin14<<8u|GpioAf4)
  789. #define PC15_4x (GpioPortC<<16u|GpioPin15<<8u|GpioAf4)
  790. #define PD00_4x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf4)
  791. #define PD01_4x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf4)
  792. #define PD02_4x (GpioPortD<<16u|GpioPin2 <<8u|GpioAf4)
  793. #define PD03_4x (GpioPortD<<16u|GpioPin3 <<8u|GpioAf4)
  794. #define PD04_4x (GpioPortD<<16u|GpioPin4 <<8u|GpioAf4)
  795. #define PD05_4x (GpioPortD<<16u|GpioPin5 <<8u|GpioAf4)
  796. #define PD06_4x (GpioPortD<<16u|GpioPin6 <<8u|GpioAf4)
  797. #define PD07_4x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf4)
  798. #define PD08_4x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf4)
  799. #define PD09_4x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf4)
  800. #define PD10_4x (GpioPortD<<16u|GpioPin10<<8u|GpioAf4)
  801. #define PD11_4x (GpioPortD<<16u|GpioPin11<<8u|GpioAf4)
  802. #define PD12_4x (GpioPortD<<16u|GpioPin12<<8u|GpioAf4)
  803. #define PD13_4x (GpioPortD<<16u|GpioPin13<<8u|GpioAf4)
  804. #define PD14_4x (GpioPortD<<16u|GpioPin14<<8u|GpioAf4)
  805. #define PD15_4x (GpioPortD<<16u|GpioPin15<<8u|GpioAf4)
  806. #define PE00_4x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf4)
  807. #define PE01_4x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf4)
  808. #define PE02_4x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf4)
  809. #define PE03_4x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf4)
  810. #define PE04_4x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf4)
  811. #define PE05_4x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf4)
  812. #define PE06_4x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf4)
  813. #define PE07_4x (GpioPortE<<16u|GpioPin7 <<8u|GpioAf4)
  814. #define PE08_4x (GpioPortE<<16u|GpioPin8 <<8u|GpioAf4)
  815. #define PE09_4x (GpioPortE<<16u|GpioPin9 <<8u|GpioAf4)
  816. #define PE10_4x (GpioPortE<<16u|GpioPin10<<8u|GpioAf4)
  817. #define PE11_4x (GpioPortE<<16u|GpioPin11<<8u|GpioAf4)
  818. #define PE12_4x (GpioPortE<<16u|GpioPin12<<8u|GpioAf4)
  819. #define PE13_4x (GpioPortE<<16u|GpioPin13<<8u|GpioAf4)
  820. #define PE14_4x (GpioPortE<<16u|GpioPin14<<8u|GpioAf4)
  821. #define PE15_4x (GpioPortE<<16u|GpioPin15<<8u|GpioAf4)
  822. #define PF00_4x (GpioPortF<<16u|GpioPin0 <<8u|GpioAf4)
  823. #define PF01_4x (GpioPortF<<16u|GpioPin1 <<8u|GpioAf4)
  824. #define PF02_4x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf4)
  825. #define PF03_4x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf4)
  826. #define PF04_4x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf4)
  827. #define PF05_4x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf4)
  828. #define PF06_4x (GpioPortF<<16u|GpioPin6 <<8u|GpioAf4)
  829. #define PF07_4x (GpioPortF<<16u|GpioPin7 <<8u|GpioAf4)
  830. #define PF09_4x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf4)
  831. #define PF10_4x (GpioPortF<<16u|GpioPin10<<8u|GpioAf4)
  832. #define PF11_4x (GpioPortF<<16u|GpioPin11<<8u|GpioAf4)
  833. ///< GpioAf5
  834. #define PA00_TIM1_CHA (GpioPortA<<16u|GpioPin0 <<8u|GpioAf5)
  835. #define PA01_TIM1_CHB (GpioPortA<<16u|GpioPin1 <<8u|GpioAf5)
  836. #define PA02_TIM2_CHA (GpioPortA<<16u|GpioPin2 <<8u|GpioAf5)
  837. #define PA03_SPI1_CS (GpioPortA<<16u|GpioPin3 <<8u|GpioAf5)
  838. #define PA04_TIM5_CHA (GpioPortA<<16u|GpioPin4 <<8u|GpioAf5)
  839. #define PA05_TIM5_CHB (GpioPortA<<16u|GpioPin5 <<8u|GpioAf5)
  840. #define PA06_VC0_OUT (GpioPortA<<16u|GpioPin6 <<8u|GpioAf5)
  841. #define PA07_TIM2_CHA (GpioPortA<<16u|GpioPin7 <<8u|GpioAf5)
  842. #define PA08_TIM1_GATE (GpioPortA<<16u|GpioPin8 <<8u|GpioAf5)
  843. #define PA09_5x (GpioPortA<<16u|GpioPin9 <<8u|GpioAf5)
  844. #define PA10_TIM2_GATE (GpioPortA<<16u|GpioPin10<<8u|GpioAf5)
  845. #define PA11_VC0_OUT (GpioPortA<<16u|GpioPin11<<8u|GpioAf5)
  846. #define PA12_VC1_OUT (GpioPortA<<16u|GpioPin12<<8u|GpioAf5)
  847. #define PA13_RTC_1HZ (GpioPortA<<16u|GpioPin13<<8u|GpioAf5)
  848. #define PA14_RCH_OUT (GpioPortA<<16u|GpioPin14<<8u|GpioAf5)
  849. #define PA15_TIM0_CHA (GpioPortA<<16u|GpioPin15<<8u|GpioAf5)
  850. #define PB00_RCH_OUT (GpioPortB<<16u|GpioPin0 <<8u|GpioAf5)
  851. #define PB01_LPUART0_RTS (GpioPortB<<16u|GpioPin1 <<8u|GpioAf5)
  852. #define PB02_TIM1_BK (GpioPortB<<16u|GpioPin2 <<8u|GpioAf5)
  853. #define PB03_LPTIM_GATE (GpioPortB<<16u|GpioPin3 <<8u|GpioAf5)
  854. #define PB04_TIM2_GATE (GpioPortB<<16u|GpioPin4 <<8u|GpioAf5)
  855. #define PB05_LPTIM_GATE (GpioPortB<<16u|GpioPin5 <<8u|GpioAf5)
  856. #define PB06_LPTIM_ETR (GpioPortB<<16u|GpioPin6 <<8u|GpioAf5)
  857. #define PB07_TIM0_CHB (GpioPortB<<16u|GpioPin7 <<8u|GpioAf5)
  858. #define PB08_TIM0_GATE (GpioPortB<<16u|GpioPin8 <<8u|GpioAf5)
  859. #define PB09_5x (GpioPortB<<16u|GpioPin9 <<8u|GpioAf5)
  860. #define PB10_TIM3_CH1A (GpioPortB<<16u|GpioPin10<<8u|GpioAf5)
  861. #define PB11_TIM6_CHA (GpioPortB<<16u|GpioPin11<<8u|GpioAf5)
  862. #define PB12_5x (GpioPortB<<16u|GpioPin12<<8u|GpioAf5)
  863. #define PB13_TIM1_CHA (GpioPortB<<16u|GpioPin13<<8u|GpioAf5)
  864. #define PB14_RTC_1HZ (GpioPortB<<16u|GpioPin14<<8u|GpioAf5)
  865. #define PB15_5x (GpioPortB<<16u|GpioPin15<<8u|GpioAf5)
  866. #define PC00_5x (GpioPortC<<16u|GpioPin0 <<8u|GpioAf5)
  867. #define PC01_5x (GpioPortC<<16u|GpioPin1 <<8u|GpioAf5)
  868. #define PC02_5x (GpioPortC<<16u|GpioPin2 <<8u|GpioAf5)
  869. #define PC03_UART2_TXD (GpioPortC<<16u|GpioPin3 <<8u|GpioAf5)
  870. #define PC04_5x (GpioPortC<<16u|GpioPin4 <<8u|GpioAf5)
  871. #define PC05_5x (GpioPortC<<16u|GpioPin5 <<8u|GpioAf5)
  872. #define PC06_5x (GpioPortC<<16u|GpioPin6 <<8u|GpioAf5)
  873. #define PC07_5x (GpioPortC<<16u|GpioPin7 <<8u|GpioAf5)
  874. #define PC08_5x (GpioPortC<<16u|GpioPin8 <<8u|GpioAf5)
  875. #define PC09_5x (GpioPortC<<16u|GpioPin9 <<8u|GpioAf5)
  876. #define PC10_5x (GpioPortC<<16u|GpioPin10<<8u|GpioAf5)
  877. #define PC11_5x (GpioPortC<<16u|GpioPin11<<8u|GpioAf5)
  878. #define PC12_5x (GpioPortC<<16u|GpioPin12<<8u|GpioAf5)
  879. #define PC13_5x (GpioPortC<<16u|GpioPin13<<8u|GpioAf5)
  880. #define PC14_5x (GpioPortC<<16u|GpioPin14<<8u|GpioAf5)
  881. #define PC15_5x (GpioPortC<<16u|GpioPin15<<8u|GpioAf5)
  882. #define PD00_5x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf5)
  883. #define PD01_5x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf5)
  884. #define PD02_5x (GpioPortD<<16u|GpioPin2 <<8u|GpioAf5)
  885. #define PD03_5x (GpioPortD<<16u|GpioPin3 <<8u|GpioAf5)
  886. #define PD04_5x (GpioPortD<<16u|GpioPin4 <<8u|GpioAf5)
  887. #define PD05_5x (GpioPortD<<16u|GpioPin5 <<8u|GpioAf5)
  888. #define PD06_5x (GpioPortD<<16u|GpioPin6 <<8u|GpioAf5)
  889. #define PD07_5x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf5)
  890. #define PD08_5x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf5)
  891. #define PD09_5x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf5)
  892. #define PD10_5x (GpioPortD<<16u|GpioPin10<<8u|GpioAf5)
  893. #define PD11_5x (GpioPortD<<16u|GpioPin11<<8u|GpioAf5)
  894. #define PD12_5x (GpioPortD<<16u|GpioPin12<<8u|GpioAf5)
  895. #define PD13_5x (GpioPortD<<16u|GpioPin13<<8u|GpioAf5)
  896. #define PD14_5x (GpioPortD<<16u|GpioPin14<<8u|GpioAf5)
  897. #define PD15_5x (GpioPortD<<16u|GpioPin15<<8u|GpioAf5)
  898. #define PE00_5x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf5)
  899. #define PE01_5x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf5)
  900. #define PE02_5x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf5)
  901. #define PE03_5x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf5)
  902. #define PE04_5x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf5)
  903. #define PE05_5x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf5)
  904. #define PE06_5x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf5)
  905. #define PE07_5x (GpioPortE<<16u|GpioPin7 <<8u|GpioAf5)
  906. #define PE08_5x (GpioPortE<<16u|GpioPin8 <<8u|GpioAf5)
  907. #define PE09_5x (GpioPortE<<16u|GpioPin9 <<8u|GpioAf5)
  908. #define PE10_5x (GpioPortE<<16u|GpioPin10<<8u|GpioAf5)
  909. #define PE11_5x (GpioPortE<<16u|GpioPin11<<8u|GpioAf5)
  910. #define PE12_5x (GpioPortE<<16u|GpioPin12<<8u|GpioAf5)
  911. #define PE13_5x (GpioPortE<<16u|GpioPin13<<8u|GpioAf5)
  912. #define PE14_5x (GpioPortE<<16u|GpioPin14<<8u|GpioAf5)
  913. #define PE15_5x (GpioPortE<<16u|GpioPin15<<8u|GpioAf5)
  914. #define PF00_5x (GpioPortF<<16u|GpioPin0 <<8u|GpioAf5)
  915. #define PF01_5x (GpioPortF<<16u|GpioPin1 <<8u|GpioAf5)
  916. #define PF02_5x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf5)
  917. #define PF03_5x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf5)
  918. #define PF04_5x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf5)
  919. #define PF05_5x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf5)
  920. #define PF06_5x (GpioPortF<<16u|GpioPin6 <<8u|GpioAf5)
  921. #define PF07_5x (GpioPortF<<16u|GpioPin7 <<8u|GpioAf5)
  922. #define PF09_5x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf5)
  923. #define PF10_5x (GpioPortF<<16u|GpioPin10<<8u|GpioAf5)
  924. #define PF11_5x (GpioPortF<<16u|GpioPin11<<8u|GpioAf5)
  925. ///< GpioAf6
  926. #define PA00_TIM3_ETR (GpioPortA<<16u|GpioPin0 <<8u|GpioAf6)
  927. #define PA01_HCLK_OUT (GpioPortA<<16u|GpioPin1 <<8u|GpioAf6)
  928. #define PA02_PCLK_OUT (GpioPortA<<16u|GpioPin2 <<8u|GpioAf6)
  929. #define PA03_TIM3_CH1A (GpioPortA<<16u|GpioPin3 <<8u|GpioAf6)
  930. #define PA04_LVD_OUT (GpioPortA<<16u|GpioPin4 <<8u|GpioAf6)
  931. #define PA05_XTL_OUT (GpioPortA<<16u|GpioPin5 <<8u|GpioAf6)
  932. #define PA06_TIM3_GATE (GpioPortA<<16u|GpioPin6 <<8u|GpioAf6)
  933. #define PA07_VC1_OUT (GpioPortA<<16u|GpioPin7 <<8u|GpioAf6)
  934. #define PA08_TIM4_CHA (GpioPortA<<16u|GpioPin8 <<8u|GpioAf6)
  935. #define PA09_HCLK_OUT (GpioPortA<<16u|GpioPin9 <<8u|GpioAf6)
  936. #define PA10_PCLK_OUT (GpioPortA<<16u|GpioPin10<<8u|GpioAf6)
  937. #define PA11_SPI0_MISO (GpioPortA<<16u|GpioPin11<<8u|GpioAf6)
  938. #define PA12_SPI0_MOSI (GpioPortA<<16u|GpioPin12<<8u|GpioAf6)
  939. #define PA13_PCNT_S1 (GpioPortA<<16u|GpioPin13<<8u|GpioAf6)
  940. #define PA14_RCL_OUT (GpioPortA<<16u|GpioPin14<<8u|GpioAf6)
  941. #define PA15_TIM3_CH1A (GpioPortA<<16u|GpioPin15<<8u|GpioAf6)
  942. #define PB00_RCL_OUT (GpioPortB<<16u|GpioPin0 <<8u|GpioAf6)
  943. #define PB01_VC2_OUT (GpioPortB<<16u|GpioPin1 <<8u|GpioAf6)
  944. #define PB02_TIM0_BK (GpioPortB<<16u|GpioPin2 <<8u|GpioAf6)
  945. #define PB03_XTL_OUT (GpioPortB<<16u|GpioPin3 <<8u|GpioAf6)
  946. #define PB04_TIM3_CH0B (GpioPortB<<16u|GpioPin4 <<8u|GpioAf6)
  947. #define PB05_PCNT_S0 (GpioPortB<<16u|GpioPin5 <<8u|GpioAf6)
  948. #define PB06_TIM3_CH0A (GpioPortB<<16u|GpioPin6 <<8u|GpioAf6)
  949. #define PB07_LPTIM_TOGN (GpioPortB<<16u|GpioPin7 <<8u|GpioAf6)
  950. #define PB08_TIM3_CH2A (GpioPortB<<16u|GpioPin8 <<8u|GpioAf6)
  951. #define PB09_TIM2_CHB (GpioPortB<<16u|GpioPin9 <<8u|GpioAf6)
  952. #define PB10_LPUART1_RTS (GpioPortB<<16u|GpioPin10<<8u|GpioAf6)
  953. #define PB11_LPUART1_CTS (GpioPortB<<16u|GpioPin11<<8u|GpioAf6)
  954. #define PB12_LPUART0_RTS (GpioPortB<<16u|GpioPin12<<8u|GpioAf6)
  955. #define PB13_TIM1_GATE (GpioPortB<<16u|GpioPin13<<8u|GpioAf6)
  956. #define PB14_LPUART0_RTS (GpioPortB<<16u|GpioPin14<<8u|GpioAf6)
  957. #define PB15_6x (GpioPortB<<16u|GpioPin15<<8u|GpioAf6)
  958. #define PC00_6x (GpioPortC<<16u|GpioPin0 <<8u|GpioAf6)
  959. #define PC01_UART2_CTS (GpioPortC<<16u|GpioPin1 <<8u|GpioAf6)
  960. #define PC02_6x (GpioPortC<<16u|GpioPin2 <<8u|GpioAf6)
  961. #define PC03_6x (GpioPortC<<16u|GpioPin3 <<8u|GpioAf6)
  962. #define PC04_6x (GpioPortC<<16u|GpioPin4 <<8u|GpioAf6)
  963. #define PC05_6x (GpioPortC<<16u|GpioPin5 <<8u|GpioAf6)
  964. #define PC06_UART3_RXD (GpioPortC<<16u|GpioPin6 <<8u|GpioAf6)
  965. #define PC07_UART3_TXD (GpioPortC<<16u|GpioPin7 <<8u|GpioAf6)
  966. #define PC08_UART3_CTS (GpioPortC<<16u|GpioPin8 <<8u|GpioAf6)
  967. #define PC09_UART3_RTS (GpioPortC<<16u|GpioPin9 <<8u|GpioAf6)
  968. #define PC10_6x (GpioPortC<<16u|GpioPin10<<8u|GpioAf6)
  969. #define PC11_6x (GpioPortC<<16u|GpioPin11<<8u|GpioAf6)
  970. #define PC12_6x (GpioPortC<<16u|GpioPin12<<8u|GpioAf6)
  971. #define PC13_6x (GpioPortC<<16u|GpioPin13<<8u|GpioAf6)
  972. #define PC14_6x (GpioPortC<<16u|GpioPin14<<8u|GpioAf6)
  973. #define PC15_6x (GpioPortC<<16u|GpioPin15<<8u|GpioAf6)
  974. #define PD00_6x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf6)
  975. #define PD01_6x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf6)
  976. #define PD02_6x (GpioPortD<<16u|GpioPin2 <<8u|GpioAf6)
  977. #define PD03_6x (GpioPortD<<16u|GpioPin3 <<8u|GpioAf6)
  978. #define PD04_6x (GpioPortD<<16u|GpioPin4 <<8u|GpioAf6)
  979. #define PD05_6x (GpioPortD<<16u|GpioPin5 <<8u|GpioAf6)
  980. #define PD06_6x (GpioPortD<<16u|GpioPin6 <<8u|GpioAf6)
  981. #define PD07_6x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf6)
  982. #define PD08_6x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf6)
  983. #define PD09_6x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf6)
  984. #define PD10_6x (GpioPortD<<16u|GpioPin10<<8u|GpioAf6)
  985. #define PD11_6x (GpioPortD<<16u|GpioPin11<<8u|GpioAf6)
  986. #define PD12_6x (GpioPortD<<16u|GpioPin12<<8u|GpioAf6)
  987. #define PD13_6x (GpioPortD<<16u|GpioPin13<<8u|GpioAf6)
  988. #define PD14_6x (GpioPortD<<16u|GpioPin14<<8u|GpioAf6)
  989. #define PD15_6x (GpioPortD<<16u|GpioPin15<<8u|GpioAf6)
  990. #define PE00_6x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf6)
  991. #define PE01_6x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf6)
  992. #define PE02_6x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf6)
  993. #define PE03_6x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf6)
  994. #define PE04_6x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf6)
  995. #define PE05_6x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf6)
  996. #define PE06_6x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf6)
  997. #define PE07_6x (GpioPortE<<16u|GpioPin7 <<8u|GpioAf6)
  998. #define PE08_6x (GpioPortE<<16u|GpioPin8 <<8u|GpioAf6)
  999. #define PE09_6x (GpioPortE<<16u|GpioPin9 <<8u|GpioAf6)
  1000. #define PE10_6x (GpioPortE<<16u|GpioPin10<<8u|GpioAf6)
  1001. #define PE11_6x (GpioPortE<<16u|GpioPin11<<8u|GpioAf6)
  1002. #define PE12_6x (GpioPortE<<16u|GpioPin12<<8u|GpioAf6)
  1003. #define PE13_6x (GpioPortE<<16u|GpioPin13<<8u|GpioAf6)
  1004. #define PE14_6x (GpioPortE<<16u|GpioPin14<<8u|GpioAf6)
  1005. #define PE15_6x (GpioPortE<<16u|GpioPin15<<8u|GpioAf6)
  1006. #define PF00_6x (GpioPortF<<16u|GpioPin0 <<8u|GpioAf6)
  1007. #define PF01_6x (GpioPortF<<16u|GpioPin1 <<8u|GpioAf6)
  1008. #define PF02_6x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf6)
  1009. #define PF03_6x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf6)
  1010. #define PF04_6x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf6)
  1011. #define PF05_6x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf6)
  1012. #define PF06_6x (GpioPortF<<16u|GpioPin6 <<8u|GpioAf6)
  1013. #define PF07_6x (GpioPortF<<16u|GpioPin7 <<8u|GpioAf6)
  1014. #define PF09_6x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf6)
  1015. #define PF10_6x (GpioPortF<<16u|GpioPin10<<8u|GpioAf6)
  1016. #define PF11_6x (GpioPortF<<16u|GpioPin11<<8u|GpioAf6)
  1017. ///< GpioAf7
  1018. #define PA00_TIM0_CHA (GpioPortA<<16u|GpioPin0 <<8u|GpioAf7)
  1019. #define PA01_SPI1_MOSI (GpioPortA<<16u|GpioPin1 <<8u|GpioAf7)
  1020. #define PA02_SPI1_MISO (GpioPortA<<16u|GpioPin2 <<8u|GpioAf7)
  1021. #define PA03_TIM5_CHA (GpioPortA<<16u|GpioPin3 <<8u|GpioAf7)
  1022. #define PA04_TIM3_CH2B (GpioPortA<<16u|GpioPin4 <<8u|GpioAf7)
  1023. #define PA05_XTH_OUT (GpioPortA<<16u|GpioPin5 <<8u|GpioAf7)
  1024. #define PA06_LPUART0_CTS (GpioPortA<<16u|GpioPin6 <<8u|GpioAf7)
  1025. #define PA07_TIM4_CHB (GpioPortA<<16u|GpioPin7 <<8u|GpioAf7)
  1026. #define PA08_TIM3_BK (GpioPortA<<16u|GpioPin8 <<8u|GpioAf7)
  1027. #define PA09_TIM5_CHA (GpioPortA<<16u|GpioPin9 <<8u|GpioAf7)
  1028. #define PA10_TIM6_CHA (GpioPortA<<16u|GpioPin10<<8u|GpioAf7)
  1029. #define PA11_TIM4_CHB (GpioPortA<<16u|GpioPin11<<8u|GpioAf7)
  1030. #define PA12_PCNT_S0 (GpioPortA<<16u|GpioPin12<<8u|GpioAf7)
  1031. #define PA13_VC2_OUT (GpioPortA<<16u|GpioPin13<<8u|GpioAf7)
  1032. #define PA14_PLL_OUT (GpioPortA<<16u|GpioPin14<<8u|GpioAf7)
  1033. #define PA15_7x (GpioPortA<<16u|GpioPin15<<8u|GpioAf7)
  1034. #define PB00_PLL_OUT (GpioPortB<<16u|GpioPin0 <<8u|GpioAf7)
  1035. #define PB01_TCLK_OUT (GpioPortB<<16u|GpioPin1 <<8u|GpioAf7)
  1036. #define PB02_TIM2_BK (GpioPortB<<16u|GpioPin2 <<8u|GpioAf7)
  1037. #define PB03_XTH_OUT (GpioPortB<<16u|GpioPin3 <<8u|GpioAf7)
  1038. #define PB04_LPTIM_ETR (GpioPortB<<16u|GpioPin4 <<8u|GpioAf7)
  1039. #define PB05_UART0_RTS (GpioPortB<<16u|GpioPin5 <<8u|GpioAf7)
  1040. #define PB06_LPTIM_TOG (GpioPortB<<16u|GpioPin6 <<8u|GpioAf7)
  1041. #define PB07_PCNT_S1 (GpioPortB<<16u|GpioPin7 <<8u|GpioAf7)
  1042. #define PB08_UART0_TXD (GpioPortB<<16u|GpioPin8 <<8u|GpioAf7)
  1043. #define PB09_UART0_RXD (GpioPortB<<16u|GpioPin9 <<8u|GpioAf7)
  1044. #define PB10_UART1_RTS (GpioPortB<<16u|GpioPin10<<8u|GpioAf7)
  1045. #define PB11_UART1_CTS (GpioPortB<<16u|GpioPin11<<8u|GpioAf7)
  1046. #define PB12_TIM6_CHA (GpioPortB<<16u|GpioPin12<<8u|GpioAf7)
  1047. #define PB13_TIM6_CHB (GpioPortB<<16u|GpioPin13<<8u|GpioAf7)
  1048. #define PB14_TIM1_BK (GpioPortB<<16u|GpioPin14<<8u|GpioAf7)
  1049. #define PB15_LPUART1_RXD (GpioPortB<<16u|GpioPin15<<8u|GpioAf7)
  1050. #define PC00_7x (GpioPortC<<16u|GpioPin0 <<8u|GpioAf7)
  1051. #define PC01_7x (GpioPortC<<16u|GpioPin1 <<8u|GpioAf7)
  1052. #define PC02_7x (GpioPortC<<16u|GpioPin2 <<8u|GpioAf7)
  1053. #define PC03_7x (GpioPortC<<16u|GpioPin3 <<8u|GpioAf7)
  1054. #define PC04_7x (GpioPortC<<16u|GpioPin4 <<8u|GpioAf7)
  1055. #define PC05_7x (GpioPortC<<16u|GpioPin5 <<8u|GpioAf7)
  1056. #define PC06_7x (GpioPortC<<16u|GpioPin6 <<8u|GpioAf7)
  1057. #define PC07_7x (GpioPortC<<16u|GpioPin7 <<8u|GpioAf7)
  1058. #define PC08_7x (GpioPortC<<16u|GpioPin8 <<8u|GpioAf7)
  1059. #define PC09_7x (GpioPortC<<16u|GpioPin9 <<8u|GpioAf7)
  1060. #define PC10_7x (GpioPortC<<16u|GpioPin10<<8u|GpioAf7)
  1061. #define PC11_7x (GpioPortC<<16u|GpioPin11<<8u|GpioAf7)
  1062. #define PC12_7x (GpioPortC<<16u|GpioPin12<<8u|GpioAf7)
  1063. #define PC13_7x (GpioPortC<<16u|GpioPin13<<8u|GpioAf7)
  1064. #define PC14_7x (GpioPortC<<16u|GpioPin14<<8u|GpioAf7)
  1065. #define PC15_7x (GpioPortC<<16u|GpioPin15<<8u|GpioAf7)
  1066. #define PD00_7x (GpioPortD<<16u|GpioPin0 <<8u|GpioAf7)
  1067. #define PD01_7x (GpioPortD<<16u|GpioPin1 <<8u|GpioAf7)
  1068. #define PD02_7x (GpioPortD<<16u|GpioPin2 <<8u|GpioAf7)
  1069. #define PD03_7x (GpioPortD<<16u|GpioPin3 <<8u|GpioAf7)
  1070. #define PD04_7x (GpioPortD<<16u|GpioPin4 <<8u|GpioAf7)
  1071. #define PD05_7x (GpioPortD<<16u|GpioPin5 <<8u|GpioAf7)
  1072. #define PD06_7x (GpioPortD<<16u|GpioPin6 <<8u|GpioAf7)
  1073. #define PD07_7x (GpioPortD<<16u|GpioPin7 <<8u|GpioAf7)
  1074. #define PD08_7x (GpioPortD<<16u|GpioPin8 <<8u|GpioAf7)
  1075. #define PD09_7x (GpioPortD<<16u|GpioPin9 <<8u|GpioAf7)
  1076. #define PD10_7x (GpioPortD<<16u|GpioPin10<<8u|GpioAf7)
  1077. #define PD11_7x (GpioPortD<<16u|GpioPin11<<8u|GpioAf7)
  1078. #define PD12_7x (GpioPortD<<16u|GpioPin12<<8u|GpioAf7)
  1079. #define PD13_7x (GpioPortD<<16u|GpioPin13<<8u|GpioAf7)
  1080. #define PD14_7x (GpioPortD<<16u|GpioPin14<<8u|GpioAf7)
  1081. #define PD15_7x (GpioPortD<<16u|GpioPin15<<8u|GpioAf7)
  1082. #define PE00_7x (GpioPortE<<16u|GpioPin0 <<8u|GpioAf7)
  1083. #define PE01_7x (GpioPortE<<16u|GpioPin1 <<8u|GpioAf7)
  1084. #define PE02_7x (GpioPortE<<16u|GpioPin2 <<8u|GpioAf7)
  1085. #define PE03_7x (GpioPortE<<16u|GpioPin3 <<8u|GpioAf7)
  1086. #define PE04_7x (GpioPortE<<16u|GpioPin4 <<8u|GpioAf7)
  1087. #define PE05_7x (GpioPortE<<16u|GpioPin5 <<8u|GpioAf7)
  1088. #define PE06_7x (GpioPortE<<16u|GpioPin6 <<8u|GpioAf7)
  1089. #define PE07_7x (GpioPortE<<16u|GpioPin7 <<8u|GpioAf7)
  1090. #define PE08_7x (GpioPortE<<16u|GpioPin8 <<8u|GpioAf7)
  1091. #define PE09_7x (GpioPortE<<16u|GpioPin9 <<8u|GpioAf7)
  1092. #define PE10_7x (GpioPortE<<16u|GpioPin10<<8u|GpioAf7)
  1093. #define PE11_7x (GpioPortE<<16u|GpioPin11<<8u|GpioAf7)
  1094. #define PE12_7x (GpioPortE<<16u|GpioPin12<<8u|GpioAf7)
  1095. #define PE13_7x (GpioPortE<<16u|GpioPin13<<8u|GpioAf7)
  1096. #define PE14_7x (GpioPortE<<16u|GpioPin14<<8u|GpioAf7)
  1097. #define PE15_7x (GpioPortE<<16u|GpioPin15<<8u|GpioAf7)
  1098. #define PF00_7x (GpioPortF<<16u|GpioPin0 <<8u|GpioAf7)
  1099. #define PF01_7x (GpioPortF<<16u|GpioPin1 <<8u|GpioAf7)
  1100. #define PF02_7x (GpioPortF<<16u|GpioPin2 <<8u|GpioAf7)
  1101. #define PF03_7x (GpioPortF<<16u|GpioPin3 <<8u|GpioAf7)
  1102. #define PF04_7x (GpioPortF<<16u|GpioPin4 <<8u|GpioAf7)
  1103. #define PF05_7x (GpioPortF<<16u|GpioPin5 <<8u|GpioAf7)
  1104. #define PF06_7x (GpioPortF<<16u|GpioPin6 <<8u|GpioAf7)
  1105. #define PF07_7x (GpioPortF<<16u|GpioPin7 <<8u|GpioAf7)
  1106. #define PF09_7x (GpioPortF<<16u|GpioPin9 <<8u|GpioAf7)
  1107. #define PF10_7x (GpioPortF<<16u|GpioPin10<<8u|GpioAf7)
  1108. #define PF11_7x (GpioPortF<<16u|GpioPin11<<8u|GpioAf7)
  1109. /******************************************************************************
  1110. * Local type definitions ('typedef')
  1111. ******************************************************************************/
  1112. typedef uint32_t GpioPinMux;
  1113. /******************************************************************************
  1114. * Global variable definitions ('extern')
  1115. ******************************************************************************/
  1116. /******************************************************************************
  1117. Global function prototypes (definition in C source)
  1118. *******************************************************************************/
  1119. ///< GPIO IO初始化/去初始化
  1120. en_result_t Gpio_Init(en_gpio_port_t enPort, en_gpio_pin_t enPin, stc_gpio_cfg_t *pstcGpioCfg);
  1121. ///< GPIO 获取端口输入电平
  1122. boolean_t Gpio_GetInputIO(en_gpio_port_t enPort, en_gpio_pin_t enPin);
  1123. uint16_t Gpio_GetInputData(en_gpio_port_t enPort);
  1124. ///< GPIO 设置端口输出
  1125. ///< GPIO 端口输出电平配置及获取
  1126. en_result_t Gpio_WriteOutputIO(en_gpio_port_t enPort, en_gpio_pin_t enPin, boolean_t bVal);
  1127. boolean_t Gpio_ReadOutputIO(en_gpio_port_t enPort, en_gpio_pin_t enPin);
  1128. ///< GPIO 端口/引脚输出电平置位
  1129. en_result_t Gpio_SetPort(en_gpio_port_t enPort, uint16_t u16ValMsk);
  1130. en_result_t Gpio_SetIO(en_gpio_port_t enPort, en_gpio_pin_t enPin);
  1131. ///< GPIO 端口/引脚输出电平清零
  1132. en_result_t Gpio_ClrPort(en_gpio_port_t enPort, uint16_t u16ValMsk);
  1133. en_result_t Gpio_ClrIO(en_gpio_port_t enPort, en_gpio_pin_t enPin);
  1134. ///< GPIO 端口输出电平置位与清零设置
  1135. en_result_t Gpio_SetClrPort(en_gpio_port_t enPort, uint32_t u32ValMsk);
  1136. ///< GPIO 设置端口为模拟功能
  1137. en_result_t Gpio_SetAnalogMode(en_gpio_port_t enPort, en_gpio_pin_t enPin);
  1138. ///< GPIO 设置端口为端口复用功能
  1139. en_result_t Gpio_SetAfMode(en_gpio_port_t enPort, en_gpio_pin_t enPin, en_gpio_af_t enAf);
  1140. void Gpio_SetAfMode_Lite(GpioPinMux PinMux);
  1141. ///< GPIO 端口中断控制功能使能/关闭
  1142. en_result_t Gpio_EnableIrq(en_gpio_port_t enPort, en_gpio_pin_t enPin, en_gpio_irqtype_t enType);
  1143. en_result_t Gpio_DisableIrq(en_gpio_port_t enPort, en_gpio_pin_t enPin, en_gpio_irqtype_t enType);
  1144. ///< GPIO 中断状态获取
  1145. boolean_t Gpio_GetIrqStatus(en_gpio_port_t enPort, en_gpio_pin_t enPin);
  1146. ///< GPIO 中断标志清除
  1147. en_result_t Gpio_ClearIrq(en_gpio_port_t enPort, en_gpio_pin_t enPin);
  1148. ///< GPIO 端口辅助功能配置
  1149. ///< GPIO 中断模式配置
  1150. en_result_t Gpio_SfIrqModeCfg(en_gpio_sf_irqmode_t enIrqMode);
  1151. ///< GPIO IR输出极性配置
  1152. en_result_t Gpio_SfIrPolCfg(en_gpio_sf_irpol_t enIrPolMode);
  1153. ///< GPIO HCLK输出配置
  1154. en_result_t Gpio_SfHClkOutputCfg(en_gpio_sf_hclkout_g_t enGate, en_gpio_sf_hclkout_div_t enDiv);
  1155. ///< GPIO PCLK输出配置
  1156. en_result_t Gpio_SfPClkOutputCfg(en_gpio_sf_pclkout_g_t enGate, en_gpio_sf_pclkout_div_t enDiv);
  1157. ///< GPIO 外部时钟输入配置
  1158. en_result_t Gpio_SfExtClkCfg(en_gpio_sf_ssn_extclk_t enExtClk);
  1159. ///< GPIO SPI SSN输入配置
  1160. en_result_t Gpio_SfSsnCfg(en_gpio_sf_ssnspi_t enSpi, en_gpio_sf_ssn_extclk_t enSsn);
  1161. ///< GPIO Timer 门控输入配置
  1162. en_result_t Gpio_SfTimGCfg(en_gpio_sf_tim_g_t enTimG, en_gpio_sf_t enSf);
  1163. ///< GPIO Timer ETR选择配置
  1164. en_result_t Gpio_SfTimECfg(en_gpio_sf_tim_e_t enTimE, en_gpio_sf_t enSf);
  1165. ///< GPIO Timer 捕获输入配置
  1166. en_result_t Gpio_SfTimCCfg(en_gpio_sf_tim_c_t enTimC, en_gpio_sf_t enSf);
  1167. ///< GPIO PCA捕获选择配置
  1168. en_result_t Gpio_SfPcaCfg(en_gpio_sf_pca_t enPca, en_gpio_sf_t enSf);
  1169. ///< GPIO PCNT捕获选择配置
  1170. en_result_t Gpio_SfPcntCfg(en_gpio_sf_pcnt_t enPcnt, en_gpio_sf_t enSf);
  1171. //@} // GpioGroup
  1172. #ifdef __cplusplus
  1173. }
  1174. #endif
  1175. #endif /* __GPIO_H__ */
  1176. /******************************************************************************
  1177. * EOF (not truncated)
  1178. ******************************************************************************/