My Marlin configs for Fabrikator Mini and CTC i3 Pro B
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

pins_PRINTRBOARD_REVF.h 9.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281
  1. /**
  2. * Marlin 3D Printer Firmware
  3. * Copyright (c) 2020 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
  4. *
  5. * Based on Sprinter and grbl.
  6. * Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
  7. *
  8. * This program is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation, either version 3 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  20. *
  21. */
  22. #pragma once
  23. /**
  24. * Rev B 2 JUN 2017
  25. *
  26. * Converted to Arduino pin numbering
  27. */
  28. /**
  29. * There are two Arduino IDE extensions that are compatible with this board
  30. * and with the mainstream Marlin software.
  31. *
  32. * Teensyduino - https://www.pjrc.com/teensy/teensyduino.html
  33. * Installation - https://www.pjrc.com/teensy/td_download.html
  34. *
  35. * Select Teensy++ 2.0 in Arduino IDE from the 'Tools > Board' menu
  36. *
  37. * Note: With Teensyduino extension, the Arduino IDE will report 130048 bytes of program storage space available,
  38. * but there is actually only 122880 bytes due to the larger DFU bootloader shipped by default on all Printrboard RevF.
  39. *
  40. * Printrboard - https://github.com/scwimbush/Printrboard-HID-Arduino-IDE-Support
  41. *
  42. * Installation:
  43. *
  44. * 1. Go to the above URL, click on the "Clone or Download" button and then
  45. * click on "Download ZIP" button.
  46. * 2. Unzip the file, find the "printrboard" directory and then copy it to the
  47. * hardware directory in Arduino. The Arduino hardware directory will probably
  48. * be located in a path similar to this: C:\Program Files (x86)\Arduino\hardware.
  49. * 3. Restart Arduino.
  50. * 4. Select "Printrboard" from the 'Tools > Board' menu.
  51. *
  52. * Teensyduino is the most popular and easiest option.
  53. */
  54. /**
  55. * To burn the bootloader that comes with Printrboard HID extension:
  56. *
  57. * 1. Connect your programmer to the board.
  58. * 2. In the Arduino IDE select "Printrboard" and then select the programmer.
  59. * 3. In the Arduino IDE click on "burn bootloader". Don't worry about the "verify failed at 1F000" error message.
  60. * 4. The programmer is no longer needed. Remove it.
  61. */
  62. #ifndef __AVR_AT90USB1286__
  63. #error "Oops! Select 'Teensy++ 2.0' or 'Printrboard' in 'Tools > Board.'"
  64. #endif
  65. #ifndef USBCON
  66. #error "USBCON should be defined by the platform for this board."
  67. #endif
  68. #define BOARD_INFO_NAME "Printrboard Rev.F"
  69. // Disable JTAG pins so EXP1 pins work correctly
  70. // (Its pins are used for the Extrudrboard and filament sensor, for example).
  71. #define DISABLE_JTAG
  72. /**
  73. * Note that REV F6 of the Printrboard stole the A HOTEND pin and
  74. * reassigned it to a second fan for the extruder heater. It's
  75. * recommended that you swap the A and B outputs on the Extrudrboard
  76. * so EXTRUDERS=2 will still work on F6, using B for E1/HEATER_1/TEMP_1.
  77. * See https://printrbot.zendesk.com/hc/en-us/articles/115003072346
  78. *
  79. * If you have REV F6 you probably also want to set E0_AUTO_FAN_PIN
  80. * to PRINTRBOARD_F6_HEATER_FAN_PIN (44).
  81. *
  82. * Define NO_EXTRUDRBOARD if you don't have an EXTRUDRBOARD and wish to
  83. * reassign different functions to EXP1.
  84. *
  85. * Define NO_EXTRUDRBOARD_OUTPUT_SWAP if you have a REV F5 or lower and
  86. * want to use EXTRUDRBOARD A for E1 and EXTRUDRBOARD B for E2.
  87. */
  88. //#define NO_EXTRUDRBOARD
  89. //#define NO_EXTRUDRBOARD_OUTPUT_SWAP
  90. //
  91. // Limit Switches
  92. //
  93. #define X_STOP_PIN 47 // E3
  94. #define Y_STOP_PIN 24 // B4 PWM2A
  95. #define Z_STOP_PIN 36 // E4
  96. //
  97. // Steppers
  98. //
  99. #define X_STEP_PIN 28 // A0
  100. #define X_DIR_PIN 29 // A1
  101. #define X_ENABLE_PIN 19 // E7
  102. #define Y_STEP_PIN 30 // A2
  103. #define Y_DIR_PIN 31 // A3
  104. #define Y_ENABLE_PIN 18 // E6
  105. #define Z_STEP_PIN 32 // A4
  106. #define Z_DIR_PIN 33 // A5
  107. #define Z_ENABLE_PIN 17 // C7
  108. #define E0_STEP_PIN 34 // A6
  109. #define E0_DIR_PIN 35 // A7
  110. #define E0_ENABLE_PIN 13 // C3
  111. #if DISABLED(NO_EXTRUDRBOARD)
  112. #if DISABLED(NO_EXTRUDRBOARD_OUTPUT_SWAP)
  113. #define E1_STEP_PIN 25 // B5
  114. #define E1_DIR_PIN 37 // E5
  115. #define E1_ENABLE_PIN 42 // F4
  116. #define E2_STEP_PIN 2 // D2
  117. #define E2_DIR_PIN 3 // D3
  118. #define E2_ENABLE_PIN 43 // F5
  119. #else
  120. #define E1_STEP_PIN 2 // D2
  121. #define E1_DIR_PIN 3 // D3
  122. #define E1_ENABLE_PIN 43 // F5
  123. #define E2_STEP_PIN 25 // B5
  124. #define E2_DIR_PIN 37 // E5
  125. #define E2_ENABLE_PIN 42 // F4
  126. #endif
  127. #endif // NO_EXTRUDRBOARD
  128. // Enable control of stepper motor currents with the I2C based MCP4728 DAC used on Printrboard REVF
  129. #define DAC_STEPPER_CURRENT
  130. // Set default drive strength percents if not already defined - X, Y, Z, E axis
  131. #ifndef DAC_MOTOR_CURRENT_DEFAULT
  132. #define DAC_MOTOR_CURRENT_DEFAULT { 70, 70, 50, 70 }
  133. #endif
  134. // Number of channels available for DAC
  135. #define DAC_STEPPER_ORDER { 3, 2, 1, 0 }
  136. #define DAC_STEPPER_SENSE 0.11
  137. #define DAC_STEPPER_ADDRESS 0
  138. #define DAC_STEPPER_MAX 3520
  139. #define DAC_STEPPER_VREF 1 // internal Vref, gain 1x = 2.048V
  140. #define DAC_STEPPER_GAIN 0
  141. #define DAC_OR_ADDRESS 0x00
  142. //
  143. // Temperature Sensors
  144. //
  145. #define TEMP_0_PIN 1 // Analog Input (Extruder)
  146. #define TEMP_BED_PIN 0 // Analog Input (Bed)
  147. #if DISABLED(NO_EXTRUDRBOARD)
  148. #if DISABLED(NO_EXTRUDRBOARD_OUTPUT_SWAP)
  149. #define TEMP_1_PIN 2 // Analog Input (Extrudrboard A THERM)
  150. #define TEMP_2_PIN 3 // Analog Input (Extrudrboard B THERM)
  151. #else
  152. #define TEMP_1_PIN 3 // Analog Input (Extrudrboard B THERM)
  153. #define TEMP_2_PIN 2 // Analog Input (Extrudrboard A THERM)
  154. #endif
  155. #endif
  156. //
  157. // Heaters / Fans
  158. //
  159. #define HEATER_0_PIN 15 // C5 PWM3B - Extruder
  160. #define HEATER_BED_PIN 14 // C4 PWM3C
  161. #if DISABLED(NO_EXTRUDRBOARD)
  162. #if DISABLED(NO_EXTRUDRBOARD_OUTPUT_SWAP)
  163. #define HEATER_1_PIN 44 // F6 - Extrudrboard A HOTEND
  164. #define HEATER_2_PIN 45 // F7 - Extrudrboard B HOTEND
  165. #else
  166. #define HEATER_1_PIN 45 // F7 - Extrudrboard B HOTEND
  167. #define HEATER_2_PIN 44 // F6 - Extrudrboard A HOTEND
  168. #endif
  169. #endif
  170. #ifndef FAN_PIN
  171. #define FAN_PIN 16 // C6 PWM3A
  172. #endif
  173. //
  174. // LCD / Controller
  175. //
  176. //#define USE_INTERNAL_SD
  177. #if HAS_SPI_LCD
  178. #define LCD_PINS_RS 9 // E1 JP11-11
  179. #define LCD_PINS_ENABLE 8 // E0 JP11-10
  180. #define LCD_PINS_D4 7 // D7 JP11-8
  181. #define LCD_PINS_D5 6 // D6 JP11-7
  182. #define LCD_PINS_D6 5 // D5 JP11-6
  183. #define LCD_PINS_D7 4 // D4 JP11-5
  184. #if ANY(VIKI2, miniVIKI)
  185. #define BEEPER_PIN 8 // E0 JP11-10
  186. #define DOGLCD_A0 40 // F2 JP2-2
  187. #define DOGLCD_CS 41 // F3 JP2-4
  188. #define LCD_SCREEN_ROT_180
  189. #define BTN_EN1 2 // D2 TX1 JP2-5
  190. #define BTN_EN2 3 // D3 RX1 JP2-7
  191. #define BTN_ENC 45 // F7 TDI JP2-12
  192. #define SDSS 3 // F5 TMS JP2-8
  193. #define STAT_LED_RED_PIN 12 // C2 JP11-14
  194. #define STAT_LED_BLUE_PIN 10 // C0 JP11-12
  195. #elif ENABLED(MINIPANEL)
  196. #if DISABLED(USE_INTERNAL_SD)
  197. // PIN FASTIO PIN# ATUSB90 PIN# Teensy2.0++ PIN# Printrboard RevF Conn. MKSLCD12864 PIN#
  198. #define SDSS 11 // 36 C1 EXP2-13 EXP2-07
  199. #define SD_DETECT_PIN 9 // 34 E1 EXP2-11 EXP2-04
  200. #endif
  201. // PIN FASTIO PIN# ATUSB90 PIN# Teensy2.0++ PIN# Printrboard RevF Conn. MKSLCD12864 PIN#
  202. #define DOGLCD_A0 4 // 29 D4 EXP2-05 EXP1-04
  203. #define DOGLCD_CS 5 // 30 D5 EXP2-06 EXP1-05
  204. #define BTN_ENC 6 // 31 D6 EXP2-07 EXP1-09
  205. #define BEEPER_PIN 7 // 32 D7 EXP2-08 EXP1-10
  206. #define KILL_PIN 8 // 33 E0 EXP2-10 EXP2-03
  207. #define BTN_EN1 10 // 35 C0 EXP2-12 EXP2-06
  208. #define BTN_EN2 12 // 37 C2 EXP2-14 EXP2-08
  209. //#define LCD_BACKLIGHT_PIN 43 // 56 F5 EXP1-12 Not Implemented
  210. //#define SCK 21 // 11 B1 ICSP-04 EXP2-09
  211. //#define MOSI 22 // 12 B2 ICSP-03 EXP2-05
  212. //#define MISO 23 // 13 B3 ICSP-06 EXP2-05
  213. // increase delays
  214. #define BOARD_ST7920_DELAY_1 DELAY_NS(313)
  215. #define BOARD_ST7920_DELAY_2 DELAY_NS(313)
  216. #define BOARD_ST7920_DELAY_3 DELAY_NS(313)
  217. #else
  218. #define BTN_EN1 10 // C0 JP11-12
  219. #define BTN_EN2 11 // C1 JP11-13
  220. #define BTN_ENC 12 // C2 JP11-14
  221. #endif
  222. #endif
  223. //
  224. // Misc. Functions
  225. //
  226. // PIN FASTIO PIN# ATUSB90 PIN# Teensy2.0++ PIN# Printrboard RevF Conn.
  227. #ifndef SDSS
  228. #define SDSS 20 // 10 B0
  229. #endif
  230. /**
  231. * This is EXP1-2, which is also the TEMP_A_PIN for the Extrudrboard.
  232. * If using w/ Extrudrboard, cut off pin 2 on the Extrudrboard male
  233. * connector to ensure this is disconnected from the A THERM pullups.
  234. * You probably want to set EXTRUDERS=2 and swap the Extrudrboard outputs,
  235. * which will let you use Channel B on the Extrudrboard as E1.
  236. */
  237. #ifndef FILWIDTH_PIN
  238. #define FILWIDTH_PIN 2 // Analog Input
  239. #endif