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.

gcode.cpp 38KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911
  1. /**
  2. * Marlin 3D Printer Firmware
  3. * Copyright (c) 2019 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. /**
  23. * gcode.cpp - Temporary container for all gcode handlers
  24. * Most will migrate to classes, by feature.
  25. */
  26. #include "gcode.h"
  27. GcodeSuite gcode;
  28. #include "parser.h"
  29. #include "queue.h"
  30. #include "../module/motion.h"
  31. #if ENABLED(PRINTCOUNTER)
  32. #include "../module/printcounter.h"
  33. #endif
  34. #if ENABLED(HOST_PROMPT_SUPPORT)
  35. #include "../feature/host_actions.h"
  36. #endif
  37. #if ENABLED(POWER_LOSS_RECOVERY)
  38. #include "../sd/cardreader.h"
  39. #include "../feature/power_loss_recovery.h"
  40. #endif
  41. #include "../Marlin.h" // for idle() and suspend_auto_report
  42. millis_t GcodeSuite::previous_move_ms;
  43. static constexpr bool ar_init[XYZE] = AXIS_RELATIVE_MODES;
  44. uint8_t GcodeSuite::axis_relative = (
  45. (ar_init[X_AXIS] ? _BV(REL_X) : 0)
  46. | (ar_init[Y_AXIS] ? _BV(REL_Y) : 0)
  47. | (ar_init[Z_AXIS] ? _BV(REL_Z) : 0)
  48. | (ar_init[E_AXIS] ? _BV(REL_E) : 0)
  49. );
  50. #if ENABLED(HOST_KEEPALIVE_FEATURE)
  51. GcodeSuite::MarlinBusyState GcodeSuite::busy_state = NOT_BUSY;
  52. uint8_t GcodeSuite::host_keepalive_interval = DEFAULT_KEEPALIVE_INTERVAL;
  53. #endif
  54. #if ENABLED(CNC_WORKSPACE_PLANES)
  55. GcodeSuite::WorkspacePlane GcodeSuite::workspace_plane = PLANE_XY;
  56. #endif
  57. #if ENABLED(CNC_COORDINATE_SYSTEMS)
  58. int8_t GcodeSuite::active_coordinate_system = -1; // machine space
  59. float GcodeSuite::coordinate_system[MAX_COORDINATE_SYSTEMS][XYZ];
  60. #endif
  61. /**
  62. * Get the target extruder from the T parameter or the active_extruder
  63. * Return -1 if the T parameter is out of range
  64. */
  65. int8_t GcodeSuite::get_target_extruder_from_command() {
  66. if (parser.seenval('T')) {
  67. const int8_t e = parser.value_byte();
  68. if (e < EXTRUDERS) return e;
  69. SERIAL_ECHO_START();
  70. SERIAL_CHAR('M'); SERIAL_ECHO(parser.codenum);
  71. SERIAL_ECHOLNPAIR(" " MSG_INVALID_EXTRUDER " ", int(e));
  72. return -1;
  73. }
  74. return active_extruder;
  75. }
  76. /**
  77. * Get the target e stepper from the T parameter
  78. * Return -1 if the T parameter is out of range or unspecified
  79. */
  80. int8_t GcodeSuite::get_target_e_stepper_from_command() {
  81. const int8_t e = parser.intval('T', -1);
  82. if (WITHIN(e, 0, E_STEPPERS - 1)) return e;
  83. SERIAL_ECHO_START();
  84. SERIAL_CHAR('M'); SERIAL_ECHO(parser.codenum);
  85. if (e == -1)
  86. SERIAL_ECHOLNPGM(" " MSG_E_STEPPER_NOT_SPECIFIED);
  87. else
  88. SERIAL_ECHOLNPAIR(" " MSG_INVALID_E_STEPPER " ", int(e));
  89. return -1;
  90. }
  91. /**
  92. * Set XYZE destination and feedrate from the current GCode command
  93. *
  94. * - Set destination from included axis codes
  95. * - Set to current for missing axis codes
  96. * - Set the feedrate, if included
  97. */
  98. void GcodeSuite::get_destination_from_command() {
  99. bool seen[XYZE] = { false, false, false, false };
  100. LOOP_XYZE(i) {
  101. if ( (seen[i] = parser.seenval(axis_codes[i])) ) {
  102. const float v = parser.value_axis_units((AxisEnum)i);
  103. destination[i] = axis_is_relative(AxisEnum(i)) ? current_position[i] + v : (i == E_AXIS) ? v : LOGICAL_TO_NATIVE(v, i);
  104. }
  105. else
  106. destination[i] = current_position[i];
  107. }
  108. #if ENABLED(POWER_LOSS_RECOVERY) && !PIN_EXISTS(POWER_LOSS)
  109. // Only update power loss recovery on moves with E
  110. if (recovery.enabled && IS_SD_PRINTING() && seen[E_AXIS] && (seen[X_AXIS] || seen[Y_AXIS]))
  111. recovery.save();
  112. #endif
  113. if (parser.linearval('F') > 0)
  114. feedrate_mm_s = MMM_TO_MMS(parser.value_feedrate());
  115. #if ENABLED(PRINTCOUNTER)
  116. if (!DEBUGGING(DRYRUN))
  117. print_job_timer.incFilamentUsed(destination[E_AXIS] - current_position[E_AXIS]);
  118. #endif
  119. // Get ABCDHI mixing factors
  120. #if BOTH(MIXING_EXTRUDER, DIRECT_MIXING_IN_G1)
  121. M165();
  122. #endif
  123. }
  124. /**
  125. * Dwell waits immediately. It does not synchronize. Use M400 instead of G4
  126. */
  127. void GcodeSuite::dwell(millis_t time) {
  128. time += millis();
  129. while (PENDING(millis(), time)) idle();
  130. }
  131. /**
  132. * When G29_RETRY_AND_RECOVER is enabled, call G29() in
  133. * a loop with recovery and retry handling.
  134. */
  135. #if HAS_LEVELING && ENABLED(G29_RETRY_AND_RECOVER)
  136. #ifndef G29_MAX_RETRIES
  137. #define G29_MAX_RETRIES 0
  138. #endif
  139. void GcodeSuite::G29_with_retry() {
  140. uint8_t retries = G29_MAX_RETRIES;
  141. while (G29()) { // G29 should return true for failed probes ONLY
  142. if (retries--) event_probe_recover();
  143. else {
  144. event_probe_failure();
  145. return;
  146. }
  147. }
  148. #if ENABLED(HOST_PROMPT_SUPPORT)
  149. host_action_prompt_end();
  150. #endif
  151. #ifdef G29_SUCCESS_COMMANDS
  152. process_subcommands_now_P(PSTR(G29_SUCCESS_COMMANDS));
  153. #endif
  154. }
  155. #endif // HAS_LEVELING && G29_RETRY_AND_RECOVER
  156. //
  157. // Placeholders for non-migrated codes
  158. //
  159. #if ENABLED(M100_FREE_MEMORY_WATCHER)
  160. extern void M100_dump_routine(PGM_P const title, char *start, char *end);
  161. #endif
  162. /**
  163. * Process the parsed command and dispatch it to its handler
  164. */
  165. void GcodeSuite::process_parsed_command(const bool no_ok/*=false*/) {
  166. KEEPALIVE_STATE(IN_HANDLER);
  167. // Handle a known G, M, or T
  168. switch (parser.command_letter) {
  169. case 'G': switch (parser.codenum) {
  170. case 0: case 1: G0_G1( // G0: Fast Move, G1: Linear Move
  171. #if IS_SCARA || defined(G0_FEEDRATE)
  172. parser.codenum == 0
  173. #endif
  174. );
  175. break;
  176. #if ENABLED(ARC_SUPPORT) && DISABLED(SCARA)
  177. case 2: case 3: G2_G3(parser.codenum == 2); break; // G2: CW ARC, G3: CCW ARC
  178. #endif
  179. case 4: G4(); break; // G4: Dwell
  180. #if ENABLED(BEZIER_CURVE_SUPPORT)
  181. case 5: G5(); break; // G5: Cubic B_spline
  182. #endif
  183. #if ENABLED(FWRETRACT)
  184. case 10: G10(); break; // G10: Retract / Swap Retract
  185. case 11: G11(); break; // G11: Recover / Swap Recover
  186. #endif
  187. #if ENABLED(NOZZLE_CLEAN_FEATURE)
  188. case 12: G12(); break; // G12: Nozzle Clean
  189. #endif
  190. #if ENABLED(CNC_WORKSPACE_PLANES)
  191. case 17: G17(); break; // G17: Select Plane XY
  192. case 18: G18(); break; // G18: Select Plane ZX
  193. case 19: G19(); break; // G19: Select Plane YZ
  194. #endif
  195. #if ENABLED(INCH_MODE_SUPPORT)
  196. case 20: G20(); break; // G20: Inch Mode
  197. case 21: G21(); break; // G21: MM Mode
  198. #else
  199. case 21: NOOP; break; // No error on unknown G21
  200. #endif
  201. #if ENABLED(G26_MESH_VALIDATION)
  202. case 26: G26(); break; // G26: Mesh Validation Pattern generation
  203. #endif
  204. #if ENABLED(NOZZLE_PARK_FEATURE)
  205. case 27: G27(); break; // G27: Nozzle Park
  206. #endif
  207. case 28: G28(false); break; // G28: Home all axes, one at a time
  208. #if HAS_LEVELING
  209. case 29: // G29: Bed leveling calibration
  210. #if ENABLED(G29_RETRY_AND_RECOVER)
  211. G29_with_retry();
  212. #else
  213. G29();
  214. #endif
  215. break;
  216. #endif // HAS_LEVELING
  217. #if HAS_BED_PROBE
  218. case 30: G30(); break; // G30: Single Z probe
  219. #if ENABLED(Z_PROBE_SLED)
  220. case 31: G31(); break; // G31: dock the sled
  221. case 32: G32(); break; // G32: undock the sled
  222. #endif
  223. #endif
  224. #if ENABLED(DELTA_AUTO_CALIBRATION)
  225. case 33: G33(); break; // G33: Delta Auto-Calibration
  226. #endif
  227. #if ENABLED(Z_STEPPER_AUTO_ALIGN)
  228. case 34: G34(); break; // G34: Z Stepper automatic alignment using probe
  229. #endif
  230. #if ENABLED(G38_PROBE_TARGET)
  231. case 38: // G38.2, G38.3: Probe towards target
  232. if (WITHIN(parser.subcode, 2,
  233. #if ENABLED(G38_PROBE_AWAY)
  234. 5
  235. #else
  236. 3
  237. #endif
  238. )) G38(parser.subcode); // G38.4, G38.5: Probe away from target
  239. break;
  240. #endif
  241. #if ENABLED(CNC_COORDINATE_SYSTEMS)
  242. case 53: G53(); break;
  243. case 54: G54(); break;
  244. case 55: G55(); break;
  245. case 56: G56(); break;
  246. case 57: G57(); break;
  247. case 58: G58(); break;
  248. case 59: G59(); break;
  249. #endif
  250. #if ENABLED(GCODE_MOTION_MODES)
  251. case 80: G80(); break; // G80: Reset the current motion mode
  252. #endif
  253. case 90: set_relative_mode(false); break; // G90: Absolute Mode
  254. case 91: set_relative_mode(true); break; // G91: Relative Mode
  255. case 92: G92(); break; // G92: Set current axis position(s)
  256. #if HAS_MESH
  257. case 42: G42(); break; // G42: Coordinated move to a mesh point
  258. #endif
  259. #if ENABLED(CALIBRATION_GCODE)
  260. case 425: G425(); break; // G425: Perform calibration with calibration cube
  261. #endif
  262. #if ENABLED(DEBUG_GCODE_PARSER)
  263. case 800: parser.debug(); break; // G800: GCode Parser Test for G
  264. #endif
  265. default: parser.unknown_command_error(); break;
  266. }
  267. break;
  268. case 'M': switch (parser.codenum) {
  269. #if HAS_RESUME_CONTINUE
  270. case 0: // M0: Unconditional stop - Wait for user button press on LCD
  271. case 1: M0_M1(); break; // M1: Conditional stop - Wait for user button press on LCD
  272. #endif
  273. #if HAS_CUTTER
  274. case 3: M3_M4(false); break; // M3: Turn ON Laser | Spindle (clockwise), set Power | Speed
  275. case 4: M3_M4(true ); break; // M4: Turn ON Laser | Spindle (counter-clockwise), set Power | Speed
  276. case 5: M5(); break; // M5: Turn OFF Laser | Spindle
  277. #endif
  278. #if ENABLED(COOLANT_CONTROL)
  279. #if ENABLED(COOLANT_MIST)
  280. case 7: M7(); break; // M7: Mist coolant ON
  281. #endif
  282. #if ENABLED(COOLANT_FLOOD)
  283. case 8: M8(); break; // M8: Flood coolant ON
  284. #endif
  285. case 9: M9(); break; // M9: Coolant OFF
  286. #endif
  287. #if ENABLED(EXTERNAL_CLOSED_LOOP_CONTROLLER)
  288. case 12: M12(); break; // M12: Synchronize and optionally force a CLC set
  289. #endif
  290. #if ENABLED(EXPECTED_PRINTER_CHECK)
  291. case 16: M16(); break; // M16: Expected printer check
  292. #endif
  293. case 17: M17(); break; // M17: Enable all stepper motors
  294. #if ENABLED(SDSUPPORT)
  295. case 20: M20(); break; // M20: List SD card
  296. case 21: M21(); break; // M21: Init SD card
  297. case 22: M22(); break; // M22: Release SD card
  298. case 23: M23(); break; // M23: Select file
  299. case 24: M24(); break; // M24: Start SD print
  300. case 25: M25(); break; // M25: Pause SD print
  301. case 26: M26(); break; // M26: Set SD index
  302. case 27: M27(); break; // M27: Get SD status
  303. case 28: M28(); break; // M28: Start SD write
  304. case 29: M29(); break; // M29: Stop SD write
  305. case 30: M30(); break; // M30 <filename> Delete File
  306. case 32: M32(); break; // M32: Select file and start SD print
  307. #if ENABLED(LONG_FILENAME_HOST_SUPPORT)
  308. case 33: M33(); break; // M33: Get the long full path to a file or folder
  309. #endif
  310. #if BOTH(SDCARD_SORT_ALPHA, SDSORT_GCODE)
  311. case 34: M34(); break; // M34: Set SD card sorting options
  312. #endif
  313. case 928: M928(); break; // M928: Start SD write
  314. #endif // SDSUPPORT
  315. case 31: M31(); break; // M31: Report time since the start of SD print or last M109
  316. case 42: M42(); break; // M42: Change pin state
  317. #if ENABLED(PINS_DEBUGGING)
  318. case 43: M43(); break; // M43: Read pin state
  319. #endif
  320. #if ENABLED(Z_MIN_PROBE_REPEATABILITY_TEST)
  321. case 48: M48(); break; // M48: Z probe repeatability test
  322. #endif
  323. #if ENABLED(LCD_SET_PROGRESS_MANUALLY)
  324. case 73: M73(); break; // M73: Set progress percentage (for display on LCD)
  325. #endif
  326. case 75: M75(); break; // M75: Start print timer
  327. case 76: M76(); break; // M76: Pause print timer
  328. case 77: M77(); break; // M77: Stop print timer
  329. #if ENABLED(PRINTCOUNTER)
  330. case 78: M78(); break; // M78: Show print statistics
  331. #endif
  332. #if ENABLED(M100_FREE_MEMORY_WATCHER)
  333. case 100: M100(); break; // M100: Free Memory Report
  334. #endif
  335. #if EXTRUDERS
  336. case 104: M104(); break; // M104: Set hot end temperature
  337. case 109: M109(); break; // M109: Wait for hotend temperature to reach target
  338. #endif
  339. case 105: M105(); return; // M105: Report Temperatures (and say "ok")
  340. #if FAN_COUNT > 0
  341. case 106: M106(); break; // M106: Fan On
  342. case 107: M107(); break; // M107: Fan Off
  343. #endif
  344. case 110: M110(); break; // M110: Set Current Line Number
  345. case 111: M111(); break; // M111: Set debug level
  346. #if DISABLED(EMERGENCY_PARSER)
  347. case 108: M108(); break; // M108: Cancel Waiting
  348. case 112: M112(); break; // M112: Full Shutdown
  349. case 410: M410(); break; // M410: Quickstop - Abort all the planned moves.
  350. #if ENABLED(HOST_PROMPT_SUPPORT)
  351. case 876: M876(); break; // M876: Handle Host prompt responses
  352. #endif
  353. #else
  354. case 108: case 112: case 410:
  355. #if ENABLED(HOST_PROMPT_SUPPORT)
  356. case 876:
  357. #endif
  358. break;
  359. #endif
  360. #if ENABLED(HOST_KEEPALIVE_FEATURE)
  361. case 113: M113(); break; // M113: Set Host Keepalive interval
  362. #endif
  363. #if HAS_HEATED_BED
  364. case 140: M140(); break; // M140: Set bed temperature
  365. case 190: M190(); break; // M190: Wait for bed temperature to reach target
  366. #endif
  367. #if HAS_HEATED_CHAMBER
  368. case 141: M141(); break; // M141: Set chamber temperature
  369. //case 191: M191(); break; // M191: Wait for chamber temperature to reach target
  370. #endif
  371. #if ENABLED(AUTO_REPORT_TEMPERATURES) && HAS_TEMP_SENSOR
  372. case 155: M155(); break; // M155: Set temperature auto-report interval
  373. #endif
  374. #if ENABLED(PARK_HEAD_ON_PAUSE)
  375. case 125: M125(); break; // M125: Store current position and move to filament change position
  376. #endif
  377. #if ENABLED(BARICUDA)
  378. // PWM for HEATER_1_PIN
  379. #if HAS_HEATER_1
  380. case 126: M126(); break; // M126: valve open
  381. case 127: M127(); break; // M127: valve closed
  382. #endif
  383. // PWM for HEATER_2_PIN
  384. #if HAS_HEATER_2
  385. case 128: M128(); break; // M128: valve open
  386. case 129: M129(); break; // M129: valve closed
  387. #endif
  388. #endif // BARICUDA
  389. #if HAS_POWER_SWITCH
  390. case 80: M80(); break; // M80: Turn on Power Supply
  391. #endif
  392. case 81: M81(); break; // M81: Turn off Power, including Power Supply, if possible
  393. case 82: M82(); break; // M82: Set E axis normal mode (same as other axes)
  394. case 83: M83(); break; // M83: Set E axis relative mode
  395. case 18: case 84: M18_M84(); break; // M18/M84: Disable Steppers / Set Timeout
  396. case 85: M85(); break; // M85: Set inactivity stepper shutdown timeout
  397. case 92: M92(); break; // M92: Set the steps-per-unit for one or more axes
  398. case 114: M114(); break; // M114: Report current position
  399. case 115: M115(); break; // M115: Report capabilities
  400. case 117: M117(); break; // M117: Set LCD message text, if possible
  401. case 118: M118(); break; // M118: Display a message in the host console
  402. case 119: M119(); break; // M119: Report endstop states
  403. case 120: M120(); break; // M120: Enable endstops
  404. case 121: M121(); break; // M121: Disable endstops
  405. #if HOTENDS && HAS_LCD_MENU
  406. case 145: M145(); break; // M145: Set material heatup parameters
  407. #endif
  408. #if ENABLED(TEMPERATURE_UNITS_SUPPORT)
  409. case 149: M149(); break; // M149: Set temperature units
  410. #endif
  411. #if HAS_COLOR_LEDS
  412. case 150: M150(); break; // M150: Set Status LED Color
  413. #endif
  414. #if ENABLED(MIXING_EXTRUDER)
  415. case 163: M163(); break; // M163: Set a component weight for mixing extruder
  416. case 164: M164(); break; // M164: Save current mix as a virtual extruder
  417. #if ENABLED(DIRECT_MIXING_IN_G1)
  418. case 165: M165(); break; // M165: Set multiple mix weights
  419. #endif
  420. #if ENABLED(GRADIENT_MIX)
  421. case 166: M166(); break; // M166: Set Gradient Mix
  422. #endif
  423. #endif
  424. #if DISABLED(NO_VOLUMETRICS)
  425. case 200: M200(); break; // M200: Set filament diameter, E to cubic units
  426. #endif
  427. case 201: M201(); break; // M201: Set max acceleration for print moves (units/s^2)
  428. #if 0
  429. case 202: M202(); break; // M202: Not used for Sprinter/grbl gen6
  430. #endif
  431. case 203: M203(); break; // M203: Set max feedrate (units/sec)
  432. case 204: M204(); break; // M204: Set acceleration
  433. case 205: M205(); break; // M205: Set advanced settings
  434. #if HAS_M206_COMMAND
  435. case 206: M206(); break; // M206: Set home offsets
  436. #endif
  437. #if ENABLED(DELTA)
  438. case 665: M665(); break; // M665: Set delta configurations
  439. #endif
  440. #if ANY(DELTA, X_DUAL_ENDSTOPS, Y_DUAL_ENDSTOPS, Z_DUAL_ENDSTOPS)
  441. case 666: M666(); break; // M666: Set delta or dual endstop adjustment
  442. #endif
  443. #if ENABLED(FWRETRACT)
  444. case 207: M207(); break; // M207: Set Retract Length, Feedrate, and Z lift
  445. case 208: M208(); break; // M208: Set Recover (unretract) Additional Length and Feedrate
  446. #if ENABLED(FWRETRACT_AUTORETRACT)
  447. case 209:
  448. if (MIN_AUTORETRACT <= MAX_AUTORETRACT) M209(); // M209: Turn Automatic Retract Detection on/off
  449. break;
  450. #endif
  451. #endif
  452. #if HAS_SOFTWARE_ENDSTOPS
  453. case 211: M211(); break; // M211: Enable, Disable, and/or Report software endstops
  454. #endif
  455. #if EXTRUDERS > 1
  456. case 217: M217(); break; // M217: Set filament swap parameters
  457. #endif
  458. #if HAS_HOTEND_OFFSET
  459. case 218: M218(); break; // M218: Set a tool offset
  460. #endif
  461. case 220: M220(); break; // M220: Set Feedrate Percentage: S<percent> ("FR" on your LCD)
  462. #if EXTRUDERS
  463. case 221: M221(); break; // M221: Set Flow Percentage
  464. #endif
  465. case 226: M226(); break; // M226: Wait until a pin reaches a state
  466. #if HAS_SERVOS
  467. case 280: M280(); break; // M280: Set servo position absolute
  468. #if ENABLED(EDITABLE_SERVO_ANGLES)
  469. case 281: M281(); break; // M281: Set servo angles
  470. #endif
  471. #endif
  472. #if ENABLED(BABYSTEPPING)
  473. case 290: M290(); break; // M290: Babystepping
  474. #endif
  475. #if HAS_BUZZER
  476. case 300: M300(); break; // M300: Play beep tone
  477. #endif
  478. #if ENABLED(PIDTEMP)
  479. case 301: M301(); break; // M301: Set hotend PID parameters
  480. #endif
  481. #if ENABLED(PIDTEMPBED)
  482. case 304: M304(); break; // M304: Set bed PID parameters
  483. #endif
  484. #if ENABLED(PHOTO_GCODE)
  485. case 240: M240(); break; // M240: Trigger a camera
  486. #endif
  487. #if HAS_LCD_CONTRAST
  488. case 250: M250(); break; // M250: Set LCD contrast
  489. #endif
  490. #if ENABLED(EXPERIMENTAL_I2CBUS)
  491. case 260: M260(); break; // M260: Send data to an i2c slave
  492. case 261: M261(); break; // M261: Request data from an i2c slave
  493. #endif
  494. #if ENABLED(PREVENT_COLD_EXTRUSION)
  495. case 302: M302(); break; // M302: Allow cold extrudes (set the minimum extrude temperature)
  496. #endif
  497. #if HAS_PID_HEATING
  498. case 303: M303(); break; // M303: PID autotune
  499. #endif
  500. #if HAS_USER_THERMISTORS
  501. case 305: M305(); break; // M305: Set user thermistor parameters
  502. #endif
  503. #if ENABLED(MORGAN_SCARA)
  504. case 360: if (M360()) return; break; // M360: SCARA Theta pos1
  505. case 361: if (M361()) return; break; // M361: SCARA Theta pos2
  506. case 362: if (M362()) return; break; // M362: SCARA Psi pos1
  507. case 363: if (M363()) return; break; // M363: SCARA Psi pos2
  508. case 364: if (M364()) return; break; // M364: SCARA Psi pos3 (90 deg to Theta)
  509. #endif
  510. #if EITHER(EXT_SOLENOID, MANUAL_SOLENOID_CONTROL)
  511. case 380: M380(); break; // M380: Activate solenoid on active (or specified) extruder
  512. case 381: M381(); break; // M381: Disable all solenoids or, if MANUAL_SOLENOID_CONTROL, active (or specified) solenoid
  513. #endif
  514. case 400: M400(); break; // M400: Finish all moves
  515. #if HAS_BED_PROBE
  516. case 401: M401(); break; // M401: Deploy probe
  517. case 402: M402(); break; // M402: Stow probe
  518. #endif
  519. #if ENABLED(PRUSA_MMU2)
  520. case 403: M403(); break;
  521. #endif
  522. #if ENABLED(FILAMENT_WIDTH_SENSOR)
  523. case 404: M404(); break; // M404: Enter the nominal filament width (3mm, 1.75mm ) N<3.0> or display nominal filament width
  524. case 405: M405(); break; // M405: Turn on filament sensor for control
  525. case 406: M406(); break; // M406: Turn off filament sensor for control
  526. case 407: M407(); break; // M407: Display measured filament diameter
  527. #endif
  528. #if HAS_FILAMENT_SENSOR
  529. case 412: M412(); break; // M412: Enable/Disable filament runout detection
  530. #endif
  531. #if HAS_LEVELING
  532. case 420: M420(); break; // M420: Enable/Disable Bed Leveling
  533. #endif
  534. #if HAS_MESH
  535. case 421: M421(); break; // M421: Set a Mesh Bed Leveling Z coordinate
  536. #endif
  537. #if ENABLED(BACKLASH_GCODE)
  538. case 425: M425(); break; // M425: Tune backlash compensation
  539. #endif
  540. #if HAS_M206_COMMAND
  541. case 428: M428(); break; // M428: Apply current_position to home_offset
  542. #endif
  543. case 500: M500(); break; // M500: Store settings in EEPROM
  544. case 501: M501(); break; // M501: Read settings from EEPROM
  545. case 502: M502(); break; // M502: Revert to default settings
  546. #if DISABLED(DISABLE_M503)
  547. case 503: M503(); break; // M503: print settings currently in memory
  548. #endif
  549. #if ENABLED(EEPROM_SETTINGS)
  550. case 504: M504(); break; // M504: Validate EEPROM contents
  551. #endif
  552. #if ENABLED(SDSUPPORT)
  553. case 524: M524(); break; // M524: Abort the current SD print job
  554. #endif
  555. #if ENABLED(SD_ABORT_ON_ENDSTOP_HIT)
  556. case 540: M540(); break; // M540: Set abort on endstop hit for SD printing
  557. #endif
  558. #if ENABLED(BAUD_RATE_GCODE)
  559. case 575: M575(); break; // M575: Set serial baudrate
  560. #endif
  561. #if HAS_BED_PROBE
  562. case 851: M851(); break; // M851: Set Z Probe Z Offset
  563. #endif
  564. #if ENABLED(SKEW_CORRECTION_GCODE)
  565. case 852: M852(); break; // M852: Set Skew factors
  566. #endif
  567. #if ENABLED(ADVANCED_PAUSE_FEATURE)
  568. case 600: M600(); break; // M600: Pause for Filament Change
  569. case 603: M603(); break; // M603: Configure Filament Change
  570. #endif
  571. #if HAS_DUPLICATION_MODE
  572. case 605: M605(); break; // M605: Set Dual X Carriage movement mode
  573. #endif
  574. #if ENABLED(FILAMENT_LOAD_UNLOAD_GCODES)
  575. case 701: M701(); break; // M701: Load Filament
  576. case 702: M702(); break; // M702: Unload Filament
  577. #endif
  578. #if ENABLED(MAX7219_GCODE)
  579. case 7219: M7219(); break; // M7219: Set LEDs, columns, and rows
  580. #endif
  581. #if ENABLED(GCODE_MACROS)
  582. case 810: case 811: case 812: case 813: case 814:
  583. case 815: case 816: case 817: case 818: case 819:
  584. M810_819(); break; // M810-M819: Define/execute G-code macro
  585. #endif
  586. #if ENABLED(LIN_ADVANCE)
  587. case 900: M900(); break; // M900: Set advance K factor.
  588. #endif
  589. #if HAS_DIGIPOTSS || HAS_MOTOR_CURRENT_PWM || EITHER(DIGIPOT_I2C, DAC_STEPPER_CURRENT)
  590. case 907: M907(); break; // M907: Set digital trimpot motor current using axis codes.
  591. #if HAS_DIGIPOTSS || ENABLED(DAC_STEPPER_CURRENT)
  592. case 908: M908(); break; // M908: Control digital trimpot directly.
  593. #if ENABLED(DAC_STEPPER_CURRENT)
  594. case 909: M909(); break; // M909: Print digipot/DAC current value
  595. case 910: M910(); break; // M910: Commit digipot/DAC value to external EEPROM
  596. #endif
  597. #endif
  598. #endif
  599. #if HAS_TRINAMIC
  600. case 122: M122(); break; // M122: Report driver configuration and status
  601. case 906: M906(); break; // M906: Set motor current in milliamps using axis codes X, Y, Z, E
  602. #if HAS_STEALTHCHOP
  603. case 569: M569(); break; // M569: Enable stealthChop on an axis.
  604. #endif
  605. #if ENABLED(MONITOR_DRIVER_STATUS)
  606. case 911: M911(); break; // M911: Report TMC2130 prewarn triggered flags
  607. case 912: M912(); break; // M912: Clear TMC2130 prewarn triggered flags
  608. #endif
  609. #if ENABLED(HYBRID_THRESHOLD)
  610. case 913: M913(); break; // M913: Set HYBRID_THRESHOLD speed.
  611. #endif
  612. #if USE_SENSORLESS
  613. case 914: M914(); break; // M914: Set StallGuard sensitivity.
  614. #endif
  615. #endif
  616. #if HAS_DRIVER(L6470)
  617. case 122: M122(); break; // M122: Report status
  618. case 906: M906(); break; // M906: Set or get motor drive level
  619. case 916: M916(); break; // M916: L6470 tuning: Increase drive level until thermal warning
  620. case 917: M917(); break; // M917: L6470 tuning: Find minimum current thresholds
  621. case 918: M918(); break; // M918: L6470 tuning: Increase speed until max or error
  622. #endif
  623. #if HAS_MICROSTEPS
  624. case 350: M350(); break; // M350: Set microstepping mode. Warning: Steps per unit remains unchanged. S code sets stepping mode for all drivers.
  625. case 351: M351(); break; // M351: Toggle MS1 MS2 pins directly, S# determines MS1 or MS2, X# sets the pin high/low.
  626. #endif
  627. #if HAS_CASE_LIGHT
  628. case 355: M355(); break; // M355: Set case light brightness
  629. #endif
  630. #if ENABLED(DEBUG_GCODE_PARSER)
  631. case 800: parser.debug(); break; // M800: GCode Parser Test for M
  632. #endif
  633. #if ENABLED(I2C_POSITION_ENCODERS)
  634. case 860: M860(); break; // M860: Report encoder module position
  635. case 861: M861(); break; // M861: Report encoder module status
  636. case 862: M862(); break; // M862: Perform axis test
  637. case 863: M863(); break; // M863: Calibrate steps/mm
  638. case 864: M864(); break; // M864: Change module address
  639. case 865: M865(); break; // M865: Check module firmware version
  640. case 866: M866(); break; // M866: Report axis error count
  641. case 867: M867(); break; // M867: Toggle error correction
  642. case 868: M868(); break; // M868: Set error correction threshold
  643. case 869: M869(); break; // M869: Report axis error
  644. #endif
  645. #if ENABLED(MAGNETIC_PARKING_EXTRUDER)
  646. case 951: M951(); break; // M951: Set Magnetic Parking Extruder parameters
  647. #endif
  648. #if ENABLED(Z_STEPPER_AUTO_ALIGN)
  649. case 422: M422(); break; // M422: Set Z Stepper automatic alignment position using probe
  650. #endif
  651. #if ENABLED(PLATFORM_M997_SUPPORT)
  652. case 997: M997(); break; // M997: Perform in-application firmware update
  653. #endif
  654. case 999: M999(); break; // M999: Restart after being Stopped
  655. #if ENABLED(POWER_LOSS_RECOVERY)
  656. case 413: M413(); break; // M413: Enable/disable/query Power-Loss Recovery
  657. case 1000: M1000(); break; // M1000: Resume from power-loss
  658. #endif
  659. default: parser.unknown_command_error(); break;
  660. }
  661. break;
  662. case 'T': T(parser.codenum); break; // Tn: Tool Change
  663. default: parser.unknown_command_error();
  664. }
  665. if (!no_ok) queue.ok_to_send();
  666. }
  667. /**
  668. * Process a single command and dispatch it to its handler
  669. * This is called from the main loop()
  670. */
  671. void GcodeSuite::process_next_command() {
  672. char * const current_command = queue.command_buffer[queue.index_r];
  673. PORT_REDIRECT(queue.port[queue.index_r]);
  674. #if ENABLED(POWER_LOSS_RECOVERY)
  675. recovery.queue_index_r = queue.index_r;
  676. #endif
  677. if (DEBUGGING(ECHO)) {
  678. SERIAL_ECHO_START();
  679. SERIAL_ECHOLN(current_command);
  680. #if ENABLED(M100_FREE_MEMORY_DUMPER)
  681. SERIAL_ECHOPAIR("slot:", queue.index_r);
  682. M100_dump_routine(PSTR(" Command Queue:"), queue.command_buffer, queue.command_buffer + sizeof(queue.command_buffer));
  683. #endif
  684. }
  685. // Parse the next command in the queue
  686. parser.parse(current_command);
  687. process_parsed_command();
  688. }
  689. /**
  690. * Run a series of commands, bypassing the command queue to allow
  691. * G-code "macros" to be called from within other G-code handlers.
  692. */
  693. void GcodeSuite::process_subcommands_now_P(PGM_P pgcode) {
  694. char * const saved_cmd = parser.command_ptr; // Save the parser state
  695. for (;;) {
  696. PGM_P const delim = strchr_P(pgcode, '\n'); // Get address of next newline
  697. const size_t len = delim ? delim - pgcode : strlen_P(pgcode); // Get the command length
  698. char cmd[len + 1]; // Allocate a stack buffer
  699. strncpy_P(cmd, pgcode, len); // Copy the command to the stack
  700. cmd[len] = '\0'; // End with a nul
  701. parser.parse(cmd); // Parse the command
  702. process_parsed_command(true); // Process it
  703. if (!delim) break; // Last command?
  704. pgcode = delim + 1; // Get the next command
  705. }
  706. parser.parse(saved_cmd); // Restore the parser state
  707. }
  708. void GcodeSuite::process_subcommands_now(char * gcode) {
  709. char * const saved_cmd = parser.command_ptr; // Save the parser state
  710. for (;;) {
  711. char * const delim = strchr(gcode, '\n'); // Get address of next newline
  712. if (delim) *delim = '\0'; // Replace with nul
  713. parser.parse(gcode); // Parse the current command
  714. process_parsed_command(true); // Process it
  715. if (!delim) break; // Last command?
  716. gcode = delim + 1; // Get the next command
  717. }
  718. parser.parse(saved_cmd); // Restore the parser state
  719. }
  720. #if ENABLED(HOST_KEEPALIVE_FEATURE)
  721. /**
  722. * Output a "busy" message at regular intervals
  723. * while the machine is not accepting commands.
  724. */
  725. void GcodeSuite::host_keepalive() {
  726. const millis_t ms = millis();
  727. static millis_t next_busy_signal_ms = 0;
  728. if (!suspend_auto_report && host_keepalive_interval && busy_state != NOT_BUSY) {
  729. if (PENDING(ms, next_busy_signal_ms)) return;
  730. switch (busy_state) {
  731. case IN_HANDLER:
  732. case IN_PROCESS:
  733. SERIAL_ECHO_MSG(MSG_BUSY_PROCESSING);
  734. break;
  735. case PAUSED_FOR_USER:
  736. SERIAL_ECHO_MSG(MSG_BUSY_PAUSED_FOR_USER);
  737. break;
  738. case PAUSED_FOR_INPUT:
  739. SERIAL_ECHO_MSG(MSG_BUSY_PAUSED_FOR_INPUT);
  740. break;
  741. default:
  742. break;
  743. }
  744. }
  745. next_busy_signal_ms = ms + host_keepalive_interval * 1000UL;
  746. }
  747. #endif // HOST_KEEPALIVE_FEATURE