board.h 110 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804
  1. /*
  2. ChibiOS - Copyright (C) 2006..2018 Giovanni Di Sirio
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. */
  13. /*
  14. * This file has been automatically generated using ChibiStudio board
  15. * generator plugin. Do not edit manually.
  16. */
  17. #ifndef BOARD_H
  18. #define BOARD_H
  19. /*===========================================================================*/
  20. /* Driver constants. */
  21. /*===========================================================================*/
  22. /*
  23. * Setup for STMicroelectronics STM32 Nucleo144-F303ZE board.
  24. */
  25. /*
  26. * Board identifier.
  27. */
  28. #define BOARD_ST_NUCLEO144_F303ZE
  29. #define BOARD_NAME "STMicroelectronics STM32 Nucleo144-F303ZE"
  30. /*
  31. * Board oscillators-related settings.
  32. * NOTE: LSE not fitted.
  33. */
  34. #if !defined(STM32_LSECLK)
  35. #define STM32_LSECLK 0U
  36. #endif
  37. #define STM32_LSEDRV (3U << 3U)
  38. #if !defined(STM32_HSECLK)
  39. #define STM32_HSECLK 8000000U
  40. #endif
  41. #define STM32_HSE_BYPASS
  42. /*
  43. * MCU type as defined in the ST header.
  44. */
  45. #define STM32F303xE
  46. /*
  47. * IO pins assignments.
  48. */
  49. #define GPIOA_ZIO_D32 0U
  50. #define GPIOA_TIM2_CH1 0U
  51. #define GPIOA_ZIO_D72 1U
  52. #define GPIOA_COMP1_IMP 1U
  53. #define GPIOA_PIN2 2U
  54. #define GPIOA_ARD_A0 3U
  55. #define GPIOA_ADC1_IN4 3U
  56. #define GPIOA_ZIO_D24 4U
  57. #define GPIOA_SPI3_NSS 4U
  58. #define GPIOA_ARD_D13 5U
  59. #define GPIOA_SPI1_SCK 5U
  60. #define GPIOA_ARD_D12 6U
  61. #define GPIOA_SPI1_MISO 6U
  62. #define GPIOA_ARD_D11 7U
  63. #define GPIOA_SPI1_MOSI 7U
  64. #define GPIOA_ZIO_D71 7U
  65. #define GPIOA_ZIO_D70 8U
  66. #define GPIOA_I2C2_SMBAL 8U
  67. #define GPIOA_ZIO_D69 9U
  68. #define GPIOA_I2C2_SCL 9U
  69. #define GPIOA_ZIO_D68 10U
  70. #define GPIOA_I2C2_SDA 10U
  71. #define GPIOA_USB_DM 11U
  72. #define GPIOA_USB_DP 12U
  73. #define GPIOA_SWDIO 13U
  74. #define GPIOA_SWCLK 14U
  75. #define GPIOA_ZIO_D20 15U
  76. #define GPIOA_I2S3_WS 15U
  77. #define GPIOB_ZIO_D33 0U
  78. #define GPIOB_TIM3_CH3 0U
  79. #define GPIOB_LED1 0U
  80. #define GPIOB_ZIO_A6 1U
  81. #define GPIOB_ADC3_IN1 1U
  82. #define GPIOB_ZIO_D27 2U
  83. #define GPIOB_ZIO_D23 3U
  84. #define GPIOB_I2S3_CK 3U
  85. #define GPIOB_ZIO_D25 4U
  86. #define GPIOB_SPI3_MISO 4U
  87. #define GPIOB_ZIO_D22 5U
  88. #define GPIOB_I2S3_SD 5U
  89. #define GPIOB_ZIO_D26 6U
  90. #define GPIOB_LED2 7U
  91. #define GPIOB_ARD_D15 8U
  92. #define GPIOB_I2C1_SCL 8U
  93. #define GPIOB_ARD_D14 9U
  94. #define GPIOB_I2C1_SDA 9U
  95. #define GPIOB_ZIO_D36 10U
  96. #define GPIOB_TIM2_CH3 10U
  97. #define GPIOB_ZIO_D35 11U
  98. #define GPIOB_TIM2_CH4 11U
  99. #define GPIOB_ZIO_D19 12U
  100. #define GPIOB_I2S2_WS 12U
  101. #define GPIOB_ZIO_D18 13U
  102. #define GPIOB_I2S2_CK 13U
  103. #define GPIOB_LED3 14U
  104. #define GPIOB_ZIO_D17 15U
  105. #define GPIOB_I2S2_SD 15U
  106. #define GPIOC_ARD_A1 0U
  107. #define GPIOC_ADC12_IN6 0U
  108. #define GPIOC_PIN1 1U
  109. #define GPIOC_ZIO_A7 2U
  110. #define GPIOC_ADC12_IN8 2U
  111. #define GPIOC_ARD_A2 3U
  112. #define GPIOC_ADC12_IN9 3U
  113. #define GPIOC_ARD_D1 4U
  114. #define GPIOC_USART1_TX 4U
  115. #define GPIOC_ARD_D0 5U
  116. #define GPIOC_USART1_RX 5U
  117. #define GPIOC_ZIO_D16 6U
  118. #define GPIOC_I2S2_MCK 6U
  119. #define GPIOC_ZIO_D21 7U
  120. #define GPIOC_I2S3_MCK 7U
  121. #define GPIOC_ZIO_D43 8U
  122. #define GPIOC_ZIO_D44 9U
  123. #define GPIOC_I2S_CKIN 9U
  124. #define GPIOC_ZIO_D45 10U
  125. #define GPIOC_ZIO_D46 11U
  126. #define GPIOC_ZIO_D47 12U
  127. #define GPIOC_BUTTON 13U
  128. #define GPIOC_OSC32_IN 14U
  129. #define GPIOC_OSC32_OUT 15U
  130. #define GPIOD_ZIO_D67 0U
  131. #define GPIOD_CAN1_RX 0U
  132. #define GPIOD_ZIO_D66 1U
  133. #define GPIOD_CAN1_TX 1U
  134. #define GPIOD_ZIO_D48 2U
  135. #define GPIOD_ZIO_D55 3U
  136. #define GPIOD_USART2_CTS 3U
  137. #define GPIOD_ZIO_D54 4U
  138. #define GPIOD_USART2_RTS 4U
  139. #define GPIOD_ZIO_D53 5U
  140. #define GPIOD_USART2_TX 5U
  141. #define GPIOD_ZIO_D52 6U
  142. #define GPIOD_USART2_RX 6U
  143. #define GPIOD_ZIO_D51 7U
  144. #define GPIOD_USART2_SCLK 7U
  145. #define GPIOD_USART3_RX 8U
  146. #define GPIOD_STLK_RX 8U
  147. #define GPIOD_USART3_TX 9U
  148. #define GPIOD_STLK_TX 9U
  149. #define GPIOD_PIN10 10U
  150. #define GPIOD_ARD_A3 11U
  151. #define GPIOD_ADC34_IN8 11U
  152. #define GPIOD_ARD_A4 12U
  153. #define GPIOD_ADC34_IN9 12U
  154. #define GPIOD_ARD_A5 13U
  155. #define GPIOD_ADC3_IN8 13U
  156. #define GPIOD_ARD_D10 14U
  157. #define GPIOD_SPI1_NSS 14U
  158. #define GPIOD_ARD_D9 15U
  159. #define GPIOD_TIM4_CH4 15U
  160. #define GPIOE_ZIO_D34 0U
  161. #define GPIOE_TIM4_ETR 0U
  162. #define GPIOE_PIN1 1U
  163. #define GPIOE_ZIO_D31 2U
  164. #define GPIOE_ZIO_D56 2U
  165. #define GPIOE_ZIO_D60 3U
  166. #define GPIOE_ZIO_D57 4U
  167. #define GPIOE_ZIO_D58 5U
  168. #define GPIOE_ZIO_D59 6U
  169. #define GPIOE_ZIO_D41 7U
  170. #define GPIOE_TIM1_ETR 7U
  171. #define GPIOE_ZIO_D42 8U
  172. #define GPIOE_TIM1_CH1N 8U
  173. #define GPIOE_ARD_D6 9U
  174. #define GPIOE_TIM1_CH1 9U
  175. #define GPIOE_ZIO_D40 10U
  176. #define GPIOE_TIM1_CH2N 10U
  177. #define GPIOE_ARD_D5 11U
  178. #define GPIOE_TIM1_CH2 11U
  179. #define GPIOE_ZIO_D39 12U
  180. #define GPIOE_TIM1_CH3N 12U
  181. #define GPIOE_ARD_D3 13U
  182. #define GPIOE_TIM1_CH3 13U
  183. #define GPIOE_ZIO_D38 14U
  184. #define GPIOE_ZIO_D37 15U
  185. #define GPIOE_TIM1_BKIN1 15U
  186. #define GPIOF_PIN0 0U
  187. #define GPIOF_PIN1 1U
  188. #define GPIOF_PIN2 2U
  189. #define GPIOF_ZIO_D30 3U
  190. #define GPIOF_ZIO_A8 4U
  191. #define GPIOF_ADC3_IN14 4U
  192. #define GPIOF_ZIO_D29 5U
  193. #define GPIOF_PIN6 6U
  194. #define GPIOF_ZIO_D62 7U
  195. #define GPIOF_ZIO_D61 8U
  196. #define GPIOF_ZIO_D63 9U
  197. #define GPIOF_ZIO_D28 10U
  198. #define GPIOF_PIN11 11U
  199. #define GPIOF_ARD_D8 12U
  200. #define GPIOF_ARD_D7 13U
  201. #define GPIOF_ARD_D4 14U
  202. #define GPIOF_ARD_D2 15U
  203. #define GPIOG_ZIO_D65 0U
  204. #define GPIOG_ZIO_D64 1U
  205. #define GPIOG_ZIO_D49 2U
  206. #define GPIOG_ZIO_D50 3U
  207. #define GPIOG_PIN4 4U
  208. #define GPIOG_PIN5 5U
  209. #define GPIOG_USB_GPIO_OUT 6U
  210. #define GPIOG_USB_GPIO_IN 7U
  211. #define GPIOG_PIN8 8U
  212. #define GPIOG_PIN9 9U
  213. #define GPIOG_PIN10 10U
  214. #define GPIOG_PIN11 11U
  215. #define GPIOG_PIN12 12U
  216. #define GPIOG_PIN13 13U
  217. #define GPIOG_PIN14 14U
  218. #define GPIOG_PIN15 15U
  219. #define GPIOH_OSC_IN 0U
  220. #define GPIOH_OSC_OUT 1U
  221. #define GPIOH_PIN2 2U
  222. #define GPIOH_PIN3 3U
  223. #define GPIOH_PIN4 4U
  224. #define GPIOH_PIN5 5U
  225. #define GPIOH_PIN6 6U
  226. #define GPIOH_PIN7 7U
  227. #define GPIOH_PIN8 8U
  228. #define GPIOH_PIN9 9U
  229. #define GPIOH_PIN10 10U
  230. #define GPIOH_PIN11 11U
  231. #define GPIOH_PIN12 12U
  232. #define GPIOH_PIN13 13U
  233. #define GPIOH_PIN14 14U
  234. #define GPIOH_PIN15 15U
  235. #define GPIOI_PIN0 0U
  236. #define GPIOI_PIN1 1U
  237. #define GPIOI_PIN2 2U
  238. #define GPIOI_PIN3 3U
  239. #define GPIOI_PIN4 4U
  240. #define GPIOI_PIN5 5U
  241. #define GPIOI_PIN6 6U
  242. #define GPIOI_PIN7 7U
  243. #define GPIOI_PIN8 8U
  244. #define GPIOI_PIN9 9U
  245. #define GPIOI_PIN10 10U
  246. #define GPIOI_PIN11 11U
  247. #define GPIOI_PIN12 12U
  248. #define GPIOI_PIN13 13U
  249. #define GPIOI_PIN14 14U
  250. #define GPIOI_PIN15 15U
  251. #define GPIOJ_PIN0 0U
  252. #define GPIOJ_PIN1 1U
  253. #define GPIOJ_PIN2 2U
  254. #define GPIOJ_PIN3 3U
  255. #define GPIOJ_PIN4 4U
  256. #define GPIOJ_PIN5 5U
  257. #define GPIOJ_PIN6 6U
  258. #define GPIOJ_PIN7 7U
  259. #define GPIOJ_PIN8 8U
  260. #define GPIOJ_PIN9 9U
  261. #define GPIOJ_PIN10 10U
  262. #define GPIOJ_PIN11 11U
  263. #define GPIOJ_PIN12 12U
  264. #define GPIOJ_PIN13 13U
  265. #define GPIOJ_PIN14 14U
  266. #define GPIOJ_PIN15 15U
  267. #define GPIOK_PIN0 0U
  268. #define GPIOK_PIN1 1U
  269. #define GPIOK_PIN2 2U
  270. #define GPIOK_PIN3 3U
  271. #define GPIOK_PIN4 4U
  272. #define GPIOK_PIN5 5U
  273. #define GPIOK_PIN6 6U
  274. #define GPIOK_PIN7 7U
  275. #define GPIOK_PIN8 8U
  276. #define GPIOK_PIN9 9U
  277. #define GPIOK_PIN10 10U
  278. #define GPIOK_PIN11 11U
  279. #define GPIOK_PIN12 12U
  280. #define GPIOK_PIN13 13U
  281. #define GPIOK_PIN14 14U
  282. #define GPIOK_PIN15 15U
  283. /*
  284. * IO lines assignments.
  285. */
  286. #define LINE_ZIO_D32 PAL_LINE(GPIOA, 0U)
  287. #define LINE_TIM2_CH1 PAL_LINE(GPIOA, 0U)
  288. #define LINE_ZIO_D72 PAL_LINE(GPIOA, 1U)
  289. #define LINE_COMP1_IMP PAL_LINE(GPIOA, 1U)
  290. #define LINE_ARD_A0 PAL_LINE(GPIOA, 3U)
  291. #define LINE_ADC1_IN4 PAL_LINE(GPIOA, 3U)
  292. #define LINE_ZIO_D24 PAL_LINE(GPIOA, 4U)
  293. #define LINE_SPI3_NSS PAL_LINE(GPIOA, 4U)
  294. #define LINE_ARD_D13 PAL_LINE(GPIOA, 5U)
  295. #define LINE_SPI1_SCK PAL_LINE(GPIOA, 5U)
  296. #define LINE_ARD_D12 PAL_LINE(GPIOA, 6U)
  297. #define LINE_SPI1_MISO PAL_LINE(GPIOA, 6U)
  298. #define LINE_ARD_D11 PAL_LINE(GPIOA, 7U)
  299. #define LINE_SPI1_MOSI PAL_LINE(GPIOA, 7U)
  300. #define LINE_ZIO_D71 PAL_LINE(GPIOA, 7U)
  301. #define LINE_ZIO_D70 PAL_LINE(GPIOA, 8U)
  302. #define LINE_I2C2_SMBAL PAL_LINE(GPIOA, 8U)
  303. #define LINE_ZIO_D69 PAL_LINE(GPIOA, 9U)
  304. #define LINE_I2C2_SCL PAL_LINE(GPIOA, 9U)
  305. #define LINE_ZIO_D68 PAL_LINE(GPIOA, 10U)
  306. #define LINE_I2C2_SDA PAL_LINE(GPIOA, 10U)
  307. #define LINE_USB_DM PAL_LINE(GPIOA, 11U)
  308. #define LINE_USB_DP PAL_LINE(GPIOA, 12U)
  309. #define LINE_SWDIO PAL_LINE(GPIOA, 13U)
  310. #define LINE_SWCLK PAL_LINE(GPIOA, 14U)
  311. #define LINE_ZIO_D20 PAL_LINE(GPIOA, 15U)
  312. #define LINE_I2S3_WS PAL_LINE(GPIOA, 15U)
  313. #define LINE_ZIO_D33 PAL_LINE(GPIOB, 0U)
  314. #define LINE_TIM3_CH3 PAL_LINE(GPIOB, 0U)
  315. #define LINE_LED1 PAL_LINE(GPIOB, 0U)
  316. #define LINE_ZIO_A6 PAL_LINE(GPIOB, 1U)
  317. #define LINE_ADC3_IN1 PAL_LINE(GPIOB, 1U)
  318. #define LINE_ZIO_D27 PAL_LINE(GPIOB, 2U)
  319. #define LINE_ZIO_D23 PAL_LINE(GPIOB, 3U)
  320. #define LINE_I2S3_CK PAL_LINE(GPIOB, 3U)
  321. #define LINE_ZIO_D25 PAL_LINE(GPIOB, 4U)
  322. #define LINE_SPI3_MISO PAL_LINE(GPIOB, 4U)
  323. #define LINE_ZIO_D22 PAL_LINE(GPIOB, 5U)
  324. #define LINE_I2S3_SD PAL_LINE(GPIOB, 5U)
  325. #define LINE_ZIO_D26 PAL_LINE(GPIOB, 6U)
  326. #define LINE_LED2 PAL_LINE(GPIOB, 7U)
  327. #define LINE_ARD_D15 PAL_LINE(GPIOB, 8U)
  328. #define LINE_I2C1_SCL PAL_LINE(GPIOB, 8U)
  329. #define LINE_ARD_D14 PAL_LINE(GPIOB, 9U)
  330. #define LINE_I2C1_SDA PAL_LINE(GPIOB, 9U)
  331. #define LINE_ZIO_D36 PAL_LINE(GPIOB, 10U)
  332. #define LINE_TIM2_CH3 PAL_LINE(GPIOB, 10U)
  333. #define LINE_ZIO_D35 PAL_LINE(GPIOB, 11U)
  334. #define LINE_TIM2_CH4 PAL_LINE(GPIOB, 11U)
  335. #define LINE_ZIO_D19 PAL_LINE(GPIOB, 12U)
  336. #define LINE_I2S2_WS PAL_LINE(GPIOB, 12U)
  337. #define LINE_ZIO_D18 PAL_LINE(GPIOB, 13U)
  338. #define LINE_I2S2_CK PAL_LINE(GPIOB, 13U)
  339. #define LINE_LED3 PAL_LINE(GPIOB, 14U)
  340. #define LINE_ZIO_D17 PAL_LINE(GPIOB, 15U)
  341. #define LINE_I2S2_SD PAL_LINE(GPIOB, 15U)
  342. #define LINE_ARD_A1 PAL_LINE(GPIOC, 0U)
  343. #define LINE_ADC12_IN6 PAL_LINE(GPIOC, 0U)
  344. #define LINE_ZIO_A7 PAL_LINE(GPIOC, 2U)
  345. #define LINE_ADC12_IN8 PAL_LINE(GPIOC, 2U)
  346. #define LINE_ARD_A2 PAL_LINE(GPIOC, 3U)
  347. #define LINE_ADC12_IN9 PAL_LINE(GPIOC, 3U)
  348. #define LINE_ARD_D1 PAL_LINE(GPIOC, 4U)
  349. #define LINE_USART1_TX PAL_LINE(GPIOC, 4U)
  350. #define LINE_ARD_D0 PAL_LINE(GPIOC, 5U)
  351. #define LINE_USART1_RX PAL_LINE(GPIOC, 5U)
  352. #define LINE_ZIO_D16 PAL_LINE(GPIOC, 6U)
  353. #define LINE_I2S2_MCK PAL_LINE(GPIOC, 6U)
  354. #define LINE_ZIO_D21 PAL_LINE(GPIOC, 7U)
  355. #define LINE_I2S3_MCK PAL_LINE(GPIOC, 7U)
  356. #define LINE_ZIO_D43 PAL_LINE(GPIOC, 8U)
  357. #define LINE_ZIO_D44 PAL_LINE(GPIOC, 9U)
  358. #define LINE_I2S_CKIN PAL_LINE(GPIOC, 9U)
  359. #define LINE_ZIO_D45 PAL_LINE(GPIOC, 10U)
  360. #define LINE_ZIO_D46 PAL_LINE(GPIOC, 11U)
  361. #define LINE_ZIO_D47 PAL_LINE(GPIOC, 12U)
  362. #define LINE_BUTTON PAL_LINE(GPIOC, 13U)
  363. #define LINE_OSC32_IN PAL_LINE(GPIOC, 14U)
  364. #define LINE_OSC32_OUT PAL_LINE(GPIOC, 15U)
  365. #define LINE_ZIO_D67 PAL_LINE(GPIOD, 0U)
  366. #define LINE_CAN1_RX PAL_LINE(GPIOD, 0U)
  367. #define LINE_ZIO_D66 PAL_LINE(GPIOD, 1U)
  368. #define LINE_CAN1_TX PAL_LINE(GPIOD, 1U)
  369. #define LINE_ZIO_D48 PAL_LINE(GPIOD, 2U)
  370. #define LINE_ZIO_D55 PAL_LINE(GPIOD, 3U)
  371. #define LINE_USART2_CTS PAL_LINE(GPIOD, 3U)
  372. #define LINE_ZIO_D54 PAL_LINE(GPIOD, 4U)
  373. #define LINE_USART2_RTS PAL_LINE(GPIOD, 4U)
  374. #define LINE_ZIO_D53 PAL_LINE(GPIOD, 5U)
  375. #define LINE_USART2_TX PAL_LINE(GPIOD, 5U)
  376. #define LINE_ZIO_D52 PAL_LINE(GPIOD, 6U)
  377. #define LINE_USART2_RX PAL_LINE(GPIOD, 6U)
  378. #define LINE_ZIO_D51 PAL_LINE(GPIOD, 7U)
  379. #define LINE_USART2_SCLK PAL_LINE(GPIOD, 7U)
  380. #define LINE_USART3_RX PAL_LINE(GPIOD, 8U)
  381. #define LINE_STLK_RX PAL_LINE(GPIOD, 8U)
  382. #define LINE_USART3_TX PAL_LINE(GPIOD, 9U)
  383. #define LINE_STLK_TX PAL_LINE(GPIOD, 9U)
  384. #define LINE_ARD_A3 PAL_LINE(GPIOD, 11U)
  385. #define LINE_ADC34_IN8 PAL_LINE(GPIOD, 11U)
  386. #define LINE_ARD_A4 PAL_LINE(GPIOD, 12U)
  387. #define LINE_ADC34_IN9 PAL_LINE(GPIOD, 12U)
  388. #define LINE_ARD_A5 PAL_LINE(GPIOD, 13U)
  389. #define LINE_ADC3_IN8 PAL_LINE(GPIOD, 13U)
  390. #define LINE_ARD_D10 PAL_LINE(GPIOD, 14U)
  391. #define LINE_SPI1_NSS PAL_LINE(GPIOD, 14U)
  392. #define LINE_ARD_D9 PAL_LINE(GPIOD, 15U)
  393. #define LINE_TIM4_CH4 PAL_LINE(GPIOD, 15U)
  394. #define LINE_ZIO_D34 PAL_LINE(GPIOE, 0U)
  395. #define LINE_TIM4_ETR PAL_LINE(GPIOE, 0U)
  396. #define LINE_ZIO_D31 PAL_LINE(GPIOE, 2U)
  397. #define LINE_ZIO_D56 PAL_LINE(GPIOE, 2U)
  398. #define LINE_ZIO_D60 PAL_LINE(GPIOE, 3U)
  399. #define LINE_ZIO_D57 PAL_LINE(GPIOE, 4U)
  400. #define LINE_ZIO_D58 PAL_LINE(GPIOE, 5U)
  401. #define LINE_ZIO_D59 PAL_LINE(GPIOE, 6U)
  402. #define LINE_ZIO_D41 PAL_LINE(GPIOE, 7U)
  403. #define LINE_TIM1_ETR PAL_LINE(GPIOE, 7U)
  404. #define LINE_ZIO_D42 PAL_LINE(GPIOE, 8U)
  405. #define LINE_TIM1_CH1N PAL_LINE(GPIOE, 8U)
  406. #define LINE_ARD_D6 PAL_LINE(GPIOE, 9U)
  407. #define LINE_TIM1_CH1 PAL_LINE(GPIOE, 9U)
  408. #define LINE_ZIO_D40 PAL_LINE(GPIOE, 10U)
  409. #define LINE_TIM1_CH2N PAL_LINE(GPIOE, 10U)
  410. #define LINE_ARD_D5 PAL_LINE(GPIOE, 11U)
  411. #define LINE_TIM1_CH2 PAL_LINE(GPIOE, 11U)
  412. #define LINE_ZIO_D39 PAL_LINE(GPIOE, 12U)
  413. #define LINE_TIM1_CH3N PAL_LINE(GPIOE, 12U)
  414. #define LINE_ARD_D3 PAL_LINE(GPIOE, 13U)
  415. #define LINE_TIM1_CH3 PAL_LINE(GPIOE, 13U)
  416. #define LINE_ZIO_D38 PAL_LINE(GPIOE, 14U)
  417. #define LINE_ZIO_D37 PAL_LINE(GPIOE, 15U)
  418. #define LINE_TIM1_BKIN1 PAL_LINE(GPIOE, 15U)
  419. #define LINE_ZIO_D30 PAL_LINE(GPIOF, 3U)
  420. #define LINE_ZIO_A8 PAL_LINE(GPIOF, 4U)
  421. #define LINE_ADC3_IN14 PAL_LINE(GPIOF, 4U)
  422. #define LINE_ZIO_D29 PAL_LINE(GPIOF, 5U)
  423. #define LINE_ZIO_D62 PAL_LINE(GPIOF, 7U)
  424. #define LINE_ZIO_D61 PAL_LINE(GPIOF, 8U)
  425. #define LINE_ZIO_D63 PAL_LINE(GPIOF, 9U)
  426. #define LINE_ZIO_D28 PAL_LINE(GPIOF, 10U)
  427. #define LINE_ARD_D8 PAL_LINE(GPIOF, 12U)
  428. #define LINE_ARD_D7 PAL_LINE(GPIOF, 13U)
  429. #define LINE_ARD_D4 PAL_LINE(GPIOF, 14U)
  430. #define LINE_ARD_D2 PAL_LINE(GPIOF, 15U)
  431. #define LINE_ZIO_D65 PAL_LINE(GPIOG, 0U)
  432. #define LINE_ZIO_D64 PAL_LINE(GPIOG, 1U)
  433. #define LINE_ZIO_D49 PAL_LINE(GPIOG, 2U)
  434. #define LINE_ZIO_D50 PAL_LINE(GPIOG, 3U)
  435. #define LINE_USB_GPIO_OUT PAL_LINE(GPIOG, 6U)
  436. #define LINE_USB_GPIO_IN PAL_LINE(GPIOG, 7U)
  437. #define LINE_OSC_IN PAL_LINE(GPIOH, 0U)
  438. #define LINE_OSC_OUT PAL_LINE(GPIOH, 1U)
  439. /*===========================================================================*/
  440. /* Driver pre-compile time settings. */
  441. /*===========================================================================*/
  442. /*===========================================================================*/
  443. /* Derived constants and error checks. */
  444. /*===========================================================================*/
  445. /*===========================================================================*/
  446. /* Driver data structures and types. */
  447. /*===========================================================================*/
  448. /*===========================================================================*/
  449. /* Driver macros. */
  450. /*===========================================================================*/
  451. /*
  452. * I/O ports initial setup, this configuration is established soon after reset
  453. * in the initialization code.
  454. * Please refer to the STM32 Reference Manual for details.
  455. */
  456. #define PIN_MODE_INPUT(n) (0U << ((n) * 2U))
  457. #define PIN_MODE_OUTPUT(n) (1U << ((n) * 2U))
  458. #define PIN_MODE_ALTERNATE(n) (2U << ((n) * 2U))
  459. #define PIN_MODE_ANALOG(n) (3U << ((n) * 2U))
  460. #define PIN_ODR_LOW(n) (0U << (n))
  461. #define PIN_ODR_HIGH(n) (1U << (n))
  462. #define PIN_OTYPE_PUSHPULL(n) (0U << (n))
  463. #define PIN_OTYPE_OPENDRAIN(n) (1U << (n))
  464. #define PIN_OSPEED_VERYLOW(n) (0U << ((n) * 2U))
  465. #define PIN_OSPEED_LOW(n) (1U << ((n) * 2U))
  466. #define PIN_OSPEED_MEDIUM(n) (2U << ((n) * 2U))
  467. #define PIN_OSPEED_HIGH(n) (3U << ((n) * 2U))
  468. #define PIN_PUPDR_FLOATING(n) (0U << ((n) * 2U))
  469. #define PIN_PUPDR_PULLUP(n) (1U << ((n) * 2U))
  470. #define PIN_PUPDR_PULLDOWN(n) (2U << ((n) * 2U))
  471. #define PIN_AFIO_AF(n, v) ((v) << (((n) % 8U) * 4U))
  472. /*
  473. * GPIOA setup:
  474. *
  475. * PA0 - ZIO_D32 TIM2_CH1 (input pullup).
  476. * PA1 - ZIO_D72 COMP1_IMP (input pullup).
  477. * PA2 - PIN2 (input pullup).
  478. * PA3 - ARD_A0 ADC1_IN4 (input pullup).
  479. * PA4 - ZIO_D24 SPI3_NSS (input pullup).
  480. * PA5 - ARD_D13 SPI1_SCK (input pullup).
  481. * PA6 - ARD_D12 SPI1_MISO (input pullup).
  482. * PA7 - ARD_D11 SPI1_MOSI ZIO_D71 (input pullup).
  483. * PA8 - ZIO_D70 I2C2_SMBAL (input pullup).
  484. * PA9 - ZIO_D69 I2C2_SCL (input pullup).
  485. * PA10 - ZIO_D68 I2C2_SDA (input pullup).
  486. * PA11 - USB_DM (alternate 14).
  487. * PA12 - USB_DP (alternate 14).
  488. * PA13 - SWDIO (alternate 0).
  489. * PA14 - SWCLK (alternate 0).
  490. * PA15 - ZIO_D20 I2S3_WS (input pullup).
  491. */
  492. #define VAL_GPIOA_MODER (PIN_MODE_INPUT(GPIOA_ZIO_D32) | \
  493. PIN_MODE_INPUT(GPIOA_ZIO_D72) | \
  494. PIN_MODE_INPUT(GPIOA_PIN2) | \
  495. PIN_MODE_INPUT(GPIOA_ARD_A0) | \
  496. PIN_MODE_INPUT(GPIOA_ZIO_D24) | \
  497. PIN_MODE_INPUT(GPIOA_ARD_D13) | \
  498. PIN_MODE_INPUT(GPIOA_ARD_D12) | \
  499. PIN_MODE_INPUT(GPIOA_ARD_D11) | \
  500. PIN_MODE_INPUT(GPIOA_ZIO_D70) | \
  501. PIN_MODE_INPUT(GPIOA_ZIO_D69) | \
  502. PIN_MODE_INPUT(GPIOA_ZIO_D68) | \
  503. PIN_MODE_ALTERNATE(GPIOA_USB_DM) | \
  504. PIN_MODE_ALTERNATE(GPIOA_USB_DP) | \
  505. PIN_MODE_ALTERNATE(GPIOA_SWDIO) | \
  506. PIN_MODE_ALTERNATE(GPIOA_SWCLK) | \
  507. PIN_MODE_INPUT(GPIOA_ZIO_D20))
  508. #define VAL_GPIOA_OTYPER (PIN_OTYPE_PUSHPULL(GPIOA_ZIO_D32) | \
  509. PIN_OTYPE_PUSHPULL(GPIOA_ZIO_D72) | \
  510. PIN_OTYPE_PUSHPULL(GPIOA_PIN2) | \
  511. PIN_OTYPE_PUSHPULL(GPIOA_ARD_A0) | \
  512. PIN_OTYPE_PUSHPULL(GPIOA_ZIO_D24) | \
  513. PIN_OTYPE_PUSHPULL(GPIOA_ARD_D13) | \
  514. PIN_OTYPE_PUSHPULL(GPIOA_ARD_D12) | \
  515. PIN_OTYPE_PUSHPULL(GPIOA_ARD_D11) | \
  516. PIN_OTYPE_PUSHPULL(GPIOA_ZIO_D70) | \
  517. PIN_OTYPE_PUSHPULL(GPIOA_ZIO_D69) | \
  518. PIN_OTYPE_PUSHPULL(GPIOA_ZIO_D68) | \
  519. PIN_OTYPE_PUSHPULL(GPIOA_USB_DM) | \
  520. PIN_OTYPE_PUSHPULL(GPIOA_USB_DP) | \
  521. PIN_OTYPE_PUSHPULL(GPIOA_SWDIO) | \
  522. PIN_OTYPE_PUSHPULL(GPIOA_SWCLK) | \
  523. PIN_OTYPE_PUSHPULL(GPIOA_ZIO_D20))
  524. #define VAL_GPIOA_OSPEEDR (PIN_OSPEED_HIGH(GPIOA_ZIO_D32) | \
  525. PIN_OSPEED_HIGH(GPIOA_ZIO_D72) | \
  526. PIN_OSPEED_VERYLOW(GPIOA_PIN2) | \
  527. PIN_OSPEED_HIGH(GPIOA_ARD_A0) | \
  528. PIN_OSPEED_HIGH(GPIOA_ZIO_D24) | \
  529. PIN_OSPEED_HIGH(GPIOA_ARD_D13) | \
  530. PIN_OSPEED_HIGH(GPIOA_ARD_D12) | \
  531. PIN_OSPEED_HIGH(GPIOA_ARD_D11) | \
  532. PIN_OSPEED_HIGH(GPIOA_ZIO_D70) | \
  533. PIN_OSPEED_HIGH(GPIOA_ZIO_D69) | \
  534. PIN_OSPEED_HIGH(GPIOA_ZIO_D68) | \
  535. PIN_OSPEED_HIGH(GPIOA_USB_DM) | \
  536. PIN_OSPEED_VERYLOW(GPIOA_USB_DP) | \
  537. PIN_OSPEED_HIGH(GPIOA_SWDIO) | \
  538. PIN_OSPEED_HIGH(GPIOA_SWCLK) | \
  539. PIN_OSPEED_HIGH(GPIOA_ZIO_D20))
  540. #define VAL_GPIOA_PUPDR (PIN_PUPDR_PULLUP(GPIOA_ZIO_D32) | \
  541. PIN_PUPDR_PULLUP(GPIOA_ZIO_D72) | \
  542. PIN_PUPDR_PULLUP(GPIOA_PIN2) | \
  543. PIN_PUPDR_PULLUP(GPIOA_ARD_A0) | \
  544. PIN_PUPDR_PULLUP(GPIOA_ZIO_D24) | \
  545. PIN_PUPDR_PULLUP(GPIOA_ARD_D13) | \
  546. PIN_PUPDR_PULLUP(GPIOA_ARD_D12) | \
  547. PIN_PUPDR_PULLUP(GPIOA_ARD_D11) | \
  548. PIN_PUPDR_PULLUP(GPIOA_ZIO_D70) | \
  549. PIN_PUPDR_PULLUP(GPIOA_ZIO_D69) | \
  550. PIN_PUPDR_PULLUP(GPIOA_ZIO_D68) | \
  551. PIN_PUPDR_FLOATING(GPIOA_USB_DM) | \
  552. PIN_PUPDR_FLOATING(GPIOA_USB_DP) | \
  553. PIN_PUPDR_FLOATING(GPIOA_SWDIO) | \
  554. PIN_PUPDR_FLOATING(GPIOA_SWCLK) | \
  555. PIN_PUPDR_PULLUP(GPIOA_ZIO_D20))
  556. #define VAL_GPIOA_ODR (PIN_ODR_HIGH(GPIOA_ZIO_D32) | \
  557. PIN_ODR_HIGH(GPIOA_ZIO_D72) | \
  558. PIN_ODR_HIGH(GPIOA_PIN2) | \
  559. PIN_ODR_HIGH(GPIOA_ARD_A0) | \
  560. PIN_ODR_HIGH(GPIOA_ZIO_D24) | \
  561. PIN_ODR_HIGH(GPIOA_ARD_D13) | \
  562. PIN_ODR_HIGH(GPIOA_ARD_D12) | \
  563. PIN_ODR_HIGH(GPIOA_ARD_D11) | \
  564. PIN_ODR_HIGH(GPIOA_ZIO_D70) | \
  565. PIN_ODR_HIGH(GPIOA_ZIO_D69) | \
  566. PIN_ODR_HIGH(GPIOA_ZIO_D68) | \
  567. PIN_ODR_HIGH(GPIOA_USB_DM) | \
  568. PIN_ODR_HIGH(GPIOA_USB_DP) | \
  569. PIN_ODR_HIGH(GPIOA_SWDIO) | \
  570. PIN_ODR_HIGH(GPIOA_SWCLK) | \
  571. PIN_ODR_HIGH(GPIOA_ZIO_D20))
  572. #define VAL_GPIOA_AFRL (PIN_AFIO_AF(GPIOA_ZIO_D32, 0U) | \
  573. PIN_AFIO_AF(GPIOA_ZIO_D72, 0U) | \
  574. PIN_AFIO_AF(GPIOA_PIN2, 0U) | \
  575. PIN_AFIO_AF(GPIOA_ARD_A0, 0U) | \
  576. PIN_AFIO_AF(GPIOA_ZIO_D24, 0U) | \
  577. PIN_AFIO_AF(GPIOA_ARD_D13, 0U) | \
  578. PIN_AFIO_AF(GPIOA_ARD_D12, 0U) | \
  579. PIN_AFIO_AF(GPIOA_ARD_D11, 0U))
  580. #define VAL_GPIOA_AFRH (PIN_AFIO_AF(GPIOA_ZIO_D70, 0U) | \
  581. PIN_AFIO_AF(GPIOA_ZIO_D69, 0U) | \
  582. PIN_AFIO_AF(GPIOA_ZIO_D68, 0U) | \
  583. PIN_AFIO_AF(GPIOA_USB_DM, 14U) | \
  584. PIN_AFIO_AF(GPIOA_USB_DP, 14U) | \
  585. PIN_AFIO_AF(GPIOA_SWDIO, 0U) | \
  586. PIN_AFIO_AF(GPIOA_SWCLK, 0U) | \
  587. PIN_AFIO_AF(GPIOA_ZIO_D20, 0U))
  588. /*
  589. * GPIOB setup:
  590. *
  591. * PB0 - ZIO_D33 TIM3_CH3 LED1 (output pushpull maximum).
  592. * PB1 - ZIO_A6 ADC3_IN1 (input pullup).
  593. * PB2 - ZIO_D27 (input pullup).
  594. * PB3 - ZIO_D23 I2S3_CK (input pullup).
  595. * PB4 - ZIO_D25 SPI3_MISO (input pullup).
  596. * PB5 - ZIO_D22 I2S3_SD (input pullup).
  597. * PB6 - ZIO_D26 (input pullup).
  598. * PB7 - LED2 (output pushpull maximum).
  599. * PB8 - ARD_D15 I2C1_SCL (input pullup).
  600. * PB9 - ARD_D14 I2C1_SDA (input pullup).
  601. * PB10 - ZIO_D36 TIM2_CH3 (input pullup).
  602. * PB11 - ZIO_D35 TIM2_CH4 (input pullup).
  603. * PB12 - ZIO_D19 I2S2_WS (input pullup).
  604. * PB13 - ZIO_D18 I2S2_CK (input pullup).
  605. * PB14 - LED3 (output pushpull maximum).
  606. * PB15 - ZIO_D17 I2S2_SD (input pullup).
  607. */
  608. #define VAL_GPIOB_MODER (PIN_MODE_OUTPUT(GPIOB_ZIO_D33) | \
  609. PIN_MODE_INPUT(GPIOB_ZIO_A6) | \
  610. PIN_MODE_INPUT(GPIOB_ZIO_D27) | \
  611. PIN_MODE_INPUT(GPIOB_ZIO_D23) | \
  612. PIN_MODE_INPUT(GPIOB_ZIO_D25) | \
  613. PIN_MODE_INPUT(GPIOB_ZIO_D22) | \
  614. PIN_MODE_INPUT(GPIOB_ZIO_D26) | \
  615. PIN_MODE_OUTPUT(GPIOB_LED2) | \
  616. PIN_MODE_INPUT(GPIOB_ARD_D15) | \
  617. PIN_MODE_INPUT(GPIOB_ARD_D14) | \
  618. PIN_MODE_INPUT(GPIOB_ZIO_D36) | \
  619. PIN_MODE_INPUT(GPIOB_ZIO_D35) | \
  620. PIN_MODE_INPUT(GPIOB_ZIO_D19) | \
  621. PIN_MODE_INPUT(GPIOB_ZIO_D18) | \
  622. PIN_MODE_OUTPUT(GPIOB_LED3) | \
  623. PIN_MODE_INPUT(GPIOB_ZIO_D17))
  624. #define VAL_GPIOB_OTYPER (PIN_OTYPE_PUSHPULL(GPIOB_ZIO_D33) | \
  625. PIN_OTYPE_PUSHPULL(GPIOB_ZIO_A6) | \
  626. PIN_OTYPE_PUSHPULL(GPIOB_ZIO_D27) | \
  627. PIN_OTYPE_PUSHPULL(GPIOB_ZIO_D23) | \
  628. PIN_OTYPE_PUSHPULL(GPIOB_ZIO_D25) | \
  629. PIN_OTYPE_PUSHPULL(GPIOB_ZIO_D22) | \
  630. PIN_OTYPE_PUSHPULL(GPIOB_ZIO_D26) | \
  631. PIN_OTYPE_PUSHPULL(GPIOB_LED2) | \
  632. PIN_OTYPE_PUSHPULL(GPIOB_ARD_D15) | \
  633. PIN_OTYPE_PUSHPULL(GPIOB_ARD_D14) | \
  634. PIN_OTYPE_PUSHPULL(GPIOB_ZIO_D36) | \
  635. PIN_OTYPE_PUSHPULL(GPIOB_ZIO_D35) | \
  636. PIN_OTYPE_PUSHPULL(GPIOB_ZIO_D19) | \
  637. PIN_OTYPE_PUSHPULL(GPIOB_ZIO_D18) | \
  638. PIN_OTYPE_PUSHPULL(GPIOB_LED3) | \
  639. PIN_OTYPE_PUSHPULL(GPIOB_ZIO_D17))
  640. #define VAL_GPIOB_OSPEEDR (PIN_OSPEED_HIGH(GPIOB_ZIO_D33) | \
  641. PIN_OSPEED_HIGH(GPIOB_ZIO_A6) | \
  642. PIN_OSPEED_VERYLOW(GPIOB_ZIO_D27) | \
  643. PIN_OSPEED_HIGH(GPIOB_ZIO_D23) | \
  644. PIN_OSPEED_HIGH(GPIOB_ZIO_D25) | \
  645. PIN_OSPEED_HIGH(GPIOB_ZIO_D22) | \
  646. PIN_OSPEED_VERYLOW(GPIOB_ZIO_D26) | \
  647. PIN_OSPEED_HIGH(GPIOB_LED2) | \
  648. PIN_OSPEED_HIGH(GPIOB_ARD_D15) | \
  649. PIN_OSPEED_HIGH(GPIOB_ARD_D14) | \
  650. PIN_OSPEED_HIGH(GPIOB_ZIO_D36) | \
  651. PIN_OSPEED_HIGH(GPIOB_ZIO_D35) | \
  652. PIN_OSPEED_HIGH(GPIOB_ZIO_D19) | \
  653. PIN_OSPEED_HIGH(GPIOB_ZIO_D18) | \
  654. PIN_OSPEED_HIGH(GPIOB_LED3) | \
  655. PIN_OSPEED_HIGH(GPIOB_ZIO_D17))
  656. #define VAL_GPIOB_PUPDR (PIN_PUPDR_FLOATING(GPIOB_ZIO_D33) | \
  657. PIN_PUPDR_PULLUP(GPIOB_ZIO_A6) | \
  658. PIN_PUPDR_PULLUP(GPIOB_ZIO_D27) | \
  659. PIN_PUPDR_PULLUP(GPIOB_ZIO_D23) | \
  660. PIN_PUPDR_PULLUP(GPIOB_ZIO_D25) | \
  661. PIN_PUPDR_PULLUP(GPIOB_ZIO_D22) | \
  662. PIN_PUPDR_PULLUP(GPIOB_ZIO_D26) | \
  663. PIN_PUPDR_FLOATING(GPIOB_LED2) | \
  664. PIN_PUPDR_PULLUP(GPIOB_ARD_D15) | \
  665. PIN_PUPDR_PULLUP(GPIOB_ARD_D14) | \
  666. PIN_PUPDR_PULLUP(GPIOB_ZIO_D36) | \
  667. PIN_PUPDR_PULLUP(GPIOB_ZIO_D35) | \
  668. PIN_PUPDR_PULLUP(GPIOB_ZIO_D19) | \
  669. PIN_PUPDR_PULLUP(GPIOB_ZIO_D18) | \
  670. PIN_PUPDR_FLOATING(GPIOB_LED3) | \
  671. PIN_PUPDR_PULLUP(GPIOB_ZIO_D17))
  672. #define VAL_GPIOB_ODR (PIN_ODR_LOW(GPIOB_ZIO_D33) | \
  673. PIN_ODR_HIGH(GPIOB_ZIO_A6) | \
  674. PIN_ODR_HIGH(GPIOB_ZIO_D27) | \
  675. PIN_ODR_HIGH(GPIOB_ZIO_D23) | \
  676. PIN_ODR_HIGH(GPIOB_ZIO_D25) | \
  677. PIN_ODR_HIGH(GPIOB_ZIO_D22) | \
  678. PIN_ODR_HIGH(GPIOB_ZIO_D26) | \
  679. PIN_ODR_LOW(GPIOB_LED2) | \
  680. PIN_ODR_HIGH(GPIOB_ARD_D15) | \
  681. PIN_ODR_HIGH(GPIOB_ARD_D14) | \
  682. PIN_ODR_HIGH(GPIOB_ZIO_D36) | \
  683. PIN_ODR_HIGH(GPIOB_ZIO_D35) | \
  684. PIN_ODR_HIGH(GPIOB_ZIO_D19) | \
  685. PIN_ODR_HIGH(GPIOB_ZIO_D18) | \
  686. PIN_ODR_LOW(GPIOB_LED3) | \
  687. PIN_ODR_HIGH(GPIOB_ZIO_D17))
  688. #define VAL_GPIOB_AFRL (PIN_AFIO_AF(GPIOB_ZIO_D33, 0U) | \
  689. PIN_AFIO_AF(GPIOB_ZIO_A6, 0U) | \
  690. PIN_AFIO_AF(GPIOB_ZIO_D27, 0U) | \
  691. PIN_AFIO_AF(GPIOB_ZIO_D23, 0U) | \
  692. PIN_AFIO_AF(GPIOB_ZIO_D25, 0U) | \
  693. PIN_AFIO_AF(GPIOB_ZIO_D22, 0U) | \
  694. PIN_AFIO_AF(GPIOB_ZIO_D26, 0U) | \
  695. PIN_AFIO_AF(GPIOB_LED2, 0U))
  696. #define VAL_GPIOB_AFRH (PIN_AFIO_AF(GPIOB_ARD_D15, 0U) | \
  697. PIN_AFIO_AF(GPIOB_ARD_D14, 0U) | \
  698. PIN_AFIO_AF(GPIOB_ZIO_D36, 0U) | \
  699. PIN_AFIO_AF(GPIOB_ZIO_D35, 0U) | \
  700. PIN_AFIO_AF(GPIOB_ZIO_D19, 0U) | \
  701. PIN_AFIO_AF(GPIOB_ZIO_D18, 0U) | \
  702. PIN_AFIO_AF(GPIOB_LED3, 0U) | \
  703. PIN_AFIO_AF(GPIOB_ZIO_D17, 0U))
  704. /*
  705. * GPIOC setup:
  706. *
  707. * PC0 - ARD_A1 ADC12_IN6 (input pullup).
  708. * PC1 - PIN1 (input pullup).
  709. * PC2 - ZIO_A7 ADC12_IN8 (input pullup).
  710. * PC3 - ARD_A2 ADC12_IN9 (input pullup).
  711. * PC4 - ARD_D1 USART1_TX (input pullup).
  712. * PC5 - ARD_D0 USART1_RX (input pullup).
  713. * PC6 - ZIO_D16 I2S2_MCK (input pullup).
  714. * PC7 - ZIO_D21 I2S3_MCK (input pullup).
  715. * PC8 - ZIO_D43 (input pullup).
  716. * PC9 - ZIO_D44 I2S_CKIN (input pullup).
  717. * PC10 - ZIO_D45 (input pullup).
  718. * PC11 - ZIO_D46 (input pullup).
  719. * PC12 - ZIO_D47 (input pullup).
  720. * PC13 - BUTTON (input floating).
  721. * PC14 - OSC32_IN (input floating).
  722. * PC15 - OSC32_OUT (input floating).
  723. */
  724. #define VAL_GPIOC_MODER (PIN_MODE_INPUT(GPIOC_ARD_A1) | \
  725. PIN_MODE_INPUT(GPIOC_PIN1) | \
  726. PIN_MODE_INPUT(GPIOC_ZIO_A7) | \
  727. PIN_MODE_INPUT(GPIOC_ARD_A2) | \
  728. PIN_MODE_INPUT(GPIOC_ARD_D1) | \
  729. PIN_MODE_INPUT(GPIOC_ARD_D0) | \
  730. PIN_MODE_INPUT(GPIOC_ZIO_D16) | \
  731. PIN_MODE_INPUT(GPIOC_ZIO_D21) | \
  732. PIN_MODE_INPUT(GPIOC_ZIO_D43) | \
  733. PIN_MODE_INPUT(GPIOC_ZIO_D44) | \
  734. PIN_MODE_INPUT(GPIOC_ZIO_D45) | \
  735. PIN_MODE_INPUT(GPIOC_ZIO_D46) | \
  736. PIN_MODE_INPUT(GPIOC_ZIO_D47) | \
  737. PIN_MODE_INPUT(GPIOC_BUTTON) | \
  738. PIN_MODE_INPUT(GPIOC_OSC32_IN) | \
  739. PIN_MODE_INPUT(GPIOC_OSC32_OUT))
  740. #define VAL_GPIOC_OTYPER (PIN_OTYPE_PUSHPULL(GPIOC_ARD_A1) | \
  741. PIN_OTYPE_PUSHPULL(GPIOC_PIN1) | \
  742. PIN_OTYPE_PUSHPULL(GPIOC_ZIO_A7) | \
  743. PIN_OTYPE_PUSHPULL(GPIOC_ARD_A2) | \
  744. PIN_OTYPE_PUSHPULL(GPIOC_ARD_D1) | \
  745. PIN_OTYPE_PUSHPULL(GPIOC_ARD_D0) | \
  746. PIN_OTYPE_PUSHPULL(GPIOC_ZIO_D16) | \
  747. PIN_OTYPE_PUSHPULL(GPIOC_ZIO_D21) | \
  748. PIN_OTYPE_PUSHPULL(GPIOC_ZIO_D43) | \
  749. PIN_OTYPE_PUSHPULL(GPIOC_ZIO_D44) | \
  750. PIN_OTYPE_PUSHPULL(GPIOC_ZIO_D45) | \
  751. PIN_OTYPE_PUSHPULL(GPIOC_ZIO_D46) | \
  752. PIN_OTYPE_PUSHPULL(GPIOC_ZIO_D47) | \
  753. PIN_OTYPE_PUSHPULL(GPIOC_BUTTON) | \
  754. PIN_OTYPE_PUSHPULL(GPIOC_OSC32_IN) | \
  755. PIN_OTYPE_PUSHPULL(GPIOC_OSC32_OUT))
  756. #define VAL_GPIOC_OSPEEDR (PIN_OSPEED_HIGH(GPIOC_ARD_A1) | \
  757. PIN_OSPEED_VERYLOW(GPIOC_PIN1) | \
  758. PIN_OSPEED_HIGH(GPIOC_ZIO_A7) | \
  759. PIN_OSPEED_HIGH(GPIOC_ARD_A2) | \
  760. PIN_OSPEED_HIGH(GPIOC_ARD_D1) | \
  761. PIN_OSPEED_HIGH(GPIOC_ARD_D0) | \
  762. PIN_OSPEED_HIGH(GPIOC_ZIO_D16) | \
  763. PIN_OSPEED_HIGH(GPIOC_ZIO_D21) | \
  764. PIN_OSPEED_VERYLOW(GPIOC_ZIO_D43) | \
  765. PIN_OSPEED_HIGH(GPIOC_ZIO_D44) | \
  766. PIN_OSPEED_VERYLOW(GPIOC_ZIO_D45) | \
  767. PIN_OSPEED_VERYLOW(GPIOC_ZIO_D46) | \
  768. PIN_OSPEED_VERYLOW(GPIOC_ZIO_D47) | \
  769. PIN_OSPEED_HIGH(GPIOC_BUTTON) | \
  770. PIN_OSPEED_VERYLOW(GPIOC_OSC32_IN) | \
  771. PIN_OSPEED_VERYLOW(GPIOC_OSC32_OUT))
  772. #define VAL_GPIOC_PUPDR (PIN_PUPDR_PULLUP(GPIOC_ARD_A1) | \
  773. PIN_PUPDR_PULLUP(GPIOC_PIN1) | \
  774. PIN_PUPDR_PULLUP(GPIOC_ZIO_A7) | \
  775. PIN_PUPDR_PULLUP(GPIOC_ARD_A2) | \
  776. PIN_PUPDR_PULLUP(GPIOC_ARD_D1) | \
  777. PIN_PUPDR_PULLUP(GPIOC_ARD_D0) | \
  778. PIN_PUPDR_PULLUP(GPIOC_ZIO_D16) | \
  779. PIN_PUPDR_PULLUP(GPIOC_ZIO_D21) | \
  780. PIN_PUPDR_PULLUP(GPIOC_ZIO_D43) | \
  781. PIN_PUPDR_PULLUP(GPIOC_ZIO_D44) | \
  782. PIN_PUPDR_PULLUP(GPIOC_ZIO_D45) | \
  783. PIN_PUPDR_PULLUP(GPIOC_ZIO_D46) | \
  784. PIN_PUPDR_PULLUP(GPIOC_ZIO_D47) | \
  785. PIN_PUPDR_FLOATING(GPIOC_BUTTON) | \
  786. PIN_PUPDR_FLOATING(GPIOC_OSC32_IN) | \
  787. PIN_PUPDR_FLOATING(GPIOC_OSC32_OUT))
  788. #define VAL_GPIOC_ODR (PIN_ODR_HIGH(GPIOC_ARD_A1) | \
  789. PIN_ODR_HIGH(GPIOC_PIN1) | \
  790. PIN_ODR_HIGH(GPIOC_ZIO_A7) | \
  791. PIN_ODR_HIGH(GPIOC_ARD_A2) | \
  792. PIN_ODR_HIGH(GPIOC_ARD_D1) | \
  793. PIN_ODR_HIGH(GPIOC_ARD_D0) | \
  794. PIN_ODR_HIGH(GPIOC_ZIO_D16) | \
  795. PIN_ODR_HIGH(GPIOC_ZIO_D21) | \
  796. PIN_ODR_HIGH(GPIOC_ZIO_D43) | \
  797. PIN_ODR_HIGH(GPIOC_ZIO_D44) | \
  798. PIN_ODR_HIGH(GPIOC_ZIO_D45) | \
  799. PIN_ODR_HIGH(GPIOC_ZIO_D46) | \
  800. PIN_ODR_HIGH(GPIOC_ZIO_D47) | \
  801. PIN_ODR_HIGH(GPIOC_BUTTON) | \
  802. PIN_ODR_HIGH(GPIOC_OSC32_IN) | \
  803. PIN_ODR_HIGH(GPIOC_OSC32_OUT))
  804. #define VAL_GPIOC_AFRL (PIN_AFIO_AF(GPIOC_ARD_A1, 0U) | \
  805. PIN_AFIO_AF(GPIOC_PIN1, 0U) | \
  806. PIN_AFIO_AF(GPIOC_ZIO_A7, 0U) | \
  807. PIN_AFIO_AF(GPIOC_ARD_A2, 0U) | \
  808. PIN_AFIO_AF(GPIOC_ARD_D1, 0U) | \
  809. PIN_AFIO_AF(GPIOC_ARD_D0, 0U) | \
  810. PIN_AFIO_AF(GPIOC_ZIO_D16, 0U) | \
  811. PIN_AFIO_AF(GPIOC_ZIO_D21, 0U))
  812. #define VAL_GPIOC_AFRH (PIN_AFIO_AF(GPIOC_ZIO_D43, 0U) | \
  813. PIN_AFIO_AF(GPIOC_ZIO_D44, 0U) | \
  814. PIN_AFIO_AF(GPIOC_ZIO_D45, 0U) | \
  815. PIN_AFIO_AF(GPIOC_ZIO_D46, 0U) | \
  816. PIN_AFIO_AF(GPIOC_ZIO_D47, 0U) | \
  817. PIN_AFIO_AF(GPIOC_BUTTON, 0U) | \
  818. PIN_AFIO_AF(GPIOC_OSC32_IN, 0U) | \
  819. PIN_AFIO_AF(GPIOC_OSC32_OUT, 0U))
  820. /*
  821. * GPIOD setup:
  822. *
  823. * PD0 - ZIO_D67 CAN1_RX (input pullup).
  824. * PD1 - ZIO_D66 CAN1_TX (input pullup).
  825. * PD2 - ZIO_D48 (input pullup).
  826. * PD3 - ZIO_D55 USART2_CTS (input pullup).
  827. * PD4 - ZIO_D54 USART2_RTS (input pullup).
  828. * PD5 - ZIO_D53 USART2_TX (input pullup).
  829. * PD6 - ZIO_D52 USART2_RX (input pullup).
  830. * PD7 - ZIO_D51 USART2_SCLK (input pullup).
  831. * PD8 - USART3_RX STLK_RX (alternate 7).
  832. * PD9 - USART3_TX STLK_TX (alternate 7).
  833. * PD10 - PIN10 (input pullup).
  834. * PD11 - ARD_A3 ADC34_IN8 (input pullup).
  835. * PD12 - ARD_A4 ADC34_IN9 (input pullup).
  836. * PD13 - ARD_A5 ADC3_IN8 (input pullup).
  837. * PD14 - ARD_D10 SPI1_NSS (input pullup).
  838. * PD15 - ARD_D9 TIM4_CH4 (input pullup).
  839. */
  840. #define VAL_GPIOD_MODER (PIN_MODE_INPUT(GPIOD_ZIO_D67) | \
  841. PIN_MODE_INPUT(GPIOD_ZIO_D66) | \
  842. PIN_MODE_INPUT(GPIOD_ZIO_D48) | \
  843. PIN_MODE_INPUT(GPIOD_ZIO_D55) | \
  844. PIN_MODE_INPUT(GPIOD_ZIO_D54) | \
  845. PIN_MODE_INPUT(GPIOD_ZIO_D53) | \
  846. PIN_MODE_INPUT(GPIOD_ZIO_D52) | \
  847. PIN_MODE_INPUT(GPIOD_ZIO_D51) | \
  848. PIN_MODE_ALTERNATE(GPIOD_USART3_RX) | \
  849. PIN_MODE_ALTERNATE(GPIOD_USART3_TX) | \
  850. PIN_MODE_INPUT(GPIOD_PIN10) | \
  851. PIN_MODE_INPUT(GPIOD_ARD_A3) | \
  852. PIN_MODE_INPUT(GPIOD_ARD_A4) | \
  853. PIN_MODE_INPUT(GPIOD_ARD_A5) | \
  854. PIN_MODE_INPUT(GPIOD_ARD_D10) | \
  855. PIN_MODE_INPUT(GPIOD_ARD_D9))
  856. #define VAL_GPIOD_OTYPER (PIN_OTYPE_PUSHPULL(GPIOD_ZIO_D67) | \
  857. PIN_OTYPE_PUSHPULL(GPIOD_ZIO_D66) | \
  858. PIN_OTYPE_PUSHPULL(GPIOD_ZIO_D48) | \
  859. PIN_OTYPE_PUSHPULL(GPIOD_ZIO_D55) | \
  860. PIN_OTYPE_PUSHPULL(GPIOD_ZIO_D54) | \
  861. PIN_OTYPE_PUSHPULL(GPIOD_ZIO_D53) | \
  862. PIN_OTYPE_PUSHPULL(GPIOD_ZIO_D52) | \
  863. PIN_OTYPE_PUSHPULL(GPIOD_ZIO_D51) | \
  864. PIN_OTYPE_PUSHPULL(GPIOD_USART3_RX) | \
  865. PIN_OTYPE_PUSHPULL(GPIOD_USART3_TX) | \
  866. PIN_OTYPE_PUSHPULL(GPIOD_PIN10) | \
  867. PIN_OTYPE_PUSHPULL(GPIOD_ARD_A3) | \
  868. PIN_OTYPE_PUSHPULL(GPIOD_ARD_A4) | \
  869. PIN_OTYPE_PUSHPULL(GPIOD_ARD_A5) | \
  870. PIN_OTYPE_PUSHPULL(GPIOD_ARD_D10) | \
  871. PIN_OTYPE_PUSHPULL(GPIOD_ARD_D9))
  872. #define VAL_GPIOD_OSPEEDR (PIN_OSPEED_HIGH(GPIOD_ZIO_D67) | \
  873. PIN_OSPEED_HIGH(GPIOD_ZIO_D66) | \
  874. PIN_OSPEED_VERYLOW(GPIOD_ZIO_D48) | \
  875. PIN_OSPEED_HIGH(GPIOD_ZIO_D55) | \
  876. PIN_OSPEED_HIGH(GPIOD_ZIO_D54) | \
  877. PIN_OSPEED_HIGH(GPIOD_ZIO_D53) | \
  878. PIN_OSPEED_HIGH(GPIOD_ZIO_D52) | \
  879. PIN_OSPEED_HIGH(GPIOD_ZIO_D51) | \
  880. PIN_OSPEED_HIGH(GPIOD_USART3_RX) | \
  881. PIN_OSPEED_HIGH(GPIOD_USART3_TX) | \
  882. PIN_OSPEED_VERYLOW(GPIOD_PIN10) | \
  883. PIN_OSPEED_HIGH(GPIOD_ARD_A3) | \
  884. PIN_OSPEED_HIGH(GPIOD_ARD_A4) | \
  885. PIN_OSPEED_HIGH(GPIOD_ARD_A5) | \
  886. PIN_OSPEED_HIGH(GPIOD_ARD_D10) | \
  887. PIN_OSPEED_HIGH(GPIOD_ARD_D9))
  888. #define VAL_GPIOD_PUPDR (PIN_PUPDR_PULLUP(GPIOD_ZIO_D67) | \
  889. PIN_PUPDR_PULLUP(GPIOD_ZIO_D66) | \
  890. PIN_PUPDR_PULLUP(GPIOD_ZIO_D48) | \
  891. PIN_PUPDR_PULLUP(GPIOD_ZIO_D55) | \
  892. PIN_PUPDR_PULLUP(GPIOD_ZIO_D54) | \
  893. PIN_PUPDR_PULLUP(GPIOD_ZIO_D53) | \
  894. PIN_PUPDR_PULLUP(GPIOD_ZIO_D52) | \
  895. PIN_PUPDR_PULLUP(GPIOD_ZIO_D51) | \
  896. PIN_PUPDR_FLOATING(GPIOD_USART3_RX) | \
  897. PIN_PUPDR_FLOATING(GPIOD_USART3_TX) | \
  898. PIN_PUPDR_PULLUP(GPIOD_PIN10) | \
  899. PIN_PUPDR_PULLUP(GPIOD_ARD_A3) | \
  900. PIN_PUPDR_PULLUP(GPIOD_ARD_A4) | \
  901. PIN_PUPDR_PULLUP(GPIOD_ARD_A5) | \
  902. PIN_PUPDR_PULLUP(GPIOD_ARD_D10) | \
  903. PIN_PUPDR_PULLUP(GPIOD_ARD_D9))
  904. #define VAL_GPIOD_ODR (PIN_ODR_HIGH(GPIOD_ZIO_D67) | \
  905. PIN_ODR_HIGH(GPIOD_ZIO_D66) | \
  906. PIN_ODR_HIGH(GPIOD_ZIO_D48) | \
  907. PIN_ODR_HIGH(GPIOD_ZIO_D55) | \
  908. PIN_ODR_HIGH(GPIOD_ZIO_D54) | \
  909. PIN_ODR_HIGH(GPIOD_ZIO_D53) | \
  910. PIN_ODR_HIGH(GPIOD_ZIO_D52) | \
  911. PIN_ODR_HIGH(GPIOD_ZIO_D51) | \
  912. PIN_ODR_HIGH(GPIOD_USART3_RX) | \
  913. PIN_ODR_HIGH(GPIOD_USART3_TX) | \
  914. PIN_ODR_HIGH(GPIOD_PIN10) | \
  915. PIN_ODR_HIGH(GPIOD_ARD_A3) | \
  916. PIN_ODR_HIGH(GPIOD_ARD_A4) | \
  917. PIN_ODR_HIGH(GPIOD_ARD_A5) | \
  918. PIN_ODR_HIGH(GPIOD_ARD_D10) | \
  919. PIN_ODR_HIGH(GPIOD_ARD_D9))
  920. #define VAL_GPIOD_AFRL (PIN_AFIO_AF(GPIOD_ZIO_D67, 0U) | \
  921. PIN_AFIO_AF(GPIOD_ZIO_D66, 0U) | \
  922. PIN_AFIO_AF(GPIOD_ZIO_D48, 0U) | \
  923. PIN_AFIO_AF(GPIOD_ZIO_D55, 0U) | \
  924. PIN_AFIO_AF(GPIOD_ZIO_D54, 0U) | \
  925. PIN_AFIO_AF(GPIOD_ZIO_D53, 0U) | \
  926. PIN_AFIO_AF(GPIOD_ZIO_D52, 0U) | \
  927. PIN_AFIO_AF(GPIOD_ZIO_D51, 0U))
  928. #define VAL_GPIOD_AFRH (PIN_AFIO_AF(GPIOD_USART3_RX, 7U) | \
  929. PIN_AFIO_AF(GPIOD_USART3_TX, 7U) | \
  930. PIN_AFIO_AF(GPIOD_PIN10, 0U) | \
  931. PIN_AFIO_AF(GPIOD_ARD_A3, 0U) | \
  932. PIN_AFIO_AF(GPIOD_ARD_A4, 0U) | \
  933. PIN_AFIO_AF(GPIOD_ARD_A5, 0U) | \
  934. PIN_AFIO_AF(GPIOD_ARD_D10, 0U) | \
  935. PIN_AFIO_AF(GPIOD_ARD_D9, 0U))
  936. /*
  937. * GPIOE setup:
  938. *
  939. * PE0 - ZIO_D34 TIM4_ETR (input pullup).
  940. * PE1 - PIN1 (input pullup).
  941. * PE2 - ZIO_D31 ZIO_D56 (input pullup).
  942. * PE3 - ZIO_D60 (input pullup).
  943. * PE4 - ZIO_D57 (input pullup).
  944. * PE5 - ZIO_D58 (input pullup).
  945. * PE6 - ZIO_D59 (input pullup).
  946. * PE7 - ZIO_D41 TIM1_ETR (input pullup).
  947. * PE8 - ZIO_D42 TIM1_CH1N (input pullup).
  948. * PE9 - ARD_D6 TIM1_CH1 (input pullup).
  949. * PE10 - ZIO_D40 TIM1_CH2N (input pullup).
  950. * PE11 - ARD_D5 TIM1_CH2 (input pullup).
  951. * PE12 - ZIO_D39 TIM1_CH3N (input pullup).
  952. * PE13 - ARD_D3 TIM1_CH3 (input pullup).
  953. * PE14 - ZIO_D38 (input pullup).
  954. * PE15 - ZIO_D37 TIM1_BKIN1 (input pullup).
  955. */
  956. #define VAL_GPIOE_MODER (PIN_MODE_INPUT(GPIOE_ZIO_D34) | \
  957. PIN_MODE_INPUT(GPIOE_PIN1) | \
  958. PIN_MODE_INPUT(GPIOE_ZIO_D31) | \
  959. PIN_MODE_INPUT(GPIOE_ZIO_D60) | \
  960. PIN_MODE_INPUT(GPIOE_ZIO_D57) | \
  961. PIN_MODE_INPUT(GPIOE_ZIO_D58) | \
  962. PIN_MODE_INPUT(GPIOE_ZIO_D59) | \
  963. PIN_MODE_INPUT(GPIOE_ZIO_D41) | \
  964. PIN_MODE_INPUT(GPIOE_ZIO_D42) | \
  965. PIN_MODE_INPUT(GPIOE_ARD_D6) | \
  966. PIN_MODE_INPUT(GPIOE_ZIO_D40) | \
  967. PIN_MODE_INPUT(GPIOE_ARD_D5) | \
  968. PIN_MODE_INPUT(GPIOE_ZIO_D39) | \
  969. PIN_MODE_INPUT(GPIOE_ARD_D3) | \
  970. PIN_MODE_INPUT(GPIOE_ZIO_D38) | \
  971. PIN_MODE_INPUT(GPIOE_ZIO_D37))
  972. #define VAL_GPIOE_OTYPER (PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D34) | \
  973. PIN_OTYPE_PUSHPULL(GPIOE_PIN1) | \
  974. PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D31) | \
  975. PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D60) | \
  976. PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D57) | \
  977. PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D58) | \
  978. PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D59) | \
  979. PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D41) | \
  980. PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D42) | \
  981. PIN_OTYPE_PUSHPULL(GPIOE_ARD_D6) | \
  982. PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D40) | \
  983. PIN_OTYPE_PUSHPULL(GPIOE_ARD_D5) | \
  984. PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D39) | \
  985. PIN_OTYPE_PUSHPULL(GPIOE_ARD_D3) | \
  986. PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D38) | \
  987. PIN_OTYPE_PUSHPULL(GPIOE_ZIO_D37))
  988. #define VAL_GPIOE_OSPEEDR (PIN_OSPEED_HIGH(GPIOE_ZIO_D34) | \
  989. PIN_OSPEED_VERYLOW(GPIOE_PIN1) | \
  990. PIN_OSPEED_VERYLOW(GPIOE_ZIO_D31) | \
  991. PIN_OSPEED_VERYLOW(GPIOE_ZIO_D60) | \
  992. PIN_OSPEED_VERYLOW(GPIOE_ZIO_D57) | \
  993. PIN_OSPEED_VERYLOW(GPIOE_ZIO_D58) | \
  994. PIN_OSPEED_VERYLOW(GPIOE_ZIO_D59) | \
  995. PIN_OSPEED_HIGH(GPIOE_ZIO_D41) | \
  996. PIN_OSPEED_HIGH(GPIOE_ZIO_D42) | \
  997. PIN_OSPEED_HIGH(GPIOE_ARD_D6) | \
  998. PIN_OSPEED_HIGH(GPIOE_ZIO_D40) | \
  999. PIN_OSPEED_HIGH(GPIOE_ARD_D5) | \
  1000. PIN_OSPEED_HIGH(GPIOE_ZIO_D39) | \
  1001. PIN_OSPEED_HIGH(GPIOE_ARD_D3) | \
  1002. PIN_OSPEED_VERYLOW(GPIOE_ZIO_D38) | \
  1003. PIN_OSPEED_HIGH(GPIOE_ZIO_D37))
  1004. #define VAL_GPIOE_PUPDR (PIN_PUPDR_PULLUP(GPIOE_ZIO_D34) | \
  1005. PIN_PUPDR_PULLUP(GPIOE_PIN1) | \
  1006. PIN_PUPDR_PULLUP(GPIOE_ZIO_D31) | \
  1007. PIN_PUPDR_PULLUP(GPIOE_ZIO_D60) | \
  1008. PIN_PUPDR_PULLUP(GPIOE_ZIO_D57) | \
  1009. PIN_PUPDR_PULLUP(GPIOE_ZIO_D58) | \
  1010. PIN_PUPDR_PULLUP(GPIOE_ZIO_D59) | \
  1011. PIN_PUPDR_PULLUP(GPIOE_ZIO_D41) | \
  1012. PIN_PUPDR_PULLUP(GPIOE_ZIO_D42) | \
  1013. PIN_PUPDR_PULLUP(GPIOE_ARD_D6) | \
  1014. PIN_PUPDR_PULLUP(GPIOE_ZIO_D40) | \
  1015. PIN_PUPDR_PULLUP(GPIOE_ARD_D5) | \
  1016. PIN_PUPDR_PULLUP(GPIOE_ZIO_D39) | \
  1017. PIN_PUPDR_PULLUP(GPIOE_ARD_D3) | \
  1018. PIN_PUPDR_PULLUP(GPIOE_ZIO_D38) | \
  1019. PIN_PUPDR_PULLUP(GPIOE_ZIO_D37))
  1020. #define VAL_GPIOE_ODR (PIN_ODR_HIGH(GPIOE_ZIO_D34) | \
  1021. PIN_ODR_HIGH(GPIOE_PIN1) | \
  1022. PIN_ODR_HIGH(GPIOE_ZIO_D31) | \
  1023. PIN_ODR_HIGH(GPIOE_ZIO_D60) | \
  1024. PIN_ODR_HIGH(GPIOE_ZIO_D57) | \
  1025. PIN_ODR_HIGH(GPIOE_ZIO_D58) | \
  1026. PIN_ODR_HIGH(GPIOE_ZIO_D59) | \
  1027. PIN_ODR_HIGH(GPIOE_ZIO_D41) | \
  1028. PIN_ODR_HIGH(GPIOE_ZIO_D42) | \
  1029. PIN_ODR_HIGH(GPIOE_ARD_D6) | \
  1030. PIN_ODR_HIGH(GPIOE_ZIO_D40) | \
  1031. PIN_ODR_HIGH(GPIOE_ARD_D5) | \
  1032. PIN_ODR_HIGH(GPIOE_ZIO_D39) | \
  1033. PIN_ODR_HIGH(GPIOE_ARD_D3) | \
  1034. PIN_ODR_HIGH(GPIOE_ZIO_D38) | \
  1035. PIN_ODR_HIGH(GPIOE_ZIO_D37))
  1036. #define VAL_GPIOE_AFRL (PIN_AFIO_AF(GPIOE_ZIO_D34, 0U) | \
  1037. PIN_AFIO_AF(GPIOE_PIN1, 0U) | \
  1038. PIN_AFIO_AF(GPIOE_ZIO_D31, 0U) | \
  1039. PIN_AFIO_AF(GPIOE_ZIO_D60, 0U) | \
  1040. PIN_AFIO_AF(GPIOE_ZIO_D57, 0U) | \
  1041. PIN_AFIO_AF(GPIOE_ZIO_D58, 0U) | \
  1042. PIN_AFIO_AF(GPIOE_ZIO_D59, 0U) | \
  1043. PIN_AFIO_AF(GPIOE_ZIO_D41, 0U))
  1044. #define VAL_GPIOE_AFRH (PIN_AFIO_AF(GPIOE_ZIO_D42, 0U) | \
  1045. PIN_AFIO_AF(GPIOE_ARD_D6, 0U) | \
  1046. PIN_AFIO_AF(GPIOE_ZIO_D40, 0U) | \
  1047. PIN_AFIO_AF(GPIOE_ARD_D5, 0U) | \
  1048. PIN_AFIO_AF(GPIOE_ZIO_D39, 0U) | \
  1049. PIN_AFIO_AF(GPIOE_ARD_D3, 0U) | \
  1050. PIN_AFIO_AF(GPIOE_ZIO_D38, 0U) | \
  1051. PIN_AFIO_AF(GPIOE_ZIO_D37, 0U))
  1052. /*
  1053. * GPIOF setup:
  1054. *
  1055. * PF0 - PIN0 (input pullup).
  1056. * PF1 - PIN1 (input pullup).
  1057. * PF2 - PIN2 (input pullup).
  1058. * PF3 - ZIO_D30 (input pullup).
  1059. * PF4 - ZIO_A8 ADC3_IN14 (input pullup).
  1060. * PF5 - ZIO_D29 (input pullup).
  1061. * PF6 - PIN6 (input pullup).
  1062. * PF7 - ZIO_D62 (input pullup).
  1063. * PF8 - ZIO_D61 (input pullup).
  1064. * PF9 - ZIO_D63 (input pullup).
  1065. * PF10 - ZIO_D28 (input pullup).
  1066. * PF11 - PIN11 (input pullup).
  1067. * PF12 - ARD_D8 (input pullup).
  1068. * PF13 - ARD_D7 (input pullup).
  1069. * PF14 - ARD_D4 (input pullup).
  1070. * PF15 - ARD_D2 (input pullup).
  1071. */
  1072. #define VAL_GPIOF_MODER (PIN_MODE_INPUT(GPIOF_PIN0) | \
  1073. PIN_MODE_INPUT(GPIOF_PIN1) | \
  1074. PIN_MODE_INPUT(GPIOF_PIN2) | \
  1075. PIN_MODE_INPUT(GPIOF_ZIO_D30) | \
  1076. PIN_MODE_INPUT(GPIOF_ZIO_A8) | \
  1077. PIN_MODE_INPUT(GPIOF_ZIO_D29) | \
  1078. PIN_MODE_INPUT(GPIOF_PIN6) | \
  1079. PIN_MODE_INPUT(GPIOF_ZIO_D62) | \
  1080. PIN_MODE_INPUT(GPIOF_ZIO_D61) | \
  1081. PIN_MODE_INPUT(GPIOF_ZIO_D63) | \
  1082. PIN_MODE_INPUT(GPIOF_ZIO_D28) | \
  1083. PIN_MODE_INPUT(GPIOF_PIN11) | \
  1084. PIN_MODE_INPUT(GPIOF_ARD_D8) | \
  1085. PIN_MODE_INPUT(GPIOF_ARD_D7) | \
  1086. PIN_MODE_INPUT(GPIOF_ARD_D4) | \
  1087. PIN_MODE_INPUT(GPIOF_ARD_D2))
  1088. #define VAL_GPIOF_OTYPER (PIN_OTYPE_PUSHPULL(GPIOF_PIN0) | \
  1089. PIN_OTYPE_PUSHPULL(GPIOF_PIN1) | \
  1090. PIN_OTYPE_PUSHPULL(GPIOF_PIN2) | \
  1091. PIN_OTYPE_PUSHPULL(GPIOF_ZIO_D30) | \
  1092. PIN_OTYPE_PUSHPULL(GPIOF_ZIO_A8) | \
  1093. PIN_OTYPE_PUSHPULL(GPIOF_ZIO_D29) | \
  1094. PIN_OTYPE_PUSHPULL(GPIOF_PIN6) | \
  1095. PIN_OTYPE_PUSHPULL(GPIOF_ZIO_D62) | \
  1096. PIN_OTYPE_PUSHPULL(GPIOF_ZIO_D61) | \
  1097. PIN_OTYPE_PUSHPULL(GPIOF_ZIO_D63) | \
  1098. PIN_OTYPE_PUSHPULL(GPIOF_ZIO_D28) | \
  1099. PIN_OTYPE_PUSHPULL(GPIOF_PIN11) | \
  1100. PIN_OTYPE_PUSHPULL(GPIOF_ARD_D8) | \
  1101. PIN_OTYPE_PUSHPULL(GPIOF_ARD_D7) | \
  1102. PIN_OTYPE_PUSHPULL(GPIOF_ARD_D4) | \
  1103. PIN_OTYPE_PUSHPULL(GPIOF_ARD_D2))
  1104. #define VAL_GPIOF_OSPEEDR (PIN_OSPEED_VERYLOW(GPIOF_PIN0) | \
  1105. PIN_OSPEED_VERYLOW(GPIOF_PIN1) | \
  1106. PIN_OSPEED_VERYLOW(GPIOF_PIN2) | \
  1107. PIN_OSPEED_VERYLOW(GPIOF_ZIO_D30) | \
  1108. PIN_OSPEED_HIGH(GPIOF_ZIO_A8) | \
  1109. PIN_OSPEED_VERYLOW(GPIOF_ZIO_D29) | \
  1110. PIN_OSPEED_VERYLOW(GPIOF_PIN6) | \
  1111. PIN_OSPEED_VERYLOW(GPIOF_ZIO_D62) | \
  1112. PIN_OSPEED_VERYLOW(GPIOF_ZIO_D61) | \
  1113. PIN_OSPEED_VERYLOW(GPIOF_ZIO_D63) | \
  1114. PIN_OSPEED_VERYLOW(GPIOF_ZIO_D28) | \
  1115. PIN_OSPEED_VERYLOW(GPIOF_PIN11) | \
  1116. PIN_OSPEED_VERYLOW(GPIOF_ARD_D8) | \
  1117. PIN_OSPEED_VERYLOW(GPIOF_ARD_D7) | \
  1118. PIN_OSPEED_VERYLOW(GPIOF_ARD_D4) | \
  1119. PIN_OSPEED_VERYLOW(GPIOF_ARD_D2))
  1120. #define VAL_GPIOF_PUPDR (PIN_PUPDR_PULLUP(GPIOF_PIN0) | \
  1121. PIN_PUPDR_PULLUP(GPIOF_PIN1) | \
  1122. PIN_PUPDR_PULLUP(GPIOF_PIN2) | \
  1123. PIN_PUPDR_PULLUP(GPIOF_ZIO_D30) | \
  1124. PIN_PUPDR_PULLUP(GPIOF_ZIO_A8) | \
  1125. PIN_PUPDR_PULLUP(GPIOF_ZIO_D29) | \
  1126. PIN_PUPDR_PULLUP(GPIOF_PIN6) | \
  1127. PIN_PUPDR_PULLUP(GPIOF_ZIO_D62) | \
  1128. PIN_PUPDR_PULLUP(GPIOF_ZIO_D61) | \
  1129. PIN_PUPDR_PULLUP(GPIOF_ZIO_D63) | \
  1130. PIN_PUPDR_PULLUP(GPIOF_ZIO_D28) | \
  1131. PIN_PUPDR_PULLUP(GPIOF_PIN11) | \
  1132. PIN_PUPDR_PULLUP(GPIOF_ARD_D8) | \
  1133. PIN_PUPDR_PULLUP(GPIOF_ARD_D7) | \
  1134. PIN_PUPDR_PULLUP(GPIOF_ARD_D4) | \
  1135. PIN_PUPDR_PULLUP(GPIOF_ARD_D2))
  1136. #define VAL_GPIOF_ODR (PIN_ODR_HIGH(GPIOF_PIN0) | \
  1137. PIN_ODR_HIGH(GPIOF_PIN1) | \
  1138. PIN_ODR_HIGH(GPIOF_PIN2) | \
  1139. PIN_ODR_HIGH(GPIOF_ZIO_D30) | \
  1140. PIN_ODR_HIGH(GPIOF_ZIO_A8) | \
  1141. PIN_ODR_HIGH(GPIOF_ZIO_D29) | \
  1142. PIN_ODR_HIGH(GPIOF_PIN6) | \
  1143. PIN_ODR_HIGH(GPIOF_ZIO_D62) | \
  1144. PIN_ODR_HIGH(GPIOF_ZIO_D61) | \
  1145. PIN_ODR_HIGH(GPIOF_ZIO_D63) | \
  1146. PIN_ODR_HIGH(GPIOF_ZIO_D28) | \
  1147. PIN_ODR_HIGH(GPIOF_PIN11) | \
  1148. PIN_ODR_HIGH(GPIOF_ARD_D8) | \
  1149. PIN_ODR_HIGH(GPIOF_ARD_D7) | \
  1150. PIN_ODR_HIGH(GPIOF_ARD_D4) | \
  1151. PIN_ODR_HIGH(GPIOF_ARD_D2))
  1152. #define VAL_GPIOF_AFRL (PIN_AFIO_AF(GPIOF_PIN0, 0U) | \
  1153. PIN_AFIO_AF(GPIOF_PIN1, 0U) | \
  1154. PIN_AFIO_AF(GPIOF_PIN2, 0U) | \
  1155. PIN_AFIO_AF(GPIOF_ZIO_D30, 0U) | \
  1156. PIN_AFIO_AF(GPIOF_ZIO_A8, 0U) | \
  1157. PIN_AFIO_AF(GPIOF_ZIO_D29, 0U) | \
  1158. PIN_AFIO_AF(GPIOF_PIN6, 0U) | \
  1159. PIN_AFIO_AF(GPIOF_ZIO_D62, 0U))
  1160. #define VAL_GPIOF_AFRH (PIN_AFIO_AF(GPIOF_ZIO_D61, 0U) | \
  1161. PIN_AFIO_AF(GPIOF_ZIO_D63, 0U) | \
  1162. PIN_AFIO_AF(GPIOF_ZIO_D28, 0U) | \
  1163. PIN_AFIO_AF(GPIOF_PIN11, 0U) | \
  1164. PIN_AFIO_AF(GPIOF_ARD_D8, 0U) | \
  1165. PIN_AFIO_AF(GPIOF_ARD_D7, 0U) | \
  1166. PIN_AFIO_AF(GPIOF_ARD_D4, 0U) | \
  1167. PIN_AFIO_AF(GPIOF_ARD_D2, 0U))
  1168. /*
  1169. * GPIOG setup:
  1170. *
  1171. * PG0 - ZIO_D65 (input pullup).
  1172. * PG1 - ZIO_D64 (input pullup).
  1173. * PG2 - ZIO_D49 (input pullup).
  1174. * PG3 - ZIO_D50 (input pullup).
  1175. * PG4 - PIN4 (input pullup).
  1176. * PG5 - PIN5 (input pullup).
  1177. * PG6 - USB_GPIO_OUT (output pushpull maximum).
  1178. * PG7 - USB_GPIO_IN (input pullup).
  1179. * PG8 - PIN8 (input pullup).
  1180. * PG9 - PIN9 (input pullup).
  1181. * PG10 - PIN10 (input pullup).
  1182. * PG11 - PIN11 (input pullup).
  1183. * PG12 - PIN12 (input pullup).
  1184. * PG13 - PIN13 (input pullup).
  1185. * PG14 - PIN14 (input pullup).
  1186. * PG15 - PIN15 (input pullup).
  1187. */
  1188. #define VAL_GPIOG_MODER (PIN_MODE_INPUT(GPIOG_ZIO_D65) | \
  1189. PIN_MODE_INPUT(GPIOG_ZIO_D64) | \
  1190. PIN_MODE_INPUT(GPIOG_ZIO_D49) | \
  1191. PIN_MODE_INPUT(GPIOG_ZIO_D50) | \
  1192. PIN_MODE_INPUT(GPIOG_PIN4) | \
  1193. PIN_MODE_INPUT(GPIOG_PIN5) | \
  1194. PIN_MODE_OUTPUT(GPIOG_USB_GPIO_OUT) | \
  1195. PIN_MODE_INPUT(GPIOG_USB_GPIO_IN) | \
  1196. PIN_MODE_INPUT(GPIOG_PIN8) | \
  1197. PIN_MODE_INPUT(GPIOG_PIN9) | \
  1198. PIN_MODE_INPUT(GPIOG_PIN10) | \
  1199. PIN_MODE_INPUT(GPIOG_PIN11) | \
  1200. PIN_MODE_INPUT(GPIOG_PIN12) | \
  1201. PIN_MODE_INPUT(GPIOG_PIN13) | \
  1202. PIN_MODE_INPUT(GPIOG_PIN14) | \
  1203. PIN_MODE_INPUT(GPIOG_PIN15))
  1204. #define VAL_GPIOG_OTYPER (PIN_OTYPE_PUSHPULL(GPIOG_ZIO_D65) | \
  1205. PIN_OTYPE_PUSHPULL(GPIOG_ZIO_D64) | \
  1206. PIN_OTYPE_PUSHPULL(GPIOG_ZIO_D49) | \
  1207. PIN_OTYPE_PUSHPULL(GPIOG_ZIO_D50) | \
  1208. PIN_OTYPE_PUSHPULL(GPIOG_PIN4) | \
  1209. PIN_OTYPE_PUSHPULL(GPIOG_PIN5) | \
  1210. PIN_OTYPE_PUSHPULL(GPIOG_USB_GPIO_OUT) |\
  1211. PIN_OTYPE_PUSHPULL(GPIOG_USB_GPIO_IN) |\
  1212. PIN_OTYPE_PUSHPULL(GPIOG_PIN8) | \
  1213. PIN_OTYPE_PUSHPULL(GPIOG_PIN9) | \
  1214. PIN_OTYPE_PUSHPULL(GPIOG_PIN10) | \
  1215. PIN_OTYPE_PUSHPULL(GPIOG_PIN11) | \
  1216. PIN_OTYPE_PUSHPULL(GPIOG_PIN12) | \
  1217. PIN_OTYPE_PUSHPULL(GPIOG_PIN13) | \
  1218. PIN_OTYPE_PUSHPULL(GPIOG_PIN14) | \
  1219. PIN_OTYPE_PUSHPULL(GPIOG_PIN15))
  1220. #define VAL_GPIOG_OSPEEDR (PIN_OSPEED_VERYLOW(GPIOG_ZIO_D65) | \
  1221. PIN_OSPEED_VERYLOW(GPIOG_ZIO_D64) | \
  1222. PIN_OSPEED_VERYLOW(GPIOG_ZIO_D49) | \
  1223. PIN_OSPEED_VERYLOW(GPIOG_ZIO_D50) | \
  1224. PIN_OSPEED_VERYLOW(GPIOG_PIN4) | \
  1225. PIN_OSPEED_VERYLOW(GPIOG_PIN5) | \
  1226. PIN_OSPEED_HIGH(GPIOG_USB_GPIO_OUT) | \
  1227. PIN_OSPEED_HIGH(GPIOG_USB_GPIO_IN) | \
  1228. PIN_OSPEED_VERYLOW(GPIOG_PIN8) | \
  1229. PIN_OSPEED_VERYLOW(GPIOG_PIN9) | \
  1230. PIN_OSPEED_VERYLOW(GPIOG_PIN10) | \
  1231. PIN_OSPEED_VERYLOW(GPIOG_PIN11) | \
  1232. PIN_OSPEED_VERYLOW(GPIOG_PIN12) | \
  1233. PIN_OSPEED_VERYLOW(GPIOG_PIN13) | \
  1234. PIN_OSPEED_VERYLOW(GPIOG_PIN14) | \
  1235. PIN_OSPEED_VERYLOW(GPIOG_PIN15))
  1236. #define VAL_GPIOG_PUPDR (PIN_PUPDR_PULLUP(GPIOG_ZIO_D65) | \
  1237. PIN_PUPDR_PULLUP(GPIOG_ZIO_D64) | \
  1238. PIN_PUPDR_PULLUP(GPIOG_ZIO_D49) | \
  1239. PIN_PUPDR_PULLUP(GPIOG_ZIO_D50) | \
  1240. PIN_PUPDR_PULLUP(GPIOG_PIN4) | \
  1241. PIN_PUPDR_PULLUP(GPIOG_PIN5) | \
  1242. PIN_PUPDR_FLOATING(GPIOG_USB_GPIO_OUT) |\
  1243. PIN_PUPDR_PULLUP(GPIOG_USB_GPIO_IN) | \
  1244. PIN_PUPDR_PULLUP(GPIOG_PIN8) | \
  1245. PIN_PUPDR_PULLUP(GPIOG_PIN9) | \
  1246. PIN_PUPDR_PULLUP(GPIOG_PIN10) | \
  1247. PIN_PUPDR_PULLUP(GPIOG_PIN11) | \
  1248. PIN_PUPDR_PULLUP(GPIOG_PIN12) | \
  1249. PIN_PUPDR_PULLUP(GPIOG_PIN13) | \
  1250. PIN_PUPDR_PULLUP(GPIOG_PIN14) | \
  1251. PIN_PUPDR_PULLUP(GPIOG_PIN15))
  1252. #define VAL_GPIOG_ODR (PIN_ODR_HIGH(GPIOG_ZIO_D65) | \
  1253. PIN_ODR_HIGH(GPIOG_ZIO_D64) | \
  1254. PIN_ODR_HIGH(GPIOG_ZIO_D49) | \
  1255. PIN_ODR_HIGH(GPIOG_ZIO_D50) | \
  1256. PIN_ODR_HIGH(GPIOG_PIN4) | \
  1257. PIN_ODR_HIGH(GPIOG_PIN5) | \
  1258. PIN_ODR_HIGH(GPIOG_USB_GPIO_OUT) | \
  1259. PIN_ODR_HIGH(GPIOG_USB_GPIO_IN) | \
  1260. PIN_ODR_HIGH(GPIOG_PIN8) | \
  1261. PIN_ODR_HIGH(GPIOG_PIN9) | \
  1262. PIN_ODR_HIGH(GPIOG_PIN10) | \
  1263. PIN_ODR_HIGH(GPIOG_PIN11) | \
  1264. PIN_ODR_HIGH(GPIOG_PIN12) | \
  1265. PIN_ODR_HIGH(GPIOG_PIN13) | \
  1266. PIN_ODR_HIGH(GPIOG_PIN14) | \
  1267. PIN_ODR_HIGH(GPIOG_PIN15))
  1268. #define VAL_GPIOG_AFRL (PIN_AFIO_AF(GPIOG_ZIO_D65, 0U) | \
  1269. PIN_AFIO_AF(GPIOG_ZIO_D64, 0U) | \
  1270. PIN_AFIO_AF(GPIOG_ZIO_D49, 0U) | \
  1271. PIN_AFIO_AF(GPIOG_ZIO_D50, 0U) | \
  1272. PIN_AFIO_AF(GPIOG_PIN4, 0U) | \
  1273. PIN_AFIO_AF(GPIOG_PIN5, 0U) | \
  1274. PIN_AFIO_AF(GPIOG_USB_GPIO_OUT, 0U) | \
  1275. PIN_AFIO_AF(GPIOG_USB_GPIO_IN, 0U))
  1276. #define VAL_GPIOG_AFRH (PIN_AFIO_AF(GPIOG_PIN8, 0U) | \
  1277. PIN_AFIO_AF(GPIOG_PIN9, 0U) | \
  1278. PIN_AFIO_AF(GPIOG_PIN10, 0U) | \
  1279. PIN_AFIO_AF(GPIOG_PIN11, 0U) | \
  1280. PIN_AFIO_AF(GPIOG_PIN12, 0U) | \
  1281. PIN_AFIO_AF(GPIOG_PIN13, 0U) | \
  1282. PIN_AFIO_AF(GPIOG_PIN14, 0U) | \
  1283. PIN_AFIO_AF(GPIOG_PIN15, 0U))
  1284. /*
  1285. * GPIOH setup:
  1286. *
  1287. * PH0 - OSC_IN (input floating).
  1288. * PH1 - OSC_OUT (input floating).
  1289. * PH2 - PIN2 (input pullup).
  1290. * PH3 - PIN3 (input pullup).
  1291. * PH4 - PIN4 (input pullup).
  1292. * PH5 - PIN5 (input pullup).
  1293. * PH6 - PIN6 (input pullup).
  1294. * PH7 - PIN7 (input pullup).
  1295. * PH8 - PIN8 (input pullup).
  1296. * PH9 - PIN9 (input pullup).
  1297. * PH10 - PIN10 (input pullup).
  1298. * PH11 - PIN11 (input pullup).
  1299. * PH12 - PIN12 (input pullup).
  1300. * PH13 - PIN13 (input pullup).
  1301. * PH14 - PIN14 (input pullup).
  1302. * PH15 - PIN15 (input pullup).
  1303. */
  1304. #define VAL_GPIOH_MODER (PIN_MODE_INPUT(GPIOH_OSC_IN) | \
  1305. PIN_MODE_INPUT(GPIOH_OSC_OUT) | \
  1306. PIN_MODE_INPUT(GPIOH_PIN2) | \
  1307. PIN_MODE_INPUT(GPIOH_PIN3) | \
  1308. PIN_MODE_INPUT(GPIOH_PIN4) | \
  1309. PIN_MODE_INPUT(GPIOH_PIN5) | \
  1310. PIN_MODE_INPUT(GPIOH_PIN6) | \
  1311. PIN_MODE_INPUT(GPIOH_PIN7) | \
  1312. PIN_MODE_INPUT(GPIOH_PIN8) | \
  1313. PIN_MODE_INPUT(GPIOH_PIN9) | \
  1314. PIN_MODE_INPUT(GPIOH_PIN10) | \
  1315. PIN_MODE_INPUT(GPIOH_PIN11) | \
  1316. PIN_MODE_INPUT(GPIOH_PIN12) | \
  1317. PIN_MODE_INPUT(GPIOH_PIN13) | \
  1318. PIN_MODE_INPUT(GPIOH_PIN14) | \
  1319. PIN_MODE_INPUT(GPIOH_PIN15))
  1320. #define VAL_GPIOH_OTYPER (PIN_OTYPE_PUSHPULL(GPIOH_OSC_IN) | \
  1321. PIN_OTYPE_PUSHPULL(GPIOH_OSC_OUT) | \
  1322. PIN_OTYPE_PUSHPULL(GPIOH_PIN2) | \
  1323. PIN_OTYPE_PUSHPULL(GPIOH_PIN3) | \
  1324. PIN_OTYPE_PUSHPULL(GPIOH_PIN4) | \
  1325. PIN_OTYPE_PUSHPULL(GPIOH_PIN5) | \
  1326. PIN_OTYPE_PUSHPULL(GPIOH_PIN6) | \
  1327. PIN_OTYPE_PUSHPULL(GPIOH_PIN7) | \
  1328. PIN_OTYPE_PUSHPULL(GPIOH_PIN8) | \
  1329. PIN_OTYPE_PUSHPULL(GPIOH_PIN9) | \
  1330. PIN_OTYPE_PUSHPULL(GPIOH_PIN10) | \
  1331. PIN_OTYPE_PUSHPULL(GPIOH_PIN11) | \
  1332. PIN_OTYPE_PUSHPULL(GPIOH_PIN12) | \
  1333. PIN_OTYPE_PUSHPULL(GPIOH_PIN13) | \
  1334. PIN_OTYPE_PUSHPULL(GPIOH_PIN14) | \
  1335. PIN_OTYPE_PUSHPULL(GPIOH_PIN15))
  1336. #define VAL_GPIOH_OSPEEDR (PIN_OSPEED_HIGH(GPIOH_OSC_IN) | \
  1337. PIN_OSPEED_HIGH(GPIOH_OSC_OUT) | \
  1338. PIN_OSPEED_VERYLOW(GPIOH_PIN2) | \
  1339. PIN_OSPEED_VERYLOW(GPIOH_PIN3) | \
  1340. PIN_OSPEED_VERYLOW(GPIOH_PIN4) | \
  1341. PIN_OSPEED_VERYLOW(GPIOH_PIN5) | \
  1342. PIN_OSPEED_VERYLOW(GPIOH_PIN6) | \
  1343. PIN_OSPEED_VERYLOW(GPIOH_PIN7) | \
  1344. PIN_OSPEED_VERYLOW(GPIOH_PIN8) | \
  1345. PIN_OSPEED_VERYLOW(GPIOH_PIN9) | \
  1346. PIN_OSPEED_VERYLOW(GPIOH_PIN10) | \
  1347. PIN_OSPEED_VERYLOW(GPIOH_PIN11) | \
  1348. PIN_OSPEED_VERYLOW(GPIOH_PIN12) | \
  1349. PIN_OSPEED_VERYLOW(GPIOH_PIN13) | \
  1350. PIN_OSPEED_VERYLOW(GPIOH_PIN14) | \
  1351. PIN_OSPEED_VERYLOW(GPIOH_PIN15))
  1352. #define VAL_GPIOH_PUPDR (PIN_PUPDR_FLOATING(GPIOH_OSC_IN) | \
  1353. PIN_PUPDR_FLOATING(GPIOH_OSC_OUT) | \
  1354. PIN_PUPDR_PULLUP(GPIOH_PIN2) | \
  1355. PIN_PUPDR_PULLUP(GPIOH_PIN3) | \
  1356. PIN_PUPDR_PULLUP(GPIOH_PIN4) | \
  1357. PIN_PUPDR_PULLUP(GPIOH_PIN5) | \
  1358. PIN_PUPDR_PULLUP(GPIOH_PIN6) | \
  1359. PIN_PUPDR_PULLUP(GPIOH_PIN7) | \
  1360. PIN_PUPDR_PULLUP(GPIOH_PIN8) | \
  1361. PIN_PUPDR_PULLUP(GPIOH_PIN9) | \
  1362. PIN_PUPDR_PULLUP(GPIOH_PIN10) | \
  1363. PIN_PUPDR_PULLUP(GPIOH_PIN11) | \
  1364. PIN_PUPDR_PULLUP(GPIOH_PIN12) | \
  1365. PIN_PUPDR_PULLUP(GPIOH_PIN13) | \
  1366. PIN_PUPDR_PULLUP(GPIOH_PIN14) | \
  1367. PIN_PUPDR_PULLUP(GPIOH_PIN15))
  1368. #define VAL_GPIOH_ODR (PIN_ODR_HIGH(GPIOH_OSC_IN) | \
  1369. PIN_ODR_HIGH(GPIOH_OSC_OUT) | \
  1370. PIN_ODR_HIGH(GPIOH_PIN2) | \
  1371. PIN_ODR_HIGH(GPIOH_PIN3) | \
  1372. PIN_ODR_HIGH(GPIOH_PIN4) | \
  1373. PIN_ODR_HIGH(GPIOH_PIN5) | \
  1374. PIN_ODR_HIGH(GPIOH_PIN6) | \
  1375. PIN_ODR_HIGH(GPIOH_PIN7) | \
  1376. PIN_ODR_HIGH(GPIOH_PIN8) | \
  1377. PIN_ODR_HIGH(GPIOH_PIN9) | \
  1378. PIN_ODR_HIGH(GPIOH_PIN10) | \
  1379. PIN_ODR_HIGH(GPIOH_PIN11) | \
  1380. PIN_ODR_HIGH(GPIOH_PIN12) | \
  1381. PIN_ODR_HIGH(GPIOH_PIN13) | \
  1382. PIN_ODR_HIGH(GPIOH_PIN14) | \
  1383. PIN_ODR_HIGH(GPIOH_PIN15))
  1384. #define VAL_GPIOH_AFRL (PIN_AFIO_AF(GPIOH_OSC_IN, 0U) | \
  1385. PIN_AFIO_AF(GPIOH_OSC_OUT, 0U) | \
  1386. PIN_AFIO_AF(GPIOH_PIN2, 0U) | \
  1387. PIN_AFIO_AF(GPIOH_PIN3, 0U) | \
  1388. PIN_AFIO_AF(GPIOH_PIN4, 0U) | \
  1389. PIN_AFIO_AF(GPIOH_PIN5, 0U) | \
  1390. PIN_AFIO_AF(GPIOH_PIN6, 0U) | \
  1391. PIN_AFIO_AF(GPIOH_PIN7, 0U))
  1392. #define VAL_GPIOH_AFRH (PIN_AFIO_AF(GPIOH_PIN8, 0U) | \
  1393. PIN_AFIO_AF(GPIOH_PIN9, 0U) | \
  1394. PIN_AFIO_AF(GPIOH_PIN10, 0U) | \
  1395. PIN_AFIO_AF(GPIOH_PIN11, 0U) | \
  1396. PIN_AFIO_AF(GPIOH_PIN12, 0U) | \
  1397. PIN_AFIO_AF(GPIOH_PIN13, 0U) | \
  1398. PIN_AFIO_AF(GPIOH_PIN14, 0U) | \
  1399. PIN_AFIO_AF(GPIOH_PIN15, 0U))
  1400. /*
  1401. * GPIOI setup:
  1402. *
  1403. * PI0 - PIN0 (input pullup).
  1404. * PI1 - PIN1 (input pullup).
  1405. * PI2 - PIN2 (input pullup).
  1406. * PI3 - PIN3 (input pullup).
  1407. * PI4 - PIN4 (input pullup).
  1408. * PI5 - PIN5 (input pullup).
  1409. * PI6 - PIN6 (input pullup).
  1410. * PI7 - PIN7 (input pullup).
  1411. * PI8 - PIN8 (input pullup).
  1412. * PI9 - PIN9 (input pullup).
  1413. * PI10 - PIN10 (input pullup).
  1414. * PI11 - PIN11 (input pullup).
  1415. * PI12 - PIN12 (input pullup).
  1416. * PI13 - PIN13 (input pullup).
  1417. * PI14 - PIN14 (input pullup).
  1418. * PI15 - PIN15 (input pullup).
  1419. */
  1420. #define VAL_GPIOI_MODER (PIN_MODE_INPUT(GPIOI_PIN0) | \
  1421. PIN_MODE_INPUT(GPIOI_PIN1) | \
  1422. PIN_MODE_INPUT(GPIOI_PIN2) | \
  1423. PIN_MODE_INPUT(GPIOI_PIN3) | \
  1424. PIN_MODE_INPUT(GPIOI_PIN4) | \
  1425. PIN_MODE_INPUT(GPIOI_PIN5) | \
  1426. PIN_MODE_INPUT(GPIOI_PIN6) | \
  1427. PIN_MODE_INPUT(GPIOI_PIN7) | \
  1428. PIN_MODE_INPUT(GPIOI_PIN8) | \
  1429. PIN_MODE_INPUT(GPIOI_PIN9) | \
  1430. PIN_MODE_INPUT(GPIOI_PIN10) | \
  1431. PIN_MODE_INPUT(GPIOI_PIN11) | \
  1432. PIN_MODE_INPUT(GPIOI_PIN12) | \
  1433. PIN_MODE_INPUT(GPIOI_PIN13) | \
  1434. PIN_MODE_INPUT(GPIOI_PIN14) | \
  1435. PIN_MODE_INPUT(GPIOI_PIN15))
  1436. #define VAL_GPIOI_OTYPER (PIN_OTYPE_PUSHPULL(GPIOI_PIN0) | \
  1437. PIN_OTYPE_PUSHPULL(GPIOI_PIN1) | \
  1438. PIN_OTYPE_PUSHPULL(GPIOI_PIN2) | \
  1439. PIN_OTYPE_PUSHPULL(GPIOI_PIN3) | \
  1440. PIN_OTYPE_PUSHPULL(GPIOI_PIN4) | \
  1441. PIN_OTYPE_PUSHPULL(GPIOI_PIN5) | \
  1442. PIN_OTYPE_PUSHPULL(GPIOI_PIN6) | \
  1443. PIN_OTYPE_PUSHPULL(GPIOI_PIN7) | \
  1444. PIN_OTYPE_PUSHPULL(GPIOI_PIN8) | \
  1445. PIN_OTYPE_PUSHPULL(GPIOI_PIN9) | \
  1446. PIN_OTYPE_PUSHPULL(GPIOI_PIN10) | \
  1447. PIN_OTYPE_PUSHPULL(GPIOI_PIN11) | \
  1448. PIN_OTYPE_PUSHPULL(GPIOI_PIN12) | \
  1449. PIN_OTYPE_PUSHPULL(GPIOI_PIN13) | \
  1450. PIN_OTYPE_PUSHPULL(GPIOI_PIN14) | \
  1451. PIN_OTYPE_PUSHPULL(GPIOI_PIN15))
  1452. #define VAL_GPIOI_OSPEEDR (PIN_OSPEED_VERYLOW(GPIOI_PIN0) | \
  1453. PIN_OSPEED_VERYLOW(GPIOI_PIN1) | \
  1454. PIN_OSPEED_VERYLOW(GPIOI_PIN2) | \
  1455. PIN_OSPEED_VERYLOW(GPIOI_PIN3) | \
  1456. PIN_OSPEED_VERYLOW(GPIOI_PIN4) | \
  1457. PIN_OSPEED_VERYLOW(GPIOI_PIN5) | \
  1458. PIN_OSPEED_VERYLOW(GPIOI_PIN6) | \
  1459. PIN_OSPEED_VERYLOW(GPIOI_PIN7) | \
  1460. PIN_OSPEED_VERYLOW(GPIOI_PIN8) | \
  1461. PIN_OSPEED_VERYLOW(GPIOI_PIN9) | \
  1462. PIN_OSPEED_VERYLOW(GPIOI_PIN10) | \
  1463. PIN_OSPEED_VERYLOW(GPIOI_PIN11) | \
  1464. PIN_OSPEED_VERYLOW(GPIOI_PIN12) | \
  1465. PIN_OSPEED_VERYLOW(GPIOI_PIN13) | \
  1466. PIN_OSPEED_VERYLOW(GPIOI_PIN14) | \
  1467. PIN_OSPEED_VERYLOW(GPIOI_PIN15))
  1468. #define VAL_GPIOI_PUPDR (PIN_PUPDR_PULLUP(GPIOI_PIN0) | \
  1469. PIN_PUPDR_PULLUP(GPIOI_PIN1) | \
  1470. PIN_PUPDR_PULLUP(GPIOI_PIN2) | \
  1471. PIN_PUPDR_PULLUP(GPIOI_PIN3) | \
  1472. PIN_PUPDR_PULLUP(GPIOI_PIN4) | \
  1473. PIN_PUPDR_PULLUP(GPIOI_PIN5) | \
  1474. PIN_PUPDR_PULLUP(GPIOI_PIN6) | \
  1475. PIN_PUPDR_PULLUP(GPIOI_PIN7) | \
  1476. PIN_PUPDR_PULLUP(GPIOI_PIN8) | \
  1477. PIN_PUPDR_PULLUP(GPIOI_PIN9) | \
  1478. PIN_PUPDR_PULLUP(GPIOI_PIN10) | \
  1479. PIN_PUPDR_PULLUP(GPIOI_PIN11) | \
  1480. PIN_PUPDR_PULLUP(GPIOI_PIN12) | \
  1481. PIN_PUPDR_PULLUP(GPIOI_PIN13) | \
  1482. PIN_PUPDR_PULLUP(GPIOI_PIN14) | \
  1483. PIN_PUPDR_PULLUP(GPIOI_PIN15))
  1484. #define VAL_GPIOI_ODR (PIN_ODR_HIGH(GPIOI_PIN0) | \
  1485. PIN_ODR_HIGH(GPIOI_PIN1) | \
  1486. PIN_ODR_HIGH(GPIOI_PIN2) | \
  1487. PIN_ODR_HIGH(GPIOI_PIN3) | \
  1488. PIN_ODR_HIGH(GPIOI_PIN4) | \
  1489. PIN_ODR_HIGH(GPIOI_PIN5) | \
  1490. PIN_ODR_HIGH(GPIOI_PIN6) | \
  1491. PIN_ODR_HIGH(GPIOI_PIN7) | \
  1492. PIN_ODR_HIGH(GPIOI_PIN8) | \
  1493. PIN_ODR_HIGH(GPIOI_PIN9) | \
  1494. PIN_ODR_HIGH(GPIOI_PIN10) | \
  1495. PIN_ODR_HIGH(GPIOI_PIN11) | \
  1496. PIN_ODR_HIGH(GPIOI_PIN12) | \
  1497. PIN_ODR_HIGH(GPIOI_PIN13) | \
  1498. PIN_ODR_HIGH(GPIOI_PIN14) | \
  1499. PIN_ODR_HIGH(GPIOI_PIN15))
  1500. #define VAL_GPIOI_AFRL (PIN_AFIO_AF(GPIOI_PIN0, 0U) | \
  1501. PIN_AFIO_AF(GPIOI_PIN1, 0U) | \
  1502. PIN_AFIO_AF(GPIOI_PIN2, 0U) | \
  1503. PIN_AFIO_AF(GPIOI_PIN3, 0U) | \
  1504. PIN_AFIO_AF(GPIOI_PIN4, 0U) | \
  1505. PIN_AFIO_AF(GPIOI_PIN5, 0U) | \
  1506. PIN_AFIO_AF(GPIOI_PIN6, 0U) | \
  1507. PIN_AFIO_AF(GPIOI_PIN7, 0U))
  1508. #define VAL_GPIOI_AFRH (PIN_AFIO_AF(GPIOI_PIN8, 0U) | \
  1509. PIN_AFIO_AF(GPIOI_PIN9, 0U) | \
  1510. PIN_AFIO_AF(GPIOI_PIN10, 0U) | \
  1511. PIN_AFIO_AF(GPIOI_PIN11, 0U) | \
  1512. PIN_AFIO_AF(GPIOI_PIN12, 0U) | \
  1513. PIN_AFIO_AF(GPIOI_PIN13, 0U) | \
  1514. PIN_AFIO_AF(GPIOI_PIN14, 0U) | \
  1515. PIN_AFIO_AF(GPIOI_PIN15, 0U))
  1516. /*
  1517. * GPIOJ setup:
  1518. *
  1519. * PJ0 - PIN0 (input pullup).
  1520. * PJ1 - PIN1 (input pullup).
  1521. * PJ2 - PIN2 (input pullup).
  1522. * PJ3 - PIN3 (input pullup).
  1523. * PJ4 - PIN4 (input pullup).
  1524. * PJ5 - PIN5 (input pullup).
  1525. * PJ6 - PIN6 (input pullup).
  1526. * PJ7 - PIN7 (input pullup).
  1527. * PJ8 - PIN8 (input pullup).
  1528. * PJ9 - PIN9 (input pullup).
  1529. * PJ10 - PIN10 (input pullup).
  1530. * PJ11 - PIN11 (input pullup).
  1531. * PJ12 - PIN12 (input pullup).
  1532. * PJ13 - PIN13 (input pullup).
  1533. * PJ14 - PIN14 (input pullup).
  1534. * PJ15 - PIN15 (input pullup).
  1535. */
  1536. #define VAL_GPIOJ_MODER (PIN_MODE_INPUT(GPIOJ_PIN0) | \
  1537. PIN_MODE_INPUT(GPIOJ_PIN1) | \
  1538. PIN_MODE_INPUT(GPIOJ_PIN2) | \
  1539. PIN_MODE_INPUT(GPIOJ_PIN3) | \
  1540. PIN_MODE_INPUT(GPIOJ_PIN4) | \
  1541. PIN_MODE_INPUT(GPIOJ_PIN5) | \
  1542. PIN_MODE_INPUT(GPIOJ_PIN6) | \
  1543. PIN_MODE_INPUT(GPIOJ_PIN7) | \
  1544. PIN_MODE_INPUT(GPIOJ_PIN8) | \
  1545. PIN_MODE_INPUT(GPIOJ_PIN9) | \
  1546. PIN_MODE_INPUT(GPIOJ_PIN10) | \
  1547. PIN_MODE_INPUT(GPIOJ_PIN11) | \
  1548. PIN_MODE_INPUT(GPIOJ_PIN12) | \
  1549. PIN_MODE_INPUT(GPIOJ_PIN13) | \
  1550. PIN_MODE_INPUT(GPIOJ_PIN14) | \
  1551. PIN_MODE_INPUT(GPIOJ_PIN15))
  1552. #define VAL_GPIOJ_OTYPER (PIN_OTYPE_PUSHPULL(GPIOJ_PIN0) | \
  1553. PIN_OTYPE_PUSHPULL(GPIOJ_PIN1) | \
  1554. PIN_OTYPE_PUSHPULL(GPIOJ_PIN2) | \
  1555. PIN_OTYPE_PUSHPULL(GPIOJ_PIN3) | \
  1556. PIN_OTYPE_PUSHPULL(GPIOJ_PIN4) | \
  1557. PIN_OTYPE_PUSHPULL(GPIOJ_PIN5) | \
  1558. PIN_OTYPE_PUSHPULL(GPIOJ_PIN6) | \
  1559. PIN_OTYPE_PUSHPULL(GPIOJ_PIN7) | \
  1560. PIN_OTYPE_PUSHPULL(GPIOJ_PIN8) | \
  1561. PIN_OTYPE_PUSHPULL(GPIOJ_PIN9) | \
  1562. PIN_OTYPE_PUSHPULL(GPIOJ_PIN10) | \
  1563. PIN_OTYPE_PUSHPULL(GPIOJ_PIN11) | \
  1564. PIN_OTYPE_PUSHPULL(GPIOJ_PIN12) | \
  1565. PIN_OTYPE_PUSHPULL(GPIOJ_PIN13) | \
  1566. PIN_OTYPE_PUSHPULL(GPIOJ_PIN14) | \
  1567. PIN_OTYPE_PUSHPULL(GPIOJ_PIN15))
  1568. #define VAL_GPIOJ_OSPEEDR (PIN_OSPEED_VERYLOW(GPIOJ_PIN0) | \
  1569. PIN_OSPEED_VERYLOW(GPIOJ_PIN1) | \
  1570. PIN_OSPEED_VERYLOW(GPIOJ_PIN2) | \
  1571. PIN_OSPEED_VERYLOW(GPIOJ_PIN3) | \
  1572. PIN_OSPEED_VERYLOW(GPIOJ_PIN4) | \
  1573. PIN_OSPEED_VERYLOW(GPIOJ_PIN5) | \
  1574. PIN_OSPEED_VERYLOW(GPIOJ_PIN6) | \
  1575. PIN_OSPEED_VERYLOW(GPIOJ_PIN7) | \
  1576. PIN_OSPEED_VERYLOW(GPIOJ_PIN8) | \
  1577. PIN_OSPEED_VERYLOW(GPIOJ_PIN9) | \
  1578. PIN_OSPEED_VERYLOW(GPIOJ_PIN10) | \
  1579. PIN_OSPEED_VERYLOW(GPIOJ_PIN11) | \
  1580. PIN_OSPEED_VERYLOW(GPIOJ_PIN12) | \
  1581. PIN_OSPEED_VERYLOW(GPIOJ_PIN13) | \
  1582. PIN_OSPEED_VERYLOW(GPIOJ_PIN14) | \
  1583. PIN_OSPEED_VERYLOW(GPIOJ_PIN15))
  1584. #define VAL_GPIOJ_PUPDR (PIN_PUPDR_PULLUP(GPIOJ_PIN0) | \
  1585. PIN_PUPDR_PULLUP(GPIOJ_PIN1) | \
  1586. PIN_PUPDR_PULLUP(GPIOJ_PIN2) | \
  1587. PIN_PUPDR_PULLUP(GPIOJ_PIN3) | \
  1588. PIN_PUPDR_PULLUP(GPIOJ_PIN4) | \
  1589. PIN_PUPDR_PULLUP(GPIOJ_PIN5) | \
  1590. PIN_PUPDR_PULLUP(GPIOJ_PIN6) | \
  1591. PIN_PUPDR_PULLUP(GPIOJ_PIN7) | \
  1592. PIN_PUPDR_PULLUP(GPIOJ_PIN8) | \
  1593. PIN_PUPDR_PULLUP(GPIOJ_PIN9) | \
  1594. PIN_PUPDR_PULLUP(GPIOJ_PIN10) | \
  1595. PIN_PUPDR_PULLUP(GPIOJ_PIN11) | \
  1596. PIN_PUPDR_PULLUP(GPIOJ_PIN12) | \
  1597. PIN_PUPDR_PULLUP(GPIOJ_PIN13) | \
  1598. PIN_PUPDR_PULLUP(GPIOJ_PIN14) | \
  1599. PIN_PUPDR_PULLUP(GPIOJ_PIN15))
  1600. #define VAL_GPIOJ_ODR (PIN_ODR_HIGH(GPIOJ_PIN0) | \
  1601. PIN_ODR_HIGH(GPIOJ_PIN1) | \
  1602. PIN_ODR_HIGH(GPIOJ_PIN2) | \
  1603. PIN_ODR_HIGH(GPIOJ_PIN3) | \
  1604. PIN_ODR_HIGH(GPIOJ_PIN4) | \
  1605. PIN_ODR_HIGH(GPIOJ_PIN5) | \
  1606. PIN_ODR_HIGH(GPIOJ_PIN6) | \
  1607. PIN_ODR_HIGH(GPIOJ_PIN7) | \
  1608. PIN_ODR_HIGH(GPIOJ_PIN8) | \
  1609. PIN_ODR_HIGH(GPIOJ_PIN9) | \
  1610. PIN_ODR_HIGH(GPIOJ_PIN10) | \
  1611. PIN_ODR_HIGH(GPIOJ_PIN11) | \
  1612. PIN_ODR_HIGH(GPIOJ_PIN12) | \
  1613. PIN_ODR_HIGH(GPIOJ_PIN13) | \
  1614. PIN_ODR_HIGH(GPIOJ_PIN14) | \
  1615. PIN_ODR_HIGH(GPIOJ_PIN15))
  1616. #define VAL_GPIOJ_AFRL (PIN_AFIO_AF(GPIOJ_PIN0, 0U) | \
  1617. PIN_AFIO_AF(GPIOJ_PIN1, 0U) | \
  1618. PIN_AFIO_AF(GPIOJ_PIN2, 0U) | \
  1619. PIN_AFIO_AF(GPIOJ_PIN3, 0U) | \
  1620. PIN_AFIO_AF(GPIOJ_PIN4, 0U) | \
  1621. PIN_AFIO_AF(GPIOJ_PIN5, 0U) | \
  1622. PIN_AFIO_AF(GPIOJ_PIN6, 0U) | \
  1623. PIN_AFIO_AF(GPIOJ_PIN7, 0U))
  1624. #define VAL_GPIOJ_AFRH (PIN_AFIO_AF(GPIOJ_PIN8, 0U) | \
  1625. PIN_AFIO_AF(GPIOJ_PIN9, 0U) | \
  1626. PIN_AFIO_AF(GPIOJ_PIN10, 0U) | \
  1627. PIN_AFIO_AF(GPIOJ_PIN11, 0U) | \
  1628. PIN_AFIO_AF(GPIOJ_PIN12, 0U) | \
  1629. PIN_AFIO_AF(GPIOJ_PIN13, 0U) | \
  1630. PIN_AFIO_AF(GPIOJ_PIN14, 0U) | \
  1631. PIN_AFIO_AF(GPIOJ_PIN15, 0U))
  1632. /*
  1633. * GPIOK setup:
  1634. *
  1635. * PK0 - PIN0 (input pullup).
  1636. * PK1 - PIN1 (input pullup).
  1637. * PK2 - PIN2 (input pullup).
  1638. * PK3 - PIN3 (input pullup).
  1639. * PK4 - PIN4 (input pullup).
  1640. * PK5 - PIN5 (input pullup).
  1641. * PK6 - PIN6 (input pullup).
  1642. * PK7 - PIN7 (input pullup).
  1643. * PK8 - PIN8 (input pullup).
  1644. * PK9 - PIN9 (input pullup).
  1645. * PK10 - PIN10 (input pullup).
  1646. * PK11 - PIN11 (input pullup).
  1647. * PK12 - PIN12 (input pullup).
  1648. * PK13 - PIN13 (input pullup).
  1649. * PK14 - PIN14 (input pullup).
  1650. * PK15 - PIN15 (input pullup).
  1651. */
  1652. #define VAL_GPIOK_MODER (PIN_MODE_INPUT(GPIOK_PIN0) | \
  1653. PIN_MODE_INPUT(GPIOK_PIN1) | \
  1654. PIN_MODE_INPUT(GPIOK_PIN2) | \
  1655. PIN_MODE_INPUT(GPIOK_PIN3) | \
  1656. PIN_MODE_INPUT(GPIOK_PIN4) | \
  1657. PIN_MODE_INPUT(GPIOK_PIN5) | \
  1658. PIN_MODE_INPUT(GPIOK_PIN6) | \
  1659. PIN_MODE_INPUT(GPIOK_PIN7) | \
  1660. PIN_MODE_INPUT(GPIOK_PIN8) | \
  1661. PIN_MODE_INPUT(GPIOK_PIN9) | \
  1662. PIN_MODE_INPUT(GPIOK_PIN10) | \
  1663. PIN_MODE_INPUT(GPIOK_PIN11) | \
  1664. PIN_MODE_INPUT(GPIOK_PIN12) | \
  1665. PIN_MODE_INPUT(GPIOK_PIN13) | \
  1666. PIN_MODE_INPUT(GPIOK_PIN14) | \
  1667. PIN_MODE_INPUT(GPIOK_PIN15))
  1668. #define VAL_GPIOK_OTYPER (PIN_OTYPE_PUSHPULL(GPIOK_PIN0) | \
  1669. PIN_OTYPE_PUSHPULL(GPIOK_PIN1) | \
  1670. PIN_OTYPE_PUSHPULL(GPIOK_PIN2) | \
  1671. PIN_OTYPE_PUSHPULL(GPIOK_PIN3) | \
  1672. PIN_OTYPE_PUSHPULL(GPIOK_PIN4) | \
  1673. PIN_OTYPE_PUSHPULL(GPIOK_PIN5) | \
  1674. PIN_OTYPE_PUSHPULL(GPIOK_PIN6) | \
  1675. PIN_OTYPE_PUSHPULL(GPIOK_PIN7) | \
  1676. PIN_OTYPE_PUSHPULL(GPIOK_PIN8) | \
  1677. PIN_OTYPE_PUSHPULL(GPIOK_PIN9) | \
  1678. PIN_OTYPE_PUSHPULL(GPIOK_PIN10) | \
  1679. PIN_OTYPE_PUSHPULL(GPIOK_PIN11) | \
  1680. PIN_OTYPE_PUSHPULL(GPIOK_PIN12) | \
  1681. PIN_OTYPE_PUSHPULL(GPIOK_PIN13) | \
  1682. PIN_OTYPE_PUSHPULL(GPIOK_PIN14) | \
  1683. PIN_OTYPE_PUSHPULL(GPIOK_PIN15))
  1684. #define VAL_GPIOK_OSPEEDR (PIN_OSPEED_VERYLOW(GPIOK_PIN0) | \
  1685. PIN_OSPEED_VERYLOW(GPIOK_PIN1) | \
  1686. PIN_OSPEED_VERYLOW(GPIOK_PIN2) | \
  1687. PIN_OSPEED_VERYLOW(GPIOK_PIN3) | \
  1688. PIN_OSPEED_VERYLOW(GPIOK_PIN4) | \
  1689. PIN_OSPEED_VERYLOW(GPIOK_PIN5) | \
  1690. PIN_OSPEED_VERYLOW(GPIOK_PIN6) | \
  1691. PIN_OSPEED_VERYLOW(GPIOK_PIN7) | \
  1692. PIN_OSPEED_VERYLOW(GPIOK_PIN8) | \
  1693. PIN_OSPEED_VERYLOW(GPIOK_PIN9) | \
  1694. PIN_OSPEED_VERYLOW(GPIOK_PIN10) | \
  1695. PIN_OSPEED_VERYLOW(GPIOK_PIN11) | \
  1696. PIN_OSPEED_VERYLOW(GPIOK_PIN12) | \
  1697. PIN_OSPEED_VERYLOW(GPIOK_PIN13) | \
  1698. PIN_OSPEED_VERYLOW(GPIOK_PIN14) | \
  1699. PIN_OSPEED_VERYLOW(GPIOK_PIN15))
  1700. #define VAL_GPIOK_PUPDR (PIN_PUPDR_PULLUP(GPIOK_PIN0) | \
  1701. PIN_PUPDR_PULLUP(GPIOK_PIN1) | \
  1702. PIN_PUPDR_PULLUP(GPIOK_PIN2) | \
  1703. PIN_PUPDR_PULLUP(GPIOK_PIN3) | \
  1704. PIN_PUPDR_PULLUP(GPIOK_PIN4) | \
  1705. PIN_PUPDR_PULLUP(GPIOK_PIN5) | \
  1706. PIN_PUPDR_PULLUP(GPIOK_PIN6) | \
  1707. PIN_PUPDR_PULLUP(GPIOK_PIN7) | \
  1708. PIN_PUPDR_PULLUP(GPIOK_PIN8) | \
  1709. PIN_PUPDR_PULLUP(GPIOK_PIN9) | \
  1710. PIN_PUPDR_PULLUP(GPIOK_PIN10) | \
  1711. PIN_PUPDR_PULLUP(GPIOK_PIN11) | \
  1712. PIN_PUPDR_PULLUP(GPIOK_PIN12) | \
  1713. PIN_PUPDR_PULLUP(GPIOK_PIN13) | \
  1714. PIN_PUPDR_PULLUP(GPIOK_PIN14) | \
  1715. PIN_PUPDR_PULLUP(GPIOK_PIN15))
  1716. #define VAL_GPIOK_ODR (PIN_ODR_HIGH(GPIOK_PIN0) | \
  1717. PIN_ODR_HIGH(GPIOK_PIN1) | \
  1718. PIN_ODR_HIGH(GPIOK_PIN2) | \
  1719. PIN_ODR_HIGH(GPIOK_PIN3) | \
  1720. PIN_ODR_HIGH(GPIOK_PIN4) | \
  1721. PIN_ODR_HIGH(GPIOK_PIN5) | \
  1722. PIN_ODR_HIGH(GPIOK_PIN6) | \
  1723. PIN_ODR_HIGH(GPIOK_PIN7) | \
  1724. PIN_ODR_HIGH(GPIOK_PIN8) | \
  1725. PIN_ODR_HIGH(GPIOK_PIN9) | \
  1726. PIN_ODR_HIGH(GPIOK_PIN10) | \
  1727. PIN_ODR_HIGH(GPIOK_PIN11) | \
  1728. PIN_ODR_HIGH(GPIOK_PIN12) | \
  1729. PIN_ODR_HIGH(GPIOK_PIN13) | \
  1730. PIN_ODR_HIGH(GPIOK_PIN14) | \
  1731. PIN_ODR_HIGH(GPIOK_PIN15))
  1732. #define VAL_GPIOK_AFRL (PIN_AFIO_AF(GPIOK_PIN0, 0U) | \
  1733. PIN_AFIO_AF(GPIOK_PIN1, 0U) | \
  1734. PIN_AFIO_AF(GPIOK_PIN2, 0U) | \
  1735. PIN_AFIO_AF(GPIOK_PIN3, 0U) | \
  1736. PIN_AFIO_AF(GPIOK_PIN4, 0U) | \
  1737. PIN_AFIO_AF(GPIOK_PIN5, 0U) | \
  1738. PIN_AFIO_AF(GPIOK_PIN6, 0U) | \
  1739. PIN_AFIO_AF(GPIOK_PIN7, 0U))
  1740. #define VAL_GPIOK_AFRH (PIN_AFIO_AF(GPIOK_PIN8, 0U) | \
  1741. PIN_AFIO_AF(GPIOK_PIN9, 0U) | \
  1742. PIN_AFIO_AF(GPIOK_PIN10, 0U) | \
  1743. PIN_AFIO_AF(GPIOK_PIN11, 0U) | \
  1744. PIN_AFIO_AF(GPIOK_PIN12, 0U) | \
  1745. PIN_AFIO_AF(GPIOK_PIN13, 0U) | \
  1746. PIN_AFIO_AF(GPIOK_PIN14, 0U) | \
  1747. PIN_AFIO_AF(GPIOK_PIN15, 0U))
  1748. /*===========================================================================*/
  1749. /* External declarations. */
  1750. /*===========================================================================*/
  1751. #if !defined(_FROM_ASM_)
  1752. #ifdef __cplusplus
  1753. extern "C" {
  1754. #endif
  1755. void boardInit(void);
  1756. #ifdef __cplusplus
  1757. }
  1758. #endif
  1759. #endif /* _FROM_ASM_ */
  1760. #endif /* BOARD_H */