Commit Graph

1395 Commits (37ac540a269ccfb5e75eaa723421b1c6f76def94)

Author SHA1 Message Date
Scott Lahteine 8e5099fa0c Update software endstop positions with M206, M428, G92, etc.
Scott Lahteine 5cfb2533d6 Initial cleaning up of arc code
Scott Lahteine 9ce4264fda Merge pull request from thinkyhead/rc_mbl_adjustments
Document some movement functions, rename a local
esenapaj 2eb1b102f8 Support for "mechanical probe" with Allen Key as a special case
Scott Lahteine cfcd3d7b3e Rename z_offset local to zoffset
Scott Lahteine 5fd20ecac3 Comments on some movement functions
Scott Lahteine a781a6f955 Apply esenapaj 3479 and delta/scara position bugfix
Scott Lahteine 525d8256d4 Merge pull request from thinkyhead/rc_extruder_offset_array
Fix: gcode_T using non-existent Z offset
Scott Lahteine 46881c846c Add comments for extruder offset options
Scott Lahteine edf376ce0d Fix: gcode_T using non-existent Z offset
As noted by @snowzach in 
gralco 178aeb79c8 Implementation of M190 bed temp hysteresis
Scott Lahteine 0439483bc8 Merge pull request from thinkyhead/rc_debug_leveling_gcode_t
Add DEBUG_LEVELING output for gcode_T
Scott Lahteine 63d8893f5d Add DEBUG_LEVELING output for gcode_T
Scott Lahteine f840c7de4d Initialize stepper counts for Delta/SCARA
Scott Lahteine 56acaf3594 Merge pull request from thinkyhead/rc_aleph_cooldownfix
Fix for M109 and M190 cooldown
gralco c218db136a Fix for M109 and M190 cooldown
Also removes the re-definition of now inside M190's while loop
Scott Lahteine c5a2ce4366 Merge pull request from thinkyhead/rc_fixup_M206_and_mesh
Fix home_offset handling and account for it in G29
Scott Lahteine b1bb1c7989 Merge pull request from thinkyhead/rc_look_for_leveling_bug
Add CORE support to st_set_position and plan_set_position
Scott Lahteine fdee2be49c More logging of matrix behavior
Scott Lahteine 7f265db3ef Move sync_plan_position after DEBUG_LEVELING
Scott Lahteine 02550af7c3 Merge pull request from thinkyhead/rc_jbrazio_m190
ELAPSED / PENDING for rollover-safe time checking
Scott Lahteine 803845ec18 Add a case for M113 to process_next_command
Scott Lahteine 386140f361 Test time difference in safe way
Scott Lahteine 1b7356b3a1 Account for home_offset in G29 handler
Scott Lahteine f3562dd895 Have M206 alter current_position, M428 use new function
Scott Lahteine 6d465321b5 Adjust timeout code in host_keepalive
Scott Lahteine 50c3140040 Merge pull request from thinkyhead/rc_host_timeout_mods
Host Keepalive configurable timeout with 2s default
Scott Lahteine 1acf901b63 Adjustments to residency_start_ms handling
gralco 907aed57db Fix bug which can cause an infinite M109 loop
Since residency_start_ms is -1 when entering the heatup while loop whilst the hotend temp is close to the target them already then it may not escape.

Hence "Start the TEMP_RESIDENCY_TIME timer when we reach target temp for the first time."
jbrazio dd3a06a95a Implemented M155 and M156, a generic TWI/I2C interface for Marlin
Scott Lahteine 843aa90b5a Merge pull request from thinkyhead/rc_more_debug_leveling
Additional debug leveling output
Scott Lahteine a644ab1de4 Minor patch ups to `G29`
This may fix a subtle bug caused by doing `G29` more than once without
`G28` between.
Scott Lahteine cba2698871 Additional DEBUG_LEVELING output
Scott Lahteine 5e18d650c4 Merge pull request from thinkyhead/rc_better_SERIAL_ECHOPAIR
No casting needed for SERIAL_ECHOPAIR
Scott Lahteine e0b0d1eb6b Add M113 to get/set Host Keepalive
Scott Lahteine 85883da90c Implement basic HOST_KEEPALIVE_INTERVAL
Scott Lahteine 098fb8f8c9 Merge pull request from thinkyhead/rc_probe_G30_position
Report the probe position in G30
Scott Lahteine c9c7c66b95 Merge pull request from jbrazio/bugfix/m109-EXTRUDE_MINTEMP-expansion
M109: Protect against EXTRUDE_MINTEMP expansion
Scott Lahteine d7cbb2eec9 Merge pull request from jbrazio/feature/stopwatch
Print job timer rework
Scott Lahteine dc19b69697 No casting needed for SERIAL_ECHOPAIR
João Brázio 471d30cc1c
M109: Protected against EXTRUDE_MINTEMP expansion
João Brázio 7c7e30f4cc
Adherence to the new OOP coding standards
Scott Lahteine 865dcf3fb4 Fix FILAMENT_WIDTH_SENSOR measurement
Only measure and store filament width when E is going forward.
Scott Lahteine 2f6c5fe2da Report the probe position in G30
João Brázio e48d0263bf Bugfix: M32 was still using the old print timer
João Brázio e8b80d8c20 Implemented M75, M76, M77 to control the print timer
João Brázio eb61051556 Rework the print job timer to use the stopwatch class
Scott Lahteine 98f2e9fc83 Reduce string storage required for DEBUG_LEVELING
Scott Lahteine 1af5d7b35f Add more leveling-debug output
Scott Lahteine 56e8e2b0eb Final tweaks to M111 output
João Brázio d819a4aff9 Fixes , followup : variables must defined with the static keyword to work with PROGMEM when defined inside functions
Scott Lahteine de39056f68 Merge pull request from thinkyhead/rc_fix_m111_output
Fix M111 output using pgm_read_word, as required
Scott Lahteine fd0ac371b0 Fix M111 output using pgm_read_word as required
As noted by @taratata2016 in https://github.com/MarlinFirmware/Marlin/issues/3300#issuecomment-204687275
Scott Lahteine d771174797 Merge pull request from esenapaj/patch-2
suppress warnings
Scott Lahteine d24f14a799 Add HAS_TEMP_HOTEND define
esenapaj f9e1a0ee6c suppress warnings
Scott Lahteine 80b8fd1cad Add MSG_HOME_OFFSETS_APPLIED
Scott Lahteine bc86ee0271 Simplify `homeaxis` with some macros
Scott Lahteine 82ef101ed5 Deploy & Stow in G29 for Delta + Z Servo Endstop
Scott Lahteine de333c4fea Merge pull request from thinkyhead/rc_filament_width_sensor
FILAMENT_SENSOR -> FILAMENT_WIDTH_SENSOR
Scott Lahteine 8def2c31db Merge pull request from thinkyhead/rc_stop_watchheat_lcdset0
Fix temperature checking conditions (backwards!)
Scott Lahteine 8bf5f7c676 Merge pull request from jbrazio/bugfix/m104-timer-wont-start
M104 not starting the print timer
Scott Lahteine 31450ad498 Fix temperature checking conditions (backwards!)
João Brázio 187c183c20 M104 was not starting the print timer
Scott Lahteine 507aef055f Patch broken M404
Scott Lahteine 1a79b13b7a FILAMENT_SENSOR -> FILAMENT_WIDTH_SENSOR
Scott Lahteine 5f32184254 Merge pull request from thinkyhead/rc_cleanup_m111_redo
Echo all debug levels in M111, default to DEBUG_NONE
Scott Lahteine 05765fb570 Add DEBUGGING macro
Scott Lahteine 4402760739 Echo all debug levels in M111, default to DEBUG_NONE
Redo of  by @jbrazio
Scott Lahteine f0b96f5cae Merge pull request from thinkyhead/rc_sdprint_and_lcd_sleuth
Refinements, fixes, reduced stack usage in CardReader
Scott Lahteine 12c0bf9521 Merge pull request from jbrazio/bugfix/m190-temp-never-reached
M190 bed temp is never reached
João Brázio c6577aea60 M190 bed temp was never reached
Scott Lahteine 27d70599d4 Change openFile default to "not-push" instead of "do-replace"
Scott Lahteine 3252df7998 Minor cleanup to filament sensor code
Scott Lahteine 0b8ef5eba6 Split get_command into units, rename to get_available_commands
Scott Lahteine 545f7997ea Continue on empty lines instead of returning
Scott Lahteine 3dcf6d42ff Don't store escaped serial characters if comment_mode
Scott Lahteine 5f8e52aefb Minor cleanup to command dispatcher
Scott Lahteine f1ed310322 Add NUMERIC compare macros to simplify code
jbrazio 443e6d26fe Formatted multi-line comments
Scott Lahteine e4039a9b5b Merge pull request from esenapaj/patch-1
Fix typo
Scott Lahteine cd4c3e90bc Send a busy signal every 10 seconds instead of every 2
Scott Lahteine 26168676e7 Merge pull request from thinkyhead/rc_fix_numeric_filenames
Fix: current_command_args skips digits at the front
esenapaj f54315c728 Fix typo
These are salvaged from closed-PR .
Scott Lahteine f423716c6a Fix: current_command_args skips digits at the front
Closes 
Scott Lahteine 18de9f55ac Merge pull request from thinkyhead/rc_epatel_mesh_fixes
Updated Mesh Bed Leveling
Scott Lahteine 3a1e6b1752 Merge pull request from AnHardt/homed
axis_known_position -> axis_homed
AnHardt 94962ee678 axis_known_position -> axis_homed
In all these cases we want the axis to be homed. If we could have lost
some steps is secondary.

Reenables homing seperate axis with DISABLE_X / DISABLE_Y true.
Edward Patel 14afe1a017 Move to Z=0 for G28 when using Manual Bed Leveling
copy of 406992f9dd
Edward Patel c606ed447a Add "G29 S4" to fine tune Z level for Mesh Bed Leveling.
Also add mbl.z_offset to the EEPROM, bumping the version to V23.
Scott Lahteine 5d8036e554 Code cleanup around MOTOR_CURRENT_PWM options
Scott Lahteine 0da744b7b0 Further cleanup of comments, partial Doxygen-style
Following up on 
Scott Lahteine 4823791eb0 Merge pull request from esenapaj/patch-1
Fix spelling
jbrazio 5e5d250832 Added gplv3 header to all Marlin files
esenapaj 89a845659a Fix spelling
PROBABLE ->PROBEABLE
This is follow-up to ?
Scott Lahteine af32a7d5d6 M120/M121 also set endstops non-homing state
Scott Lahteine 04fa9d4f47 Make Autotune options into Menu Edit Items
WPBack e3f583a3be Fixes for PID AutoTune from menu
Fixes for 

Setting a temp is still missing
WPBack 3b3e8a02b5 Initial implementation of PID Autotune Menu Items
Adds the parameter U to M303. If U1 is included , it will use the
PID-values from the auto-tune.
Scott Lahteine c5857f96c8 Merge pull request from thinkyhead/rcbugfix_printrboard_revf
Add support for Printrboard RevF
Scott Lahteine f774420488 Merge pull request from thinkyhead/rc_controllerfan_bug
Make DISABLE_INACTIVE_X, etc., true if missing
AnHardt 1c6a16d5bb Send position updates to RH
Send position updates to RH where RH can not know the end position.

For example after G28 RepetierHost assumes to be at the homing-point,
but with a servo probe we are much higher. Now the RH-software-endstops
will prevent us from going down (if activated). With this patch the
internal position of RH is updated with `current_position[]`.
AnHardt 6486e8b74a Call buzz() directly from M428
Scott Lahteine b1a3a95ad4 Tweak controllerFan to save a cycle or two
Scott Lahteine 10caee2b7c Merge pull request from AnHardt/target_extruder_number
Fix extrudernum in MSG_INVALID_EXTRUDER
Scott Lahteine 1cc316f1fd Merge pull request from thinkyhead/updated_2820
This is quite comprehensive. If probes are disabled in any case when they shouldn't be, I'm sure we will hear about it soon.
Scott Lahteine 7bf5d117e7 Merge pull request from thinkyhead/rc_delta_compat_m48
Delta-compatible extensions to M48
Scott Lahteine 06332f20be Merge pull request from jbrazio/bugfix/3061-stop-print-time-counter
Stop print timer with M105/M109
AnHardt 338b69c24b Fix extrudernum in MSG_INVALID_EXTRUDER
SERIAL_ECHO is not very good in printing uint8_t - so cast. to int.
AnHardt b39b54031b Fix KEEPALIVE_STATE
Add return to NOT_BUSY for M105
Replace WAIT_FOR_USER with PAUSED_FOR_USER

Add Travis test for FILAMENTCHANGEENABLE
Scott Lahteine 41145e6e81 Patch drain_queued_commands_P
Fix a SNAFU that should have been caught in 
Scott Lahteine 59483221d5 Move stepper DAC to a separate file
Scott Lahteine 5d0570cea0 Make digitalPotWrite depend on HAS_DIGIPOTSS
Scott Lahteine f96bc03081 Add M907-M910 g-codes support for Printrbot Rev. F
Scott Lahteine cf7c444aff Apply unknown_position_error elsewhere
Scott Lahteine eda5190581 Check for known position in `M48`
Scott Lahteine 68085ca855 Updated M48 friendly for DELTA
Partial implementation with reference to 
Scott Lahteine 38b0082bf2 Additional tweaks to M42 exit conditions
Scott Lahteine 4bbea5124d Support for multiple PWM fans
Scott Lahteine 637cc03686 Fix M109 so it won't wait for cooling
Addressing issue 
AnHardt 3f45a1acf9 Check probes only when deployed
Aim: Test probes in update_endstops only when activated

Changes:
Configurations
 Add define for FIX_MOUNTED_PROBE to handle the situation where formerly ENDSTOPS_ONLY_FOR_HOMING had to be set, or lowering the nozzle below Z_PROBE_OFFSET_FROM_EXTRUDER could give an "endstop hit" message.
 Add define for Z_MIN_PROBE_USES_Z_MIN_ENDSTOP_PIN to indicate a common situation, that we have a probe but it is connected to an endstop pin
 Add some comments
 Shift some entries to have related things together.

Conditionals.h
 We have a probe (HAS_Z_MIN_PROBE) if one of the pins is defined AND one of the probes is defined.

SanityCheck.h
 Add some tests if the probe is connected and if we have defined a probe.

stepper.cpp
 Changes to test the probe only when it is deployed (z_probe_is_active).
 Test update_endstops() when the probe is deployed.

MarlinMain.cpp
 a. set and reset z_probe_is_active in deploy_z_probe(), stow_z_probe() and dock_sled()
 b. set and reset z_probe_is_active in the case a z-servo is moved to a defined position. The only remaining unhandled servo move is in M280 where we do not end in a defined position. If you want to handle a probe use M401/402
 c. skip deploying/stowing when already deployed/stowed in the dedicated deploy/stow functions.
 d. Handle the new FIX_MOUNTED_PROBE in parallel to a servo driven probe/endstop.

 To do: In another PR. handle all probes in deploy/stow_z_probe.
 Sort out SERVO_LEVELING vs. HAS_SERVO_ENDSTOPS.
Scott Lahteine 4634feaeab Merge pull request from thinkyhead/fix_command_injection
Use a serial line buffer to prevent queue corruption
Scott Lahteine 963a92ceda Patch idle forevermore
Scott Lahteine 7ec7bb31c4 Send a Busy signal to hosts during long processes, wait for input, etc
If Marlin is blocking the serial input or command queue for any length
of time (for example more than 2 seconds), it needs to send a message
to serial out to inform the host that it is busy. Marlin should only
send these messages out when busy, and preferably not when trying to
print formatted output.
Scott Lahteine 80277cc9c8 drain_queued_commands_P now returns true if there are more
Scott Lahteine 8fe7420310 Use a separate serial line buffer
Scott Lahteine 7d25c107a8 Merge pull request from esenapaj/patch-1
suppress warnings
Scott Lahteine e8fa843c2d Merge pull request from epatel/epatel/RCBugFix
Fix for  MESH_BED_LEVELING broke correct G1 movement in Z
Scott Lahteine d7c6fd5c2f Merge pull request from thinkyhead/rc_enabled_true_false
Support "true" and "false" in the ENABLED macro
Edward Patel cb0dbfa3b5 Fix for MESH_BED_LEVELING broke correct G1 movement in Z
Scott Lahteine 6e1bc03d3b Additional wrapping for
Scott Lahteine 1c384930f3 Merge pull request from thinkyhead/rc_fix_macro_expansion
Wrap macros to prevent bad expansions
esenapaj a4314c4907 Use local variable in recalc_delta_settings()
diagonal_rod hadn't been used anywhere.
esenapaj 8de7a6f9b1 suppress warnings
Scott Lahteine 4b648793f2 Use ENABLED with DISABLE_[INACTIVE_][XYZ]
Scott Lahteine 3f5fbbd398 Merge pull request from jbrazio/bugfix/update-g29-auto-level-bed-topography
Update the bed topography output done by G29
Scott Lahteine f9ded2a7c4 Wrap macros to prevent bad expansions
jbrazio a645860431 All print timer related activity now uses print_job_start(), print_job_timer() or print_job_stop()
jbrazio 1981e53d68 M109 R option if misused could cause a wait-forever situation
João Brázio 4d4a842cfb Update the bed topography output done by G29
João Brázio 793cd0ae3b Clean up the code a bit
jbrazio 986b508ff7 Print timer now stops when it sees the last extruder temperature being shutdown
AnHardt fd5414c6ea Z_RAISE_BEFORE_HOMING -> MIN_Z_HEIGHT_FOR_HOMING
rebased
corrected spelling
changed to #elif for error

Still with MIN_Z_HEIGHT_FOR_HOMING but con be done with (folder wide) search-replace when we have a better name.
Scott Lahteine b7928a000a Merge pull request from AnHardt/M110+
M110 and M29 rework
Scott Lahteine 5cba0b4187 Merge pull request from thinkyhead/rc_drop_old_condition
Drop obsolete test for leading "N"
Scott Lahteine 302d1bfbc4 Drop obsolete test for leading "N"
AnHardt 37b857e8ec M110 ang M29 rework
Add 'ok' output for G29 actually closing the file.
Handle M110 when received without linenumber/checksumm.
Scott Lahteine fac85f6fa1 Merge pull request from jbrazio/bugfix-g28-multiple-z-movements
Bugfix: G28 was lifting Z-axis multiple times
jbrazio 642e3699ce Z-axis was being lift multiple times if Z_SAFE_HOMING was enabled and Z_RAISE_BEFORE_HOMING was greater than zero
Scott Lahteine 501f63802a Merge pull request from Blue-Marlin/watchdogreset-in-kill
Add Watchdog timer reset in kill()
Scott Lahteine ef68c1910c Check that the temperature is close to target
Scott Lahteine ea9fd1200b Fix M109 so it won't wait for cooling
Addressing issue 
Scott Lahteine ff13070b59 Use _BV macros, patch up others
Scott Lahteine 209f5f21e0 Use macros where possible
Apply `constrain`, `NOMORE`, `NOLESS` and `CRITICAL_SECTION` macros
wherever possible.
Scott Lahteine 6e64895c30 Merge pull request from AlwaysTinkering/RCBugFix
Rc bug fix - Fix for issue 
Scott Lahteine 34b8b9f0f5 Merge pull request from thinkyhead/rcbugfix_corexy_corexz
Add CORE support to st_get_position_mm (and elsewhere)
Scott Lahteine 3a3d358df9 Fix Printrboard with LCD (redo)
Based on  - rebased for RCBugFix
Scott Lahteine eb85342fd9 Merge pull request from AnHardt/fix2661
Pre home display - Stepper release
Scott Lahteine 14f3ca1b2e Merge pull request from thinkyhead/tool_offset_abl_rcbugfix
Apply bed leveling matrix when switching extruders
lrpirlet 0fb507a75d correct raise_z_for_servo
Blue-Marlin b4e5e0f11d Add Watchdog reset in kill()
Add watchdog reset in the kill loop to simplify recovering.
Scott Lahteine 222d13d5ed Merge pull request from thinkyhead/rcbugfix_dual_axis_offset
Code cleanup in gcode_T
Scott Lahteine 186629aee8 Merge pull request from jbrazio/3034-z_raise_after_probing_fix
Fix Z_RAISE_AFTER_PROBING for non DELTA printers
jbrazio 67e15aac3d As pointed out by @Blue-Marlin the previous code would raise the Z axis
twice for a servo based probe.
jbrazio 17cc2a9663 Z_RAISE_AFTER_PROBING value was being ignored by Marlin because
raise_z_after_probing() was only called if the printer type was set to a
DELTA or if the printer had a docking sled for the probe.
AnHardt 1c889cd303 Refresh previous_cmd_ms during run_z_probe()
Refresh previous_cmd_ms during run_z_probe() to prevent:
stepper shutdown for expired DEFAULT_STEPPER_DEACTIVE_TIME
and extrudes for expired EXTRUDER_RUNOUT_SECONDS
(https://github.com/MarlinFirmware/MarlinDev/issues/238)
AnHardt 4b02f33e69 Distribute config-changes to the other configurations
AnHardt 32ae9f9ab7 Fix stepper shutdown during waiting for temperatures
In the wait loops of M109 M190 idle() is called, what checks
stepper_inactive_time against previous_cmd_ms.
Because we can be several minutes inside the loop, resetting
previous_cmd_ms only outside the loop caused stepper shutdowns.

The name of previous_cmd_ms does not really reflect its use. It's set
not only when a new command was received or executed but also in many of
the movement routines. For that the little extension of using it during
the wait will (hopefully) not hurt.

# Conflicts:
#	Marlin/Configuration_adv.h
AnHardt b6e69e71ce Make stepper shutdown after inactivity dependent
Make stepper shutdown after inactivity dependent on a new set of
#defines.
DISABLE_INACTIV_X
DISABLE_INACTIV_Y
DISABLE_INACTIV_Z
DISABLE_INACTIV_E

And make exemplaric Configuration.
Names can be discussed.

This makes the disabling of the steppers independent from the DISABLE_?
settings witch shut down the steppers immediately.
AnHardt 051325ccd7 Introduce axis_homed
Introduce additional variable axis_homed to replace axix_known_position
when the coordinate display should indicate the axis is not homed.
This is to distinguish between "not homed" and "inexact position possible
because stepper was disabled".

# Conflicts:
#	Marlin/ultralcd_implementation_hitachi_HD44780.h
solved
Scott Lahteine 100271e6ac minor cleanup in gcode_T
Scott Lahteine 6a4f06d35d Fix GCode handling of spaces between command letter and first digit
CONSULitAS ea8409ad5d Fix: current_command_args contains command
@thinkyhead
Hi Scott,
your code from a0f362c@thinkyhead is great, but you forgot to skip the
command.
Symptom `M117 Test`shows `M117 Test` on LCD instead of `Test`.

see also
https://github.com/MarlinFirmware/Marlin/commit/a0f362c735401ebbcd95de3f
6f8e3c2f17ecc770 lines 941, 2851 and so on

Greetings and welcome back

Jochen
Scott Lahteine e1beaf61eb Merge pull request from AnHardt/adv-ok
Repair N in ADVANCED_OK
Scott Lahteine 0c9db67273 Merge pull request from AnHardt/ok-echo
Replace the "ok" in M280, M301, M304, M851 with output not including …
Scott Lahteine 8eaba020fb Merge pull request from thinkyhead/fix_splash_url
Remove references to marlinfirmware.org
Scott Lahteine be691b51f1 Remove references to marlinfirmware.org
The domain is gone and doesn’t redirect, so for now show no URL on the boot screen.
Scott Lahteine 83ffc9eb4f Show raw steps in M114
This is a proposed change. This section of M114 output is a debug
extension according to RepRap wiki.
Scott Lahteine 373e8a1ad4 Fixes for COREXY and COREXZ coordinates
unknown 31656e68bc Fix for homing X and Y before raising Z when Z_SAFE_HOMING is set.
unknown 8ea55323d8 Fix for not raising Z before homing X and Y
Scott Lahteine 711e5db19a Tweak comment in process_next_command
Scott Lahteine 400e9329be Allow spaces after a code letter
Scott Lahteine cdcb80f3c5 Allow no-space after initial command
Addresses issue 
AnHardt 6f473f7fc6 Repair N in ADVANCED_OK
Send the correct line number.
If no N was in the command - non't send an N.
AnHardt efbd705eda Replace the "ok" in M280, M301, M304, M851 with output not including an "ok"
Replace the "ok" in M280, M301, M304, M851 with output not including an "ok"
to avoid senting two "ok"s for a single g-code.

Doing the same for M105 would break the input filters of the hosts.
For M105 the other "ok" is omitted.
Scott Lahteine 8e66028d25 Apply the ABL rotation matrix to the extruder offset.
Richard Wackerbarth f6950acb8e Residual unused variable — Backport
AnHardt 57da1b8497 Host parseble output for M109, M190 and M303
Make the output of M105 more similar to Repetier.
Make the text-print pert of M105 an extra function to make it reusable. `print_heaterstates()`
Use `print_heaterstates()` in M019, M190 and M303
AnHardt fcceb98191 Unglobalize no_wait_for_cooling
Richard Wackerbarth e293ea57f0 Unbalanced brackets in setPwmFrequency
This is a back port of the correct in issue 
Scott Lahteine 17c23bbaf3 Shorten gcode_M221 yet function the same
Scott Lahteine c0e791dbe9 Only look for "N" line number as first parameter
Scott Lahteine b4af4441c5 Clean up watchdog impl.
Scott Lahteine 9bdab4f3a8 Clean up "else" and other spacing
Richard Wackerbarth 25d636c9e0 Compiler issues (PR#2696)
Scott Lahteine ba6a243197 DEBUG message has no parameter (PR#2671)
Scott Lahteine 0c7f7ebcfb Styling adjustments (PR#2668 & PR#2670)
Keep "astyled" reformatting
fmalpartida 0f149ea0c6 LCD home button causes repeated homing (PR#175)
Fix: increased debounce delay.
Scott Lahteine b825567e0f Drop www. from marlinfirmware.org (PR#175)
Scott Lahteine bc50db9cf6 Implement PID_ADD_EXTRUSION_RATE
Scott Lahteine fabf3ae4a0 Add final Z raise after Delta probe
Shane Francis 4c8330c15c Trim Adjustments for Delta Configurations
Scott Lahteine 962120d1d2 Fix spacing in some conditional blocks
Richard Wackerbarth 20b4772155 Create DEBUG_LEVELING_FEATURE
Scott Lahteine 194f98ff95 Debug messages for homing and leveling
Richard Wackerbarth 6292d9e815 Rename ENABLE_AUTO_BED_LEVELING
With the introduction of the #if ENABLED(…)

reads better than
Christian Lefrançois 9897a9147c Update ABL comments (PR#95)
* Updates the auto bed leveling comments ONLY.
* Renames "Z probe" word usage in //comments and #errors properly.
Scott Lahteine 23d742bf06 Don't free the stack array plane_equation_coefficients (PR#83)
Scott Lahteine e3b1e08777 Patch G30 to use raise_z_for_servo (PR#73)
Scott Lahteine a1eb90d5c0 Save another 30 bytes in gcode_SET_Z_PROBE_OFFSET
Scott Lahteine 91122277f4 Reduce gcode_SET_Z_PROBE_OFFSET by 88 bytes
AnHardt 5707a2c3d5 indexindexIntoAB is only vald for !DELTA
AnHardt d8860f9ad9 Alway end at the same point
Always end at [RIGHT_PROBE_BED_POSITION, BACK_PROBE_BED_POSITION]
Regardles the evennes of auto_bed_leveling_grid_points.
AnHardt 4ca8f4a9a7 Always zigzag
Use the shortest way between probing-points.
AnHardt 3d23424121 Add array indexIntoAB[xx][yy]
and use it.
AnHardt e2d69f66b2 Make Z_PROBE a Z_MIN_PROBE (PR#65)
Currently we use the probe exclusively as a device to find the build platform(bed).
For the currently supported setups this means, we use it as a additional min-endstop.
A triggered when not deployed probe disturbs the homing process for max-endstops.

Rename ENDSTOPPULLUP_ZPROBE to ENDSTOPPULLUP_ZMIN_PROBE
Rename Z_PROBE_ENDSTOP_INVERTING to Z_MIN_PROBE_ENDSTOP_INVERTING
Rename Z_PROBE_ENDSTOP to Z_MIN_PROBE_ENDSTOP
Rename DISABLE_Z_PROBE_ENDSTOP to DISABLE_Z_MIN_PROBE_ENDSTOP
Rename Z_PROBE_REPEATABILITY_TEST to Z_MIN_PROBE_REPEATABILITY_TEST
Rename Z_PROBE_ENDSTOP to Z_MIN_PROBE_ENDSTOP
Adjust comments accordingly
Remove Z_MAX  check for the probe in update_endstops().

Using an delta related idea of @clefranc from ,
extended to the general change for all setups.

Tested with Prusa i3, max-z-endstop and permanently triggered z-probe.
Worked for @clefranc's delta.
Richard Wackerbarth 9d8cc24abf Continue from the line following the M999 (PR#60)
If the printer is going to accept the M999,
then it should continue from that line number.
Scott Lahteine 46453905d6 Apply remaining ENABLED/DISABLED conditionals
Richard Wackerbarth b227d8c128 Supply a VERSION in a short form for displays
The long descriptor will still be available in M115
AnHardt 4f46df5dab Make bootscreen configurable for the graphic displays
Saves about 473 byte of progmem and 28 bytes of RAM.
Scott Lahteine b4abb0ae7f Apply ENABLED / DISABLED to Marlin core files (PR#2558)
Scott Lahteine 9d151bb61b servo_endstop_angles -> servo_endstop_angle
Scott Lahteine 1f63293624 servo_endstops -> servo_endstop_id
Scott Lahteine ed4a6371ad Add HAS_SERVO_ENDSTOPS to simplify conditonals
Scott Lahteine ae9274be05 Fix minor compiler warnings in for loops
Scott Lahteine 4a58e447a1 Add array size to servo_endstop_angles (PR#2553)
AnHardt d03f037a92 Get rid of malloc() and free() (PR#2549)
Just the minimal changes to qr_solve.cpp and .h to get rid of malloc() and free().

Saves about 656 bytes of progmem (library-code)
and 22 bytes for static variables.

Should use exactly the same amount of stack as it did before on the heap.
Scott Lahteine 3b2b2313ff Combine if block related to SERVO_ENDSTOPS
Scott Lahteine 0af2a80e06 Make SERVO_ENDSTOP_ANGLES 2-dimensional
Scott Lahteine 9f48798ffd Replace ENABLED with DEFINED for SERVO_ENDSTOPS (PR#2542)
Richard Wackerbarth ae00fad75b Rename as M100
Richard Wackerbarth a401d738df There is an echo in here
Richard Wackerbarth ed7d45e8f5 Memory watcher
Scott Lahteine bea6739774 Don't include Z_RAISE_AFTER_PROBING if not used (PR#2527)
Scott Lahteine e4c01f1c7e Simplify init with ARRAY_BY_EXTRUDERS1 macro (PR#2507)
Scott Lahteine e2957df05c Shorthand for do_blocking_move_to
Scott Lahteine 819c5b9b50 Adjust comment on Z adjustment
Scott Lahteine 5a7356b6fc Patch for G29 final Z position
Include all the necessary pieces to get the final Z position after
probing the bed, and add commentary about other possible changes.
AnHardt 088e09e052 Add forgotten Marlin_main.cpp
Scott Lahteine b116c096bd Reduce set_homing_bump_feedrate, save 42 bytes (PR#2512)
Updates to `set_homing_bump_feedrate`:
- Move the string into Program Memory, reduce length by 31 bytes
- Use an auto to get the divisor, adjust it on error
- Set feedrate once, at the end
Scott Lahteine 469843427d Reduce code in gcode_M81 (PR#2497)
Scott Lahteine c66955aaf9 Mark unchanging arrays as const (PR#2494)
The compiler may be able to optimize if it knows an array won’t be
changing.
Scott Lahteine 278aa15301 Add COUNT macro and apply
Scott Lahteine aac2b9aa9d Reduce code in gcode_M84 (PR#2492)
`gcode_M84` only needs to call `finishAndDisableSteppers`, which calls
all the other functions.
Scott Lahteine e83eac312e Move plan_arc next to prepare_move
Scott Lahteine 5c5936508d G2/G3 Arcs for Delta
- Update prepare_move_delta to take a target argument
- Add Delta support to plan_arc
Scott Lahteine 3b23ccd366 Patch servos code for move
- Have `Servo::attach` explicitly return -1 if it fails
- Check for -1 in `Servo::move` because `servoIndex` might be 0
- Make `attach` / `detach` calls conditional on `SERVO_LEVELING`
- Move `SERVO_LEVELING` define to `Conditionals.h`
Patrick Bogen fba4e6241b Specify print format for reporting invalid tmp_extruder (PR#2465)
AnHardt d15d869267 Rename axis_is_at_home() to set_axis_is_at_home() (PR#2464)
to make clear - it's not a question but an order.
Scott Lahteine f209b755a5 Move the Z probe as far as needed to trigger the switch (PR#2461)
Scott Lahteine 0f1df62389 Fixup comments in code_seen
Scott Lahteine 2945eb6650 Call code_seen only once per parameter
Scott Lahteine db23b9b184 Minor tweak to M204 code (PR#2457)
Scott Lahteine 81d42406b7 Move braces in homeaxis to prevent a hanging else (PR#2451)
AnHardt ed6598adf5 Corrected Bed Height vs. Bed Topology for verbosity > 3
and cleaned out some tabs.

Everything else is a rebased PR#2017 as proposed by @CptanPanic
brian 62302ceb9e Add calculation of difference between auto-correct bed level plane, and measured topo map.
AnHardt 49609f6c14 Activate the new servo.move() function
by replacing the sequences (attach, write, delay, detach), and their conditions with the new function in Marlin.main.cpp
and removing the old configuration in the ABL part of Configuration.h
Scott Lahteine 87a872e103 Use st_get_position_mm where possible (PR#2411)
Scott Lahteine 2e0da8abdc Allow N to take a negative argument (PR@2402)
Scott Lahteine 447dbd6fa5 Add STEPPER_RESET_PIN support
Scott Lahteine 6b1b8cb2b3 Also nullify spaces before the checksum asterisk (PR#2409)
Scott Lahteine 4e9d658141 Prevent a hanging SERIAL_ECHO_START in M111
Scott Lahteine 6b494c1535 Use disable_all_heaters in M111
Scott Lahteine 15190d40df Add extra EOL after M111
AnHardt d421f5250d Correct the sign of zprobe_zoffset for G29 (PR#@391)
Sign flipped with .
See also comments
https://github.com/MarlinFirmware/Marlin/issues/2040#issuecomment-118568355
and following.
Scott Lahteine 52fcc743ab Replace "target" with "destination" in M600 (PR#2374)
- Also fix a bug in `M600` where `Z_MAX_ENDSTOP_INVERTING` is being
used as the index into the `destination[AxisEnum]` array.
AnHardt 23c8c5348f Z-height fix V2b (PR#2351)
here the other two occurences of `Z_PROBE_OFFSET_FROM_EXTRUDER` are
replaced with `zprobe_zoffset`.
Todd Swindoll a111fbbd0a z-probe offset fix (PR#2361)
verified via 1.0.2 tag that compiles by multiple people,
credit for the fix goes to paulusjacobus for the initial find and
sniffle for the correction so M851 works.
Scott Lahteine 9682ed455e Fix comment on M83, add comment to prepare_move
AnHardt 36746143a1 Correct output of M48 (PR#2336)
n_samples is an uint8_t .
Got printouts like:
50 of 2  ...
Scott Lahteine f6ca5a8da8 Allow "M110 N123" without a checksum
Scott Lahteine aaad65ff5d Include a comment documenting M110
Scott Lahteine 862c72b030 Put the mandatory test of gcode_N first
Scott Lahteine 30976f9773 Allow M110 to handle a second N argument
Scott Lahteine 5ccb1c9e7d Use millis for M600 audio feedback interval
Scott Lahteine fb16a83b8a Cleanup M600 documentation comments
Scott Lahteine 97ec224d72 Replace target with destination in M600
Scott Lahteine 4ce9ddbb74 Check the temperature before filament change
AnHardt 722829b058 Move buzzing code to buzzr.h & buzzer.cpp (PR#2307)
at least the lcd independent part from Marlin_main.cpp.
schlotzz 1e9cf905c7 Enable ZigZag AutoBedLeveling on Deltas (PR#2273)
ZigZag has been disabled by fault due to do_topography_map
AnHardt 6ab7b560af Rework buzzing (PR#2296)
by:
Moving HAS_LCD_BUZZ macro to Coditionals.h
Renaming HAS_LCD_BUZZ to HAS_BUZZER to make clear is has nothing to do with the lcd.
Removing the ULTRALCD condition.

Moving declaration of lcd_buzz() out of the ULTRA_LCD block in ultralcd.h
Moving definition of lcd_buzz() out of the ULTIPANEL block in ultralcd.cpp
Renaming lcd_buzz() to buzz() to make clear is has nothing to do with the lcd.

All buzzing code is now only dependent on the existence of a BEEPER-pin or the definition of a LCD_USE_I2C_BUZZER.

To do: Check the conditions for the BEEPER-pin in all pin-files.
Scott Lahteine 29122db2fa Fix ULTRA_LCD spelling in HAS_LCD_BUZZ
Scott Lahteine e2a4a83586 Don't re-apply Z_RAISE_BETWEEN_PROBINGS in probe_pt (PR )
MagoKimbra eb81982fcd Fix error next command in autotune (PR#2274)
Now send only temperature for T or B, but not send OK.
Host interprets the line to show the right temperature, but not in
response to M105 then stop and send commands until it ends the autotune.
AnHardt 55b23c896a Optimise out_of_range_error() (PR#2265)
by avoiding the strncopy()
AnHardt 45642b7fe8 Respect DISABLE_AXIS settings (PR#2216)
when DEFAULT_STEPPER_DEACTIVE_TIME is over
instead of simply turn off all.
Scott Lahteine 962b107341 Prevent current_command_args from bypassing nul (PR#2270)
Scott Lahteine ff6081be3a Parse N[0-9]+[ ]* differently (PR )
More general solution to skip N[0-9]+[ ]* in the parser as in 
Scott Lahteine 96a3fba8ac Reverse the sign of zprobe_zoffset
- When editing on the LCD, minus now means below the nozzle
- Stores the opposite sign in EEPROM, so bumped to “V20”
paclema 8d295547be * Auto filament change on CHANGEFILAMENT feature. Now you can activate this option that extrude filament until you press the button.
Richard Wackerbarth ad09d6a60f 3 Step Allen Key Probe
AnHardt e400fce271 Merge pull request from MagoKimbra/Dryrun
Insert Debug DRYRUN Repetier Host compatible
AnHardt c3fe6e61ae Merge pull request from AnHardt/position-out-of-range
Fix out_of_range_error()
AnHardt d1f4471000 Merge pull request from Wackerbarth/Versioning
Versioning
AnHardt 17b0ec84ed Fix out_of_range_error()
For sprintf_P() the first parameter has to be a `char*` not `const char*`.
AnHardt 35af5ef23e Merge pull request from Wurstnase/naming
consistency name for multiplier
wurstnase e7e964432b consistency name for multiplier
replace extruder_multiply with extruder_multiplier
like feedrate_multiplier or volumetric_multiplier
MagoKimbra 76306f9073 Insert Debug DRYRUN Repetier Host compatible
MagoKimbra 881146bc22 Fix problem Width Cura
AnHardt 9d2a980bcf Merge pull request from thinkyhead/beep_M600_elsewise
Slight size reduction by adding idle()
AnHardt 2728dc0606 Merge pull request from thinkyhead/reduce_strings
Redo "invalid extruder" to save 304 bytes
Scott Lahteine be5236e839 Reduce setTargetedHotend by removing the switch
Scott Lahteine 06f401e7e5 Redo "invalid extruder" to save 264 bytes
- Use `setTargetedHotend` in `M200`, as with other commands that use
`T` for the extruder
- Synthesize the "invalid extruder" message, obviating several long
strings
Scott Lahteine 1a882bcc2e Merge pull request from thinkyhead/ignore_unrecognized_commands
Ignore unknown commands if they start with G, M, or T
Scott Lahteine a672872717 Merge pull request from AnHardt/MAX6675M105
Print active extruder with M105 for MAX6675
Scott Lahteine 9beed830eb Drop commented code_is_good lines
Scott Lahteine 068d4a1eb2 Ignore unknown commands if they start with G, M, or T
Scott Lahteine c5c9d12630 Merge pull request from AnHardt/displayinit
Initialize the display earlier
Scott Lahteine 0564625757 Update M33 for new gcode parser
AnHardt af7e3f5076 Print active extruder with M105 for MAX6675
Was omitted when T0 is a MAX6675.
AnHardt f0523b5816 Initialize the display earlier
to have it ready to display errors during (temperature)-setup.
Scott Lahteine 03d5709b09 M110 is a known command
- The command parser now displays “unknown command” in more cases.
Known commands must be added to the `switch` inside `process_commands`
to suppress the error.
Scott Lahteine d76a01194d Slight size reduction by adding idle()
Richard Wackerbarth 5ea139fd79 Revised Versioning mechanism
Scott Lahteine 68f6f149d0 Reduce code size with out_of_range_error function
- Affects code size when automatic bed leveling is enabled
Scott Lahteine b55f8718c3 Indent G90/G91, G92
Scott Lahteine b0d520b109 Indent G30, G31/G32
Scott Lahteine ffe27a6225 Indent G29
Scott Lahteine 86083badc2 Indent G4, G10/G11, G28
Scott Lahteine 47d7a9cb5e Indent G2/G3
Scott Lahteine 350f239d84 Indent G0/G1
Scott Lahteine 15a2351675 No need for +1 on initial seen_pointer
Scott Lahteine 550dd87b2a Set seen_pointer before calling code_value
Scott Lahteine 04a1622172 Merge pull request from Wackerbarth/Kossel_Pro
Kossel Pro
Scott Lahteine f919a2fed1 Merge pull request from AnHardt/preheat-all
Shift call of start_watching_heater() into setTargetHotend()
AnHardt 0c0ace2a04 Remove start_watching_heater() fom M104 and M109
Scott Lahteine bde9c70d42 Suppress the line mismatch error after M303
Scott Lahteine 50bd7493cc Merge pull request from thinkyhead/m33_long_filename_host_support
M33 LONG_FILENAME_HOST_SUPPORT
Scott Lahteine 4d11b29959 Merge pull request from thinkyhead/command_sanitizer
Command sanitizer
Richard Wackerbarth 735bf2d35f Describe Custom M Code
Scott Lahteine f39658c822 M120 and M121 are reversed
AnHardt 89d2ee6f13 Make output on display dependant of ULTRA_LCD
AnHardt f4a93ed997 Add a string parameter to kill()
Makes the output on the LCD adjustable.
Scott Lahteine a0f362c735 Simplify & optimize with current_command_args
Scott Lahteine adc8fcb77f More parser comments, optimize code_seen, save with goto
Scott Lahteine c6d8dd19d9 use fetched value
Scott Lahteine 1116e13f5a Further optimization of command parser
Scott Lahteine 3a4c3ab76e Pre-sanitize the command before handling
- Use a global pointer for the current sanitized command
- Pre-sanitize the current command to bypass `N` and nullify `*`,
removing the need for handlers to bypass, ignore, or nullify these
parts, and reducing overhead for `code_seen`, etc.
- Pre-skip leading whitespace.
- Only look for G, M, T codes at the start of the command.
- Verify that G, M, T codes are followed by command codes.
Scott Lahteine 0f2c9bacfd M33 LONG_FILENAME_HOST_SUPPORT
Scott Lahteine 3feaef6526 Have G92 set the nozzle position on Delta and SCARA
Scott Lahteine 6c27eaf864 Merge pull request from thinkyhead/code_style
Code style and a dangling "else"
Scott Lahteine d580a0d186 Use "+=" in plane rotation
Scott Lahteine 2f3a410cb0 Fix a potential hanging "else" bug
Scott Lahteine b83e3f0905 Combine "Bed X: " strings
Scott Lahteine 7dfb8becdb Adjust some names and types in Marlin_main.cpp
Scott Lahteine c966aa26ff Comments in Marlin_main.cpp
Scott Lahteine c54a2ea042 Adjust spacing in Marlin_main.cpp and stepper.*
Scott Lahteine 072625ccad Update headings in Marlin_main.cpp and stepper.cpp
Scott Lahteine 16032f149f Rename to codenum as a consistency
Scott Lahteine 273a4a253f Merge pull request from thinkyhead/cherry_picking3
Hide M117 with no LCD
Scott Lahteine 64825a3d1e Merge pull request from thinkyhead/cherry_picking2
Add gcode_line_error to reduce code size
Scott Lahteine ca79282eaf Hide M117 with no LCD
Scott Lahteine ce218cafdb Add gcode_line_error to reduce code size
Scott Lahteine 46d59784ad Rename preocess_command to process_next_command
Scott Lahteine 19166a92e4 Merge pull request from Wurstnase/serial_wait
add plan buffer remaining for 'P' and block buffer remaining 'B'
Scott Lahteine e97fcafd0e Merge pull request from thinkyhead/mendel_inverting
Use MSG_OK in M105
Scott Lahteine 0f6cd3640b Drop extraneous ok_to_send
Scott Lahteine 0ce355d9e7 Use MSG_OK in M105
Scott Lahteine 7b3acfbb6f Merge pull request from thinkyhead/better_arc_code
Consolidate arc code, remove motion_control.*
Scott Lahteine 68ce419147 Note on segment size
Scott Lahteine 8b92249f18 Bring arc_offset into auto scope
Scott Lahteine 80807b2d71 Consolidate arc code, remove motion_control.*
Scott Lahteine f65833931d Formatting tweaks
Scott Lahteine 747fd5801c Merge pull request from thinkyhead/thermal_unified
Combine thermal runaway and watch-period
Scott Lahteine 6e5572228d Merge pull request from thinkyhead/wait_before_g28
Split up prepare_move by type
Scott Lahteine 27ad381e25 Allow fractional seconds in G4 and M0
Scott Lahteine b2bd9aae7c SCARA_SEGMENTS_PER_SECOND
Scott Lahteine bd20bd5444 Merge pull request from chris-bo/autobed_sled
improve sled handling
Scott Lahteine 9e95ceb3fc Split up prepare_move by type
- For better encapsulation add inlines for each prepare_move type
- Move controllerFan vars inside the function as statics
- Some formatting cleanup
- Rename `ClearToSend` as `ok_to_send`
Christian Bohn f48599f172 add pin definition to some motherboards
Scott Lahteine b5200e184c Remove extra setup_for_endstop_move
Scott Lahteine 8d814de558 Return void in prevent_dangerous_extrude
Scott Lahteine 367e2eb9f4 Global setup_for_endstop_move
Scott Lahteine fa951f8a0b Always do st_synchronize() before G28
Christian Bohn 27a3b1d895 disable sled pin by default
Christian Bohn fb44b53ae3 sled improvements
- create sled pin definition
- G28 Works with sled
Wurstnase 46d1932380 add plan buffer remaining for 'P' and block buffer remaining 'B'
Scott Lahteine 8a0dc4d54a Merge pull request from Wurstnase/serial_wait
Serial wait
Wurstnase 526ad82d20 activate advanced_ok and no_timeout
Scott Lahteine 2445ae3d3a Combine thermal runaway and watch-period
- Make thermal protection for all hotends and/or bed into simple
switches
- Now enable `WATCH_TEMP_PERIOD` when `THERMAL_PROTECTION_HOTENDS` is
enabled
- Move detailed thermal parameters to `Configuration_adv.h`
- Add sanity checks to warn about old configurations
- Change `WATCH_TEMP_PERIOD` to seconds instead of milliseconds
Scott Lahteine 4097207c75 Merge pull request from thinkyhead/watch_temp
More thermal protection
Scott Lahteine 9b3d4380d3 Only watch the heater that was set
Scott Lahteine f73f4ce555 Make some z probe and servo code tweaks
Scott Lahteine 54deb9eea3 Enable WATCH_TEMP_PERIOD by default
Wurstnase 0cb87795a3 advanced 'ok'
ok N(linenumber) P(bufferremaining)
the host can use this to send the data much faster.

Some pseudo code:
If (bufferremaining > 0)  send command
## as long there is free buffer send command

Also
if (linenumber > lastsend - bufferremaining) send command
## as long last linenumber received is bigger than lastsend (host) - last bufferremaining received
Wurstnase 182e0d99c9 Merge remote-tracking branch 'Marlin8bit/Development' into serial_wait
Scott Lahteine 7f3252eea9 Merge pull request from paclema/Filrunout_configurable_script
Added configurable script for filrunout from configuration.h
Scott Lahteine 79633a74ab Fix MBL compile error
Scott Lahteine 777f2d3820 Merge pull request from fmalpartida/bugFixing
Bug corrected: persistent HOMING message when HOME button pressed for homing.
Scott Lahteine ecb46de349 Merge pull request from bq/Fix_lowercase
Fixed lowercase change missing on commit a22a228b.
fmalpartida 150a35eff8 Bug corrected:
Persistent homing message.
Message was declared as an alert, therefore it was persistent.
Updated to message.
Gina Häußge ab246ab032 Reverting changes to error messages on serial console
This reverts the changes done to the error message for line number mismatches done in commit d43cc2dd5f
Ivan Galvez Junquera 59529b755d Fixed lowercase change missing on commit a22a228b.
Servo.cpp and Servo.h were changed to lowercase in Makefile but not their actual filenames.
Scott Lahteine 1f039cde61 Merge pull request from thinkyhead/too_many_probes
Stow Z probe on M402 without extra raise
Scott Lahteine ca8cec8e8a Merge pull request from paclema/Filament_runout_fix
Fixed sintaxis error of filament runout
Scott Lahteine d4c74b8f8c Don't apply M428 if an error occurs
- Also move audio feedback into the command
- Added shorthand for `lcd_buzz` availability
Scott Lahteine d065d37822 Add M428 to set home_offset logically
paclema 013a09dbe6 Added configurable script for filrunout form configuration.h
paclema 4dcc0fd55a Fixed sintaxis error of filament runout
Scott Lahteine ce3caf447b Tweak how homeaxis deploys and stows
Scott Lahteine a235dca79c Stow z on M402 without extra raise
Scott Lahteine 3688256f86 Merge pull request from thinkyhead/eeprom_in_gcode
Make EEPROM reproducible in GCode
Scott Lahteine 31516e2a3b Merge pull request from Arengorn/Development
Update of servo.h
Scott Lahteine 0f687b5dda Merge branch 'Development' into eeprom_in_gcode
Latest upstream commits
Scott Lahteine 28aef684b4 Merge pull request from Voxel8/sjk/home_y_before_x
Allow Y to home before X with option in Configuration_adv.h.
Scott Lahteine 71a0b1a5bb Disable endstops between homing bumps
Scott Lahteine c36226c4dc Fix homing Z position
Add `sync_plan_position()` after `axis_is_at_home(axis)` to keep the
planner position in sync when homing.
Scott Lahteine ff178d8cf7 Change M421 to take coordinates
This makes `M421` more amenable for irregular matrices
Bernardo ff67ee73fc Update Marlin_main.cpp
Corrected "servo.h" to "Servo.h" because of the updated filename.
Steve Kelly 98ca46006c Allow Y to home before X with option in Configuration_adv.h.
This addresses comments in  and . In particular, this is useful
when both endstops are stationary on a CoreXY system, and the Y axis needs
to be homed before the X so the flags are aligned.
Scott Lahteine 0fca084ea6 Make EEPROM reproducible in GCode
With these changes the output of `M503 S0` is all you need to restore
the EEPROM. Building on this it is straightforward to save and restore
the EEPROM state using the SD card or external GCode file.

- Added `M145` to set “heatup states” for the LCD menu
- Added `M420` to toggle Mesh Bed Leveling
- Added `M421` to set a single Mesh coordinate
- Extended `Config_PrintSettings` with added M codes
- Cleaned up some comments here and there
Scott Lahteine d43cc2dd5f M111 - Debug Level
- Add `M111` as a standard option to set the debug level
- Implement `DEBUG_ECHO` in `process_commands`
- Other debug levels (e.g., `DEBUG_DRYRUN`) need more work
Scott Lahteine a22a228bcc Rename files to move them in the IDE
Scott Lahteine 0438f0d835 Merge pull request from thinkyhead/raise_z_for_m401_m402
Raise Z for M401 and M402
Scott Lahteine b275946a52 Merge pull request from thinkyhead/g4_dwell_message
G4 shows status message only if no message is set already
Scott Lahteine 182f2cda35 Minor cleanup of M48
Scott Lahteine 3a6fd912cd Latest upstream commits, merged
Scott Lahteine 3c9e94e035 Merge pull request from AnHardt/Max6675again
Add variant for MAX6675 in M104
Scott Lahteine 56ff46eb8b Improve code_has_value test
Scott Lahteine ce142afdda G4 shows status message only if no message is set already
- Address issue raised in 
Scott Lahteine 35e79d56a5 Remove set-coordinate extension of G28
Scott Lahteine 3a74bb5039 Merge pull request from Wurstnase/max_endstopp
Max endstopp
AnHardt 0fed46360c Add variant for MAX6675 in M104
Else will throw error:
@:0 B@:0
Error:No thermistors - no temperature
[ERROR] Error:No thermistors - no temperature

when no bed is defined
Scott Lahteine 588ed70d4a Latest upstream commits, merged
Scott Lahteine 0165560333 Apply zprobe_zoffset in axis_is_at_home
Ensure the probe offset will always be included when homing Z.
Scott Lahteine 075386e7fe Merge pull request from thinkyhead/lcd_move_rate
Include axis parameter to ultralcd's line_to_current
Scott Lahteine 2558c10c6c Use the slower feedrate for XY axes
Scott Lahteine 64268f3312 Fixup axis_is_at_home a little
Scott Lahteine 996d0a9185 Squish the code down a little
Scott Lahteine 8534bc376c Fix homing of YZ with DUAL_X_CARRIAGE
Scott Lahteine 3b97a7d446 Merge pull request from AnHardt/beep2
More Beeper clean up
Wurstnase be9e4ceddc fix typo
c'n'p ftw :/
unknown c26d816839 filter any 0
Wurstnase 61ae43f35e v <-> code_value
Wurstnase da0d91a79b max endstopp
no user will home to 0 with a max endstopp
AnHardt 064f2b37d0 More Beeper clean up.
Centralised beep code to lcd_buzz().
From gcode_M300() and lcd_quick_feedback().

Enforced max. duration for M300 to 5 seconds.

Corrected description in 'Configuration.h'

LCD_FEEDBACK_FREQUENCY_HZ 0 gives now a silent delay of
LCD_FEEDBACK_FREQUENCY_DURATION_MS.
Wurstnase 92575cecca new timout/add adv_ok
AnHardt 671aaf2dc9 Minor fix for M300
Corrected wrong order of parameters.
Scott Lahteine d931220a65 Tweak comments
Scott Lahteine 47847765e2 Add M410 QuickStop command
Wurstnase b09a957fce make 'wait' optional and mark as workaround
Scott Lahteine 63b98b8280 Raise Z for M401 and M402
wurstnase d69da22f7c last_command_time inside get_command()
wurstnase 574e2d856e remove config
paclema cde5eee2a5 Removed unnecessary comments
paclema e1b69db6d1 Fixed M48 mismatch between n and P parameter on documentation
Scott Lahteine e0e68c5cbc Rename servos[] array in Marlin to servo[]
Scott Lahteine 642f6a92bc fix type of code_has_value
Scott Lahteine 17ad80c1e1 Spacing in XYZ_CONSTS
Scott Lahteine 09d60e0128 Naming and code comments
Mehmet Sutas 5a9e45cc4a Fix Syntax Error Filament Runout Statement
Scott Lahteine ccddc280be Apply three more commits
Scott Lahteine ac2b23f574 Homing fixes
- Prevent `Z_SAFE_HOMING` from homing Z twice in some cases
- Allow `G28` with XYZ values of 0 to explicitly set the position
- Don’t add `home_offset` when setting XYZ explicitly in `G28`
- Add `code_has_value` function to check for the presence of a numeric
value (could just test for space or nul to allow other types of values)
Scott Lahteine 5fe382949b Some G-Codes comment cleanup
Scott Lahteine 8b16ebe705 Break out prevent_dangerous_extrude feature
- It’s inline here, but could be a macro and duplicated for
`planner.cpp`
Scott Lahteine 9189cc66ab Fix moves for DELTA for MANUAL_BED_LEVELING
- Use `line_to_current` in place of `plan_buffer_line`
Scott Lahteine 2ca099d1e7 Merge pull request from thinkyhead/cold_extrude
Catch dangerous extrude before trying several
Scott Lahteine a00ebf03d4 Merge pull request from AnHardt/LCD_STR
Moved the definitions of the LCD_STR_* to Conditionals.h
Scott Lahteine 1269c445ab Catch dangerous extrude before trying several
AnHardt 540dbb35e2 And an other MSG_BED in Marlin_main.cpp
AnHardt 14d4419e16 Replaced SERIAL_PROTOCOLPGM(MSG_BED) with SERIAL_PROTOCOLPGM("Bed")
Resolved some warnings in Marlin_main.cpp regarding compares of signed and unsigned integers by replacing 'int' or 'uint16_t' with 'uint8_t'.
AnHardt 6a514f3dc9 Aplied HAS_LCD_CONTRAST also to Marlin_main.cpp
and cleaned typo.
Scott Lahteine 3162971cd6 current_position not static
Scott Lahteine 27cb90da8b IsStopped / IsRunning inline
Scott Lahteine e03da4805b Merge pull request from epatel/Development
Mesh bed leveling: Added G29 S3 + finer display steps during manual input + bug fix
Scott Lahteine f7c4e7e19f Fix G29 not deploying in some instances
Edward Patel 002340f32c Merge branch 'Development-Marlin' into Development
Scott Lahteine c379f17117 Encapsulate setting of homing_bump_feedrate
Scott Lahteine d20f42c883 Don't stow the probe until the last grid point!
- Address Issue  at hash #issuecomment-89756858
Scott Lahteine 6d084c017f Fix typo in FWRETRACT handler
Should be `retracting` and not `retract`
Edward Patel 2f0081bbb5 Compile error fix! Fix for merge artifacts.
Edward Patel ea10601406 Merge branch 'Development-Marlin' into Development
Conflicts:
	Marlin/Configuration.h
	Marlin/Marlin_main.cpp
Scott Lahteine 61f8394361 Compare indices instead of floats for probe actions
Scott Lahteine 0935084141 Fix manage_inactivity
- Document `manage_inactivity` function
- Allow `EXTRUDER_RUNOUT_PREVENT` to work with all extruders
- Use faster `memcpy` for copying coordinates
Scott Lahteine c065da52ec Spacing and spelling
Scott Lahteine 8680b515b0 Fix missing tmp_extruder -> target_extruder
Scott Lahteine c185912c19 Latest upstream commits, mostly
Scott Lahteine 1e5c18bb14 Add code_value_short and SERIAL_CHAR
Scott Lahteine 84e4edaea7 Add M48 comment for
Scott Lahteine b98ebd517e disable / enable_all_steppers functions
Scott Lahteine 713953d8c1 Upstream commits, allow no extruder in M105
Scott Lahteine 8f893eb8df Merge pull request from thinkyhead/fixup_probing
Fix probe height at G28 start
Scott Lahteine dde7e11f8e Merge branch 'Development' into fixup_tr
Latest upstream commits
Scott Lahteine abd7fc36b6 Fix probe height at G28 start
Scott Lahteine 610c8c5471 Merge pull request from thinkyhead/fixup_probing
Finish pin tests
Scott Lahteine e4934164e4 Merge pull request from Wurstnase/fix_home_z
fix feedrate for homing z
Scott Lahteine a469d796e1 Add cleanups needed for
Scott Lahteine c0ca26cd50 Merge branch 'Development' into fixup_probing
Latest upstream commits
Scott Lahteine 5c1f08a35f Merge pull request from croadfeldt/Merge_cleanup
Z_PROBE_ENDSTOP
Scott Lahteine 92119d0f7d Static delta[] for SCARA
Scott Lahteine 6b919e14c1 Group all universal variables
Scott Lahteine 21cd2e4fae Merge branch 'Development' into fixup_probing
Latest upstream commits
Scott Lahteine 0e8182bbf2 Additional pin tests, cleanup
Wurstnase 45565b680d second wrong feedrate
Wurstnase 581b2aae04 fix feedrate for homing z
max_feedrate is in mm/s. line_to_destination needs a feedrate in mm/min because there is feedrate/60.
AnHardt 23cd54755f Fix typo in Marlin_main.cpp
related to current_position[Z_AXIS] and retract_zlift.

'+ =' -> '+='

Fix for 
Scott Lahteine e96df67630 Clarify thermal_runaway_protection
- Add comments documenting `thermal_runaway_protection`
- Add an enum for the thermal runaway states
- Add macros for temperature helper functions
- Fix a glitch with the z probe sled in homeaxis
Edward Patel 6b91b7b411 Mesh bed leveling: Added G29 S3 + finer steps in manual probing.
* Use "G29 S3 Xn Yn Zn.nn" to modify bad probed point manually
* Changed manual Z steps from 0.05 to 0.025 and made brought it to Configuration.h
Chris Roadfeldt 26dc80bf2d Typo fixed...