board.h 113 KB

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