variant_MARLIN_STM32H743VI.h 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. /*
  2. *******************************************************************************
  3. * Copyright (c) 2020-2021, STMicroelectronics
  4. * All rights reserved.
  5. *
  6. * This software component is licensed by ST under BSD 3-Clause license,
  7. * the "License"; You may not use this file except in compliance with the
  8. * License. You may obtain a copy of the License at:
  9. * opensource.org/licenses/BSD-3-Clause
  10. *
  11. *******************************************************************************
  12. */
  13. #pragma once
  14. /*----------------------------------------------------------------------------
  15. * STM32 pins number
  16. *----------------------------------------------------------------------------*/
  17. #define PA0 PIN_A0
  18. #define PA1 PIN_A1
  19. #define PA2 PIN_A2
  20. #define PA3 PIN_A3
  21. #define PA4 PIN_A4
  22. #define PA5 PIN_A5
  23. #define PA6 PIN_A6
  24. #define PA7 PIN_A7
  25. #define PA8 8
  26. #define PA9 9
  27. #define PA10 10
  28. #define PA11 11
  29. #define PA12 12
  30. #define PA13 13
  31. #define PA14 14
  32. #define PA15 15
  33. #define PB0 PIN_A8
  34. #define PB1 PIN_A9
  35. #define PB2 18
  36. #define PB3 19
  37. #define PB4 20
  38. #define PB5 21
  39. #define PB6 22
  40. #define PB7 23
  41. #define PB8 24
  42. #define PB9 25
  43. #define PB10 26
  44. #define PB11 27
  45. #define PB12 28
  46. #define PB13 29
  47. #define PB14 30
  48. #define PB15 31
  49. #define PC0 PIN_A10
  50. #define PC1 PIN_A11
  51. #define PC4 PIN_A12
  52. #define PC5 PIN_A13
  53. #define PC6 36
  54. #define PC7 37
  55. #define PC8 38
  56. #define PC9 39
  57. #define PC10 40
  58. #define PC11 41
  59. #define PC12 42
  60. #define PC13 43
  61. #define PC14 44
  62. #define PC15 45
  63. #define PD0 46
  64. #define PD1 47
  65. #define PD2 48
  66. #define PD3 49
  67. #define PD4 50
  68. #define PD5 51
  69. #define PD6 52
  70. #define PD7 53
  71. #define PD8 54
  72. #define PD9 55
  73. #define PD10 56
  74. #define PD11 57
  75. #define PD12 58
  76. #define PD13 59
  77. #define PD14 60
  78. #define PD15 61
  79. #define PE0 62
  80. #define PE1 63
  81. #define PE2 64
  82. #define PE3 65
  83. #define PE4 66
  84. #define PE5 67
  85. #define PE6 68
  86. #define PE7 69
  87. #define PE8 70
  88. #define PE9 71
  89. #define PE10 72
  90. #define PE11 73
  91. #define PE12 74
  92. #define PE13 75
  93. #define PE14 76
  94. #define PE15 77
  95. #define PH0 78
  96. #define PH1 79
  97. #define PC2_C PIN_A14
  98. #define PC3_C PIN_A15
  99. #define PC2 PC2_C
  100. #define PC3 PC3_C
  101. // Alternate pins number
  102. #define PA0_ALT1 (PA0 | ALT1)
  103. #define PA1_ALT1 (PA1 | ALT1)
  104. #define PA1_ALT2 (PA1 | ALT2)
  105. #define PA2_ALT1 (PA2 | ALT1)
  106. #define PA2_ALT2 (PA2 | ALT2)
  107. #define PA3_ALT1 (PA3 | ALT1)
  108. #define PA3_ALT2 (PA3 | ALT2)
  109. #define PA4_ALT1 (PA4 | ALT1)
  110. #define PA4_ALT2 (PA4 | ALT2)
  111. #define PA5_ALT1 (PA5 | ALT1)
  112. #define PA6_ALT1 (PA6 | ALT1)
  113. #define PA7_ALT1 (PA7 | ALT1)
  114. #define PA7_ALT2 (PA7 | ALT2)
  115. #define PA7_ALT3 (PA7 | ALT3)
  116. #define PA9_ALT1 (PA9 | ALT1)
  117. #define PA10_ALT1 (PA10 | ALT1)
  118. #define PA11_ALT1 (PA11 | ALT1)
  119. #define PA12_ALT1 (PA12 | ALT1)
  120. #define PA15_ALT1 (PA15 | ALT1)
  121. #define PA15_ALT2 (PA15 | ALT2)
  122. #define PB0_ALT1 (PB0 | ALT1)
  123. #define PB0_ALT2 (PB0 | ALT2)
  124. #define PB1_ALT1 (PB1 | ALT1)
  125. #define PB1_ALT2 (PB1 | ALT2)
  126. #define PB3_ALT1 (PB3 | ALT1)
  127. #define PB3_ALT2 (PB3 | ALT2)
  128. #define PB4_ALT1 (PB4 | ALT1)
  129. #define PB4_ALT2 (PB4 | ALT2)
  130. #define PB5_ALT1 (PB5 | ALT1)
  131. #define PB5_ALT2 (PB5 | ALT2)
  132. #define PB6_ALT1 (PB6 | ALT1)
  133. #define PB6_ALT2 (PB6 | ALT2)
  134. #define PB7_ALT1 (PB7 | ALT1)
  135. #define PB8_ALT1 (PB8 | ALT1)
  136. #define PB8_ALT2 (PB8 | ALT2)
  137. #define PB9_ALT1 (PB9 | ALT1)
  138. #define PB9_ALT2 (PB9 | ALT2)
  139. #define PB14_ALT1 (PB14 | ALT1)
  140. #define PB14_ALT2 (PB14 | ALT2)
  141. #define PB15_ALT1 (PB15 | ALT1)
  142. #define PB15_ALT2 (PB15 | ALT2)
  143. #define PC0_ALT1 (PC0 | ALT1)
  144. #define PC0_ALT2 (PC0 | ALT2)
  145. #define PC1_ALT1 (PC1 | ALT1)
  146. #define PC1_ALT2 (PC1 | ALT2)
  147. #define PC4_ALT1 (PC4 | ALT1)
  148. #define PC5_ALT1 (PC5 | ALT1)
  149. #define PC6_ALT1 (PC6 | ALT1)
  150. #define PC6_ALT2 (PC6 | ALT2)
  151. #define PC7_ALT1 (PC7 | ALT1)
  152. #define PC7_ALT2 (PC7 | ALT2)
  153. #define PC8_ALT1 (PC8 | ALT1)
  154. #define PC9_ALT1 (PC9 | ALT1)
  155. #define PC10_ALT1 (PC10 | ALT1)
  156. #define PC11_ALT1 (PC11 | ALT1)
  157. #define NUM_DIGITAL_PINS 82
  158. #define NUM_DUALPAD_PINS 2
  159. #define NUM_ANALOG_INPUTS 16
  160. #define NUM_ANALOG_FIRST PA0
  161. // On-board LED pin number
  162. #ifndef LED_BUILTIN
  163. #define LED_BUILTIN PNUM_NOT_DEFINED
  164. #endif
  165. // On-board user button
  166. #ifndef USER_BTN
  167. #define USER_BTN PNUM_NOT_DEFINED
  168. #endif
  169. // SPI definitions
  170. #ifndef PIN_SPI_SS
  171. #define PIN_SPI_SS PA4
  172. #endif
  173. #ifndef PIN_SPI_SS1
  174. #define PIN_SPI_SS1 PA15
  175. #endif
  176. #ifndef PIN_SPI_SS2
  177. #define PIN_SPI_SS2 PNUM_NOT_DEFINED
  178. #endif
  179. #ifndef PIN_SPI_SS3
  180. #define PIN_SPI_SS3 PNUM_NOT_DEFINED
  181. #endif
  182. #ifndef PIN_SPI_MOSI
  183. #define PIN_SPI_MOSI PA7
  184. #endif
  185. #ifndef PIN_SPI_MISO
  186. #define PIN_SPI_MISO PA6
  187. #endif
  188. #ifndef PIN_SPI_SCK
  189. #define PIN_SPI_SCK PA5
  190. #endif
  191. // I2C definitions
  192. #ifndef PIN_WIRE_SDA
  193. #define PIN_WIRE_SDA PB7
  194. #endif
  195. #ifndef PIN_WIRE_SCL
  196. #define PIN_WIRE_SCL PB6
  197. #endif
  198. // Timer Definitions
  199. // Use TIM6/TIM7 when possible as servo and tone don't need GPIO output pin
  200. #ifndef TIMER_TONE
  201. #define TIMER_TONE TIM6
  202. #endif
  203. #ifndef TIMER_SERVO
  204. #define TIMER_SERVO TIM7
  205. #endif
  206. // UART Definitions
  207. #ifndef SERIAL_UART_INSTANCE
  208. #define SERIAL_UART_INSTANCE 4
  209. #endif
  210. // Default pin used for generic 'Serial' instance
  211. // Mandatory for Firmata
  212. #ifndef PIN_SERIAL_RX
  213. #define PIN_SERIAL_RX PA1
  214. #endif
  215. #ifndef PIN_SERIAL_TX
  216. #define PIN_SERIAL_TX PA0
  217. #endif
  218. // Extra HAL modules
  219. #ifndef HAL_DAC_MODULE_DISABLED
  220. #define HAL_DAC_MODULE_ENABLED
  221. #endif
  222. #ifndef HAL_ETH_MODULE_DISABLED
  223. #define HAL_ETH_MODULE_ENABLED
  224. #endif
  225. #ifndef HAL_QSPI_MODULE_DISABLED
  226. #define HAL_QSPI_MODULE_ENABLED
  227. #endif
  228. #ifndef HAL_SD_MODULE_DISABLED
  229. #define HAL_SD_MODULE_ENABLED
  230. #endif
  231. /*----------------------------------------------------------------------------
  232. * Arduino objects - C++ only
  233. *----------------------------------------------------------------------------*/
  234. #ifdef __cplusplus
  235. // These serial port names are intended to allow libraries and architecture-neutral
  236. // sketches to automatically default to the correct port name for a particular type
  237. // of use. For example, a GPS module would normally connect to SERIAL_PORT_HARDWARE_OPEN,
  238. // the first hardware serial port whose RX/TX pins are not dedicated to another use.
  239. //
  240. // SERIAL_PORT_MONITOR Port which normally prints to the Arduino Serial Monitor
  241. //
  242. // SERIAL_PORT_USBVIRTUAL Port which is USB virtual serial
  243. //
  244. // SERIAL_PORT_LINUXBRIDGE Port which connects to a Linux system via Bridge library
  245. //
  246. // SERIAL_PORT_HARDWARE Hardware serial port, physical RX & TX pins.
  247. //
  248. // SERIAL_PORT_HARDWARE_OPEN Hardware serial ports which are open for use. Their RX & TX
  249. // pins are NOT connected to anything by default.
  250. #ifndef SERIAL_PORT_MONITOR
  251. #define SERIAL_PORT_MONITOR Serial
  252. #endif
  253. #ifndef SERIAL_PORT_HARDWARE
  254. #define SERIAL_PORT_HARDWARE Serial
  255. #endif
  256. #endif