Unify debugging output with debug_out.h (#13388)
This commit is contained in:
		
							
								
								
									
										89
									
								
								Marlin/src/core/debug_out.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										89
									
								
								Marlin/src/core/debug_out.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,89 @@ | |||||||
|  | /** | ||||||
|  |  * Marlin 3D Printer Firmware | ||||||
|  |  * Copyright (C) 2019 MarlinFirmware [https://github.com/MarlinFirmware/Marlin] | ||||||
|  |  * | ||||||
|  |  * Based on Sprinter and grbl. | ||||||
|  |  * Copyright (C) 2011 Camiel Gubbels / Erik van der Zalm | ||||||
|  |  * | ||||||
|  |  * This program is free software: you can redistribute it and/or modify | ||||||
|  |  * it under the terms of the GNU General Public License as published by | ||||||
|  |  * the Free Software Foundation, either version 3 of the License, or | ||||||
|  |  * (at your option) any later version. | ||||||
|  |  * | ||||||
|  |  * This program is distributed in the hope that it will be useful, | ||||||
|  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
|  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | ||||||
|  |  * GNU General Public License for more details. | ||||||
|  |  * | ||||||
|  |  * You should have received a copy of the GNU General Public License | ||||||
|  |  * along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||||
|  |  * | ||||||
|  |  */ | ||||||
|  | #pragma once | ||||||
|  |  | ||||||
|  | // | ||||||
|  | // Serial aliases for debugging. | ||||||
|  | // Include this header after defining DEBUG_OUT | ||||||
|  | //  (or not) in a given .cpp file | ||||||
|  | // | ||||||
|  |  | ||||||
|  | #undef DEBUG_ECHO_START | ||||||
|  | #undef DEBUG_ERROR_START | ||||||
|  | #undef DEBUG_CHAR | ||||||
|  | #undef DEBUG_ECHO | ||||||
|  | #undef DEBUG_ECHO_F | ||||||
|  | #undef DEBUG_ECHOLN | ||||||
|  | #undef DEBUG_ECHOPGM | ||||||
|  | #undef DEBUG_ECHOLNPGM | ||||||
|  | #undef DEBUG_ECHOPAIR | ||||||
|  | #undef DEBUG_ECHOPAIR_F | ||||||
|  | #undef DEBUG_ECHOLNPAIR | ||||||
|  | #undef DEBUG_ECHOLNPAIR_F | ||||||
|  | #undef DEBUG_ECHO_MSG | ||||||
|  | #undef DEBUG_ERROR_MSG | ||||||
|  | #undef DEBUG_EOL | ||||||
|  | #undef DEBUG_POS | ||||||
|  | #undef DEBUG_XYZ | ||||||
|  | #undef DEBUG_DELAY | ||||||
|  |  | ||||||
|  | #if DEBUG_OUT | ||||||
|  |   #define DEBUG_ECHO_START        SERIAL_ECHO_START | ||||||
|  |   #define DEBUG_ERROR_START       SERIAL_ERROR_START | ||||||
|  |   #define DEBUG_CHAR              SERIAL_CHAR | ||||||
|  |   #define DEBUG_ECHO              SERIAL_ECHO | ||||||
|  |   #define DEBUG_ECHO_F            SERIAL_ECHO_F | ||||||
|  |   #define DEBUG_ECHOLN            SERIAL_ECHOLN | ||||||
|  |   #define DEBUG_ECHOPGM           SERIAL_ECHOPGM | ||||||
|  |   #define DEBUG_ECHOLNPGM         SERIAL_ECHOLNPGM | ||||||
|  |   #define DEBUG_ECHOPAIR          SERIAL_ECHOPAIR | ||||||
|  |   #define DEBUG_ECHOPAIR_F        SERIAL_ECHOPAIR_F | ||||||
|  |   #define DEBUG_ECHOLNPAIR        SERIAL_ECHOLNPAIR | ||||||
|  |   #define DEBUG_ECHOLNPAIR_F      SERIAL_ECHOLNPAIR_F | ||||||
|  |   #define DEBUG_ECHO_MSG          SERIAL_ECHO_MSG | ||||||
|  |   #define DEBUG_ERROR_MSG         SERIAL_ERROR_MSG | ||||||
|  |   #define DEBUG_EOL               SERIAL_EOL | ||||||
|  |   #define DEBUG_POS               SERIAL_POS | ||||||
|  |   #define DEBUG_XYZ               SERIAL_XYZ | ||||||
|  |   #define DEBUG_DELAY(ms)         serial_delay(ms) | ||||||
|  | #else | ||||||
|  |   #define DEBUG_ECHO_START()      NOOP | ||||||
|  |   #define DEBUG_ERROR_START()     NOOP | ||||||
|  |   #define DEBUG_CHAR(...)         NOOP | ||||||
|  |   #define DEBUG_ECHO(...)         NOOP | ||||||
|  |   #define DEBUG_ECHO_F(...)       NOOP | ||||||
|  |   #define DEBUG_ECHOLN(...)       NOOP | ||||||
|  |   #define DEBUG_ECHOPGM(...)      NOOP | ||||||
|  |   #define DEBUG_ECHOLNPGM(...)    NOOP | ||||||
|  |   #define DEBUG_ECHOPAIR(...)     NOOP | ||||||
|  |   #define DEBUG_ECHOPAIR_F(...)   NOOP | ||||||
|  |   #define DEBUG_ECHOLNPAIR(...)   NOOP | ||||||
|  |   #define DEBUG_ECHOLNPAIR_F(...) NOOP | ||||||
|  |   #define DEBUG_ECHO_MSG(...)     NOOP | ||||||
|  |   #define DEBUG_ERROR_MSG(...)    NOOP | ||||||
|  |   #define DEBUG_EOL()             NOOP | ||||||
|  |   #define DEBUG_POS(...)          NOOP | ||||||
|  |   #define DEBUG_XYZ(...)          NOOP | ||||||
|  |   #define DEBUG_DELAY(...)        NOOP | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #undef DEBUG_OUT | ||||||
| @@ -35,8 +35,13 @@ enum MarlinDebugFlags : uint8_t { | |||||||
|   MARLIN_DEBUG_ERRORS        = _BV(2), ///< Not implemented |   MARLIN_DEBUG_ERRORS        = _BV(2), ///< Not implemented | ||||||
|   MARLIN_DEBUG_DRYRUN        = _BV(3), ///< Ignore temperature setting and E movement commands |   MARLIN_DEBUG_DRYRUN        = _BV(3), ///< Ignore temperature setting and E movement commands | ||||||
|   MARLIN_DEBUG_COMMUNICATION = _BV(4), ///< Not implemented |   MARLIN_DEBUG_COMMUNICATION = _BV(4), ///< Not implemented | ||||||
|  |   #if ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|     MARLIN_DEBUG_LEVELING    = _BV(5), ///< Print detailed output for homing and leveling |     MARLIN_DEBUG_LEVELING    = _BV(5), ///< Print detailed output for homing and leveling | ||||||
|     MARLIN_DEBUG_MESH_ADJUST = _BV(6), ///< UBL bed leveling |     MARLIN_DEBUG_MESH_ADJUST = _BV(6), ///< UBL bed leveling | ||||||
|  |   #else | ||||||
|  |     MARLIN_DEBUG_LEVELING    = 0, | ||||||
|  |     MARLIN_DEBUG_MESH_ADJUST = 0, | ||||||
|  |   #endif | ||||||
|   MARLIN_DEBUG_ALL           = 0xFF |   MARLIN_DEBUG_ALL           = 0xFF | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -178,5 +183,9 @@ void print_bin(const uint16_t val); | |||||||
| #if ENABLED(DEBUG_LEVELING_FEATURE) | #if ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|   void print_xyz(PGM_P const prefix, PGM_P const suffix, const float x, const float y, const float z); |   void print_xyz(PGM_P const prefix, PGM_P const suffix, const float x, const float y, const float z); | ||||||
|   void print_xyz(PGM_P const prefix, PGM_P const suffix, const float xyz[]); |   void print_xyz(PGM_P const prefix, PGM_P const suffix, const float xyz[]); | ||||||
|   #define DEBUG_POS(SUFFIX,VAR) do { print_xyz(PSTR("  " STRINGIFY(VAR) "="), PSTR(" : " SUFFIX "\n"), VAR); } while(0) |   #define SERIAL_POS(SUFFIX,VAR) do { print_xyz(PSTR("  " STRINGIFY(VAR) "="), PSTR(" : " SUFFIX "\n"), VAR); } while(0) | ||||||
|  |   #define SERIAL_XYZ(PREFIX,...) do { print_xyz(PSTR(PREFIX), NULL, __VA_ARGS__); } while(0) | ||||||
|  | #else | ||||||
|  |   #define SERIAL_POS(...) NOOP | ||||||
|  |   #define SERIAL_XYZ(...) NOOP | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -321,8 +321,11 @@ void safe_delay(millis_t ms) { | |||||||
|     ); |     ); | ||||||
|  |  | ||||||
|     #if HAS_BED_PROBE |     #if HAS_BED_PROBE | ||||||
|       SERIAL_ECHOPGM("Probe Offset X:" STRINGIFY(X_PROBE_OFFSET_FROM_EXTRUDER) " Y:" STRINGIFY(Y_PROBE_OFFSET_FROM_EXTRUDER)); |       SERIAL_ECHOPAIR( | ||||||
|       SERIAL_ECHOPAIR(" Z:", zprobe_zoffset); |         "Probe Offset X:" STRINGIFY(X_PROBE_OFFSET_FROM_EXTRUDER) | ||||||
|  |                     " Y:" STRINGIFY(Y_PROBE_OFFSET_FROM_EXTRUDER) | ||||||
|  |                     " Z:", zprobe_zoffset | ||||||
|  |       ); | ||||||
|       if ((X_PROBE_OFFSET_FROM_EXTRUDER) > 0) |       if ((X_PROBE_OFFSET_FROM_EXTRUDER) > 0) | ||||||
|         SERIAL_ECHOPGM(" (Right"); |         SERIAL_ECHOPGM(" (Right"); | ||||||
|       else if ((X_PROBE_OFFSET_FROM_EXTRUDER) < 0) |       else if ((X_PROBE_OFFSET_FROM_EXTRUDER) < 0) | ||||||
|   | |||||||
| @@ -118,6 +118,8 @@ inline void serial_delay(const millis_t ms) { | |||||||
|  |  | ||||||
| #if ENABLED(DEBUG_LEVELING_FEATURE) | #if ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|   void log_machine_info(); |   void log_machine_info(); | ||||||
|  | #else | ||||||
|  |   #define log_machine_info() NOOP | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| template<typename T> | template<typename T> | ||||||
|   | |||||||
| @@ -29,6 +29,9 @@ | |||||||
|  |  | ||||||
| #include "../../../module/motion.h" | #include "../../../module/motion.h" | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../../../core/debug_out.h" | ||||||
|  |  | ||||||
| int bilinear_grid_spacing[2], bilinear_start[2]; | int bilinear_grid_spacing[2], bilinear_start[2]; | ||||||
| float bilinear_grid_factor[2], | float bilinear_grid_factor[2], | ||||||
|       z_values[GRID_MAX_POINTS_X][GRID_MAX_POINTS_Y]; |       z_values[GRID_MAX_POINTS_X][GRID_MAX_POINTS_Y]; | ||||||
| @@ -37,26 +40,21 @@ float bilinear_grid_factor[2], | |||||||
|  * Extrapolate a single point from its neighbors |  * Extrapolate a single point from its neighbors | ||||||
|  */ |  */ | ||||||
| static void extrapolate_one_point(const uint8_t x, const uint8_t y, const int8_t xdir, const int8_t ydir) { | static void extrapolate_one_point(const uint8_t x, const uint8_t y, const int8_t xdir, const int8_t ydir) { | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) { |   if (DEBUGGING(LEVELING)) { | ||||||
|       SERIAL_ECHOPGM("Extrapolate ["); |     DEBUG_ECHOPGM("Extrapolate ["); | ||||||
|       if (x < 10) SERIAL_CHAR(' '); |     if (x < 10) DEBUG_CHAR(' '); | ||||||
|       SERIAL_ECHO((int)x); |     DEBUG_ECHO((int)x); | ||||||
|       SERIAL_CHAR(xdir ? (xdir > 0 ? '+' : '-') : ' '); |     DEBUG_CHAR(xdir ? (xdir > 0 ? '+' : '-') : ' '); | ||||||
|       SERIAL_CHAR(' '); |     DEBUG_CHAR(' '); | ||||||
|       if (y < 10) SERIAL_CHAR(' '); |     if (y < 10) DEBUG_CHAR(' '); | ||||||
|       SERIAL_ECHO((int)y); |     DEBUG_ECHO((int)y); | ||||||
|       SERIAL_CHAR(ydir ? (ydir > 0 ? '+' : '-') : ' '); |     DEBUG_CHAR(ydir ? (ydir > 0 ? '+' : '-') : ' '); | ||||||
|       SERIAL_CHAR(']'); |     DEBUG_ECHOLNPGM("]"); | ||||||
|   } |   } | ||||||
|   #endif |  | ||||||
|   if (!isnan(z_values[x][y])) { |   if (!isnan(z_values[x][y])) { | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM(" (done)"); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM(" (done)"); |  | ||||||
|     #endif |  | ||||||
|     return;  // Don't overwrite good values. |     return;  // Don't overwrite good values. | ||||||
|   } |   } | ||||||
|   SERIAL_EOL(); |  | ||||||
|  |  | ||||||
|   // Get X neighbors, Y neighbors, and XY neighbors |   // Get X neighbors, Y neighbors, and XY neighbors | ||||||
|   const uint8_t x1 = x + xdir, y1 = y + ydir, x2 = x1 + xdir, y2 = y1 + ydir; |   const uint8_t x1 = x + xdir, y1 = y + ydir, x2 = x1 + xdir, y2 = y1 + ydir; | ||||||
|   | |||||||
| @@ -39,6 +39,9 @@ | |||||||
|   #include "../../lcd/ultralcd.h" |   #include "../../lcd/ultralcd.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../../core/debug_out.h" | ||||||
|  |  | ||||||
| #if ENABLED(G26_MESH_VALIDATION) | #if ENABLED(G26_MESH_VALIDATION) | ||||||
|   bool g26_debug_flag; // = false |   bool g26_debug_flag; // = false | ||||||
| #endif | #endif | ||||||
| @@ -122,9 +125,7 @@ void set_bed_leveling_enabled(const bool enable/*=true*/) { | |||||||
|  * Reset calibration results to zero. |  * Reset calibration results to zero. | ||||||
|  */ |  */ | ||||||
| void reset_bed_level() { | void reset_bed_level() { | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("reset_bed_level"); | ||||||
|     if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("reset_bed_level"); |  | ||||||
|   #endif |  | ||||||
|   set_bed_leveling_enabled(false); |   set_bed_leveling_enabled(false); | ||||||
|   #if ENABLED(MESH_BED_LEVELING) |   #if ENABLED(MESH_BED_LEVELING) | ||||||
|     mbl.reset(); |     mbl.reset(); | ||||||
|   | |||||||
| @@ -29,6 +29,9 @@ | |||||||
| #include "../../../lcd/ultralcd.h" | #include "../../../lcd/ultralcd.h" | ||||||
| #include "../../../Marlin.h" | #include "../../../Marlin.h" | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../../../core/debug_out.h" | ||||||
|  |  | ||||||
| #define UBL_VERSION "1.01" | #define UBL_VERSION "1.01" | ||||||
| #define UBL_OK false | #define UBL_OK false | ||||||
| #define UBL_ERR true | #define UBL_ERR true | ||||||
| @@ -199,12 +202,11 @@ class unified_bed_leveling { | |||||||
|      */ |      */ | ||||||
|     static inline float z_correction_for_x_on_horizontal_mesh_line(const float &rx0, const int x1_i, const int yi) { |     static inline float z_correction_for_x_on_horizontal_mesh_line(const float &rx0, const int x1_i, const int yi) { | ||||||
|       if (!WITHIN(x1_i, 0, GRID_MAX_POINTS_X - 1) || !WITHIN(yi, 0, GRID_MAX_POINTS_Y - 1)) { |       if (!WITHIN(x1_i, 0, GRID_MAX_POINTS_X - 1) || !WITHIN(yi, 0, GRID_MAX_POINTS_Y - 1)) { | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|         if (DEBUGGING(LEVELING)) { |         if (DEBUGGING(LEVELING)) { | ||||||
|             serialprintPGM( !WITHIN(x1_i, 0, GRID_MAX_POINTS_X - 1) ? PSTR("x1_i") : PSTR("yi") ); |           if (WITHIN(x1_i, 0, GRID_MAX_POINTS_X - 1)) DEBUG_ECHOPGM("yi"); else DEBUG_ECHOPGM("x1_i"); | ||||||
|             SERIAL_ECHOLNPAIR(" out of bounds in z_correction_for_x_on_horizontal_mesh_line(rx0=", rx0, ",x1_i=", x1_i, ",yi=", yi, ")"); |           DEBUG_ECHOLNPAIR(" out of bounds in z_correction_for_x_on_horizontal_mesh_line(rx0=", rx0, ",x1_i=", x1_i, ",yi=", yi, ")"); | ||||||
|         } |         } | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         // The requested location is off the mesh. Return UBL_Z_RAISE_WHEN_OFF_MESH or NAN. |         // The requested location is off the mesh. Return UBL_Z_RAISE_WHEN_OFF_MESH or NAN. | ||||||
|         return ( |         return ( | ||||||
| @@ -229,12 +231,11 @@ class unified_bed_leveling { | |||||||
|     // |     // | ||||||
|     static inline float z_correction_for_y_on_vertical_mesh_line(const float &ry0, const int xi, const int y1_i) { |     static inline float z_correction_for_y_on_vertical_mesh_line(const float &ry0, const int xi, const int y1_i) { | ||||||
|       if (!WITHIN(xi, 0, GRID_MAX_POINTS_X - 1) || !WITHIN(y1_i, 0, GRID_MAX_POINTS_Y - 1)) { |       if (!WITHIN(xi, 0, GRID_MAX_POINTS_X - 1) || !WITHIN(y1_i, 0, GRID_MAX_POINTS_Y - 1)) { | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|         if (DEBUGGING(LEVELING)) { |         if (DEBUGGING(LEVELING)) { | ||||||
|             serialprintPGM(!WITHIN(xi, 0, GRID_MAX_POINTS_X - 1) ? PSTR("xi") : PSTR("y1_i")); |           if (WITHIN(xi, 0, GRID_MAX_POINTS_X - 1)) DEBUG_ECHOPGM("y1_i"); else DEBUG_ECHOPGM("xi"); | ||||||
|             SERIAL_ECHOLNPAIR(" out of bounds in z_correction_for_y_on_vertical_mesh_line(ry0=", ry0, ", xi=", xi, ", y1_i=", y1_i, ")"); |           DEBUG_ECHOLNPAIR(" out of bounds in z_correction_for_y_on_vertical_mesh_line(ry0=", ry0, ", xi=", xi, ", y1_i=", y1_i, ")"); | ||||||
|         } |         } | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         // The requested location is off the mesh. Return UBL_Z_RAISE_WHEN_OFF_MESH or NAN. |         // The requested location is off the mesh. Return UBL_Z_RAISE_WHEN_OFF_MESH or NAN. | ||||||
|         return ( |         return ( | ||||||
| @@ -285,17 +286,12 @@ class unified_bed_leveling { | |||||||
|                          mesh_index_to_ypos(cy), z1, |                          mesh_index_to_ypos(cy), z1, | ||||||
|                          mesh_index_to_ypos(cy + 1), z2); |                          mesh_index_to_ypos(cy + 1), z2); | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(MESH_ADJUST)) { |       if (DEBUGGING(MESH_ADJUST)) { | ||||||
|           SERIAL_ECHOPAIR(" raw get_z_correction(", rx0); |         DEBUG_ECHOPAIR(" raw get_z_correction(", rx0); | ||||||
|           SERIAL_CHAR(','); SERIAL_ECHO(ry0); |         DEBUG_CHAR(','); DEBUG_ECHO(ry0); | ||||||
|           SERIAL_ECHOPAIR_F(") = ", z0, 6); |         DEBUG_ECHOPAIR_F(") = ", z0, 6); | ||||||
|  |         DEBUG_ECHOLNPAIR_F(" >>>---> ", z0, 6); | ||||||
|       } |       } | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|         if (DEBUGGING(MESH_ADJUST)) SERIAL_ECHOLNPAIR_F(" >>>---> ", z0, 6); |  | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       if (isnan(z0)) { // if part of the Mesh is undefined, it will show up as NAN |       if (isnan(z0)) { // if part of the Mesh is undefined, it will show up as NAN | ||||||
|         z0 = 0.0;      // in ubl.z_values[][] and propagate through the |         z0 = 0.0;      // in ubl.z_values[][] and propagate through the | ||||||
| @@ -303,15 +299,13 @@ class unified_bed_leveling { | |||||||
|                        // because part of the Mesh is undefined and we don't have the |                        // because part of the Mesh is undefined and we don't have the | ||||||
|                        // information we need to complete the height correction. |                        // information we need to complete the height correction. | ||||||
|  |  | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|         if (DEBUGGING(MESH_ADJUST)) { |         if (DEBUGGING(MESH_ADJUST)) { | ||||||
|             SERIAL_ECHOPAIR("??? Yikes!  NAN in get_z_correction(", rx0); |           DEBUG_ECHOPAIR("??? Yikes!  NAN in get_z_correction(", rx0); | ||||||
|             SERIAL_CHAR(','); |           DEBUG_CHAR(','); | ||||||
|             SERIAL_ECHO(ry0); |           DEBUG_ECHO(ry0); | ||||||
|             SERIAL_CHAR(')'); |           DEBUG_CHAR(')'); | ||||||
|             SERIAL_EOL(); |           DEBUG_EOL(); | ||||||
|         } |         } | ||||||
|         #endif |  | ||||||
|       } |       } | ||||||
|       return z0; |       return z0; | ||||||
|     } |     } | ||||||
| @@ -342,3 +336,6 @@ class unified_bed_leveling { | |||||||
| extern unified_bed_leveling ubl; | extern unified_bed_leveling ubl; | ||||||
|  |  | ||||||
| #define Z_VALUES(X,Y) ubl.z_values[X][Y] | #define Z_VALUES(X,Y) ubl.z_values[X][Y] | ||||||
|  |  | ||||||
|  | // Prevent debugging propagating to other files | ||||||
|  | #include "../../../core/debug_out.h" | ||||||
|   | |||||||
| @@ -46,6 +46,9 @@ | |||||||
|     #include "../../../module/tool_change.h" |     #include "../../../module/tool_change.h" | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|  |   #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  |   #include "../../../core/debug_out.h" | ||||||
|  |  | ||||||
|   #include <math.h> |   #include <math.h> | ||||||
|  |  | ||||||
|   #define UBL_G29_P31 |   #define UBL_G29_P31 | ||||||
| @@ -442,7 +445,7 @@ | |||||||
|               SERIAL_ECHOLNPGM("Mesh invalidated. Probing mesh."); |               SERIAL_ECHOLNPGM("Mesh invalidated. Probing mesh."); | ||||||
|             } |             } | ||||||
|             if (g29_verbose_level > 1) { |             if (g29_verbose_level > 1) { | ||||||
|               SERIAL_ECHOPAIR("Probing Mesh Points Closest to (", g29_x_pos); |               SERIAL_ECHOPAIR("Probing around (", g29_x_pos); | ||||||
|               SERIAL_CHAR(','); |               SERIAL_CHAR(','); | ||||||
|               SERIAL_ECHO(g29_y_pos); |               SERIAL_ECHO(g29_y_pos); | ||||||
|               SERIAL_ECHOLNPGM(").\n"); |               SERIAL_ECHOLNPGM(").\n"); | ||||||
| @@ -1463,27 +1466,24 @@ | |||||||
|  |  | ||||||
|               abort_flag = isnan(measured_z); |               abort_flag = isnan(measured_z); | ||||||
|  |  | ||||||
|               #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|               if (DEBUGGING(LEVELING)) { |               if (DEBUGGING(LEVELING)) { | ||||||
|                   SERIAL_CHAR('('); |                 DEBUG_CHAR('('); | ||||||
|                   SERIAL_ECHO_F(rx, 7); |                 DEBUG_ECHO_F(rx, 7); | ||||||
|                   SERIAL_CHAR(','); |                 DEBUG_CHAR(','); | ||||||
|                   SERIAL_ECHO_F(ry, 7); |                 DEBUG_ECHO_F(ry, 7); | ||||||
|                   SERIAL_ECHOPGM(")   logical: "); |                 DEBUG_ECHOPGM(")   logical: "); | ||||||
|                   SERIAL_CHAR('('); |                 DEBUG_CHAR('('); | ||||||
|                   SERIAL_ECHO_F(LOGICAL_X_POSITION(rx), 7); |                 DEBUG_ECHO_F(LOGICAL_X_POSITION(rx), 7); | ||||||
|                   SERIAL_CHAR(','); |                 DEBUG_CHAR(','); | ||||||
|                   SERIAL_ECHO_F(LOGICAL_Y_POSITION(ry), 7); |                 DEBUG_ECHO_F(LOGICAL_Y_POSITION(ry), 7); | ||||||
|                   SERIAL_ECHOPAIR_F(")   measured: ", measured_z, 7); |                 DEBUG_ECHOPAIR_F(")   measured: ", measured_z, 7); | ||||||
|                   SERIAL_ECHOPAIR_F("   correction: ", get_z_correction(rx, ry), 7); |                 DEBUG_ECHOPAIR_F("   correction: ", get_z_correction(rx, ry), 7); | ||||||
|               } |               } | ||||||
|               #endif |  | ||||||
|  |  | ||||||
|               measured_z -= get_z_correction(rx, ry) /* + zprobe_zoffset */ ; |               measured_z -= get_z_correction(rx, ry) /* + zprobe_zoffset */ ; | ||||||
|  |  | ||||||
|               #if ENABLED(DEBUG_LEVELING_FEATURE) |               if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR_F("   final >>>---> ", measured_z, 7); | ||||||
|                 if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPAIR_F("   final >>>---> ", measured_z, 7); |  | ||||||
|               #endif |  | ||||||
|               if (g29_verbose_level > 3) { |               if (g29_verbose_level > 3) { | ||||||
|                 serial_spaces(16); |                 serial_spaces(16); | ||||||
|                 SERIAL_ECHOLNPAIR("Corrected_Z=", measured_z); |                 SERIAL_ECHOLNPAIR("Corrected_Z=", measured_z); | ||||||
| @@ -1524,31 +1524,27 @@ | |||||||
|                 y_tmp = mesh_index_to_ypos(j), |                 y_tmp = mesh_index_to_ypos(j), | ||||||
|                 z_tmp = z_values[i][j]; |                 z_tmp = z_values[i][j]; | ||||||
|  |  | ||||||
|           #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|           if (DEBUGGING(LEVELING)) { |           if (DEBUGGING(LEVELING)) { | ||||||
|               SERIAL_ECHOPAIR_F("before rotation = [", x_tmp, 7); |             DEBUG_ECHOPAIR_F("before rotation = [", x_tmp, 7); | ||||||
|               SERIAL_CHAR(','); |             DEBUG_CHAR(','); | ||||||
|               SERIAL_ECHO_F(y_tmp, 7); |             DEBUG_ECHO_F(y_tmp, 7); | ||||||
|               SERIAL_CHAR(','); |             DEBUG_CHAR(','); | ||||||
|               SERIAL_ECHO_F(z_tmp, 7); |             DEBUG_ECHO_F(z_tmp, 7); | ||||||
|               SERIAL_ECHOPGM("]   ---> "); |             DEBUG_ECHOPGM("]   ---> "); | ||||||
|               serial_delay(20); |             DEBUG_DELAY(20); | ||||||
|           } |           } | ||||||
|           #endif |  | ||||||
|  |  | ||||||
|           apply_rotation_xyz(rotation, x_tmp, y_tmp, z_tmp); |           apply_rotation_xyz(rotation, x_tmp, y_tmp, z_tmp); | ||||||
|  |  | ||||||
|           #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|           if (DEBUGGING(LEVELING)) { |           if (DEBUGGING(LEVELING)) { | ||||||
|               SERIAL_ECHOPAIR_F("after rotation = [", x_tmp, 7); |             DEBUG_ECHOPAIR_F("after rotation = [", x_tmp, 7); | ||||||
|               SERIAL_CHAR(','); |             DEBUG_CHAR(','); | ||||||
|               SERIAL_ECHO_F(y_tmp, 7); |             DEBUG_ECHO_F(y_tmp, 7); | ||||||
|               SERIAL_CHAR(','); |             DEBUG_CHAR(','); | ||||||
|               SERIAL_ECHO_F(z_tmp, 7); |             DEBUG_ECHO_F(z_tmp, 7); | ||||||
|               SERIAL_ECHOLNPGM("]"); |             DEBUG_ECHOLNPGM("]"); | ||||||
|               serial_delay(55); |             DEBUG_DELAY(55); | ||||||
|           } |           } | ||||||
|           #endif |  | ||||||
|  |  | ||||||
|           z_values[i][j] = z_tmp - lsf_results.D; |           z_values[i][j] = z_tmp - lsf_results.D; | ||||||
|           #if ENABLED(EXTENSIBLE_UI) |           #if ENABLED(EXTENSIBLE_UI) | ||||||
| @@ -1557,21 +1553,20 @@ | |||||||
|         } |         } | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) { |       if (DEBUGGING(LEVELING)) { | ||||||
|         rotation.debug(PSTR("rotation matrix:\n")); |         rotation.debug(PSTR("rotation matrix:\n")); | ||||||
|           SERIAL_ECHOPAIR_F("LSF Results A=", lsf_results.A, 7); |         DEBUG_ECHOPAIR_F("LSF Results A=", lsf_results.A, 7); | ||||||
|           SERIAL_ECHOPAIR_F("  B=", lsf_results.B, 7); |         DEBUG_ECHOPAIR_F("  B=", lsf_results.B, 7); | ||||||
|           SERIAL_ECHOLNPAIR_F("  D=", lsf_results.D, 7); |         DEBUG_ECHOLNPAIR_F("  D=", lsf_results.D, 7); | ||||||
|           serial_delay(55); |         DEBUG_DELAY(55); | ||||||
|  |  | ||||||
|           SERIAL_ECHOPAIR_F("bed plane normal = [", normal.x, 7); |         DEBUG_ECHOPAIR_F("bed plane normal = [", normal.x, 7); | ||||||
|           SERIAL_CHAR(','); |         DEBUG_CHAR(','); | ||||||
|           SERIAL_ECHO_F(normal.y, 7); |         DEBUG_ECHO_F(normal.y, 7); | ||||||
|           SERIAL_CHAR(','); |         DEBUG_CHAR(','); | ||||||
|           SERIAL_ECHO_F(normal.z, 7); |         DEBUG_ECHO_F(normal.z, 7); | ||||||
|           SERIAL_ECHOLNPGM("]"); |         DEBUG_ECHOLNPGM("]"); | ||||||
|           SERIAL_EOL(); |         DEBUG_EOL(); | ||||||
|  |  | ||||||
|         /** |         /** | ||||||
|          * The following code can be used to check the validity of the mesh tilting algorithm. |          * The following code can be used to check the validity of the mesh tilting algorithm. | ||||||
| @@ -1585,34 +1580,32 @@ | |||||||
|         float t, t1, d; |         float t, t1, d; | ||||||
|         t = normal.x * (PROBE_PT_1_X) + normal.y * (PROBE_PT_1_Y); |         t = normal.x * (PROBE_PT_1_X) + normal.y * (PROBE_PT_1_Y); | ||||||
|         d = t + normal.z * z1; |         d = t + normal.z * z1; | ||||||
|           SERIAL_ECHOPAIR_F("D from 1st point: ", d, 6); |         DEBUG_ECHOPAIR_F("D from 1st point: ", d, 6); | ||||||
|           SERIAL_ECHOLNPAIR_F("   Z error: ", normal.z*z1-get_z_correction(PROBE_PT_1_X, PROBE_PT_1_Y), 6); |         DEBUG_ECHOLNPAIR_F("   Z error: ", normal.z*z1-get_z_correction(PROBE_PT_1_X, PROBE_PT_1_Y), 6); | ||||||
|  |  | ||||||
|         t = normal.x * (PROBE_PT_2_X) + normal.y * (PROBE_PT_2_Y); |         t = normal.x * (PROBE_PT_2_X) + normal.y * (PROBE_PT_2_Y); | ||||||
|         d = t + normal.z * z2; |         d = t + normal.z * z2; | ||||||
|           SERIAL_EOL(); |         DEBUG_EOL(); | ||||||
|           SERIAL_ECHOPAIR_F("D from 2nd point: ", d, 6); |         DEBUG_ECHOPAIR_F("D from 2nd point: ", d, 6); | ||||||
|           SERIAL_ECHOLNPAIR_F("   Z error: ", normal.z*z2-get_z_correction(PROBE_PT_2_X, PROBE_PT_2_Y), 6); |         DEBUG_ECHOLNPAIR_F("   Z error: ", normal.z*z2-get_z_correction(PROBE_PT_2_X, PROBE_PT_2_Y), 6); | ||||||
|  |  | ||||||
|         t = normal.x * (PROBE_PT_3_X) + normal.y * (PROBE_PT_3_Y); |         t = normal.x * (PROBE_PT_3_X) + normal.y * (PROBE_PT_3_Y); | ||||||
|         d = t + normal.z * z3; |         d = t + normal.z * z3; | ||||||
|           SERIAL_ECHOPAIR_F("D from 3rd point: ", d, 6); |         DEBUG_ECHOPAIR_F("D from 3rd point: ", d, 6); | ||||||
|           SERIAL_ECHOLNPAIR_F("   Z error: ", normal.z*z3-get_z_correction(PROBE_PT_3_X, PROBE_PT_3_Y), 6); |         DEBUG_ECHOLNPAIR_F("   Z error: ", normal.z*z3-get_z_correction(PROBE_PT_3_X, PROBE_PT_3_Y), 6); | ||||||
|  |  | ||||||
|         t = normal.x * (Z_SAFE_HOMING_X_POINT) + normal.y * (Z_SAFE_HOMING_Y_POINT); |         t = normal.x * (Z_SAFE_HOMING_X_POINT) + normal.y * (Z_SAFE_HOMING_Y_POINT); | ||||||
|         d = t + normal.z * 0; |         d = t + normal.z * 0; | ||||||
|           SERIAL_ECHOLNPAIR_F("D from home location with Z=0 : ", d, 6); |         DEBUG_ECHOLNPAIR_F("D from home location with Z=0 : ", d, 6); | ||||||
|  |  | ||||||
|         t = normal.x * (Z_SAFE_HOMING_X_POINT) + normal.y * (Z_SAFE_HOMING_Y_POINT); |         t = normal.x * (Z_SAFE_HOMING_X_POINT) + normal.y * (Z_SAFE_HOMING_Y_POINT); | ||||||
|         d = t + get_z_correction(Z_SAFE_HOMING_X_POINT, Z_SAFE_HOMING_Y_POINT); // normal.z * 0; |         d = t + get_z_correction(Z_SAFE_HOMING_X_POINT, Z_SAFE_HOMING_Y_POINT); // normal.z * 0; | ||||||
|           SERIAL_ECHOPAIR_F("D from home location using mesh value for Z: ", d, 6); |         DEBUG_ECHOPAIR_F("D from home location using mesh value for Z: ", d, 6); | ||||||
|  |  | ||||||
|           SERIAL_ECHOPAIR("   Z error: (", Z_SAFE_HOMING_X_POINT); |         DEBUG_ECHOPAIR("   Z error: (", Z_SAFE_HOMING_X_POINT, ",", Z_SAFE_HOMING_Y_POINT); | ||||||
|           SERIAL_ECHOPAIR(",", Z_SAFE_HOMING_Y_POINT); |         DEBUG_ECHOLNPAIR_F(") = ", get_z_correction(Z_SAFE_HOMING_X_POINT, Z_SAFE_HOMING_Y_POINT), 6); | ||||||
|           SERIAL_ECHOLNPAIR_F(") = ", get_z_correction(Z_SAFE_HOMING_X_POINT, Z_SAFE_HOMING_Y_POINT), 6); |  | ||||||
|         #endif |         #endif | ||||||
|       } // DEBUGGING(LEVELING) |       } // DEBUGGING(LEVELING) | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -42,6 +42,9 @@ MMU2 mmu2; | |||||||
|   #include "../../feature/host_actions.h" |   #include "../../feature/host_actions.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(MMU2_DEBUG) | ||||||
|  | #include "../../core/debug_out.h" | ||||||
|  |  | ||||||
| #define MMU_TODELAY 100 | #define MMU_TODELAY 100 | ||||||
| #define MMU_TIMEOUT 10 | #define MMU_TIMEOUT 10 | ||||||
| #define MMU_CMD_TIMEOUT 60000ul //5min timeout for mmu commands (except P0) | #define MMU_CMD_TIMEOUT 60000ul //5min timeout for mmu commands (except P0) | ||||||
| @@ -128,9 +131,7 @@ void MMU2::init() { | |||||||
| } | } | ||||||
|  |  | ||||||
| void MMU2::reset() { | void MMU2::reset() { | ||||||
|   #if ENABLED(MMU2_DEBUG) |   DEBUG_ECHOLNPGM("MMU <= reset"); | ||||||
|     SERIAL_ECHOLNPGM("MMU <= reset"); |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   #if PIN_EXISTS(MMU2_RST) |   #if PIN_EXISTS(MMU2_RST) | ||||||
|     WRITE(MMU2_RST_PIN, LOW); |     WRITE(MMU2_RST_PIN, LOW); | ||||||
| @@ -153,10 +154,8 @@ void MMU2::mmuLoop() { | |||||||
|  |  | ||||||
|     case -1: |     case -1: | ||||||
|       if (rx_start()) { |       if (rx_start()) { | ||||||
|         #if ENABLED(MMU2_DEBUG) |         DEBUG_ECHOLNPGM("MMU => 'start'"); | ||||||
|           SERIAL_ECHOLNPGM("MMU => 'start'"); |         DEBUG_ECHOLNPGM("MMU <= 'S1'"); | ||||||
|           SERIAL_ECHOLNPGM("MMU <= 'S1'"); |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         // send "read version" request |         // send "read version" request | ||||||
|         tx_str_P(PSTR("S1\n")); |         tx_str_P(PSTR("S1\n")); | ||||||
| @@ -173,9 +172,7 @@ void MMU2::mmuLoop() { | |||||||
|       if (rx_ok()) { |       if (rx_ok()) { | ||||||
|         sscanf(rx_buffer, "%uok\n", &version); |         sscanf(rx_buffer, "%uok\n", &version); | ||||||
|  |  | ||||||
|         #if ENABLED(MMU2_DEBUG) |         DEBUG_ECHOLNPAIR("MMU => ", version, "\nMMU <= 'S2'"); | ||||||
|           SERIAL_ECHOLNPAIR("MMU => ", version, "\nMMU <= 'S2'"); |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         tx_str_P(PSTR("S2\n")); // read build number |         tx_str_P(PSTR("S2\n")); // read build number | ||||||
|         state = -3; |         state = -3; | ||||||
| @@ -185,24 +182,19 @@ void MMU2::mmuLoop() { | |||||||
|     case -3: |     case -3: | ||||||
|       if (rx_ok()) { |       if (rx_ok()) { | ||||||
|         sscanf(rx_buffer, "%uok\n", &buildnr); |         sscanf(rx_buffer, "%uok\n", &buildnr); | ||||||
|         #if ENABLED(MMU2_DEBUG) |  | ||||||
|           SERIAL_ECHOLNPAIR("MMU => ", buildnr); |         DEBUG_ECHOLNPAIR("MMU => ", buildnr); | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         checkVersion(); |         checkVersion(); | ||||||
|  |  | ||||||
|         #if ENABLED(MMU2_MODE_12V) |         #if ENABLED(MMU2_MODE_12V) | ||||||
|           #if ENABLED(MMU2_DEBUG) |           DEBUG_ECHOLNPGM("MMU <= 'M1'"); | ||||||
|             SERIAL_ECHOLNPGM("MMU <= 'M1'"); |  | ||||||
|           #endif |  | ||||||
|  |  | ||||||
|           tx_str_P(PSTR("M1\n")); // switch to stealth mode |           tx_str_P(PSTR("M1\n")); // switch to stealth mode | ||||||
|           state = -5; |           state = -5; | ||||||
|  |  | ||||||
|         #else |         #else | ||||||
|           #if ENABLED(MMU2_DEBUG) |           DEBUG_ECHOLNPGM("MMU <= 'P0'"); | ||||||
|             SERIAL_ECHOLNPGM("MMU <= 'P0'"); |  | ||||||
|           #endif |  | ||||||
|  |  | ||||||
|           tx_str_P(PSTR("P0\n")); // read finda |           tx_str_P(PSTR("P0\n")); // read finda | ||||||
|           state = -4; |           state = -4; | ||||||
| @@ -213,15 +205,11 @@ void MMU2::mmuLoop() { | |||||||
|     case -5: |     case -5: | ||||||
|       // response to M1 |       // response to M1 | ||||||
|       if (rx_ok()) { |       if (rx_ok()) { | ||||||
|         #if ENABLED(MMU2_DEBUG) |         DEBUG_ECHOLNPGM("MMU => ok"); | ||||||
|           SERIAL_ECHOLNPGM("MMU => ok"); |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         checkVersion(); |         checkVersion(); | ||||||
|  |  | ||||||
|         #if ENABLED(MMU2_DEBUG) |         DEBUG_ECHOLNPGM("MMU <= 'P0'"); | ||||||
|           SERIAL_ECHOLNPGM("MMU <= 'P0'"); |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         tx_str_P(PSTR("P0\n")); // read finda |         tx_str_P(PSTR("P0\n")); // read finda | ||||||
|         state = -4; |         state = -4; | ||||||
| @@ -232,9 +220,7 @@ void MMU2::mmuLoop() { | |||||||
|       if (rx_ok()) { |       if (rx_ok()) { | ||||||
|         sscanf(rx_buffer, "%hhuok\n", &finda); |         sscanf(rx_buffer, "%hhuok\n", &finda); | ||||||
|  |  | ||||||
|         #if ENABLED(MMU2_DEBUG) |         DEBUG_ECHOLNPAIR("MMU => ", finda, "\nMMU - ENABLED"); | ||||||
|           SERIAL_ECHOLNPAIR("MMU => ", finda, "\nMMU - ENABLED"); |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         enabled = true; |         enabled = true; | ||||||
|         state = 1; |         state = 1; | ||||||
| @@ -246,40 +232,26 @@ void MMU2::mmuLoop() { | |||||||
|         if (WITHIN(cmd, MMU_CMD_T0, MMU_CMD_T4)) { |         if (WITHIN(cmd, MMU_CMD_T0, MMU_CMD_T4)) { | ||||||
|           // tool change |           // tool change | ||||||
|           int filament = cmd - MMU_CMD_T0; |           int filament = cmd - MMU_CMD_T0; | ||||||
|  |           DEBUG_ECHOLNPAIR("MMU <= T", filament); | ||||||
|           #if ENABLED(MMU2_DEBUG) |  | ||||||
|             SERIAL_ECHOLNPAIR("MMU <= T", filament); |  | ||||||
|           #endif |  | ||||||
|  |  | ||||||
|           tx_printf_P(PSTR("T%d\n"), filament); |           tx_printf_P(PSTR("T%d\n"), filament); | ||||||
|           state = 3; // wait for response |           state = 3; // wait for response | ||||||
|         } |         } | ||||||
|         else if (WITHIN(cmd, MMU_CMD_L0, MMU_CMD_L4)) { |         else if (WITHIN(cmd, MMU_CMD_L0, MMU_CMD_L4)) { | ||||||
|           // load |           // load | ||||||
|           int filament = cmd - MMU_CMD_L0; |           int filament = cmd - MMU_CMD_L0; | ||||||
|  |           DEBUG_ECHOLNPAIR("MMU <= L", filament); | ||||||
|           #if ENABLED(MMU2_DEBUG) |  | ||||||
|             SERIAL_ECHOLNPAIR("MMU <= L", filament); |  | ||||||
|           #endif |  | ||||||
|  |  | ||||||
|           tx_printf_P(PSTR("L%d\n"), filament); |           tx_printf_P(PSTR("L%d\n"), filament); | ||||||
|           state = 3; // wait for response |           state = 3; // wait for response | ||||||
|         } |         } | ||||||
|         else if (cmd == MMU_CMD_C0) { |         else if (cmd == MMU_CMD_C0) { | ||||||
|           // continue loading |           // continue loading | ||||||
|  |           DEBUG_ECHOLNPGM("MMU <= 'C0'"); | ||||||
|           #if ENABLED(MMU2_DEBUG) |  | ||||||
|             SERIAL_ECHOLNPGM("MMU <= 'C0'"); |  | ||||||
|           #endif |  | ||||||
|  |  | ||||||
|           tx_str_P(PSTR("C0\n")); |           tx_str_P(PSTR("C0\n")); | ||||||
|           state = 3; // wait for response |           state = 3; // wait for response | ||||||
|         } |         } | ||||||
|         else if (cmd == MMU_CMD_U0) { |         else if (cmd == MMU_CMD_U0) { | ||||||
|           // unload current |           // unload current | ||||||
|           #if ENABLED(MMU2_DEBUG) |           DEBUG_ECHOLNPGM("MMU <= 'U0'"); | ||||||
|             SERIAL_ECHOLNPGM("MMU <= 'U0'"); |  | ||||||
|           #endif |  | ||||||
|  |  | ||||||
|           tx_str_P(PSTR("U0\n")); |           tx_str_P(PSTR("U0\n")); | ||||||
|           state = 3; // wait for response |           state = 3; // wait for response | ||||||
| @@ -287,31 +259,22 @@ void MMU2::mmuLoop() { | |||||||
|         else if (WITHIN(cmd, MMU_CMD_E0, MMU_CMD_E4)) { |         else if (WITHIN(cmd, MMU_CMD_E0, MMU_CMD_E4)) { | ||||||
|           // eject filament |           // eject filament | ||||||
|           int filament = cmd - MMU_CMD_E0; |           int filament = cmd - MMU_CMD_E0; | ||||||
|  |           DEBUG_ECHOLNPAIR("MMU <= E", filament); | ||||||
|           #if ENABLED(MMU2_DEBUG) |  | ||||||
|             SERIAL_ECHOLNPAIR("MMU <= E", filament); |  | ||||||
|           #endif |  | ||||||
|           tx_printf_P(PSTR("E%d\n"), filament); |           tx_printf_P(PSTR("E%d\n"), filament); | ||||||
|           state = 3; // wait for response |           state = 3; // wait for response | ||||||
|         } |         } | ||||||
|         else if (cmd == MMU_CMD_R0) { |         else if (cmd == MMU_CMD_R0) { | ||||||
|           // recover after eject |           // recover after eject | ||||||
|           #if ENABLED(MMU2_DEBUG) |           DEBUG_ECHOLNPGM("MMU <= 'R0'"); | ||||||
|             SERIAL_ECHOLNPGM("MMU <= 'R0'"); |  | ||||||
|           #endif |  | ||||||
|  |  | ||||||
|           tx_str_P(PSTR("R0\n")); |           tx_str_P(PSTR("R0\n")); | ||||||
|           state = 3; // wait for response |           state = 3; // wait for response | ||||||
|         } |         } | ||||||
|         else if (WITHIN(cmd, MMU_CMD_F0, MMU_CMD_F4)) { |         else if (WITHIN(cmd, MMU_CMD_F0, MMU_CMD_F4)) { | ||||||
|           // filament type |           // filament type | ||||||
|           int filament = cmd - MMU_CMD_F0; |           int filament = cmd - MMU_CMD_F0; | ||||||
|           #if ENABLED(MMU2_DEBUG) |           DEBUG_ECHOPAIR("MMU <= F", filament, " "); | ||||||
|             SERIAL_ECHOPAIR("MMU <= F", filament, " "); |           DEBUG_ECHO_F(cmd_arg, DEC); | ||||||
|             SERIAL_ECHO_F(cmd_arg, DEC); |           DEBUG_EOL(); | ||||||
|             SERIAL_ECHOPGM("\n"); |  | ||||||
|           #endif |  | ||||||
|  |  | ||||||
|           tx_printf_P(PSTR("F%d %d\n"), filament, cmd_arg); |           tx_printf_P(PSTR("F%d %d\n"), filament, cmd_arg); | ||||||
|           state = 3; // wait for response |           state = 3; // wait for response | ||||||
|         } |         } | ||||||
| @@ -330,17 +293,8 @@ void MMU2::mmuLoop() { | |||||||
|       if (rx_ok()) { |       if (rx_ok()) { | ||||||
|         sscanf(rx_buffer, "%hhuok\n", &finda); |         sscanf(rx_buffer, "%hhuok\n", &finda); | ||||||
|  |  | ||||||
|         #if ENABLED(MMU2_DEBUG) |  | ||||||
|         // This is super annoying. Only activate if necessary |         // This is super annoying. Only activate if necessary | ||||||
|           /* |         // if (findaRunoutValid) DEBUG_ECHOLNPAIR_F("MMU <= 'P0'\nMMU => ", finda, 6); | ||||||
|             if (findaRunoutValid) { |  | ||||||
|               SERIAL_ECHOLNPGM("MMU <= 'P0'"); |  | ||||||
|               SERIAL_ECHOPGM("MMU => "); |  | ||||||
|               SERIAL_ECHO_F(finda, DEC); |  | ||||||
|               SERIAL_ECHOPGM("\n"); |  | ||||||
|             } |  | ||||||
|           */ |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         state = 1; |         state = 1; | ||||||
|  |  | ||||||
| @@ -355,10 +309,7 @@ void MMU2::mmuLoop() { | |||||||
|  |  | ||||||
|     case 3:   // response to mmu commands |     case 3:   // response to mmu commands | ||||||
|       if (rx_ok()) { |       if (rx_ok()) { | ||||||
|         #if ENABLED(MMU2_DEBUG) |         DEBUG_ECHOLNPGM("MMU => 'ok'"); | ||||||
|           SERIAL_ECHOLNPGM("MMU => 'ok'"); |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         ready = true; |         ready = true; | ||||||
|         state = 1; |         state = 1; | ||||||
|         last_cmd = MMU_CMD_NONE; |         last_cmd = MMU_CMD_NONE; | ||||||
| @@ -366,10 +317,7 @@ void MMU2::mmuLoop() { | |||||||
|       else if (ELAPSED(millis(), last_request + MMU_CMD_TIMEOUT)) { |       else if (ELAPSED(millis(), last_request + MMU_CMD_TIMEOUT)) { | ||||||
|         // resend request after timeout |         // resend request after timeout | ||||||
|         if (last_cmd) { |         if (last_cmd) { | ||||||
|           #if ENABLED(MMU2_DEBUG) |           DEBUG_ECHOLNPGM("MMU retry"); | ||||||
|             SERIAL_ECHOLNPGM("MMU retry"); |  | ||||||
|           #endif |  | ||||||
|  |  | ||||||
|           cmd = last_cmd; |           cmd = last_cmd; | ||||||
|           last_cmd = MMU_CMD_NONE; |           last_cmd = MMU_CMD_NONE; | ||||||
|         } |         } | ||||||
| @@ -404,10 +352,7 @@ bool MMU2::rx_str_P(const char* str) { | |||||||
|     rx_buffer[i] = '\0'; |     rx_buffer[i] = '\0'; | ||||||
|  |  | ||||||
|     if (i == sizeof(rx_buffer) - 1) { |     if (i == sizeof(rx_buffer) - 1) { | ||||||
|       #if ENABLED(MMU2_DEBUG) |       DEBUG_ECHOLNPGM("rx buffer overrun"); | ||||||
|         SERIAL_ECHOLNPGM("rx buffer overrun"); |  | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @@ -876,12 +821,8 @@ void MMU2::filamentRunout() { | |||||||
|       const float es = pgm_read_float(&(step->extrude)), |       const float es = pgm_read_float(&(step->extrude)), | ||||||
|                   fr = pgm_read_float(&(step->feedRate)); |                   fr = pgm_read_float(&(step->feedRate)); | ||||||
|  |  | ||||||
|       #if ENABLED(MMU2_DEBUG) |       DEBUG_ECHO_START(); | ||||||
|         SERIAL_ECHO_START(); |       DEBUG_ECHOLNPAIR("E step ", es, "/", fr); | ||||||
|         SERIAL_ECHOPAIR("E step ", es); |  | ||||||
|         SERIAL_CHAR('/'); |  | ||||||
|         SERIAL_ECHOLN(fr); |  | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       current_position[E_AXIS] += es; |       current_position[E_AXIS] += es; | ||||||
|       planner.buffer_line(current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS], |       planner.buffer_line(current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS], | ||||||
|   | |||||||
| @@ -48,6 +48,9 @@ | |||||||
|   #include "../../../libs/vector_3.h" |   #include "../../../libs/vector_3.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../../../core/debug_out.h" | ||||||
|  |  | ||||||
| #if ABL_GRID | #if ABL_GRID | ||||||
|   #if ENABLED(PROBE_Y_FIRST) |   #if ENABLED(PROBE_Y_FIRST) | ||||||
|     #define PR_OUTER_VAR xCount |     #define PR_OUTER_VAR xCount | ||||||
| @@ -187,12 +190,7 @@ G29_TYPE GcodeSuite::G29() { | |||||||
|   if (axis_unhomed_error()) G29_RETURN(false); |   if (axis_unhomed_error()) G29_RETURN(false); | ||||||
|  |  | ||||||
|   if (!no_action && planner.leveling_active && parser.boolval('O')) { // Auto-level only if needed |   if (!no_action && planner.leveling_active && parser.boolval('O')) { // Auto-level only if needed | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("> Auto-level not needed, skip\n<<< G29"); | ||||||
|       if (DEBUGGING(LEVELING)) { |  | ||||||
|         SERIAL_ECHOLNPGM("> Auto-level not needed, skip"); |  | ||||||
|         SERIAL_ECHOLNPGM("<<< G29"); |  | ||||||
|       } |  | ||||||
|     #endif |  | ||||||
|     G29_RETURN(false); |     G29_RETURN(false); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -470,9 +468,7 @@ G29_TYPE GcodeSuite::G29() { | |||||||
|  |  | ||||||
|     #if ENABLED(AUTO_BED_LEVELING_3POINT) |     #if ENABLED(AUTO_BED_LEVELING_3POINT) | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("> 3-point Leveling"); | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("> 3-point Leveling"); |  | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       // Probe at 3 arbitrary points |       // Probe at 3 arbitrary points | ||||||
|       points[0].z = points[1].z = points[2].z = 0; |       points[0].z = points[1].z = points[2].z = 0; | ||||||
| @@ -555,13 +551,7 @@ G29_TYPE GcodeSuite::G29() { | |||||||
|           ExtUI::onMeshUpdate(xCount, yCount, z_values[xCount][yCount]); |           ExtUI::onMeshUpdate(xCount, yCount, z_values[xCount][yCount]); | ||||||
|         #endif |         #endif | ||||||
|  |  | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |         if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("Save X", xCount, " Y", yCount, " Z", measured_z + zoffset); | ||||||
|           if (DEBUGGING(LEVELING)) { |  | ||||||
|             SERIAL_ECHOPAIR("Save X", xCount); |  | ||||||
|             SERIAL_ECHOPAIR(" Y", yCount); |  | ||||||
|             SERIAL_ECHOLNPAIR(" Z", measured_z + zoffset); |  | ||||||
|           } |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|       #endif |       #endif | ||||||
|     } |     } | ||||||
| @@ -790,9 +780,7 @@ G29_TYPE GcodeSuite::G29() { | |||||||
|   // return or loop before this point. |   // return or loop before this point. | ||||||
|   // |   // | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) DEBUG_POS("> probing complete", current_position); |   if (DEBUGGING(LEVELING)) DEBUG_POS("> probing complete", current_position); | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   #if ENABLED(PROBE_MANUALLY) |   #if ENABLED(PROBE_MANUALLY) | ||||||
|     g29_in_progress = false; |     g29_in_progress = false; | ||||||
| @@ -929,9 +917,7 @@ G29_TYPE GcodeSuite::G29() { | |||||||
|         // Correct the current XYZ position based on the tilted plane. |         // Correct the current XYZ position based on the tilted plane. | ||||||
|         // |         // | ||||||
|  |  | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|         if (DEBUGGING(LEVELING)) DEBUG_POS("G29 uncorrected XYZ", current_position); |         if (DEBUGGING(LEVELING)) DEBUG_POS("G29 uncorrected XYZ", current_position); | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         float converted[XYZ]; |         float converted[XYZ]; | ||||||
|         COPY(converted, current_position); |         COPY(converted, current_position); | ||||||
| @@ -945,46 +931,32 @@ G29_TYPE GcodeSuite::G29() { | |||||||
|           && NEAR(current_position[Y_AXIS], yProbe - (Y_PROBE_OFFSET_FROM_EXTRUDER)) |           && NEAR(current_position[Y_AXIS], yProbe - (Y_PROBE_OFFSET_FROM_EXTRUDER)) | ||||||
|         ) { |         ) { | ||||||
|           const float simple_z = current_position[Z_AXIS] - measured_z; |           const float simple_z = current_position[Z_AXIS] - measured_z; | ||||||
|           #if ENABLED(DEBUG_LEVELING_FEATURE) |           if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("Probed Z", simple_z, "  Matrix Z", converted[Z_AXIS], "  Discrepancy ", simple_z - converted[Z_AXIS]); | ||||||
|             if (DEBUGGING(LEVELING)) { |  | ||||||
|               SERIAL_ECHOPAIR("Z from Probe:", simple_z); |  | ||||||
|               SERIAL_ECHOPAIR("  Matrix:", converted[Z_AXIS]); |  | ||||||
|               SERIAL_ECHOLNPAIR("  Discrepancy:", simple_z - converted[Z_AXIS]); |  | ||||||
|             } |  | ||||||
|           #endif |  | ||||||
|           converted[Z_AXIS] = simple_z; |           converted[Z_AXIS] = simple_z; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // The rotated XY and corrected Z are now current_position |         // The rotated XY and corrected Z are now current_position | ||||||
|         COPY(current_position, converted); |         COPY(current_position, converted); | ||||||
|  |  | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|         if (DEBUGGING(LEVELING)) DEBUG_POS("G29 corrected XYZ", current_position); |         if (DEBUGGING(LEVELING)) DEBUG_POS("G29 corrected XYZ", current_position); | ||||||
|         #endif |  | ||||||
|       } |       } | ||||||
|  |  | ||||||
|     #elif ENABLED(AUTO_BED_LEVELING_BILINEAR) |     #elif ENABLED(AUTO_BED_LEVELING_BILINEAR) | ||||||
|  |  | ||||||
|       if (!dryrun) { |       if (!dryrun) { | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |         if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("G29 uncorrected Z:", current_position[Z_AXIS]); | ||||||
|           if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPAIR("G29 uncorrected Z:", current_position[Z_AXIS]); |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         // Unapply the offset because it is going to be immediately applied |         // Unapply the offset because it is going to be immediately applied | ||||||
|         // and cause compensation movement in Z |         // and cause compensation movement in Z | ||||||
|         current_position[Z_AXIS] -= bilinear_z_offset(current_position); |         current_position[Z_AXIS] -= bilinear_z_offset(current_position); | ||||||
|  |  | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |         if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR(" corrected Z:", current_position[Z_AXIS]); | ||||||
|           if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPAIR(" corrected Z:", current_position[Z_AXIS]); |  | ||||||
|         #endif |  | ||||||
|       } |       } | ||||||
|  |  | ||||||
|     #endif // ABL_PLANAR |     #endif // ABL_PLANAR | ||||||
|  |  | ||||||
|     #ifdef Z_PROBE_END_SCRIPT |     #ifdef Z_PROBE_END_SCRIPT | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("Z Probe End Script: ", Z_PROBE_END_SCRIPT); | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPAIR("Z Probe End Script: ", Z_PROBE_END_SCRIPT); |  | ||||||
|       #endif |  | ||||||
|       planner.synchronize(); |       planner.synchronize(); | ||||||
|       enqueue_and_echo_commands_P(PSTR(Z_PROBE_END_SCRIPT)); |       enqueue_and_echo_commands_P(PSTR(Z_PROBE_END_SCRIPT)); | ||||||
|     #endif |     #endif | ||||||
| @@ -996,9 +968,7 @@ G29_TYPE GcodeSuite::G29() { | |||||||
|   // Restore state after probing |   // Restore state after probing | ||||||
|   if (!faux) clean_up_after_endstop_or_probe_move(); |   if (!faux) clean_up_after_endstop_or_probe_move(); | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("<<< G29"); | ||||||
|     if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("<<< G29"); |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   KEEPALIVE_STATE(IN_HANDLER); |   KEEPALIVE_STATE(IN_HANDLER); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -49,6 +49,9 @@ | |||||||
|   #include "../../libs/L6470/L6470_Marlin.h" |   #include "../../libs/L6470/L6470_Marlin.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../../core/debug_out.h" | ||||||
|  |  | ||||||
| #if ENABLED(QUICK_HOME) | #if ENABLED(QUICK_HOME) | ||||||
|  |  | ||||||
|   static void quick_home_xy() { |   static void quick_home_xy() { | ||||||
| @@ -113,9 +116,7 @@ | |||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Z_SAFE_HOMING >>>"); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("Z_SAFE_HOMING >>>"); |  | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     sync_plan_position(); |     sync_plan_position(); | ||||||
|  |  | ||||||
| @@ -133,9 +134,7 @@ | |||||||
|  |  | ||||||
|     if (position_is_reachable(destination[X_AXIS], destination[Y_AXIS])) { |     if (position_is_reachable(destination[X_AXIS], destination[Y_AXIS])) { | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) DEBUG_POS("Z_SAFE_HOMING", destination); |       if (DEBUGGING(LEVELING)) DEBUG_POS("Z_SAFE_HOMING", destination); | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       // This causes the carriage on Dual X to unpark |       // This causes the carriage on Dual X to unpark | ||||||
|       #if ENABLED(DUAL_X_CARRIAGE) |       #if ENABLED(DUAL_X_CARRIAGE) | ||||||
| @@ -154,9 +153,7 @@ | |||||||
|       SERIAL_ECHO_MSG(MSG_ZPROBE_OUT); |       SERIAL_ECHO_MSG(MSG_ZPROBE_OUT); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("<<< Z_SAFE_HOMING"); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("<<< Z_SAFE_HOMING"); |  | ||||||
|     #endif |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
| #endif // Z_SAFE_HOMING | #endif // Z_SAFE_HOMING | ||||||
| @@ -182,12 +179,10 @@ | |||||||
|  */ |  */ | ||||||
| void GcodeSuite::G28(const bool always_home_all) { | void GcodeSuite::G28(const bool always_home_all) { | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) { |   if (DEBUGGING(LEVELING)) { | ||||||
|       SERIAL_ECHOLNPGM(">>> G28"); |     DEBUG_ECHOLNPGM(">>> G28"); | ||||||
|     log_machine_info(); |     log_machine_info(); | ||||||
|   } |   } | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   #if ENABLED(DUAL_X_CARRIAGE) |   #if ENABLED(DUAL_X_CARRIAGE) | ||||||
|     bool IDEX_saved_duplication_state = extruder_duplication_enabled; |     bool IDEX_saved_duplication_state = extruder_duplication_enabled; | ||||||
| @@ -200,9 +195,7 @@ void GcodeSuite::G28(const bool always_home_all) { | |||||||
|       sync_plan_position(); |       sync_plan_position(); | ||||||
|       SERIAL_ECHOLNPGM("Simulated Homing"); |       SERIAL_ECHOLNPGM("Simulated Homing"); | ||||||
|       report_current_position(); |       report_current_position(); | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("<<< G28"); | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("<<< G28"); |  | ||||||
|       #endif |  | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|   #endif |   #endif | ||||||
| @@ -215,12 +208,7 @@ void GcodeSuite::G28(const bool always_home_all) { | |||||||
|         all_axes_homed()  // homing needed only if never homed |         all_axes_homed()  // homing needed only if never homed | ||||||
|       #endif |       #endif | ||||||
|     ) { |     ) { | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("> homing not needed, skip\n<<< G28"); | ||||||
|         if (DEBUGGING(LEVELING)) { |  | ||||||
|           SERIAL_ECHOLNPGM("> homing not needed, skip"); |  | ||||||
|           SERIAL_ECHOLNPGM("<<< G28"); |  | ||||||
|         } |  | ||||||
|       #endif |  | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @@ -297,12 +285,7 @@ void GcodeSuite::G28(const bool always_home_all) { | |||||||
|       // Raise Z before homing any other axes and z is not already high enough (never lower z) |       // Raise Z before homing any other axes and z is not already high enough (never lower z) | ||||||
|       destination[Z_AXIS] = z_homing_height; |       destination[Z_AXIS] = z_homing_height; | ||||||
|       if (destination[Z_AXIS] > current_position[Z_AXIS]) { |       if (destination[Z_AXIS] > current_position[Z_AXIS]) { | ||||||
|  |         if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("Raise Z (before homing) to ", destination[Z_AXIS]); | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|           if (DEBUGGING(LEVELING)) |  | ||||||
|             SERIAL_ECHOLNPAIR("Raise Z (before homing) to ", destination[Z_AXIS]); |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         do_blocking_move_to_z(destination[Z_AXIS]); |         do_blocking_move_to_z(destination[Z_AXIS]); | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
| @@ -451,9 +434,7 @@ void GcodeSuite::G28(const bool always_home_all) { | |||||||
|       SERIAL_ECHOLNPGM(MSG_Z_MOVE_COMP); |       SERIAL_ECHOLNPGM(MSG_Z_MOVE_COMP); | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("<<< G28"); | ||||||
|     if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("<<< G28"); |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   #if HAS_DRIVER(L6470) |   #if HAS_DRIVER(L6470) | ||||||
|     // Set L6470 absolute position registers to counts |     // Set L6470 absolute position registers to counts | ||||||
|   | |||||||
| @@ -42,6 +42,9 @@ | |||||||
|   #include "../../feature/bedlevel/bedlevel.h" |   #include "../../feature/bedlevel/bedlevel.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../../core/debug_out.h" | ||||||
|  |  | ||||||
| float z_auto_align_xpos[Z_STEPPER_COUNT] = Z_STEPPER_ALIGN_X, | float z_auto_align_xpos[Z_STEPPER_COUNT] = Z_STEPPER_ALIGN_X, | ||||||
|       z_auto_align_ypos[Z_STEPPER_COUNT] = Z_STEPPER_ALIGN_Y; |       z_auto_align_ypos[Z_STEPPER_COUNT] = Z_STEPPER_ALIGN_Y; | ||||||
|  |  | ||||||
| @@ -59,19 +62,15 @@ inline void set_all_z_lock(const bool lock) { | |||||||
|  * Parameters: I<iterations> T<accuracy> A<amplification> |  * Parameters: I<iterations> T<accuracy> A<amplification> | ||||||
|  */ |  */ | ||||||
| void GcodeSuite::G34() { | void GcodeSuite::G34() { | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) { |   if (DEBUGGING(LEVELING)) { | ||||||
|       SERIAL_ECHOLNPGM(">>> G34"); |     DEBUG_ECHOLNPGM(">>> G34"); | ||||||
|     log_machine_info(); |     log_machine_info(); | ||||||
|   } |   } | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   do { // break out on error |   do { // break out on error | ||||||
|  |  | ||||||
|     if (!TEST(axis_known_position, X_AXIS) || !TEST(axis_known_position, Y_AXIS)) { |     if (!TEST(axis_known_position, X_AXIS) || !TEST(axis_known_position, Y_AXIS)) { | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("> XY homing required."); | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("> XY homing required."); |  | ||||||
|       #endif |  | ||||||
|       break; |       break; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -128,9 +127,7 @@ void GcodeSuite::G34() { | |||||||
|           z_measured[Z_STEPPER_COUNT] = { 0 }; |           z_measured[Z_STEPPER_COUNT] = { 0 }; | ||||||
|     bool err_break = false; |     bool err_break = false; | ||||||
|     for (uint8_t iteration = 0; iteration < z_auto_align_iterations; ++iteration) { |     for (uint8_t iteration = 0; iteration < z_auto_align_iterations; ++iteration) { | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("> probing all positions."); | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("> probing all positions."); |  | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       // Reset minimum value |       // Reset minimum value | ||||||
|       float z_measured_min = 100000.0f; |       float z_measured_min = 100000.0f; | ||||||
| @@ -141,19 +138,12 @@ void GcodeSuite::G34() { | |||||||
|  |  | ||||||
|         // Stop on error |         // Stop on error | ||||||
|         if (isnan(z_measured[zstepper])) { |         if (isnan(z_measured[zstepper])) { | ||||||
|           #if ENABLED(DEBUG_LEVELING_FEATURE) |           if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("> PROBING FAILED!"); | ||||||
|             if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("> PROBING FAILED!"); |  | ||||||
|           #endif |  | ||||||
|           err_break = true; |           err_break = true; | ||||||
|           break; |           break; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |         if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("> Z", int(zstepper + 1), " measured position is ", z_measured[zstepper]); | ||||||
|           if (DEBUGGING(LEVELING)) { |  | ||||||
|             SERIAL_ECHOPAIR("> Z", int(zstepper + 1)); |  | ||||||
|             SERIAL_ECHOLNPAIR(" measured position is ", z_measured[zstepper]); |  | ||||||
|           } |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         // Remember the maximum position to calculate the correction |         // Remember the maximum position to calculate the correction | ||||||
|         z_measured_min = MIN(z_measured_min, z_measured[zstepper]); |         z_measured_min = MIN(z_measured_min, z_measured[zstepper]); | ||||||
| @@ -178,9 +168,7 @@ void GcodeSuite::G34() { | |||||||
|         // Check for lost accuracy compared to last move |         // Check for lost accuracy compared to last move | ||||||
|         if (last_z_align_move[zstepper] < z_align_abs - 1.0) { |         if (last_z_align_move[zstepper] < z_align_abs - 1.0) { | ||||||
|           // Stop here |           // Stop here | ||||||
|           #if ENABLED(DEBUG_LEVELING_FEATURE) |           if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("> detected decreasing accuracy."); | ||||||
|             if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("> detected decreasing accuracy."); |  | ||||||
|           #endif |  | ||||||
|           err_break = true; |           err_break = true; | ||||||
|           break; |           break; | ||||||
|         } |         } | ||||||
| @@ -190,12 +178,7 @@ void GcodeSuite::G34() { | |||||||
|         // Only stop early if all measured points achieve accuracy target |         // Only stop early if all measured points achieve accuracy target | ||||||
|         if (z_align_abs > z_auto_align_accuracy) success_break = false; |         if (z_align_abs > z_auto_align_accuracy) success_break = false; | ||||||
|  |  | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |         if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("> Z", int(zstepper + 1), " corrected by ", z_align_move); | ||||||
|           if (DEBUGGING(LEVELING)) { |  | ||||||
|             SERIAL_ECHOPAIR("> Z", int(zstepper + 1)); |  | ||||||
|             SERIAL_ECHOLNPAIR(" corrected by ", z_align_move); |  | ||||||
|           } |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         switch (zstepper) { |         switch (zstepper) { | ||||||
|           case 0: stepper.set_z_lock(false); break; |           case 0: stepper.set_z_lock(false); break; | ||||||
| @@ -219,9 +202,7 @@ void GcodeSuite::G34() { | |||||||
|       stepper.set_separate_multi_axis(false); |       stepper.set_separate_multi_axis(false); | ||||||
|  |  | ||||||
|       if (success_break) { |       if (success_break) { | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |         if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("> achieved target accuracy."); | ||||||
|           if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("> achieved target accuracy."); |  | ||||||
|         #endif |  | ||||||
|         break; |         break; | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
| @@ -252,9 +233,7 @@ void GcodeSuite::G34() { | |||||||
|  |  | ||||||
|   } while(0); |   } while(0); | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("<<< G34"); | ||||||
|     if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("<<< G34"); |  | ||||||
|   #endif |  | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
|   | |||||||
| @@ -31,32 +31,22 @@ | |||||||
|   #include "../../module/delta.h" |   #include "../../module/delta.h" | ||||||
|   #include "../../module/motion.h" |   #include "../../module/motion.h" | ||||||
|  |  | ||||||
|  |   #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  |   #include "../../core/debug_out.h" | ||||||
|  |  | ||||||
|   /** |   /** | ||||||
|    * M666: Set delta endstop adjustment |    * M666: Set delta endstop adjustment | ||||||
|    */ |    */ | ||||||
|   void GcodeSuite::M666() { |   void GcodeSuite::M666() { | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM(">>> M666"); | ||||||
|       if (DEBUGGING(LEVELING)) { |  | ||||||
|         SERIAL_ECHOLNPGM(">>> M666"); |  | ||||||
|       } |  | ||||||
|     #endif |  | ||||||
|     LOOP_XYZ(i) { |     LOOP_XYZ(i) { | ||||||
|       if (parser.seen(axis_codes[i])) { |       if (parser.seen(axis_codes[i])) { | ||||||
|         const float v = parser.value_linear_units(); |         const float v = parser.value_linear_units(); | ||||||
|         if (v * Z_HOME_DIR <= 0) delta_endstop_adj[i] = v; |         if (v * Z_HOME_DIR <= 0) delta_endstop_adj[i] = v; | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |         if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("delta_endstop_adj[", axis_codes[i], "] = ", delta_endstop_adj[i]); | ||||||
|           if (DEBUGGING(LEVELING)) { |  | ||||||
|             SERIAL_ECHOPAIR("delta_endstop_adj[", axis_codes[i]); |  | ||||||
|             SERIAL_ECHOLNPAIR("] = ", delta_endstop_adj[i]); |  | ||||||
|           } |  | ||||||
|         #endif |  | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("<<< M666"); | ||||||
|       if (DEBUGGING(LEVELING)) { |  | ||||||
|         SERIAL_ECHOLNPGM("<<< M666"); |  | ||||||
|       } |  | ||||||
|     #endif |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
| #elif HAS_EXTRA_ENDSTOPS | #elif HAS_EXTRA_ENDSTOPS | ||||||
|   | |||||||
| @@ -34,14 +34,14 @@ void GcodeSuite::M111() { | |||||||
|                     str_debug_8[] PROGMEM = MSG_DEBUG_DRYRUN, |                     str_debug_8[] PROGMEM = MSG_DEBUG_DRYRUN, | ||||||
|                     str_debug_16[] PROGMEM = MSG_DEBUG_COMMUNICATION |                     str_debug_16[] PROGMEM = MSG_DEBUG_COMMUNICATION | ||||||
|                     #if ENABLED(DEBUG_LEVELING_FEATURE) |                     #if ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|                       , str_debug_32[] PROGMEM = MSG_DEBUG_LEVELING |                       , str_debug_lvl[] PROGMEM = MSG_DEBUG_LEVELING | ||||||
|                     #endif |                     #endif | ||||||
|                     ; |                     ; | ||||||
|  |  | ||||||
|   static PGM_P const debug_strings[] PROGMEM = { |   static PGM_P const debug_strings[] PROGMEM = { | ||||||
|     str_debug_1, str_debug_2, str_debug_4, str_debug_8, str_debug_16 |     str_debug_1, str_debug_2, str_debug_4, str_debug_8, str_debug_16 | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     #if ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|       , str_debug_32 |       , str_debug_lvl | ||||||
|     #endif |     #endif | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -31,6 +31,9 @@ | |||||||
|   #include "../../feature/prusa_MMU2/mmu2.h" |   #include "../../feature/prusa_MMU2/mmu2.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../../core/debug_out.h" | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * T0-T<n>: Switch tool, usually switching extruders |  * T0-T<n>: Switch tool, usually switching extruders | ||||||
|  * |  * | ||||||
| @@ -45,14 +48,10 @@ | |||||||
|  */ |  */ | ||||||
| void GcodeSuite::T(const uint8_t tool_index) { | void GcodeSuite::T(const uint8_t tool_index) { | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) { |   if (DEBUGGING(LEVELING)) { | ||||||
|       SERIAL_ECHOPAIR(">>> T(", tool_index); |     DEBUG_ECHOLNPAIR(">>> T(", tool_index, ")"); | ||||||
|       SERIAL_CHAR(')'); |  | ||||||
|       SERIAL_EOL(); |  | ||||||
|     DEBUG_POS("BEFORE", current_position); |     DEBUG_POS("BEFORE", current_position); | ||||||
|   } |   } | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   #if ENABLED(PRUSA_MMU2) |   #if ENABLED(PRUSA_MMU2) | ||||||
|     if (parser.string_arg) { |     if (parser.string_arg) { | ||||||
| @@ -75,10 +74,8 @@ void GcodeSuite::T(const uint8_t tool_index) { | |||||||
|  |  | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) { |   if (DEBUGGING(LEVELING)) { | ||||||
|     DEBUG_POS("AFTER", current_position); |     DEBUG_POS("AFTER", current_position); | ||||||
|       SERIAL_ECHOLNPGM("<<< T()"); |     DEBUG_ECHOLNPGM("<<< T()"); | ||||||
|   } |   } | ||||||
|   #endif |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -29,6 +29,9 @@ | |||||||
| #include "../../../module/stepper_indirection.h" | #include "../../../module/stepper_indirection.h" | ||||||
| #include "../../../module/planner.h" | #include "../../../module/planner.h" | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(L6470_CHITCHAT) | ||||||
|  | #include "../../../core/debug_out.h" | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * |  * | ||||||
|  * M906: report or set KVAL_HOLD which sets the maximum effective voltage provided by the |  * M906: report or set KVAL_HOLD which sets the maximum effective voltage provided by the | ||||||
| @@ -93,7 +96,7 @@ void L6470_report_current(L6470 &motor, const uint8_t axis) { | |||||||
|   L6470.say_axis(axis); |   L6470.say_axis(axis); | ||||||
|   #if ENABLED(L6470_CHITCHAT) |   #if ENABLED(L6470_CHITCHAT) | ||||||
|     sprintf_P(temp_buf, PSTR("   status: %4x   "), status); |     sprintf_P(temp_buf, PSTR("   status: %4x   "), status); | ||||||
|     SERIAL_ECHO(temp_buf); |     DEBUG_ECHO(temp_buf); | ||||||
|     print_bin(status); |     print_bin(status); | ||||||
|   #endif |   #endif | ||||||
|   sprintf_P(temp_buf, PSTR("\n...OverCurrent Threshold: %2d (%4d mA)"), overcurrent_threshold, (overcurrent_threshold + 1) * 375); |   sprintf_P(temp_buf, PSTR("\n...OverCurrent Threshold: %2d (%4d mA)"), overcurrent_threshold, (overcurrent_threshold + 1) * 375); | ||||||
| @@ -134,7 +137,7 @@ void L6470_report_current(L6470 &motor, const uint8_t axis) { | |||||||
| void GcodeSuite::M906() { | void GcodeSuite::M906() { | ||||||
|   #define L6470_SET_KVAL_HOLD(Q) stepper##Q.SetParam(L6470_KVAL_HOLD, value) |   #define L6470_SET_KVAL_HOLD(Q) stepper##Q.SetParam(L6470_KVAL_HOLD, value) | ||||||
|  |  | ||||||
|   L6470_ECHOLNPGM("M906"); |   DEBUG_ECHOLNPGM("M906"); | ||||||
|  |  | ||||||
|   bool report_current = true; |   bool report_current = true; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -29,6 +29,9 @@ | |||||||
| #include "../../../module/planner.h" | #include "../../../module/planner.h" | ||||||
| #include "../../../libs/L6470/L6470_Marlin.h" | #include "../../../libs/L6470/L6470_Marlin.h" | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(L6470_CHITCHAT) | ||||||
|  | #include "../../../core/debug_out.h" | ||||||
|  |  | ||||||
| /** | /** | ||||||
|  * |  * | ||||||
|  * M916: increase KVAL_HOLD until get thermal warning |  * M916: increase KVAL_HOLD until get thermal warning | ||||||
| @@ -59,7 +62,7 @@ | |||||||
|  |  | ||||||
| void GcodeSuite::M916() { | void GcodeSuite::M916() { | ||||||
|  |  | ||||||
|   L6470_ECHOLNPGM("M916"); |   DEBUG_ECHOLNPGM("M916"); | ||||||
|  |  | ||||||
|   // Variables used by L6470_get_user_input function - some may not be used |   // Variables used by L6470_get_user_input function - some may not be used | ||||||
|   char axis_mon[3][3] = { "  ", "  ", "  " };  // list of Axes to be monitored |   char axis_mon[3][3] = { "  ", "  ", "  " };  // list of Axes to be monitored | ||||||
| @@ -80,7 +83,7 @@ void GcodeSuite::M916() { | |||||||
|   if (L6470.get_user_input(driver_count, axis_index, axis_mon, position_max, position_min, final_feedrate, kval_hold, over_current_flag, ocd_th_val, stall_th_val, over_current_threshold)) |   if (L6470.get_user_input(driver_count, axis_index, axis_mon, position_max, position_min, final_feedrate, kval_hold, over_current_flag, ocd_th_val, stall_th_val, over_current_threshold)) | ||||||
|     return;  // quit if invalid user input |     return;  // quit if invalid user input | ||||||
|  |  | ||||||
|   L6470_ECHOLNPAIR("feedrate = ", final_feedrate); |   DEBUG_ECHOLNPAIR("feedrate = ", final_feedrate); | ||||||
|  |  | ||||||
|   planner.synchronize();                             // wait for all current movement commands to complete |   planner.synchronize();                             // wait for all current movement commands to complete | ||||||
|  |  | ||||||
| @@ -92,11 +95,11 @@ void GcodeSuite::M916() { | |||||||
|   char gcode_string[80]; |   char gcode_string[80]; | ||||||
|   uint16_t status_composite = 0; |   uint16_t status_composite = 0; | ||||||
|  |  | ||||||
|   L6470_ECHOLNPGM(".\n."); |   DEBUG_ECHOLNPGM(".\n."); | ||||||
|  |  | ||||||
|   do { |   do { | ||||||
|  |  | ||||||
|     L6470_ECHOLNPAIR("kval_hold = ", kval_hold);   // set & report KVAL_HOLD for this run |     DEBUG_ECHOLNPAIR("kval_hold = ", kval_hold);   // set & report KVAL_HOLD for this run | ||||||
|  |  | ||||||
|     for (j = 0; j < driver_count; j++) |     for (j = 0; j < driver_count; j++) | ||||||
|       L6470.set_param(axis_index[j], L6470_KVAL_HOLD, kval_hold); |       L6470.set_param(axis_index[j], L6470_KVAL_HOLD, kval_hold); | ||||||
| @@ -119,9 +122,9 @@ void GcodeSuite::M916() { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (status_composite && (status_composite & STATUS_UVLO)) { |     if (status_composite && (status_composite & STATUS_UVLO)) { | ||||||
|       L6470_ECHOLNPGM("Test aborted (Undervoltage lockout active)"); |       DEBUG_ECHOLNPGM("Test aborted (Undervoltage lockout active)"); | ||||||
|       for (j = 0; j < driver_count; j++) { |       for (j = 0; j < driver_count; j++) { | ||||||
|         L6470_ECHOPGM("..."); |         DEBUG_ECHOPGM("..."); | ||||||
|         L6470.error_status_decode(axis_status[j], axis_index[j]); |         L6470.error_status_decode(axis_status[j], axis_index[j]); | ||||||
|       } |       } | ||||||
|       return; |       return; | ||||||
| @@ -133,18 +136,18 @@ void GcodeSuite::M916() { | |||||||
|  |  | ||||||
|   } while (!(status_composite & (STATUS_TH_WRN | STATUS_TH_SD)) && kval_hold);  // exit when kval_hold == 0 (rolls over) |   } while (!(status_composite & (STATUS_TH_WRN | STATUS_TH_SD)) && kval_hold);  // exit when kval_hold == 0 (rolls over) | ||||||
|  |  | ||||||
|   L6470_ECHOPGM(".\n.\nThermal warning/shutdown "); |   DEBUG_ECHOPGM(".\n.\nThermal warning/shutdown "); | ||||||
|   if ((status_composite & (STATUS_TH_WRN | STATUS_TH_SD))) { |   if ((status_composite & (STATUS_TH_WRN | STATUS_TH_SD))) { | ||||||
|     L6470_ECHOLNPGM("has occurred"); |     DEBUG_ECHOLNPGM("has occurred"); | ||||||
|     for (j = 0; j < driver_count; j++) { |     for (j = 0; j < driver_count; j++) { | ||||||
|       L6470_ECHOPGM("..."); |       DEBUG_ECHOPGM("..."); | ||||||
|       L6470.error_status_decode(axis_status[j], axis_index[j]); |       L6470.error_status_decode(axis_status[j], axis_index[j]); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   else |   else | ||||||
|     L6470_ECHOLNPGM("(Unable to get)"); |     DEBUG_ECHOLNPGM("(Unable to get)"); | ||||||
|  |  | ||||||
|   L6470_ECHOLNPGM("."); |   DEBUG_ECHOLNPGM("."); | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -176,7 +179,7 @@ void GcodeSuite::M916() { | |||||||
|  */ |  */ | ||||||
| void GcodeSuite::M917() { | void GcodeSuite::M917() { | ||||||
|  |  | ||||||
|   L6470_ECHOLNPGM("M917"); |   DEBUG_ECHOLNPGM("M917"); | ||||||
|  |  | ||||||
|   char axis_mon[3][3] = { "  ", "  ", "  " };  // list of axes to be monitored |   char axis_mon[3][3] = { "  ", "  ", "  " };  // list of axes to be monitored | ||||||
|   uint8_t axis_index[3]; |   uint8_t axis_index[3]; | ||||||
| @@ -196,7 +199,7 @@ void GcodeSuite::M917() { | |||||||
|   if (L6470.get_user_input(driver_count, axis_index, axis_mon, position_max, position_min, final_feedrate, kval_hold, over_current_flag, ocd_th_val, stall_th_val, over_current_threshold)) |   if (L6470.get_user_input(driver_count, axis_index, axis_mon, position_max, position_min, final_feedrate, kval_hold, over_current_flag, ocd_th_val, stall_th_val, over_current_threshold)) | ||||||
|     return;  // quit if invalid user input |     return;  // quit if invalid user input | ||||||
|  |  | ||||||
|   L6470_ECHOLNPAIR("feedrate = ", final_feedrate); |   DEBUG_ECHOLNPAIR("feedrate = ", final_feedrate); | ||||||
|  |  | ||||||
|   planner.synchronize();                             // wait for all current movement commands to complete |   planner.synchronize();                             // wait for all current movement commands to complete | ||||||
|   for (j = 0; j < driver_count; j++) |   for (j = 0; j < driver_count; j++) | ||||||
| @@ -211,16 +214,16 @@ void GcodeSuite::M917() { | |||||||
|         // 2 - OCD finalized - decreasing STALL - exit when STALL warning happens |         // 2 - OCD finalized - decreasing STALL - exit when STALL warning happens | ||||||
|         // 3 - OCD finalized - increasing STALL - exit when STALL warning stop |         // 3 - OCD finalized - increasing STALL - exit when STALL warning stop | ||||||
|         // 4 - all testing completed |         // 4 - all testing completed | ||||||
|   L6470_ECHOPAIR(".\n.\n.\nover_current threshold : ", (ocd_th_val + 1) * 375);   // first status display |   DEBUG_ECHOPAIR(".\n.\n.\nover_current threshold : ", (ocd_th_val + 1) * 375);   // first status display | ||||||
|   L6470_ECHOPAIR("  (OCD_TH:  : ", ocd_th_val); |   DEBUG_ECHOPAIR("  (OCD_TH:  : ", ocd_th_val); | ||||||
|   L6470_ECHOPAIR(")   Stall threshold: ", (stall_th_val + 1) * 31.25); |   DEBUG_ECHOPAIR(")   Stall threshold: ", (stall_th_val + 1) * 31.25); | ||||||
|   L6470_ECHOPAIR("  (STALL_TH: ", stall_th_val); |   DEBUG_ECHOPAIR("  (STALL_TH: ", stall_th_val); | ||||||
|   L6470_ECHOLNPGM(")"); |   DEBUG_ECHOLNPGM(")"); | ||||||
|  |  | ||||||
|   do { |   do { | ||||||
|  |  | ||||||
|     L6470_ECHOPAIR("STALL threshold : ", (stall_th_val + 1) * 31.25); |     DEBUG_ECHOPAIR("STALL threshold : ", (stall_th_val + 1) * 31.25); | ||||||
|     L6470_ECHOLNPAIR("   OCD threshold : ", (ocd_th_val + 1) * 375); |     DEBUG_ECHOLNPAIR("   OCD threshold : ", (ocd_th_val + 1) * 375); | ||||||
|  |  | ||||||
|     sprintf_P(gcode_string, PSTR("G0 %s%4.3f  F%4.3f"), temp_axis_string, position_min, final_feedrate); |     sprintf_P(gcode_string, PSTR("G0 %s%4.3f  F%4.3f"), temp_axis_string, position_min, final_feedrate); | ||||||
|     gcode.process_subcommands_now_P(gcode_string); |     gcode.process_subcommands_now_P(gcode_string); | ||||||
| @@ -238,16 +241,16 @@ void GcodeSuite::M917() { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (status_composite && (status_composite & STATUS_UVLO)) { |     if (status_composite && (status_composite & STATUS_UVLO)) { | ||||||
|       L6470_ECHOLNPGM("Test aborted (Undervoltage lockout active)"); |       DEBUG_ECHOLNPGM("Test aborted (Undervoltage lockout active)"); | ||||||
|       for (j = 0; j < driver_count; j++) { |       for (j = 0; j < driver_count; j++) { | ||||||
|         L6470_ECHOPGM("..."); |         DEBUG_ECHOPGM("..."); | ||||||
|         L6470.error_status_decode(axis_status[j], axis_index[j]); |         L6470.error_status_decode(axis_status[j], axis_index[j]); | ||||||
|       } |       } | ||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (status_composite & (STATUS_TH_WRN | STATUS_TH_SD)) { |     if (status_composite & (STATUS_TH_WRN | STATUS_TH_SD)) { | ||||||
|       L6470_ECHOLNPGM("thermal problem - waiting for chip(s) to cool down "); |       DEBUG_ECHOLNPGM("thermal problem - waiting for chip(s) to cool down "); | ||||||
|       uint16_t status_composite_temp = 0; |       uint16_t status_composite_temp = 0; | ||||||
|       uint8_t k = 0; |       uint8_t k = 0; | ||||||
|       do { |       do { | ||||||
| @@ -255,11 +258,11 @@ void GcodeSuite::M917() { | |||||||
|         if (!(k % 4)) { |         if (!(k % 4)) { | ||||||
|           kval_hold *= 0.95; |           kval_hold *= 0.95; | ||||||
|           L6470_EOL(); |           L6470_EOL(); | ||||||
|           L6470_ECHOLNPAIR("Lowering KVAL_HOLD by about 5% to ", kval_hold); |           DEBUG_ECHOLNPAIR("Lowering KVAL_HOLD by about 5% to ", kval_hold); | ||||||
|           for (j = 0; j < driver_count; j++) |           for (j = 0; j < driver_count; j++) | ||||||
|             L6470.set_param(axis_index[j], L6470_KVAL_HOLD, kval_hold); |             L6470.set_param(axis_index[j], L6470_KVAL_HOLD, kval_hold); | ||||||
|         } |         } | ||||||
|         L6470_ECHOLNPGM("."); |         DEBUG_ECHOLNPGM("."); | ||||||
|         gcode.reset_stepper_timeout(); // reset_stepper_timeout to keep steppers powered |         gcode.reset_stepper_timeout(); // reset_stepper_timeout to keep steppers powered | ||||||
|         watchdog_reset();   // beat the dog |         watchdog_reset();   // beat the dog | ||||||
|         safe_delay(5000); |         safe_delay(5000); | ||||||
| @@ -281,22 +284,22 @@ void GcodeSuite::M917() { | |||||||
|             if (ocd_th_val >=15) { |             if (ocd_th_val >=15) { | ||||||
|               ocd_th_val = 15;           // limit to max |               ocd_th_val = 15;           // limit to max | ||||||
|               test_phase = 2;            // at highest value so skip phase 1 |               test_phase = 2;            // at highest value so skip phase 1 | ||||||
|               L6470_ECHOLNPGM("LOGIC E0A OCD at highest - skip to 2"); |               DEBUG_ECHOLNPGM("LOGIC E0A OCD at highest - skip to 2"); | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
|               ocd_th_val++;              // normal exit to next phase |               ocd_th_val++;              // normal exit to next phase | ||||||
|               test_phase = 1;            // setup for first pass of phase 1 |               test_phase = 1;            // setup for first pass of phase 1 | ||||||
|               L6470_ECHOLNPGM("LOGIC E0B - inc OCD  & go to 1"); |               DEBUG_ECHOLNPGM("LOGIC E0B - inc OCD  & go to 1"); | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|           else {  // phase 0 without OCD warning - keep on decrementing if can |           else {  // phase 0 without OCD warning - keep on decrementing if can | ||||||
|             if (ocd_th_val) { |             if (ocd_th_val) { | ||||||
|               ocd_th_val--;              // try lower value |               ocd_th_val--;              // try lower value | ||||||
|               L6470_ECHOLNPGM("LOGIC E0C - dec OCD"); |               DEBUG_ECHOLNPGM("LOGIC E0C - dec OCD"); | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
|               test_phase = 2;            // at lowest value without warning so skip phase 1 |               test_phase = 2;            // at lowest value without warning so skip phase 1 | ||||||
|               L6470_ECHOLNPGM("LOGIC E0D - OCD at latest - go to 2"); |               DEBUG_ECHOLNPGM("LOGIC E0D - OCD at latest - go to 2"); | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|         } break; |         } break; | ||||||
| @@ -307,16 +310,16 @@ void GcodeSuite::M917() { | |||||||
|             if (ocd_th_val >= 15) { |             if (ocd_th_val >= 15) { | ||||||
|               ocd_th_val = 15;           // limit to max |               ocd_th_val = 15;           // limit to max | ||||||
|               test_phase = 2;            // at highest value so go to next phase |               test_phase = 2;            // at highest value so go to next phase | ||||||
|               L6470_ECHOLNPGM("LOGIC E1A - OCD at max - go to 2"); |               DEBUG_ECHOLNPGM("LOGIC E1A - OCD at max - go to 2"); | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
|               ocd_th_val++;              // try a higher value |               ocd_th_val++;              // try a higher value | ||||||
|               L6470_ECHOLNPGM("LOGIC E1B - inc OCD"); |               DEBUG_ECHOLNPGM("LOGIC E1B - inc OCD"); | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|           else { // phase 1 without OCD warning - normal exit to phase 2 |           else { // phase 1 without OCD warning - normal exit to phase 2 | ||||||
|             test_phase = 2; |             test_phase = 2; | ||||||
|             L6470_ECHOLNPGM("LOGIC E1C - no OCD warning - go to 1"); |             DEBUG_ECHOLNPGM("LOGIC E1C - no OCD warning - go to 1"); | ||||||
|           } |           } | ||||||
|         } break; |         } break; | ||||||
|  |  | ||||||
| @@ -325,25 +328,25 @@ void GcodeSuite::M917() { | |||||||
|             // phase 2 with stall warning - time to go to next phase |             // phase 2 with stall warning - time to go to next phase | ||||||
|             if (stall_th_val >= 127) { |             if (stall_th_val >= 127) { | ||||||
|               stall_th_val = 127;  // limit to max |               stall_th_val = 127;  // limit to max | ||||||
|               L6470_ECHOLNPGM("LOGIC E2A - STALL warning, STALL at max, quit"); |               DEBUG_ECHOLNPGM("LOGIC E2A - STALL warning, STALL at max, quit"); | ||||||
|               L6470_ECHOLNPGM("finished - STALL at maximum value but still have stall warning"); |               DEBUG_ECHOLNPGM("finished - STALL at maximum value but still have stall warning"); | ||||||
|               test_phase = 4; |               test_phase = 4; | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
|               test_phase = 3;              // normal exit to next phase (found failing value of STALL) |               test_phase = 3;              // normal exit to next phase (found failing value of STALL) | ||||||
|               stall_th_val++;              // setup for first pass of phase 3 |               stall_th_val++;              // setup for first pass of phase 3 | ||||||
|               L6470_ECHOLNPGM("LOGIC E2B - INC - STALL warning, inc Stall, go to 3"); |               DEBUG_ECHOLNPGM("LOGIC E2B - INC - STALL warning, inc Stall, go to 3"); | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|           else {  // phase 2 without stall warning - decrement if can |           else {  // phase 2 without stall warning - decrement if can | ||||||
|             if (stall_th_val) { |             if (stall_th_val) { | ||||||
|               stall_th_val--;              // try a lower value |               stall_th_val--;              // try a lower value | ||||||
|               L6470_ECHOLNPGM("LOGIC E2C - no STALL, dec STALL"); |               DEBUG_ECHOLNPGM("LOGIC E2C - no STALL, dec STALL"); | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
|               L6470_ECHOLNPGM("finished - STALL at lowest value but still do NOT have stall warning"); |               DEBUG_ECHOLNPGM("finished - STALL at lowest value but still do NOT have stall warning"); | ||||||
|               test_phase = 4; |               test_phase = 4; | ||||||
|               L6470_ECHOLNPGM("LOGIC E2D - no STALL, at lowest so quit"); |               DEBUG_ECHOLNPGM("LOGIC E2D - no STALL, at lowest so quit"); | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|         } break; |         } break; | ||||||
| @@ -353,19 +356,19 @@ void GcodeSuite::M917() { | |||||||
|             // phase 3 with stall warning - increment if can |             // phase 3 with stall warning - increment if can | ||||||
|             if (stall_th_val >= 127) { |             if (stall_th_val >= 127) { | ||||||
|               stall_th_val = 127; // limit to max |               stall_th_val = 127; // limit to max | ||||||
|               L6470_ECHOLNPGM("finished - STALL at maximum value but still have stall warning"); |               DEBUG_ECHOLNPGM("finished - STALL at maximum value but still have stall warning"); | ||||||
|               test_phase = 4; |               test_phase = 4; | ||||||
|               L6470_ECHOLNPGM("LOGIC E3A - STALL, at max so quit"); |               DEBUG_ECHOLNPGM("LOGIC E3A - STALL, at max so quit"); | ||||||
|             } |             } | ||||||
|             else { |             else { | ||||||
|               stall_th_val++;              // still looking for passing value |               stall_th_val++;              // still looking for passing value | ||||||
|               L6470_ECHOLNPGM("LOGIC E3B - STALL, inc stall"); |               DEBUG_ECHOLNPGM("LOGIC E3B - STALL, inc stall"); | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|           else {  //phase 3 without stall warning  but have OCD warning |           else {  //phase 3 without stall warning  but have OCD warning | ||||||
|             L6470_ECHOLNPGM("Hardware problem - OCD warning without STALL warning"); |             DEBUG_ECHOLNPGM("Hardware problem - OCD warning without STALL warning"); | ||||||
|             test_phase = 4; |             test_phase = 4; | ||||||
|             L6470_ECHOLNPGM("LOGIC E3C - not STALLED, hardware problem (quit)"); |             DEBUG_ECHOLNPGM("LOGIC E3C - not STALLED, hardware problem (quit)"); | ||||||
|           } |           } | ||||||
|         } break; |         } break; | ||||||
|  |  | ||||||
| @@ -377,30 +380,30 @@ void GcodeSuite::M917() { | |||||||
|         case 0: { // phase 0 without OCD warning - keep on decrementing if can |         case 0: { // phase 0 without OCD warning - keep on decrementing if can | ||||||
|           if (ocd_th_val) { |           if (ocd_th_val) { | ||||||
|             ocd_th_val--;             // try lower value |             ocd_th_val--;             // try lower value | ||||||
|             L6470_ECHOLNPGM("LOGIC N0A - DEC OCD"); |             DEBUG_ECHOLNPGM("LOGIC N0A - DEC OCD"); | ||||||
|           } |           } | ||||||
|           else { |           else { | ||||||
|             test_phase = 2;           // at lowest value without warning so skip phase 1 |             test_phase = 2;           // at lowest value without warning so skip phase 1 | ||||||
|             L6470_ECHOLNPGM("LOGIC N0B - OCD at lowest (go to phase 2)"); |             DEBUG_ECHOLNPGM("LOGIC N0B - OCD at lowest (go to phase 2)"); | ||||||
|           } |           } | ||||||
|         } break; |         } break; | ||||||
|  |  | ||||||
|         case 1: L6470_ECHOLNPGM("LOGIC N1 (go directly to 2)"); // phase 1 without OCD warning - drop directly to phase 2 |         case 1: DEBUG_ECHOLNPGM("LOGIC N1 (go directly to 2)"); // phase 1 without OCD warning - drop directly to phase 2 | ||||||
|  |  | ||||||
|         case 2: { // phase 2 without stall warning - keep on decrementing if can |         case 2: { // phase 2 without stall warning - keep on decrementing if can | ||||||
|           if (stall_th_val) { |           if (stall_th_val) { | ||||||
|             stall_th_val--;              // try a lower value (stay in phase 2) |             stall_th_val--;              // try a lower value (stay in phase 2) | ||||||
|             L6470_ECHOLNPGM("LOGIC N2B - dec STALL"); |             DEBUG_ECHOLNPGM("LOGIC N2B - dec STALL"); | ||||||
|           } |           } | ||||||
|           else { |           else { | ||||||
|             L6470_ECHOLNPGM("finished - STALL at lowest value but still no stall warning"); |             DEBUG_ECHOLNPGM("finished - STALL at lowest value but still no stall warning"); | ||||||
|             test_phase = 4; |             test_phase = 4; | ||||||
|             L6470_ECHOLNPGM("LOGIC N2C - STALL at lowest (quit)"); |             DEBUG_ECHOLNPGM("LOGIC N2C - STALL at lowest (quit)"); | ||||||
|           } |           } | ||||||
|         } break; |         } break; | ||||||
|  |  | ||||||
|         case 3: { test_phase = 4; |         case 3: { test_phase = 4; | ||||||
|            L6470_ECHOLNPGM("LOGIC N3 - finished!"); |            DEBUG_ECHOLNPGM("LOGIC N3 - finished!"); | ||||||
|         } break;  // phase 3 without any warnings - desired exit |         } break;  // phase 3 without any warnings - desired exit | ||||||
|       }  // |       }  // | ||||||
|     }  // end of status checks |     }  // end of status checks | ||||||
| @@ -409,22 +412,22 @@ void GcodeSuite::M917() { | |||||||
|       for (j = 0; j < driver_count; j++) {                       // update threshold(s) |       for (j = 0; j < driver_count; j++) {                       // update threshold(s) | ||||||
|         L6470.set_param(axis_index[j], L6470_OCD_TH, ocd_th_val); |         L6470.set_param(axis_index[j], L6470_OCD_TH, ocd_th_val); | ||||||
|         L6470.set_param(axis_index[j], L6470_STALL_TH, stall_th_val); |         L6470.set_param(axis_index[j], L6470_STALL_TH, stall_th_val); | ||||||
|         if (L6470.get_param(axis_index[j], L6470_OCD_TH) != ocd_th_val) L6470_ECHOLNPGM("OCD mismatch"); |         if (L6470.get_param(axis_index[j], L6470_OCD_TH) != ocd_th_val) DEBUG_ECHOLNPGM("OCD mismatch"); | ||||||
|         if (L6470.get_param(axis_index[j], L6470_STALL_TH) != stall_th_val) L6470_ECHOLNPGM("STALL mismatch"); |         if (L6470.get_param(axis_index[j], L6470_STALL_TH) != stall_th_val) DEBUG_ECHOLNPGM("STALL mismatch"); | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   } while (test_phase != 4); |   } while (test_phase != 4); | ||||||
|  |  | ||||||
|   if (status_composite) { |   if (status_composite) { | ||||||
|     L6470_ECHOLNPGM("Completed with errors"); |     DEBUG_ECHOLNPGM("Completed with errors"); | ||||||
|     for (j = 0; j < driver_count; j++) { |     for (j = 0; j < driver_count; j++) { | ||||||
|       L6470_ECHOPGM("..."); |       DEBUG_ECHOPGM("..."); | ||||||
|       L6470.error_status_decode(axis_status[j], axis_index[j]); |       L6470.error_status_decode(axis_status[j], axis_index[j]); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   else |   else | ||||||
|     L6470_ECHOLNPGM("Completed with no errors"); |     DEBUG_ECHOLNPGM("Completed with no errors"); | ||||||
|  |  | ||||||
| } // M917 | } // M917 | ||||||
|  |  | ||||||
| @@ -448,7 +451,7 @@ void GcodeSuite::M917() { | |||||||
|  */ |  */ | ||||||
| void GcodeSuite::M918() { | void GcodeSuite::M918() { | ||||||
|  |  | ||||||
|   L6470_ECHOLNPGM("M918"); |   DEBUG_ECHOLNPGM("M918"); | ||||||
|  |  | ||||||
|   char axis_mon[3][3] = { "  ", "  ", "  " };  // List of axes to monitor |   char axis_mon[3][3] = { "  ", "  ", "  " };  // List of axes to monitor | ||||||
|   uint8_t axis_index[3]; |   uint8_t axis_index[3]; | ||||||
| @@ -469,7 +472,7 @@ void GcodeSuite::M918() { | |||||||
|  |  | ||||||
|   uint8_t m_steps = parser.byteval('M'); |   uint8_t m_steps = parser.byteval('M'); | ||||||
|   LIMIT(m_steps, 0, 128); |   LIMIT(m_steps, 0, 128); | ||||||
|   L6470_ECHOLNPAIR("M = ", m_steps); |   DEBUG_ECHOLNPAIR("M = ", m_steps); | ||||||
|  |  | ||||||
|   int8_t m_bits = -1; |   int8_t m_bits = -1; | ||||||
|        if (m_steps > 85) m_bits = 7;  // 128 (no synch output) |        if (m_steps > 85) m_bits = 7;  // 128 (no synch output) | ||||||
| @@ -484,15 +487,15 @@ void GcodeSuite::M918() { | |||||||
|  |  | ||||||
|   if (m_bits >= 0) { |   if (m_bits >= 0) { | ||||||
|     const int micros = _BV(m_bits); |     const int micros = _BV(m_bits); | ||||||
|     if (micros < 100) { L6470_CHAR(' '); if (micros < 10) L6470_CHAR(' '); } |     if (micros < 100) { DEBUG_CHAR(' '); if (micros < 10) DEBUG_CHAR(' '); } | ||||||
|     L6470_ECHO(micros); |     DEBUG_ECHO(micros); | ||||||
|     L6470_ECHOPGM(" uSTEPS"); |     DEBUG_ECHOPGM(" uSTEPS"); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   for (j = 0; j < driver_count; j++) |   for (j = 0; j < driver_count; j++) | ||||||
|     L6470.set_param(axis_index[j], L6470_STEP_MODE, m_bits);   // set microsteps |     L6470.set_param(axis_index[j], L6470_STEP_MODE, m_bits);   // set microsteps | ||||||
|  |  | ||||||
|   L6470_ECHOLNPAIR("target (maximum) feedrate = ",final_feedrate); |   DEBUG_ECHOLNPAIR("target (maximum) feedrate = ",final_feedrate); | ||||||
|  |  | ||||||
|   float feedrate_inc = final_feedrate / 10, // start at 1/10 of max & go up by 1/10 per step) |   float feedrate_inc = final_feedrate / 10, // start at 1/10 of max & go up by 1/10 per step) | ||||||
|         current_feedrate = 0; |         current_feedrate = 0; | ||||||
| @@ -508,11 +511,11 @@ void GcodeSuite::M918() { | |||||||
|  |  | ||||||
|   char gcode_string[80]; |   char gcode_string[80]; | ||||||
|   uint16_t status_composite = 0; |   uint16_t status_composite = 0; | ||||||
|   L6470_ECHOLNPGM(".\n.\n.");            // make the feedrate prints easier to see |   DEBUG_ECHOLNPGM(".\n.\n.");            // make the feedrate prints easier to see | ||||||
|  |  | ||||||
|   do { |   do { | ||||||
|     current_feedrate += feedrate_inc; |     current_feedrate += feedrate_inc; | ||||||
|     L6470_ECHOLNPAIR("...feedrate = ", current_feedrate); |     DEBUG_ECHOLNPAIR("...feedrate = ", current_feedrate); | ||||||
|  |  | ||||||
|     sprintf_P(gcode_string, PSTR("G0 %s%4.3f F%4.3f"), temp_axis_string, position_min, current_feedrate); |     sprintf_P(gcode_string, PSTR("G0 %s%4.3f F%4.3f"), temp_axis_string, position_min, current_feedrate); | ||||||
|     gcode.process_subcommands_now_P(gcode_string); |     gcode.process_subcommands_now_P(gcode_string); | ||||||
| @@ -529,15 +532,16 @@ void GcodeSuite::M918() { | |||||||
|     if (status_composite) break;       // quit if any errors flags are raised |     if (status_composite) break;       // quit if any errors flags are raised | ||||||
|   } while (current_feedrate < final_feedrate * 0.99); |   } while (current_feedrate < final_feedrate * 0.99); | ||||||
|  |  | ||||||
|  |   DEBUG_ECHOPGM("Completed with errors"); | ||||||
|   if (status_composite) { |   if (status_composite) { | ||||||
|     L6470_ECHOLNPGM("Completed with errors"); |     DEBUG_ECHOLNPGM("errors"); | ||||||
|     for (j = 0; j < driver_count; j++) { |     for (j = 0; j < driver_count; j++) { | ||||||
|       L6470_ECHOPGM("..."); |       DEBUG_ECHOPGM("..."); | ||||||
|       L6470.error_status_decode(axis_status[j], axis_index[j]); |       L6470.error_status_decode(axis_status[j], axis_index[j]); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   else |   else | ||||||
|     L6470_ECHOLNPGM("Completed with no errors"); |     DEBUG_ECHOLNPGM("no errors"); | ||||||
|  |  | ||||||
| } // M918 | } // M918 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -32,6 +32,8 @@ | |||||||
|     //C:\Users\bobku\Documents\GitHub\Marlin-Bob-2\Marlin\src\gcode\host\M114.cpp |     //C:\Users\bobku\Documents\GitHub\Marlin-Bob-2\Marlin\src\gcode\host\M114.cpp | ||||||
|     //C:\Users\bobku\Documents\GitHub\Marlin-Bob-2\Marlin\src\module\bob_L6470.cpp |     //C:\Users\bobku\Documents\GitHub\Marlin-Bob-2\Marlin\src\module\bob_L6470.cpp | ||||||
|     #include "../../module/L6470/L6470_Marlin.h" |     #include "../../module/L6470/L6470_Marlin.h" | ||||||
|  |     #define DEBUG_OUT ENABLED(L6470_CHITCHAT) | ||||||
|  |     #include "../../core/debug_out.h" | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   void report_xyze(const float pos[], const uint8_t n = 4, const uint8_t precision = 3) { |   void report_xyze(const float pos[], const uint8_t n = 4, const uint8_t precision = 3) { | ||||||
| @@ -95,10 +97,10 @@ | |||||||
|           temp = L6470_GETPARAM(L6470_ABS_POS,Q);                   \ |           temp = L6470_GETPARAM(L6470_ABS_POS,Q);                   \ | ||||||
|           if (temp & ABS_POS_SIGN_MASK) temp |= ABS_POS_SIGN_MASK;  \ |           if (temp & ABS_POS_SIGN_MASK) temp |= ABS_POS_SIGN_MASK;  \ | ||||||
|           sprintf_P(temp_buf, PSTR(":%8ld   "), temp);              \ |           sprintf_P(temp_buf, PSTR(":%8ld   "), temp);              \ | ||||||
|           L6470_ECHO(temp_buf);                                     \ |           DEBUG_ECHO(temp_buf);                                     \ | ||||||
|         }while(0) |         }while(0) | ||||||
|  |  | ||||||
|       L6470_ECHOPGM("\nL6470:"); |       DEBUG_ECHOPGM("\nL6470:"); | ||||||
|       #if AXIS_DRIVER_TYPE_X(L6470) |       #if AXIS_DRIVER_TYPE_X(L6470) | ||||||
|         REPORT_ABSOLUTE_POS(X); |         REPORT_ABSOLUTE_POS(X); | ||||||
|       #endif |       #endif | ||||||
|   | |||||||
| @@ -36,6 +36,9 @@ L6470_Marlin L6470; | |||||||
| #include "../../gcode/gcode.h" | #include "../../gcode/gcode.h" | ||||||
| #include "../planner.h" | #include "../planner.h" | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(L6470_CHITCHAT) | ||||||
|  | #include "../../core/debug_out.h" | ||||||
|  |  | ||||||
| uint8_t L6470_Marlin::dir_commands[MAX_L6470];  // array to hold direction command for each driver | uint8_t L6470_Marlin::dir_commands[MAX_L6470];  // array to hold direction command for each driver | ||||||
|  |  | ||||||
| char L6470_Marlin::index_to_axis[MAX_L6470][3] = { "X ", "Y ", "Z ", "X2", "Y2", "Z2", "Z3", "E0", "E1", "E2", "E3", "E4", "E5" }; | char L6470_Marlin::index_to_axis[MAX_L6470][3] = { "X ", "Y ", "Z ", "X2", "Y2", "Z2", "Z3", "E0", "E1", "E2", "E3", "E4", "E5" }; | ||||||
| @@ -286,16 +289,16 @@ void L6470_Marlin::set_param(uint8_t axis, uint8_t param, uint32_t value) { | |||||||
| } | } | ||||||
|  |  | ||||||
| inline void echo_min_max(const char a, const float &min, const float &max) { | inline void echo_min_max(const char a, const float &min, const float &max) { | ||||||
|   L6470_CHAR(' '); L6470_CHAR(a); |   DEBUG_CHAR(' '); DEBUG_CHAR(a); | ||||||
|   L6470_ECHOPAIR(" min = ", min); |   DEBUG_ECHOPAIR(" min = ", min); | ||||||
|   L6470_ECHOLNPAIR("  max = ", max); |   DEBUG_ECHOLNPAIR("  max = ", max); | ||||||
| } | } | ||||||
| inline void echo_oct_used(const float &oct, const bool stall) { | inline void echo_oct_used(const float &oct, const bool stall) { | ||||||
|   L6470_ECHOPAIR("over_current_threshold used     : ", oct); |   DEBUG_ECHOPAIR("over_current_threshold used     : ", oct); | ||||||
|   serialprintPGM(stall ? PSTR("  (Stall") : PSTR("  (OCD")); |   serialprintPGM(stall ? PSTR("  (Stall") : PSTR("  (OCD")); | ||||||
|   L6470_ECHOLNPGM(" threshold)"); |   DEBUG_ECHOLNPGM(" threshold)"); | ||||||
| } | } | ||||||
| inline void err_out_of_bounds() { L6470_ECHOLNPGM("ERROR - motion out of bounds"); } | inline void err_out_of_bounds() { DEBUG_ECHOLNPGM("ERROR - motion out of bounds"); } | ||||||
|  |  | ||||||
| bool L6470_Marlin::get_user_input(uint8_t &driver_count, uint8_t axis_index[3], char axis_mon[3][3], | bool L6470_Marlin::get_user_input(uint8_t &driver_count, uint8_t axis_index[3], char axis_mon[3][3], | ||||||
|                           float &position_max, float &position_min, float &final_feedrate, uint8_t &kval_hold, |                           float &position_max, float &position_min, float &final_feedrate, uint8_t &kval_hold, | ||||||
| @@ -307,7 +310,7 @@ bool L6470_Marlin::get_user_input(uint8_t &driver_count, uint8_t axis_index[3], | |||||||
|   uint8_t j;   // general purpose counter |   uint8_t j;   // general purpose counter | ||||||
|  |  | ||||||
|   if (!all_axes_homed()) { |   if (!all_axes_homed()) { | ||||||
|     L6470_ECHOLNPGM("ERROR - home all before running this command"); |     DEBUG_ECHOLNPGM("ERROR - home all before running this command"); | ||||||
|     //return true; |     //return true; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -424,12 +427,12 @@ bool L6470_Marlin::get_user_input(uint8_t &driver_count, uint8_t axis_index[3], | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (driver_count == 0) { |   if (driver_count == 0) { | ||||||
|     L6470_ECHOLNPGM("ERROR - not a L6470 axis"); |     DEBUG_ECHOLNPGM("ERROR - not a L6470 axis"); | ||||||
|     return true; |     return true; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   L6470_ECHOPGM("Monitoring:"); |   DEBUG_ECHOPGM("Monitoring:"); | ||||||
|   for (j = 0; j < driver_count; j++) L6470_ECHOPAIR("  ", axis_mon[j]); |   for (j = 0; j < driver_count; j++) DEBUG_ECHOPAIR("  ", axis_mon[j]); | ||||||
|   L6470_EOL(); |   L6470_EOL(); | ||||||
|  |  | ||||||
|   // now have a list of driver(s) to monitor |   // now have a list of driver(s) to monitor | ||||||
| @@ -440,14 +443,14 @@ bool L6470_Marlin::get_user_input(uint8_t &driver_count, uint8_t axis_index[3], | |||||||
|  |  | ||||||
|   kval_hold = parser.byteval('K'); |   kval_hold = parser.byteval('K'); | ||||||
|   if (kval_hold) { |   if (kval_hold) { | ||||||
|     L6470_ECHOLNPAIR("kval_hold = ", kval_hold); |     DEBUG_ECHOLNPAIR("kval_hold = ", kval_hold); | ||||||
|     for (j = 0; j < driver_count; j++) |     for (j = 0; j < driver_count; j++) | ||||||
|       set_param(axis_index[j], L6470_KVAL_HOLD, kval_hold); |       set_param(axis_index[j], L6470_KVAL_HOLD, kval_hold); | ||||||
|   } |   } | ||||||
|   else { |   else { | ||||||
|     // only print the KVAL_HOLD from one of the drivers |     // only print the KVAL_HOLD from one of the drivers | ||||||
|     kval_hold = get_param(axis_index[0], L6470_KVAL_HOLD); |     kval_hold = get_param(axis_index[0], L6470_KVAL_HOLD); | ||||||
|     L6470_ECHOLNPAIR("KVAL_HOLD = ", kval_hold); |     DEBUG_ECHOLNPAIR("KVAL_HOLD = ", kval_hold); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // |   // | ||||||
| @@ -474,7 +477,7 @@ bool L6470_Marlin::get_user_input(uint8_t &driver_count, uint8_t axis_index[3], | |||||||
|         OCD_TH_actual = (OCD_TH_val_local + 1) * 375; |         OCD_TH_actual = (OCD_TH_val_local + 1) * 375; | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       L6470_ECHOLNPAIR("over_current_threshold specified: ", over_current_threshold); |       DEBUG_ECHOLNPAIR("over_current_threshold specified: ", over_current_threshold); | ||||||
|       echo_oct_used(STALL_TH_actual, true); |       echo_oct_used(STALL_TH_actual, true); | ||||||
|       echo_oct_used(OCD_TH_actual, false); |       echo_oct_used(OCD_TH_actual, false); | ||||||
|  |  | ||||||
| @@ -547,13 +550,13 @@ void L6470_Marlin::error_status_decode(const uint16_t status, const uint8_t axis | |||||||
|     char temp_buf[10]; |     char temp_buf[10]; | ||||||
|     say_axis(axis); |     say_axis(axis); | ||||||
|     sprintf_P(temp_buf, PSTR("  %4x   "), status); |     sprintf_P(temp_buf, PSTR("  %4x   "), status); | ||||||
|     L6470_ECHO(temp_buf); |     DEBUG_ECHO(temp_buf); | ||||||
|     print_bin(status); |     print_bin(status); | ||||||
|     L6470_ECHOPGM("  THERMAL: "); |     DEBUG_ECHOPGM("  THERMAL: "); | ||||||
|     serialprintPGM((status & STATUS_TH_SD) ? PSTR("SHUTDOWN") : (status & STATUS_TH_WRN) ? PSTR("WARNING ") : PSTR("OK      ")); |     serialprintPGM((status & STATUS_TH_SD) ? PSTR("SHUTDOWN") : (status & STATUS_TH_WRN) ? PSTR("WARNING ") : PSTR("OK      ")); | ||||||
|     L6470_ECHOPGM("   OVERCURRENT: "); |     DEBUG_ECHOPGM("   OVERCURRENT: "); | ||||||
|     echo_yes_no(status & STATUS_OCD); |     echo_yes_no(status & STATUS_OCD); | ||||||
|     L6470_ECHOPGM("   STALL: "); |     DEBUG_ECHOPGM("   STALL: "); | ||||||
|     echo_yes_no(status & (STATUS_STEP_LOSS_A | STATUS_STEP_LOSS_B)); |     echo_yes_no(status & (STATUS_STEP_LOSS_A | STATUS_STEP_LOSS_B)); | ||||||
|     L6470_EOL(); |     L6470_EOL(); | ||||||
|   #else |   #else | ||||||
| @@ -642,14 +645,14 @@ void L6470_Marlin::error_status_decode(const uint16_t status, const uint8_t axis | |||||||
|       if (driver_L6470_data[j].com_counter == 0) {      // warn user when it first happens |       if (driver_L6470_data[j].com_counter == 0) {      // warn user when it first happens | ||||||
|         driver_L6470_data[j].com_counter++; |         driver_L6470_data[j].com_counter++; | ||||||
|         append_stepper_err(p, stepper_index, PSTR(" - communications lost\n")); |         append_stepper_err(p, stepper_index, PSTR(" - communications lost\n")); | ||||||
|         L6470_ECHO(temp_buf); |         DEBUG_ECHO(temp_buf); | ||||||
|       } |       } | ||||||
|       else { |       else { | ||||||
|         driver_L6470_data[j].com_counter++; |         driver_L6470_data[j].com_counter++; | ||||||
|         if (driver_L6470_data[j].com_counter > 240) {  // remind of com problem about every 2 minutes |         if (driver_L6470_data[j].com_counter > 240) {  // remind of com problem about every 2 minutes | ||||||
|           driver_L6470_data[j].com_counter = 1; |           driver_L6470_data[j].com_counter = 1; | ||||||
|           append_stepper_err(p, stepper_index, PSTR(" - still no communications\n")); |           append_stepper_err(p, stepper_index, PSTR(" - still no communications\n")); | ||||||
|           L6470_ECHO(temp_buf); |           DEBUG_ECHO(temp_buf); | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
| @@ -657,7 +660,7 @@ void L6470_Marlin::error_status_decode(const uint16_t status, const uint8_t axis | |||||||
|       if (driver_L6470_data[j].com_counter) {   // comms re-established |       if (driver_L6470_data[j].com_counter) {   // comms re-established | ||||||
|         driver_L6470_data[j].com_counter = 0; |         driver_L6470_data[j].com_counter = 0; | ||||||
|         append_stepper_err(p, stepper_index, PSTR(" - communications re-established\n.. setting all drivers to default values\n")); |         append_stepper_err(p, stepper_index, PSTR(" - communications re-established\n.. setting all drivers to default values\n")); | ||||||
|         L6470_ECHO(temp_buf); |         DEBUG_ECHO(temp_buf); | ||||||
|         init_to_defaults(); |         init_to_defaults(); | ||||||
|       } |       } | ||||||
|       else { |       else { | ||||||
| @@ -718,7 +721,7 @@ void L6470_Marlin::error_status_decode(const uint16_t status, const uint8_t axis | |||||||
|             p += sprintf_P(p, PSTR("%c\n"), ' '); |             p += sprintf_P(p, PSTR("%c\n"), ' '); | ||||||
|           #endif |           #endif | ||||||
|  |  | ||||||
|           L6470_ECHOLN(temp_buf);  // print the error message |           DEBUG_ECHOLN(temp_buf);  // print the error message | ||||||
|         } |         } | ||||||
|         else { |         else { | ||||||
|           driver_L6470_data[j].is_ot = false; |           driver_L6470_data[j].is_ot = false; | ||||||
|   | |||||||
| @@ -25,26 +25,6 @@ | |||||||
|  |  | ||||||
| #include <L6470.h> | #include <L6470.h> | ||||||
|  |  | ||||||
| #if ENABLED(L6470_CHITCHAT) |  | ||||||
|   #define L6470_EOL()           SERIAL_EOL() |  | ||||||
|   #define L6470_CHAR(C)         SERIAL_CHAR(C) |  | ||||||
|   #define L6470_ECHO(V)         SERIAL_ECHO(V) |  | ||||||
|   #define L6470_ECHOLN(V)       SERIAL_ECHOLN(V) |  | ||||||
|   #define L6470_ECHOPGM(S)      SERIAL_ECHOPGM(S) |  | ||||||
|   #define L6470_ECHOLNPGM(S)    SERIAL_ECHOLNPGM(S) |  | ||||||
|   #define L6470_ECHOPAIR(S,V)   SERIAL_ECHOPAIR(S,V) |  | ||||||
|   #define L6470_ECHOLNPAIR(S,V) SERIAL_ECHOLNPAIR(S,V) |  | ||||||
| #else |  | ||||||
|   #define L6470_EOL()           NOOP |  | ||||||
|   #define L6470_CHAR(C)         NOOP |  | ||||||
|   #define L6470_ECHO(V)         NOOP |  | ||||||
|   #define L6470_ECHOLN(V)       NOOP |  | ||||||
|   #define L6470_ECHOPGM(S)      NOOP |  | ||||||
|   #define L6470_ECHOLNPGM(S)    NOOP |  | ||||||
|   #define L6470_ECHOPAIR(S,V)   NOOP |  | ||||||
|   #define L6470_ECHOLNPAIR(S,V) NOOP |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #define L6470_GETPARAM(P,Q) stepper##Q.GetParam(P) | #define L6470_GETPARAM(P,Q) stepper##Q.GetParam(P) | ||||||
|  |  | ||||||
| #define MAX_L6470  (7 + MAX_EXTRUDERS) // Maximum number of axes in Marlin | #define MAX_L6470  (7 + MAX_EXTRUDERS) // Maximum number of axes in Marlin | ||||||
|   | |||||||
| @@ -379,27 +379,8 @@ void MarlinSettings::postprocess() { | |||||||
|  |  | ||||||
| #endif // SD_FIRMWARE_UPDATE | #endif // SD_FIRMWARE_UPDATE | ||||||
|  |  | ||||||
| #if ENABLED(EEPROM_CHITCHAT) | #define DEBUG_OUT ENABLED(EEPROM_CHITCHAT) | ||||||
|   #define CHITCHAT_ECHO(V)              SERIAL_ECHO(V) | #include "../core/debug_out.h" | ||||||
|   #define CHITCHAT_ECHOLNPGM(STR)       SERIAL_ECHOLNPGM(STR) |  | ||||||
|   #define CHITCHAT_ECHOPAIR(...)        SERIAL_ECHOPAIR(__VA_ARGS__) |  | ||||||
|   #define CHITCHAT_ECHOLNPAIR(...)      SERIAL_ECHOLNPAIR(__VA_ARGS__) |  | ||||||
|   #define CHITCHAT_ECHO_START()         SERIAL_ECHO_START() |  | ||||||
|   #define CHITCHAT_ERROR_START()        SERIAL_ERROR_START() |  | ||||||
|   #define CHITCHAT_ERROR_MSG(STR)       SERIAL_ERROR_MSG(STR) |  | ||||||
|   #define CHITCHAT_ECHOPGM(STR)         SERIAL_ECHOPGM(STR) |  | ||||||
|   #define CHITCHAT_EOL()                SERIAL_EOL() |  | ||||||
| #else |  | ||||||
|   #define CHITCHAT_ECHO(V)              NOOP |  | ||||||
|   #define CHITCHAT_ECHOLNPGM(STR)       NOOP |  | ||||||
|   #define CHITCHAT_ECHOPAIR(...)        NOOP |  | ||||||
|   #define CHITCHAT_ECHOLNPAIR(...)      NOOP |  | ||||||
|   #define CHITCHAT_ECHO_START()         NOOP |  | ||||||
|   #define CHITCHAT_ERROR_START()        NOOP |  | ||||||
|   #define CHITCHAT_ERROR_MSG(STR)       NOOP |  | ||||||
|   #define CHITCHAT_ECHOPGM(STR)         NOOP |  | ||||||
|   #define CHITCHAT_EOL()                NOOP |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if ENABLED(EEPROM_SETTINGS) | #if ENABLED(EEPROM_SETTINGS) | ||||||
|  |  | ||||||
| @@ -427,7 +408,7 @@ void MarlinSettings::postprocess() { | |||||||
|  |  | ||||||
|   bool MarlinSettings::size_error(const uint16_t size) { |   bool MarlinSettings::size_error(const uint16_t size) { | ||||||
|     if (size != datasize()) { |     if (size != datasize()) { | ||||||
|       CHITCHAT_ERROR_MSG("EEPROM datasize error."); |       DEBUG_ERROR_MSG("EEPROM datasize error."); | ||||||
|       return true; |       return true; | ||||||
|     } |     } | ||||||
|     return false; |     return false; | ||||||
| @@ -1103,8 +1084,8 @@ void MarlinSettings::postprocess() { | |||||||
|       EEPROM_WRITE(final_crc); |       EEPROM_WRITE(final_crc); | ||||||
|  |  | ||||||
|       // Report storage size |       // Report storage size | ||||||
|       CHITCHAT_ECHO_START(); |       DEBUG_ECHO_START(); | ||||||
|       CHITCHAT_ECHOLNPAIR("Settings Stored (", eeprom_size, " bytes; crc ", (uint32_t)final_crc, ")"); |       DEBUG_ECHOLNPAIR("Settings Stored (", eeprom_size, " bytes; crc ", (uint32_t)final_crc, ")"); | ||||||
|  |  | ||||||
|       eeprom_error |= size_error(eeprom_size); |       eeprom_error |= size_error(eeprom_size); | ||||||
|     } |     } | ||||||
| @@ -1141,8 +1122,8 @@ void MarlinSettings::postprocess() { | |||||||
|         stored_ver[0] = '?'; |         stored_ver[0] = '?'; | ||||||
|         stored_ver[1] = '\0'; |         stored_ver[1] = '\0'; | ||||||
|       } |       } | ||||||
|       CHITCHAT_ECHO_START(); |       DEBUG_ECHO_START(); | ||||||
|       CHITCHAT_ECHOLNPAIR("EEPROM version mismatch (EEPROM=", stored_ver, " Marlin=" EEPROM_VERSION ")"); |       DEBUG_ECHOLNPAIR("EEPROM version mismatch (EEPROM=", stored_ver, " Marlin=" EEPROM_VERSION ")"); | ||||||
|       eeprom_error = true; |       eeprom_error = true; | ||||||
|     } |     } | ||||||
|     else { |     else { | ||||||
| @@ -1807,18 +1788,18 @@ void MarlinSettings::postprocess() { | |||||||
|  |  | ||||||
|       eeprom_error = size_error(eeprom_index - (EEPROM_OFFSET)); |       eeprom_error = size_error(eeprom_index - (EEPROM_OFFSET)); | ||||||
|       if (eeprom_error) { |       if (eeprom_error) { | ||||||
|         CHITCHAT_ECHO_START(); |         DEBUG_ECHO_START(); | ||||||
|         CHITCHAT_ECHOLNPAIR("Index: ", int(eeprom_index - (EEPROM_OFFSET)), " Size: ", datasize()); |         DEBUG_ECHOLNPAIR("Index: ", int(eeprom_index - (EEPROM_OFFSET)), " Size: ", datasize()); | ||||||
|       } |       } | ||||||
|       else if (working_crc != stored_crc) { |       else if (working_crc != stored_crc) { | ||||||
|         eeprom_error = true; |         eeprom_error = true; | ||||||
|         CHITCHAT_ERROR_START(); |         DEBUG_ERROR_START(); | ||||||
|         CHITCHAT_ECHOLNPAIR("EEPROM CRC mismatch - (stored) ", stored_crc, " != ", working_crc, " (calculated)!"); |         DEBUG_ECHOLNPAIR("EEPROM CRC mismatch - (stored) ", stored_crc, " != ", working_crc, " (calculated)!"); | ||||||
|       } |       } | ||||||
|       else if (!validating) { |       else if (!validating) { | ||||||
|         CHITCHAT_ECHO_START(); |         DEBUG_ECHO_START(); | ||||||
|         CHITCHAT_ECHO(version); |         DEBUG_ECHO(version); | ||||||
|         CHITCHAT_ECHOLNPAIR(" stored settings retrieved (", eeprom_index - (EEPROM_OFFSET), " bytes; crc ", (uint32_t)working_crc, ")"); |         DEBUG_ECHOLNPAIR(" stored settings retrieved (", eeprom_index - (EEPROM_OFFSET), " bytes; crc ", (uint32_t)working_crc, ")"); | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       if (!validating && !eeprom_error) postprocess(); |       if (!validating && !eeprom_error) postprocess(); | ||||||
| @@ -1831,26 +1812,26 @@ void MarlinSettings::postprocess() { | |||||||
|             SERIAL_EOL(); |             SERIAL_EOL(); | ||||||
|             #if ENABLED(EEPROM_CHITCHAT) |             #if ENABLED(EEPROM_CHITCHAT) | ||||||
|               ubl.echo_name(); |               ubl.echo_name(); | ||||||
|               CHITCHAT_ECHOLNPGM(" initialized.\n"); |               DEBUG_ECHOLNPGM(" initialized.\n"); | ||||||
|             #endif |             #endif | ||||||
|           } |           } | ||||||
|           else { |           else { | ||||||
|             eeprom_error = true; |             eeprom_error = true; | ||||||
|             #if ENABLED(EEPROM_CHITCHAT) |             #if ENABLED(EEPROM_CHITCHAT) | ||||||
|               CHITCHAT_ECHOPGM("?Can't enable "); |               DEBUG_ECHOPGM("?Can't enable "); | ||||||
|               ubl.echo_name(); |               ubl.echo_name(); | ||||||
|               CHITCHAT_ECHOLNPGM("."); |               DEBUG_ECHOLNPGM("."); | ||||||
|             #endif |             #endif | ||||||
|             ubl.reset(); |             ubl.reset(); | ||||||
|           } |           } | ||||||
|  |  | ||||||
|           if (ubl.storage_slot >= 0) { |           if (ubl.storage_slot >= 0) { | ||||||
|             load_mesh(ubl.storage_slot); |             load_mesh(ubl.storage_slot); | ||||||
|             CHITCHAT_ECHOLNPAIR("Mesh ", ubl.storage_slot, " loaded from storage."); |             DEBUG_ECHOLNPAIR("Mesh ", ubl.storage_slot, " loaded from storage."); | ||||||
|           } |           } | ||||||
|           else { |           else { | ||||||
|             ubl.reset(); |             ubl.reset(); | ||||||
|             CHITCHAT_ECHOLNPGM("UBL System reset()"); |             DEBUG_ECHOLNPGM("UBL System reset()"); | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       #endif |       #endif | ||||||
| @@ -1881,9 +1862,9 @@ void MarlinSettings::postprocess() { | |||||||
|  |  | ||||||
|     inline void ubl_invalid_slot(const int s) { |     inline void ubl_invalid_slot(const int s) { | ||||||
|       #if ENABLED(EEPROM_CHITCHAT) |       #if ENABLED(EEPROM_CHITCHAT) | ||||||
|         CHITCHAT_ECHOLNPGM("?Invalid slot."); |         DEBUG_ECHOLNPGM("?Invalid slot."); | ||||||
|         CHITCHAT_ECHO(s); |         DEBUG_ECHO(s); | ||||||
|         CHITCHAT_ECHOLNPGM(" mesh slots available."); |         DEBUG_ECHOLNPGM(" mesh slots available."); | ||||||
|       #else |       #else | ||||||
|         UNUSED(s); |         UNUSED(s); | ||||||
|       #endif |       #endif | ||||||
| @@ -1912,8 +1893,8 @@ void MarlinSettings::postprocess() { | |||||||
|         const int16_t a = calc_num_meshes(); |         const int16_t a = calc_num_meshes(); | ||||||
|         if (!WITHIN(slot, 0, a - 1)) { |         if (!WITHIN(slot, 0, a - 1)) { | ||||||
|           ubl_invalid_slot(a); |           ubl_invalid_slot(a); | ||||||
|           CHITCHAT_ECHOLNPAIR("E2END=", persistentStore.capacity() - 1, " meshes_end=", meshes_end, " slot=", slot); |           DEBUG_ECHOLNPAIR("E2END=", persistentStore.capacity() - 1, " meshes_end=", meshes_end, " slot=", slot); | ||||||
|           CHITCHAT_EOL(); |           DEBUG_EOL(); | ||||||
|           return; |           return; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @@ -1926,7 +1907,7 @@ void MarlinSettings::postprocess() { | |||||||
|         persistentStore.access_finish(); |         persistentStore.access_finish(); | ||||||
|  |  | ||||||
|         if (status) SERIAL_ECHOLNPGM("?Unable to save mesh data."); |         if (status) SERIAL_ECHOLNPGM("?Unable to save mesh data."); | ||||||
|         else        CHITCHAT_ECHOLNPAIR("Mesh saved in slot ", slot); |         else        DEBUG_ECHOLNPAIR("Mesh saved in slot ", slot); | ||||||
|  |  | ||||||
|       #else |       #else | ||||||
|  |  | ||||||
| @@ -1955,7 +1936,7 @@ void MarlinSettings::postprocess() { | |||||||
|         persistentStore.access_finish(); |         persistentStore.access_finish(); | ||||||
|  |  | ||||||
|         if (status) SERIAL_ECHOLNPGM("?Unable to load mesh data."); |         if (status) SERIAL_ECHOLNPGM("?Unable to load mesh data."); | ||||||
|         else        CHITCHAT_ECHOLNPAIR("Mesh loaded from slot ", slot); |         else        DEBUG_ECHOLNPAIR("Mesh loaded from slot ", slot); | ||||||
|  |  | ||||||
|         EEPROM_FINISH(); |         EEPROM_FINISH(); | ||||||
|  |  | ||||||
| @@ -1974,7 +1955,7 @@ void MarlinSettings::postprocess() { | |||||||
| #else // !EEPROM_SETTINGS | #else // !EEPROM_SETTINGS | ||||||
|  |  | ||||||
|   bool MarlinSettings::save() { |   bool MarlinSettings::save() { | ||||||
|     CHITCHAT_ERROR_MSG("EEPROM disabled"); |     DEBUG_ERROR_MSG("EEPROM disabled"); | ||||||
|     return false; |     return false; | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -2281,8 +2262,8 @@ void MarlinSettings::reset() { | |||||||
|  |  | ||||||
|   postprocess(); |   postprocess(); | ||||||
|  |  | ||||||
|   CHITCHAT_ECHO_START(); |   DEBUG_ECHO_START(); | ||||||
|   CHITCHAT_ECHOLNPGM("Hardcoded Default Settings Loaded"); |   DEBUG_ECHOLNPGM("Hardcoded Default Settings Loaded"); | ||||||
| } | } | ||||||
|  |  | ||||||
| #if DISABLED(DISABLE_M503) | #if DISABLED(DISABLE_M503) | ||||||
|   | |||||||
| @@ -46,6 +46,9 @@ | |||||||
|   #include "stepper_indirection.h" |   #include "stepper_indirection.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../core/debug_out.h" | ||||||
|  |  | ||||||
| // Initialized by settings.load() | // Initialized by settings.load() | ||||||
| float delta_height, | float delta_height, | ||||||
|       delta_endstop_adj[ABC] = { 0 }, |       delta_endstop_adj[ABC] = { 0 }, | ||||||
| @@ -216,9 +219,7 @@ void forward_kinematics_DELTA(const float &z1, const float &z2, const float &z3) | |||||||
|  * This is like quick_home_xy() but for 3 towers. |  * This is like quick_home_xy() but for 3 towers. | ||||||
|  */ |  */ | ||||||
| void home_delta() { | void home_delta() { | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) DEBUG_POS(">>> home_delta", current_position); |   if (DEBUGGING(LEVELING)) DEBUG_POS(">>> home_delta", current_position); | ||||||
|   #endif |  | ||||||
|   // Init the current position of all carriages to 0,0,0 |   // Init the current position of all carriages to 0,0,0 | ||||||
|   ZERO(current_position); |   ZERO(current_position); | ||||||
|   ZERO(destination); |   ZERO(destination); | ||||||
| @@ -264,9 +265,7 @@ void home_delta() { | |||||||
|  |  | ||||||
|   sync_plan_position(); |   sync_plan_position(); | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) DEBUG_POS("<<< home_delta", current_position); |   if (DEBUGGING(LEVELING)) DEBUG_POS("<<< home_delta", current_position); | ||||||
|   #endif |  | ||||||
| } | } | ||||||
|  |  | ||||||
| #endif // DELTA | #endif // DELTA | ||||||
|   | |||||||
| @@ -59,6 +59,9 @@ | |||||||
|   #include "../feature/fwretract.h" |   #include "../feature/fwretract.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../core/debug_out.h" | ||||||
|  |  | ||||||
| #define XYZ_CONSTS(type, array, CONFIG) const PROGMEM type array##_P[XYZ] = { X_##CONFIG, Y_##CONFIG, Z_##CONFIG } | #define XYZ_CONSTS(type, array, CONFIG) const PROGMEM type array##_P[XYZ] = { X_##CONFIG, Y_##CONFIG, Z_##CONFIG } | ||||||
|  |  | ||||||
| XYZ_CONSTS(float, base_min_pos,   MIN_POS); | XYZ_CONSTS(float, base_min_pos,   MIN_POS); | ||||||
| @@ -205,9 +208,7 @@ void report_current_position() { | |||||||
|  * no kinematic translation. Used for homing axes and cartesian/core syncing. |  * no kinematic translation. Used for homing axes and cartesian/core syncing. | ||||||
|  */ |  */ | ||||||
| void sync_plan_position() { | void sync_plan_position() { | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) DEBUG_POS("sync_plan_position", current_position); |   if (DEBUGGING(LEVELING)) DEBUG_POS("sync_plan_position", current_position); | ||||||
|   #endif |  | ||||||
|   planner.set_position_mm(current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS], current_position[E_AXIS]); |   planner.set_position_mm(current_position[X_AXIS], current_position[Y_AXIS], current_position[Z_AXIS], current_position[E_AXIS]); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -294,9 +295,7 @@ void buffer_line_to_destination(const float fr_mm_s) { | |||||||
|    * Calculate delta, start a line, and set current_position to destination |    * Calculate delta, start a line, and set current_position to destination | ||||||
|    */ |    */ | ||||||
|   void prepare_uninterpolated_move_to_destination(const float &fr_mm_s/*=0.0*/) { |   void prepare_uninterpolated_move_to_destination(const float &fr_mm_s/*=0.0*/) { | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("prepare_uninterpolated_move_to_destination", destination); |     if (DEBUGGING(LEVELING)) DEBUG_POS("prepare_uninterpolated_move_to_destination", destination); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     #if UBL_SEGMENTED |     #if UBL_SEGMENTED | ||||||
|       // ubl segmented line will do z-only moves in single segment |       // ubl segmented line will do z-only moves in single segment | ||||||
| @@ -320,9 +319,7 @@ void buffer_line_to_destination(const float fr_mm_s) { | |||||||
|  * Plan a move to (X, Y, Z) and set the current_position |  * Plan a move to (X, Y, Z) and set the current_position | ||||||
|  */ |  */ | ||||||
| void do_blocking_move_to(const float rx, const float ry, const float rz, const float &fr_mm_s/*=0.0*/) { | void do_blocking_move_to(const float rx, const float ry, const float rz, const float &fr_mm_s/*=0.0*/) { | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_XYZ(">>> do_blocking_move_to", rx, ry, rz); | ||||||
|     if (DEBUGGING(LEVELING)) print_xyz(PSTR(">>> do_blocking_move_to"), NULL, rx, ry, rz); |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   const float z_feedrate  = fr_mm_s ? fr_mm_s : homing_feedrate(Z_AXIS), |   const float z_feedrate  = fr_mm_s ? fr_mm_s : homing_feedrate(Z_AXIS), | ||||||
|               xy_feedrate = fr_mm_s ? fr_mm_s : XY_PROBE_FEEDRATE_MM_S; |               xy_feedrate = fr_mm_s ? fr_mm_s : XY_PROBE_FEEDRATE_MM_S; | ||||||
| @@ -335,9 +332,7 @@ void do_blocking_move_to(const float rx, const float ry, const float rz, const f | |||||||
|  |  | ||||||
|     set_destination_from_current();          // sync destination at the start |     set_destination_from_current();          // sync destination at the start | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("set_destination_from_current", destination); |     if (DEBUGGING(LEVELING)) DEBUG_POS("set_destination_from_current", destination); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     // when in the danger zone |     // when in the danger zone | ||||||
|     if (current_position[Z_AXIS] > delta_clip_start_height) { |     if (current_position[Z_AXIS] > delta_clip_start_height) { | ||||||
| @@ -346,39 +341,29 @@ void do_blocking_move_to(const float rx, const float ry, const float rz, const f | |||||||
|         destination[Y_AXIS] = ry; |         destination[Y_AXIS] = ry; | ||||||
|         destination[Z_AXIS] = rz; |         destination[Z_AXIS] = rz; | ||||||
|         prepare_uninterpolated_move_to_destination(); // set_current_from_destination() |         prepare_uninterpolated_move_to_destination(); // set_current_from_destination() | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|         if (DEBUGGING(LEVELING)) DEBUG_POS("danger zone move", current_position); |         if (DEBUGGING(LEVELING)) DEBUG_POS("danger zone move", current_position); | ||||||
|         #endif |  | ||||||
|         return; |         return; | ||||||
|       } |       } | ||||||
|       destination[Z_AXIS] = delta_clip_start_height; |       destination[Z_AXIS] = delta_clip_start_height; | ||||||
|       prepare_uninterpolated_move_to_destination(); // set_current_from_destination() |       prepare_uninterpolated_move_to_destination(); // set_current_from_destination() | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) DEBUG_POS("zone border move", current_position); |       if (DEBUGGING(LEVELING)) DEBUG_POS("zone border move", current_position); | ||||||
|       #endif |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (rz > current_position[Z_AXIS]) {    // raising? |     if (rz > current_position[Z_AXIS]) {    // raising? | ||||||
|       destination[Z_AXIS] = rz; |       destination[Z_AXIS] = rz; | ||||||
|       prepare_uninterpolated_move_to_destination(z_feedrate);   // set_current_from_destination() |       prepare_uninterpolated_move_to_destination(z_feedrate);   // set_current_from_destination() | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) DEBUG_POS("z raise move", current_position); |       if (DEBUGGING(LEVELING)) DEBUG_POS("z raise move", current_position); | ||||||
|       #endif |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     destination[X_AXIS] = rx; |     destination[X_AXIS] = rx; | ||||||
|     destination[Y_AXIS] = ry; |     destination[Y_AXIS] = ry; | ||||||
|     prepare_move_to_destination();         // set_current_from_destination() |     prepare_move_to_destination();         // set_current_from_destination() | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("xy move", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("xy move", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     if (rz < current_position[Z_AXIS]) {    // lowering? |     if (rz < current_position[Z_AXIS]) {    // lowering? | ||||||
|       destination[Z_AXIS] = rz; |       destination[Z_AXIS] = rz; | ||||||
|       prepare_uninterpolated_move_to_destination(z_feedrate);   // set_current_from_destination() |       prepare_uninterpolated_move_to_destination(z_feedrate);   // set_current_from_destination() | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) DEBUG_POS("z lower move", current_position); |       if (DEBUGGING(LEVELING)) DEBUG_POS("z lower move", current_position); | ||||||
|       #endif |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   #elif IS_SCARA |   #elif IS_SCARA | ||||||
| @@ -423,9 +408,7 @@ void do_blocking_move_to(const float rx, const float ry, const float rz, const f | |||||||
|  |  | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("<<< do_blocking_move_to"); | ||||||
|     if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("<<< do_blocking_move_to"); |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   planner.synchronize(); |   planner.synchronize(); | ||||||
| } | } | ||||||
| @@ -938,19 +921,12 @@ void clean_up_after_endstop_or_probe_move() { | |||||||
|                   planner.buffer_line(   CUR_X,    CUR_Y,    CUR_Z, CUR_E, planner.settings.max_feedrate_mm_s[Z_AXIS], active_extruder); |                   planner.buffer_line(   CUR_X,    CUR_Y,    CUR_Z, CUR_E, planner.settings.max_feedrate_mm_s[Z_AXIS], active_extruder); | ||||||
|           delayed_move_time = 0; |           delayed_move_time = 0; | ||||||
|           active_extruder_parked = false; |           active_extruder_parked = false; | ||||||
|           #if ENABLED(DEBUG_LEVELING_FEATURE) |           if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Clear active_extruder_parked"); | ||||||
|             if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("Clear active_extruder_parked"); |  | ||||||
|           #endif |  | ||||||
|           break; |           break; | ||||||
|         case DXC_SCALED_DUPLICATION_MODE: |         case DXC_SCALED_DUPLICATION_MODE: | ||||||
|         case DXC_DUPLICATION_MODE: |         case DXC_DUPLICATION_MODE: | ||||||
|           if (active_extruder == 0) { |           if (active_extruder == 0) { | ||||||
|             #if ENABLED(DEBUG_LEVELING_FEATURE) |             if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("Set planner X", inactive_extruder_x_pos, " ... Line to X", current_position[X_AXIS] + duplicate_extruder_x_offset); | ||||||
|               if (DEBUGGING(LEVELING)) { |  | ||||||
|                 SERIAL_ECHOPAIR("Set planner X", inactive_extruder_x_pos); |  | ||||||
|                 SERIAL_ECHOLNPAIR(" ... Line to X", current_position[X_AXIS] + duplicate_extruder_x_offset); |  | ||||||
|               } |  | ||||||
|             #endif |  | ||||||
|             // move duplicate extruder into correct duplication position. |             // move duplicate extruder into correct duplication position. | ||||||
|             planner.set_position_mm(inactive_extruder_x_pos, current_position[Y_AXIS], current_position[Z_AXIS], current_position[E_AXIS]); |             planner.set_position_mm(inactive_extruder_x_pos, current_position[Y_AXIS], current_position[Z_AXIS], current_position[E_AXIS]); | ||||||
|  |  | ||||||
| @@ -964,15 +940,9 @@ void clean_up_after_endstop_or_probe_move() { | |||||||
|             sync_plan_position(); |             sync_plan_position(); | ||||||
|             extruder_duplication_enabled = true; |             extruder_duplication_enabled = true; | ||||||
|             active_extruder_parked = false; |             active_extruder_parked = false; | ||||||
|             #if ENABLED(DEBUG_LEVELING_FEATURE) |             if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Set extruder_duplication_enabled\nClear active_extruder_parked"); | ||||||
|               if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("Set extruder_duplication_enabled\nClear active_extruder_parked"); |  | ||||||
|             #endif |  | ||||||
|           } |  | ||||||
|           else { |  | ||||||
|             #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|               if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("Active extruder not 0"); |  | ||||||
|             #endif |  | ||||||
|           } |           } | ||||||
|  |           else if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Active extruder not 0"); | ||||||
|           break; |           break; | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
| @@ -1189,20 +1159,14 @@ float get_homing_bump_feedrate(const AxisEnum axis) { | |||||||
|  */ |  */ | ||||||
| void do_homing_move(const AxisEnum axis, const float distance, const float fr_mm_s=0.0) { | void do_homing_move(const AxisEnum axis, const float distance, const float fr_mm_s=0.0) { | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) { |   if (DEBUGGING(LEVELING)) { | ||||||
|       SERIAL_ECHOPAIR(">>> do_homing_move(", axis_codes[axis]); |     DEBUG_ECHOPAIR(">>> do_homing_move(", axis_codes[axis], ", ", distance, ", "); | ||||||
|       SERIAL_ECHOPAIR(", ", distance); |  | ||||||
|       SERIAL_ECHOPGM(", "); |  | ||||||
|     if (fr_mm_s) |     if (fr_mm_s) | ||||||
|         SERIAL_ECHO(fr_mm_s); |       DEBUG_ECHO(fr_mm_s); | ||||||
|       else { |     else | ||||||
|         SERIAL_ECHOPAIR("[", homing_feedrate(axis)); |       DEBUG_ECHOPAIR("[", homing_feedrate(axis), "]"); | ||||||
|         SERIAL_CHAR(']'); |     DEBUG_ECHOLNPGM(")"); | ||||||
|   } |   } | ||||||
|       SERIAL_ECHOLNPGM(")"); |  | ||||||
|     } |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   #if HOMING_Z_WITH_PROBE && HAS_HEATED_BED && ENABLED(WAIT_FOR_BED_HEATER) |   #if HOMING_Z_WITH_PROBE && HAS_HEATED_BED && ENABLED(WAIT_FOR_BED_HEATER) | ||||||
|     // Wait for bed to heat back up between probing points |     // Wait for bed to heat back up between probing points | ||||||
| @@ -1279,13 +1243,7 @@ void do_homing_move(const AxisEnum axis, const float distance, const float fr_mm | |||||||
|     #endif |     #endif | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("<<< do_homing_move(", axis_codes[axis], ")"); | ||||||
|     if (DEBUGGING(LEVELING)) { |  | ||||||
|       SERIAL_ECHOPAIR("<<< do_homing_move(", axis_codes[axis]); |  | ||||||
|       SERIAL_CHAR(')'); |  | ||||||
|       SERIAL_EOL(); |  | ||||||
|     } |  | ||||||
|   #endif |  | ||||||
| } | } | ||||||
|  |  | ||||||
| /** | /** | ||||||
| @@ -1307,13 +1265,7 @@ void do_homing_move(const AxisEnum axis, const float distance, const float fr_mm | |||||||
|  * Callers must sync the planner position after calling this! |  * Callers must sync the planner position after calling this! | ||||||
|  */ |  */ | ||||||
| void set_axis_is_at_home(const AxisEnum axis) { | void set_axis_is_at_home(const AxisEnum axis) { | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR(">>> set_axis_is_at_home(", axis_codes[axis], ")"); | ||||||
|     if (DEBUGGING(LEVELING)) { |  | ||||||
|       SERIAL_ECHOPAIR(">>> set_axis_is_at_home(", axis_codes[axis]); |  | ||||||
|       SERIAL_CHAR(')'); |  | ||||||
|       SERIAL_EOL(); |  | ||||||
|     } |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   SBI(axis_known_position, axis); |   SBI(axis_known_position, axis); | ||||||
|   SBI(axis_homed, axis); |   SBI(axis_homed, axis); | ||||||
| @@ -1351,33 +1303,23 @@ void set_axis_is_at_home(const AxisEnum axis) { | |||||||
|  |  | ||||||
|         current_position[Z_AXIS] -= zprobe_zoffset; |         current_position[Z_AXIS] -= zprobe_zoffset; | ||||||
|  |  | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |         if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("*** Z HOMED WITH PROBE (Z_MIN_PROBE_USES_Z_MIN_ENDSTOP_PIN) ***\n> zprobe_zoffset = ", zprobe_zoffset); | ||||||
|           if (DEBUGGING(LEVELING)) { |  | ||||||
|             SERIAL_ECHOLNPGM("*** Z HOMED WITH PROBE (Z_MIN_PROBE_USES_Z_MIN_ENDSTOP_PIN) ***"); |  | ||||||
|             SERIAL_ECHOLNPAIR("> zprobe_zoffset = ", zprobe_zoffset); |  | ||||||
|           } |  | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|       #elif ENABLED(DEBUG_LEVELING_FEATURE) |       #else | ||||||
|  |  | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("*** Z HOMED TO ENDSTOP ***"); |         if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("*** Z HOMED TO ENDSTOP ***"); | ||||||
|  |  | ||||||
|       #endif |       #endif | ||||||
|     } |     } | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) { |   if (DEBUGGING(LEVELING)) { | ||||||
|     #if HAS_HOME_OFFSET |     #if HAS_HOME_OFFSET | ||||||
|         SERIAL_ECHOPAIR("> home_offset[", axis_codes[axis]); |       DEBUG_ECHOLNPAIR("> home_offset[", axis_codes[axis], "] = ", home_offset[axis]); | ||||||
|         SERIAL_ECHOLNPAIR("] = ", home_offset[axis]); |  | ||||||
|     #endif |     #endif | ||||||
|     DEBUG_POS("", current_position); |     DEBUG_POS("", current_position); | ||||||
|       SERIAL_ECHOPAIR("<<< set_axis_is_at_home(", axis_codes[axis]); |     DEBUG_ECHOLNPAIR("<<< set_axis_is_at_home(", axis_codes[axis], ")"); | ||||||
|       SERIAL_CHAR(')'); |  | ||||||
|       SERIAL_EOL(); |  | ||||||
|   } |   } | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   #if ENABLED(I2C_POSITION_ENCODERS) |   #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|     I2CPEM.homed(axis); |     I2CPEM.homed(axis); | ||||||
| @@ -1388,24 +1330,12 @@ void set_axis_is_at_home(const AxisEnum axis) { | |||||||
|  * Set an axis' to be unhomed. |  * Set an axis' to be unhomed. | ||||||
|  */ |  */ | ||||||
| void set_axis_is_not_at_home(const AxisEnum axis) { | void set_axis_is_not_at_home(const AxisEnum axis) { | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR(">>> set_axis_is_not_at_home(", axis_codes[axis], ")"); | ||||||
|     if (DEBUGGING(LEVELING)) { |  | ||||||
|       SERIAL_ECHOPAIR(">>> set_axis_is_not_at_home(", axis_codes[axis]); |  | ||||||
|       SERIAL_CHAR(')'); |  | ||||||
|       SERIAL_EOL(); |  | ||||||
|     } |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   CBI(axis_known_position, axis); |   CBI(axis_known_position, axis); | ||||||
|   CBI(axis_homed, axis); |   CBI(axis_homed, axis); | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("<<< set_axis_is_not_at_home(", axis_codes[axis], ")"); | ||||||
|     if (DEBUGGING(LEVELING)) { |  | ||||||
|       SERIAL_ECHOPAIR("<<< set_axis_is_not_at_home(", axis_codes[axis]); |  | ||||||
|       SERIAL_CHAR(')'); |  | ||||||
|       SERIAL_EOL(); |  | ||||||
|     } |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   #if ENABLED(I2C_POSITION_ENCODERS) |   #if ENABLED(I2C_POSITION_ENCODERS) | ||||||
|     I2CPEM.unhomed(axis); |     I2CPEM.unhomed(axis); | ||||||
| @@ -1434,13 +1364,7 @@ void homeaxis(const AxisEnum axis) { | |||||||
|     if (!CAN_HOME(X) && !CAN_HOME(Y) && !CAN_HOME(Z)) return; |     if (!CAN_HOME(X) && !CAN_HOME(Y) && !CAN_HOME(Z)) return; | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR(">>> homeaxis(", axis_codes[axis], ")"); | ||||||
|     if (DEBUGGING(LEVELING)) { |  | ||||||
|       SERIAL_ECHOPAIR(">>> homeaxis(", axis_codes[axis]); |  | ||||||
|       SERIAL_CHAR(')'); |  | ||||||
|       SERIAL_EOL(); |  | ||||||
|     } |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   const int axis_home_dir = ( |   const int axis_home_dir = ( | ||||||
|     #if ENABLED(DUAL_X_CARRIAGE) |     #if ENABLED(DUAL_X_CARRIAGE) | ||||||
| @@ -1472,9 +1396,7 @@ void homeaxis(const AxisEnum axis) { | |||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   // Fast move towards endstop until triggered |   // Fast move towards endstop until triggered | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Home 1 Fast:"); | ||||||
|     if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("Home 1 Fast:"); |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   #if HOMING_Z_WITH_PROBE && ENABLED(BLTOUCH) |   #if HOMING_Z_WITH_PROBE && ENABLED(BLTOUCH) | ||||||
|     // BLTOUCH needs to be deployed every time |     // BLTOUCH needs to be deployed every time | ||||||
| @@ -1506,9 +1428,7 @@ void homeaxis(const AxisEnum axis) { | |||||||
|   // If a second homing move is configured... |   // If a second homing move is configured... | ||||||
|   if (bump) { |   if (bump) { | ||||||
|     // Move away from the endstop by the axis HOME_BUMP_MM |     // Move away from the endstop by the axis HOME_BUMP_MM | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Move Away:"); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("Move Away:"); |  | ||||||
|     #endif |  | ||||||
|     do_homing_move(axis, -bump |     do_homing_move(axis, -bump | ||||||
|       #if HOMING_Z_WITH_PROBE |       #if HOMING_Z_WITH_PROBE | ||||||
|         , axis == Z_AXIS ? MMM_TO_MMS(Z_PROBE_SPEED_FAST) : 0.0 |         , axis == Z_AXIS ? MMM_TO_MMS(Z_PROBE_SPEED_FAST) : 0.0 | ||||||
| @@ -1516,9 +1436,7 @@ void homeaxis(const AxisEnum axis) { | |||||||
|     ); |     ); | ||||||
|  |  | ||||||
|     // Slow move towards endstop until triggered |     // Slow move towards endstop until triggered | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Home 2 Slow:"); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("Home 2 Slow:"); |  | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     #if HOMING_Z_WITH_PROBE && ENABLED(BLTOUCH) |     #if HOMING_Z_WITH_PROBE && ENABLED(BLTOUCH) | ||||||
|       // BLTOUCH needs to be deployed every time |       // BLTOUCH needs to be deployed every time | ||||||
| @@ -1644,9 +1562,7 @@ void homeaxis(const AxisEnum axis) { | |||||||
|  |  | ||||||
|     // retrace by the amount specified in delta_endstop_adj + additional dist in order to have minimum steps |     // retrace by the amount specified in delta_endstop_adj + additional dist in order to have minimum steps | ||||||
|     if (delta_endstop_adj[axis] * Z_HOME_DIR <= 0) { |     if (delta_endstop_adj[axis] * Z_HOME_DIR <= 0) { | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("delta_endstop_adj:"); | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("delta_endstop_adj:"); |  | ||||||
|       #endif |  | ||||||
|       do_homing_move(axis, delta_endstop_adj[axis] - (MIN_STEPS_PER_SEGMENT + 1) * planner.steps_to_mm[axis] * Z_HOME_DIR); |       do_homing_move(axis, delta_endstop_adj[axis] - (MIN_STEPS_PER_SEGMENT + 1) * planner.steps_to_mm[axis] * Z_HOME_DIR); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1657,9 +1573,7 @@ void homeaxis(const AxisEnum axis) { | |||||||
|  |  | ||||||
|     destination[axis] = current_position[axis]; |     destination[axis] = current_position[axis]; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("> AFTER set_axis_is_at_home", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("> AFTER set_axis_is_at_home", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
| @@ -1673,25 +1587,14 @@ void homeaxis(const AxisEnum axis) { | |||||||
|     if (axis == Z_AXIS) fwretract.current_hop = 0.0; |     if (axis == Z_AXIS) fwretract.current_hop = 0.0; | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("<<< homeaxis(", axis_codes[axis], ")"); | ||||||
|     if (DEBUGGING(LEVELING)) { |  | ||||||
|       SERIAL_ECHOPAIR("<<< homeaxis(", axis_codes[axis]); |  | ||||||
|       SERIAL_CHAR(')'); |  | ||||||
|       SERIAL_EOL(); |  | ||||||
|     } |  | ||||||
|   #endif |  | ||||||
| } // homeaxis() | } // homeaxis() | ||||||
|  |  | ||||||
| #if HAS_WORKSPACE_OFFSET | #if HAS_WORKSPACE_OFFSET | ||||||
|   void update_workspace_offset(const AxisEnum axis) { |   void update_workspace_offset(const AxisEnum axis) { | ||||||
|     workspace_offset[axis] = home_offset[axis] + position_shift[axis]; |     workspace_offset[axis] = home_offset[axis] + position_shift[axis]; | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("Axis ", axis_codes[axis], " home_offset = ", home_offset[axis], " position_shift = ", position_shift[axis]); | ||||||
|       if (DEBUGGING(LEVELING)) { |  | ||||||
|         SERIAL_ECHOPAIR("For ", axis_codes[axis]); |  | ||||||
|         SERIAL_ECHOPAIR(" axis:\n home_offset = ", home_offset[axis]); |  | ||||||
|         SERIAL_ECHOLNPAIR("\n position_shift = ", position_shift[axis]); |  | ||||||
|       } |  | ||||||
|     #endif |  | ||||||
|   } |   } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -69,6 +69,9 @@ float zprobe_zoffset; // Initialized by settings.load() | |||||||
|   #include "stepper_indirection.h" |   #include "stepper_indirection.h" | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../core/debug_out.h" | ||||||
|  |  | ||||||
| #if ENABLED(Z_PROBE_SLED) | #if ENABLED(Z_PROBE_SLED) | ||||||
|  |  | ||||||
|   #ifndef SLED_DOCKING_OFFSET |   #ifndef SLED_DOCKING_OFFSET | ||||||
| @@ -82,9 +85,7 @@ float zprobe_zoffset; // Initialized by settings.load() | |||||||
|    *              If true, move to MAX_X and release the solenoid |    *              If true, move to MAX_X and release the solenoid | ||||||
|    */ |    */ | ||||||
|   static void dock_sled(bool stow) { |   static void dock_sled(bool stow) { | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("dock_sled(", stow, ")"); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPAIR("dock_sled(", stow, ")"); |  | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     // Dock sled a bit closer to ensure proper capturing |     // Dock sled a bit closer to ensure proper capturing | ||||||
|     do_blocking_move_to_x(X_MAX_POS + SLED_DOCKING_OFFSET - ((stow) ? 1 : 0)); |     do_blocking_move_to_x(X_MAX_POS + SLED_DOCKING_OFFSET - ((stow) ? 1 : 0)); | ||||||
| @@ -312,9 +313,7 @@ float zprobe_zoffset; // Initialized by settings.load() | |||||||
|  |  | ||||||
|     bltouch_command(deploy ? BLTOUCH_DEPLOY : BLTOUCH_STOW); |     bltouch_command(deploy ? BLTOUCH_DEPLOY : BLTOUCH_STOW); | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("set_bltouch_deployed(", deploy, ")"); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPAIR("set_bltouch_deployed(", deploy, ")"); |  | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     return false; |     return false; | ||||||
|   } |   } | ||||||
| @@ -325,9 +324,7 @@ float zprobe_zoffset; // Initialized by settings.load() | |||||||
|  * Raise Z to a minimum height to make room for a probe to move |  * Raise Z to a minimum height to make room for a probe to move | ||||||
|  */ |  */ | ||||||
| inline void do_probe_raise(const float z_raise) { | inline void do_probe_raise(const float z_raise) { | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("do_probe_raise(", z_raise, ")"); | ||||||
|     if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPAIR("do_probe_raise(", z_raise, ")"); |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   float z_dest = z_raise; |   float z_dest = z_raise; | ||||||
|   if (zprobe_zoffset < 0) z_dest -= zprobe_zoffset; |   if (zprobe_zoffset < 0) z_dest -= zprobe_zoffset; | ||||||
| @@ -393,12 +390,10 @@ FORCE_INLINE void probe_specific_action(const bool deploy) { | |||||||
| // returns false for ok and true for failure | // returns false for ok and true for failure | ||||||
| bool set_probe_deployed(const bool deploy) { | bool set_probe_deployed(const bool deploy) { | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) { |   if (DEBUGGING(LEVELING)) { | ||||||
|     DEBUG_POS("set_probe_deployed", current_position); |     DEBUG_POS("set_probe_deployed", current_position); | ||||||
|       SERIAL_ECHOLNPAIR("deploy: ", deploy); |     DEBUG_ECHOLNPAIR("deploy: ", deploy); | ||||||
|   } |   } | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   if (endstops.z_probe_enabled == deploy) return false; |   if (endstops.z_probe_enabled == deploy) return false; | ||||||
|  |  | ||||||
| @@ -521,9 +516,7 @@ bool set_probe_deployed(const bool deploy) { | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| static bool do_probe_move(const float z, const float fr_mm_s) { | static bool do_probe_move(const float z, const float fr_mm_s) { | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) DEBUG_POS(">>> do_probe_move", current_position); |   if (DEBUGGING(LEVELING)) DEBUG_POS(">>> do_probe_move", current_position); | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   #if HAS_HEATED_BED && ENABLED(WAIT_FOR_BED_HEATER) |   #if HAS_HEATED_BED && ENABLED(WAIT_FOR_BED_HEATER) | ||||||
|     // Wait for bed to heat back up between probing points |     // Wait for bed to heat back up between probing points | ||||||
| @@ -601,9 +594,7 @@ static bool do_probe_move(const float z, const float fr_mm_s) { | |||||||
|   // Tell the planner where we actually are |   // Tell the planner where we actually are | ||||||
|   sync_plan_position(); |   sync_plan_position(); | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) DEBUG_POS("<<< do_probe_move", current_position); |   if (DEBUGGING(LEVELING)) DEBUG_POS("<<< do_probe_move", current_position); | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   return !probe_triggered; |   return !probe_triggered; | ||||||
| } | } | ||||||
| @@ -616,9 +607,7 @@ static bool do_probe_move(const float z, const float fr_mm_s) { | |||||||
|  */ |  */ | ||||||
| static float run_z_probe() { | static float run_z_probe() { | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) DEBUG_POS(">>> run_z_probe", current_position); |   if (DEBUGGING(LEVELING)) DEBUG_POS(">>> run_z_probe", current_position); | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   // Stop the probe before it goes too low to prevent damage. |   // Stop the probe before it goes too low to prevent damage. | ||||||
|   // If Z isn't known then probe to -10mm. |   // If Z isn't known then probe to -10mm. | ||||||
| @@ -629,20 +618,16 @@ static float run_z_probe() { | |||||||
|  |  | ||||||
|     // Do a first probe at the fast speed |     // Do a first probe at the fast speed | ||||||
|     if (do_probe_move(z_probe_low_point, MMM_TO_MMS(Z_PROBE_SPEED_FAST))) { |     if (do_probe_move(z_probe_low_point, MMM_TO_MMS(Z_PROBE_SPEED_FAST))) { | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) { |       if (DEBUGGING(LEVELING)) { | ||||||
|           SERIAL_ECHOLNPGM("FAST Probe fail!"); |         DEBUG_ECHOLNPGM("FAST Probe fail!"); | ||||||
|         DEBUG_POS("<<< run_z_probe", current_position); |         DEBUG_POS("<<< run_z_probe", current_position); | ||||||
|       } |       } | ||||||
|       #endif |  | ||||||
|       return NAN; |       return NAN; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     float first_probe_z = current_position[Z_AXIS]; |     float first_probe_z = current_position[Z_AXIS]; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("1st Probe Z:", first_probe_z); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPAIR("1st Probe Z:", first_probe_z); |  | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     // move up to make clearance for the probe |     // move up to make clearance for the probe | ||||||
|     do_blocking_move_to_z(current_position[Z_AXIS] + Z_CLEARANCE_MULTI_PROBE, MMM_TO_MMS(Z_PROBE_SPEED_FAST)); |     do_blocking_move_to_z(current_position[Z_AXIS] + Z_CLEARANCE_MULTI_PROBE, MMM_TO_MMS(Z_PROBE_SPEED_FAST)); | ||||||
| @@ -666,12 +651,10 @@ static float run_z_probe() { | |||||||
|  |  | ||||||
|       // move down slowly to find bed |       // move down slowly to find bed | ||||||
|       if (do_probe_move(z_probe_low_point, MMM_TO_MMS(Z_PROBE_SPEED_SLOW))) { |       if (do_probe_move(z_probe_low_point, MMM_TO_MMS(Z_PROBE_SPEED_SLOW))) { | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|         if (DEBUGGING(LEVELING)) { |         if (DEBUGGING(LEVELING)) { | ||||||
|             SERIAL_ECHOLNPGM("SLOW Probe fail!"); |           DEBUG_ECHOLNPGM("SLOW Probe fail!"); | ||||||
|           DEBUG_POS("<<< run_z_probe", current_position); |           DEBUG_POS("<<< run_z_probe", current_position); | ||||||
|         } |         } | ||||||
|         #endif |  | ||||||
|         return NAN; |         return NAN; | ||||||
|       } |       } | ||||||
|  |  | ||||||
| @@ -694,9 +677,7 @@ static float run_z_probe() { | |||||||
|  |  | ||||||
|     const float z2 = current_position[Z_AXIS]; |     const float z2 = current_position[Z_AXIS]; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("2nd Probe Z:", z2, " Discrepancy:", first_probe_z - z2); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPAIR("2nd Probe Z:", z2, " Discrepancy:", first_probe_z - z2); |  | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     // Return a weighted average of the fast and slow probes |     // Return a weighted average of the fast and slow probes | ||||||
|     const float measured_z = (z2 * 3.0 + first_probe_z * 2.0) * 0.2; |     const float measured_z = (z2 * 3.0 + first_probe_z * 2.0) * 0.2; | ||||||
| @@ -708,9 +689,7 @@ static float run_z_probe() { | |||||||
|  |  | ||||||
|   #endif |   #endif | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) DEBUG_POS("<<< run_z_probe", current_position); |   if (DEBUGGING(LEVELING)) DEBUG_POS("<<< run_z_probe", current_position); | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   return measured_z; |   return measured_z; | ||||||
| } | } | ||||||
| @@ -725,19 +704,15 @@ static float run_z_probe() { | |||||||
|  * - Return the probed Z position |  * - Return the probed Z position | ||||||
|  */ |  */ | ||||||
| float probe_pt(const float &rx, const float &ry, const ProbePtRaise raise_after/*=PROBE_PT_NONE*/, const uint8_t verbose_level/*=0*/, const bool probe_relative/*=true*/) { | float probe_pt(const float &rx, const float &ry, const ProbePtRaise raise_after/*=PROBE_PT_NONE*/, const uint8_t verbose_level/*=0*/, const bool probe_relative/*=true*/) { | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|   if (DEBUGGING(LEVELING)) { |   if (DEBUGGING(LEVELING)) { | ||||||
|       SERIAL_ECHOLNPAIR( |     DEBUG_ECHOLNPAIR( | ||||||
|         ">>> probe_pt(", LOGICAL_X_POSITION(rx), |       ">>> probe_pt(", LOGICAL_X_POSITION(rx), ", ", LOGICAL_Y_POSITION(ry), | ||||||
|         ", ", LOGICAL_Y_POSITION(ry), |  | ||||||
|       ", ", raise_after == PROBE_PT_RAISE ? "raise" : raise_after == PROBE_PT_STOW ? "stow" : "none", |       ", ", raise_after == PROBE_PT_RAISE ? "raise" : raise_after == PROBE_PT_STOW ? "stow" : "none", | ||||||
|       ", ", int(verbose_level), |       ", ", int(verbose_level), | ||||||
|         ", ", probe_relative ? "probe" : "nozzle", |       ", ", probe_relative ? "probe" : "nozzle", "_relative)" | ||||||
|         "_relative)" |  | ||||||
|     ); |     ); | ||||||
|     DEBUG_POS("", current_position); |     DEBUG_POS("", current_position); | ||||||
|   } |   } | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   // TODO: Adapt for SCARA, where the offset rotates |   // TODO: Adapt for SCARA, where the offset rotates | ||||||
|   float nx = rx, ny = ry; |   float nx = rx, ny = ry; | ||||||
| @@ -788,9 +763,7 @@ float probe_pt(const float &rx, const float &ry, const ProbePtRaise raise_after/ | |||||||
|     SERIAL_ERROR_MSG(MSG_ERR_PROBING_FAILED); |     SERIAL_ERROR_MSG(MSG_ERR_PROBING_FAILED); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   #if ENABLED(DEBUG_LEVELING_FEATURE) |   if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("<<< probe_pt"); | ||||||
|     if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("<<< probe_pt"); |  | ||||||
|   #endif |  | ||||||
|  |  | ||||||
|   return measured_z; |   return measured_z; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -31,6 +31,9 @@ | |||||||
|  |  | ||||||
| #include "../Marlin.h" | #include "../Marlin.h" | ||||||
|  |  | ||||||
|  | #define DEBUG_OUT ENABLED(DEBUG_LEVELING_FEATURE) | ||||||
|  | #include "../core/debug_out.h" | ||||||
|  |  | ||||||
| #if EXTRUDERS > 1 | #if EXTRUDERS > 1 | ||||||
|   toolchange_settings_t toolchange_settings;  // Initialized by settings.load() |   toolchange_settings_t toolchange_settings;  // Initialized by settings.load() | ||||||
| #endif | #endif | ||||||
| @@ -169,12 +172,10 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|  |  | ||||||
|     current_position[X_AXIS] = mpe_settings.parking_xpos[tmp_extruder] + offsetcompensation; |     current_position[X_AXIS] = mpe_settings.parking_xpos[tmp_extruder] + offsetcompensation; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) { |     if (DEBUGGING(LEVELING)) { | ||||||
|         SERIAL_ECHOPAIR("(1) Move extruder ", int(tmp_extruder)); |       DEBUG_ECHOPAIR("(1) Move extruder ", int(tmp_extruder)); | ||||||
|       DEBUG_POS(" to new extruder ParkPos", current_position); |       DEBUG_POS(" to new extruder ParkPos", current_position); | ||||||
|     } |     } | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     planner.buffer_line(current_position, mpe_settings.fast_feedrate, tmp_extruder); |     planner.buffer_line(current_position, mpe_settings.fast_feedrate, tmp_extruder); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
| @@ -183,12 +184,10 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|  |  | ||||||
|     current_position[X_AXIS] = grabpos + offsetcompensation; |     current_position[X_AXIS] = grabpos + offsetcompensation; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) { |     if (DEBUGGING(LEVELING)) { | ||||||
|         SERIAL_ECHOPAIR("(2) Couple extruder ", int(tmp_extruder)); |       DEBUG_ECHOPAIR("(2) Couple extruder ", int(tmp_extruder)); | ||||||
|       DEBUG_POS(" to new extruder GrabPos", current_position); |       DEBUG_POS(" to new extruder GrabPos", current_position); | ||||||
|     } |     } | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     planner.buffer_line(current_position, mpe_settings.slow_feedrate, tmp_extruder); |     planner.buffer_line(current_position, mpe_settings.slow_feedrate, tmp_extruder); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
| @@ -199,12 +198,10 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|     // STEP 3 |     // STEP 3 | ||||||
|  |  | ||||||
|     current_position[X_AXIS] = mpe_settings.parking_xpos[tmp_extruder] + offsetcompensation; |     current_position[X_AXIS] = mpe_settings.parking_xpos[tmp_extruder] + offsetcompensation; | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) { |     if (DEBUGGING(LEVELING)) { | ||||||
|         SERIAL_ECHOPAIR("(3) Move extruder ", int(tmp_extruder)); |       DEBUG_ECHOPAIR("(3) Move extruder ", int(tmp_extruder)); | ||||||
|       DEBUG_POS(" back to new extruder ParkPos", current_position); |       DEBUG_POS(" back to new extruder ParkPos", current_position); | ||||||
|     } |     } | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     planner.buffer_line(current_position, mpe_settings.slow_feedrate, tmp_extruder); |     planner.buffer_line(current_position, mpe_settings.slow_feedrate, tmp_extruder); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
| @@ -212,12 +209,10 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|     // STEP 4 |     // STEP 4 | ||||||
|  |  | ||||||
|     current_position[X_AXIS] = mpe_settings.parking_xpos[active_extruder] + (active_extruder == 0 ? MPE_TRAVEL_DISTANCE : -MPE_TRAVEL_DISTANCE) + offsetcompensation; |     current_position[X_AXIS] = mpe_settings.parking_xpos[active_extruder] + (active_extruder == 0 ? MPE_TRAVEL_DISTANCE : -MPE_TRAVEL_DISTANCE) + offsetcompensation; | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) { |     if (DEBUGGING(LEVELING)) { | ||||||
|         SERIAL_ECHOPAIR("(4) Move extruder ", int(tmp_extruder)); |       DEBUG_ECHOPAIR("(4) Move extruder ", int(tmp_extruder)); | ||||||
|       DEBUG_POS(" close to old extruder ParkPos", current_position); |       DEBUG_POS(" close to old extruder ParkPos", current_position); | ||||||
|     } |     } | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     planner.buffer_line(current_position, mpe_settings.fast_feedrate, tmp_extruder); |     planner.buffer_line(current_position, mpe_settings.fast_feedrate, tmp_extruder); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
| @@ -226,12 +221,10 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|  |  | ||||||
|     current_position[X_AXIS] = mpe_settings.parking_xpos[active_extruder] + offsetcompensation; |     current_position[X_AXIS] = mpe_settings.parking_xpos[active_extruder] + offsetcompensation; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) { |     if (DEBUGGING(LEVELING)) { | ||||||
|         SERIAL_ECHOPAIR("(5) Park extruder ", int(tmp_extruder)); |       DEBUG_ECHOPAIR("(5) Park extruder ", int(tmp_extruder)); | ||||||
|       DEBUG_POS(" at old extruder ParkPos", current_position); |       DEBUG_POS(" at old extruder ParkPos", current_position); | ||||||
|     } |     } | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     planner.buffer_line(current_position, mpe_settings.slow_feedrate, tmp_extruder); |     planner.buffer_line(current_position, mpe_settings.slow_feedrate, tmp_extruder); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
| @@ -240,19 +233,15 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|  |  | ||||||
|     current_position[X_AXIS] = oldx; |     current_position[X_AXIS] = oldx; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) { |     if (DEBUGGING(LEVELING)) { | ||||||
|         SERIAL_ECHOPAIR("(6) Move extruder ", int(tmp_extruder)); |       DEBUG_ECHOPAIR("(6) Move extruder ", int(tmp_extruder)); | ||||||
|       DEBUG_POS(" to starting position", current_position); |       DEBUG_POS(" to starting position", current_position); | ||||||
|     } |     } | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     planner.buffer_line(current_position, mpe_settings.fast_feedrate, tmp_extruder); |     planner.buffer_line(current_position, mpe_settings.fast_feedrate, tmp_extruder); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Autopark done."); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("Autopark done."); |  | ||||||
|     #endif |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
| #elif ENABLED(PARKING_EXTRUDER) | #elif ENABLED(PARKING_EXTRUDER) | ||||||
| @@ -302,15 +291,11 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|  |  | ||||||
|       // STEP 1 |       // STEP 1 | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) DEBUG_POS("Start Autopark", current_position); |       if (DEBUGGING(LEVELING)) DEBUG_POS("Start Autopark", current_position); | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       current_position[Z_AXIS] += toolchange_settings.z_raise; |       current_position[Z_AXIS] += toolchange_settings.z_raise; | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) DEBUG_POS("(1) Raise Z-Axis", current_position); |       if (DEBUGGING(LEVELING)) DEBUG_POS("(1) Raise Z-Axis", current_position); | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       fast_line_to_current(Z_AXIS); |       fast_line_to_current(Z_AXIS); | ||||||
|       planner.synchronize(); |       planner.synchronize(); | ||||||
| @@ -319,43 +304,33 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|  |  | ||||||
|       current_position[X_AXIS] = parkingposx[active_extruder] + x_offset; |       current_position[X_AXIS] = parkingposx[active_extruder] + x_offset; | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) { |       if (DEBUGGING(LEVELING)) { | ||||||
|           SERIAL_ECHOLNPAIR("(2) Park extruder ", int(active_extruder)); |         DEBUG_ECHOLNPAIR("(2) Park extruder ", int(active_extruder)); | ||||||
|         DEBUG_POS("Moving ParkPos", current_position); |         DEBUG_POS("Moving ParkPos", current_position); | ||||||
|       } |       } | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       fast_line_to_current(X_AXIS); |       fast_line_to_current(X_AXIS); | ||||||
|       planner.synchronize(); |       planner.synchronize(); | ||||||
|  |  | ||||||
|       // STEP 3 |       // STEP 3 | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("(3) Disengage magnet "); | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("(3) Disengage magnet "); |  | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       pe_deactivate_solenoid(active_extruder); |       pe_deactivate_solenoid(active_extruder); | ||||||
|  |  | ||||||
|       // STEP 4 |       // STEP 4 | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("(4) Move to position near new extruder"); | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("(4) Move to position near new extruder"); |  | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       current_position[X_AXIS] += active_extruder ? -10 : 10; // move 10mm away from parked extruder |       current_position[X_AXIS] += active_extruder ? -10 : 10; // move 10mm away from parked extruder | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) DEBUG_POS("Move away from parked extruder", current_position); |       if (DEBUGGING(LEVELING)) DEBUG_POS("Move away from parked extruder", current_position); | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       fast_line_to_current(X_AXIS); |       fast_line_to_current(X_AXIS); | ||||||
|       planner.synchronize(); |       planner.synchronize(); | ||||||
|  |  | ||||||
|       // STEP 5 |       // STEP 5 | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("(5) Engage magnetic field"); | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("(5) Engage magnetic field"); |  | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       #if ENABLED(PARKING_EXTRUDER_SOLENOIDS_INVERT) |       #if ENABLED(PARKING_EXTRUDER_SOLENOIDS_INVERT) | ||||||
|         pe_activate_solenoid(active_extruder); //just save power for inverted magnets |         pe_activate_solenoid(active_extruder); //just save power for inverted magnets | ||||||
| @@ -368,9 +343,7 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|       current_position[X_AXIS] = grabpos + (tmp_extruder ? -10 : 10); |       current_position[X_AXIS] = grabpos + (tmp_extruder ? -10 : 10); | ||||||
|       fast_line_to_current(X_AXIS); |       fast_line_to_current(X_AXIS); | ||||||
|       current_position[X_AXIS] = grabpos; |       current_position[X_AXIS] = grabpos; | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) DEBUG_POS("(6) Unpark extruder", current_position); |       if (DEBUGGING(LEVELING)) DEBUG_POS("(6) Unpark extruder", current_position); | ||||||
|       #endif |  | ||||||
|       planner.buffer_line(current_position, planner.settings.max_feedrate_mm_s[X_AXIS] * 0.5, active_extruder); |       planner.buffer_line(current_position, planner.settings.max_feedrate_mm_s[X_AXIS] * 0.5, active_extruder); | ||||||
|       planner.synchronize(); |       planner.synchronize(); | ||||||
|  |  | ||||||
| @@ -382,16 +355,12 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|         #endif |         #endif | ||||||
|       ; |       ; | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|       if (DEBUGGING(LEVELING)) DEBUG_POS("(7) Move midway between hotends", current_position); |       if (DEBUGGING(LEVELING)) DEBUG_POS("(7) Move midway between hotends", current_position); | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       fast_line_to_current(X_AXIS); |       fast_line_to_current(X_AXIS); | ||||||
|       planner.synchronize(); |       planner.synchronize(); | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       DEBUG_ECHOLNPGM("Autopark done."); | ||||||
|         SERIAL_ECHOLNPGM("Autopark done."); |  | ||||||
|       #endif |  | ||||||
|     } |     } | ||||||
|     else { // nomove == true |     else { // nomove == true | ||||||
|       // Only engage magnetic field for new extruder |       // Only engage magnetic field for new extruder | ||||||
| @@ -405,9 +374,7 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|       current_position[Z_AXIS] += hotend_offset[Z_AXIS][active_extruder] - hotend_offset[Z_AXIS][tmp_extruder]; |       current_position[Z_AXIS] += hotend_offset[Z_AXIS][active_extruder] - hotend_offset[Z_AXIS][tmp_extruder]; | ||||||
|     #endif |     #endif | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("Applying Z-offset", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("Applying Z-offset", current_position); | ||||||
|     #endif |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
| #endif // PARKING_EXTRUDER | #endif // PARKING_EXTRUDER | ||||||
| @@ -433,15 +400,11 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|  |  | ||||||
|     // 1. Raise Z to give enough clearance |     // 1. Raise Z to give enough clearance | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("Starting Toolhead change", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("Starting Toolhead change", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     current_position[Z_AXIS] += toolchange_settings.z_raise; |     current_position[Z_AXIS] += toolchange_settings.z_raise; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("(1) Raise Z-Axis", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("(1) Raise Z-Axis", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     fast_line_to_current(Z_AXIS); |     fast_line_to_current(Z_AXIS); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
| @@ -450,86 +413,66 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|  |  | ||||||
|     current_position[X_AXIS] = placexpos; |     current_position[X_AXIS] = placexpos; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) { |     if (DEBUGGING(LEVELING)) { | ||||||
|         SERIAL_ECHOLNPAIR("(2) Place old tool ", int(active_extruder)); |       DEBUG_ECHOLNPAIR("(2) Place old tool ", int(active_extruder)); | ||||||
|       DEBUG_POS("Move X SwitchPos", current_position); |       DEBUG_POS("Move X SwitchPos", current_position); | ||||||
|     } |     } | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     fast_line_to_current(X_AXIS); |     fast_line_to_current(X_AXIS); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
|  |  | ||||||
|     current_position[Y_AXIS] = SWITCHING_TOOLHEAD_Y_POS - SWITCHING_TOOLHEAD_Y_SECURITY; |     current_position[Y_AXIS] = SWITCHING_TOOLHEAD_Y_POS - SWITCHING_TOOLHEAD_Y_SECURITY; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("Move Y SwitchPos + Security", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("Move Y SwitchPos + Security", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     fast_line_to_current(Y_AXIS); |     fast_line_to_current(Y_AXIS); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
|  |  | ||||||
|     // 3. Unlock tool and drop it in the dock |     // 3. Unlock tool and drop it in the dock | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("(3) Unlock and Place Toolhead"); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("(3) Unlock and Place Toolhead"); |  | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     MOVE_SERVO(SWITCHING_TOOLHEAD_SERVO_NR, angles[1]); |     MOVE_SERVO(SWITCHING_TOOLHEAD_SERVO_NR, angles[1]); | ||||||
|     safe_delay(500); |     safe_delay(500); | ||||||
|  |  | ||||||
|     current_position[Y_AXIS] = SWITCHING_TOOLHEAD_Y_POS; |     current_position[Y_AXIS] = SWITCHING_TOOLHEAD_Y_POS; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("Move Y SwitchPos", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("Move Y SwitchPos", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     planner.buffer_line(current_position,(planner.settings.max_feedrate_mm_s[Y_AXIS] * 0.5), active_extruder); |     planner.buffer_line(current_position,(planner.settings.max_feedrate_mm_s[Y_AXIS] * 0.5), active_extruder); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
|     safe_delay(200); |     safe_delay(200); | ||||||
|     current_position[Y_AXIS] -= SWITCHING_TOOLHEAD_Y_CLEAR; |     current_position[Y_AXIS] -= SWITCHING_TOOLHEAD_Y_CLEAR; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("Move back Y clear", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("Move back Y clear", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     fast_line_to_current(Y_AXIS); // move away from docked toolhead |     fast_line_to_current(Y_AXIS); // move away from docked toolhead | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
|  |  | ||||||
|     // 4. Move to the new toolhead |     // 4. Move to the new toolhead | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("(4) Move to new toolhead position"); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("(4) Move to new toolhead position"); |  | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     current_position[X_AXIS] = grabxpos; |     current_position[X_AXIS] = grabxpos; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("Move to new toolhead X", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("Move to new toolhead X", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     fast_line_to_current(X_AXIS); |     fast_line_to_current(X_AXIS); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
|     current_position[Y_AXIS] = SWITCHING_TOOLHEAD_Y_POS - SWITCHING_TOOLHEAD_Y_SECURITY; |     current_position[Y_AXIS] = SWITCHING_TOOLHEAD_Y_POS - SWITCHING_TOOLHEAD_Y_SECURITY; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("Move Y SwitchPos + Security", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("Move Y SwitchPos + Security", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     fast_line_to_current(Y_AXIS); |     fast_line_to_current(Y_AXIS); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
|  |  | ||||||
|     // 5. Grab and lock the new toolhead |     // 5. Grab and lock the new toolhead | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("(5) Grab and lock new toolhead "); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("(5) Grab and lock new toolhead "); |  | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     current_position[Y_AXIS] = SWITCHING_TOOLHEAD_Y_POS; |     current_position[Y_AXIS] = SWITCHING_TOOLHEAD_Y_POS; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("Move Y SwitchPos", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("Move Y SwitchPos", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     planner.buffer_line(current_position, planner.settings.max_feedrate_mm_s[Y_AXIS] * 0.5, active_extruder); |     planner.buffer_line(current_position, planner.settings.max_feedrate_mm_s[Y_AXIS] * 0.5, active_extruder); | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
| @@ -540,16 +483,12 @@ inline void fast_line_to_current(const AxisEnum fr_axis) { | |||||||
|  |  | ||||||
|     current_position[Y_AXIS] -= SWITCHING_TOOLHEAD_Y_CLEAR; |     current_position[Y_AXIS] -= SWITCHING_TOOLHEAD_Y_CLEAR; | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("Move back Y clear", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("Move back Y clear", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     fast_line_to_current(Y_AXIS); // move away from docked toolhead |     fast_line_to_current(Y_AXIS); // move away from docked toolhead | ||||||
|     planner.synchronize(); |     planner.synchronize(); | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |     if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("Toolhead change done."); | ||||||
|       if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("Toolhead change done."); |  | ||||||
|     #endif |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
| #endif // SWITCHING_TOOLHEAD | #endif // SWITCHING_TOOLHEAD | ||||||
| @@ -563,17 +502,15 @@ inline void invalid_extruder_error(const uint8_t e) { | |||||||
| #if ENABLED(DUAL_X_CARRIAGE) | #if ENABLED(DUAL_X_CARRIAGE) | ||||||
|  |  | ||||||
|   inline void dualx_tool_change(const uint8_t tmp_extruder, bool &no_move) { |   inline void dualx_tool_change(const uint8_t tmp_extruder, bool &no_move) { | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) { |     if (DEBUGGING(LEVELING)) { | ||||||
|         SERIAL_ECHOPGM("Dual X Carriage Mode "); |       DEBUG_ECHOPGM("Dual X Carriage Mode "); | ||||||
|       switch (dual_x_carriage_mode) { |       switch (dual_x_carriage_mode) { | ||||||
|           case DXC_FULL_CONTROL_MODE: SERIAL_ECHOLNPGM("DXC_FULL_CONTROL_MODE"); break; |         case DXC_FULL_CONTROL_MODE: DEBUG_ECHOLNPGM("DXC_FULL_CONTROL_MODE"); break; | ||||||
|           case DXC_AUTO_PARK_MODE: SERIAL_ECHOLNPGM("DXC_AUTO_PARK_MODE"); break; |         case DXC_AUTO_PARK_MODE: DEBUG_ECHOLNPGM("DXC_AUTO_PARK_MODE"); break; | ||||||
|           case DXC_DUPLICATION_MODE: SERIAL_ECHOLNPGM("DXC_DUPLICATION_MODE"); break; |         case DXC_DUPLICATION_MODE: DEBUG_ECHOLNPGM("DXC_DUPLICATION_MODE"); break; | ||||||
|           case DXC_SCALED_DUPLICATION_MODE: SERIAL_ECHOLNPGM("DXC_SCALED_DUPLICATION_MODE"); break; |         case DXC_SCALED_DUPLICATION_MODE: DEBUG_ECHOLNPGM("DXC_SCALED_DUPLICATION_MODE"); break; | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     const float xhome = x_home_pos(active_extruder); |     const float xhome = x_home_pos(active_extruder); | ||||||
|     if (dual_x_carriage_mode == DXC_AUTO_PARK_MODE |     if (dual_x_carriage_mode == DXC_AUTO_PARK_MODE | ||||||
| @@ -581,9 +518,8 @@ inline void invalid_extruder_error(const uint8_t e) { | |||||||
|         && (delayed_move_time || current_position[X_AXIS] != xhome) && ! no_move |         && (delayed_move_time || current_position[X_AXIS] != xhome) && ! no_move | ||||||
|     ) { |     ) { | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("MoveX to ", xhome); | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPAIR("MoveX to ", xhome); |  | ||||||
|       #endif |  | ||||||
|       // Park old head |       // Park old head | ||||||
|       planner.buffer_line(xhome, current_position[Y_AXIS], current_position[Z_AXIS], current_position[E_AXIS], planner.settings.max_feedrate_mm_s[X_AXIS], active_extruder); |       planner.buffer_line(xhome, current_position[Y_AXIS], current_position[Z_AXIS], current_position[E_AXIS], planner.settings.max_feedrate_mm_s[X_AXIS], active_extruder); | ||||||
|       planner.synchronize(); |       planner.synchronize(); | ||||||
| @@ -599,9 +535,7 @@ inline void invalid_extruder_error(const uint8_t e) { | |||||||
|     // This function resets the max/min values - the current position may be overwritten below. |     // This function resets the max/min values - the current position may be overwritten below. | ||||||
|     set_axis_is_at_home(X_AXIS); |     set_axis_is_at_home(X_AXIS); | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) DEBUG_POS("New Extruder", current_position); |     if (DEBUGGING(LEVELING)) DEBUG_POS("New Extruder", current_position); | ||||||
|     #endif |  | ||||||
|  |  | ||||||
|     switch (dual_x_carriage_mode) { |     switch (dual_x_carriage_mode) { | ||||||
|       case DXC_FULL_CONTROL_MODE: |       case DXC_FULL_CONTROL_MODE: | ||||||
| @@ -620,12 +554,10 @@ inline void invalid_extruder_error(const uint8_t e) { | |||||||
|         break; |         break; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|     if (DEBUGGING(LEVELING)) { |     if (DEBUGGING(LEVELING)) { | ||||||
|         SERIAL_ECHOLNPAIR("Active extruder parked: ", active_extruder_parked ? "yes" : "no"); |       DEBUG_ECHOLNPAIR("Active extruder parked: ", active_extruder_parked ? "yes" : "no"); | ||||||
|       DEBUG_POS("New extruder (parked)", current_position); |       DEBUG_POS("New extruder (parked)", current_position); | ||||||
|     } |     } | ||||||
|     #endif |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
| #endif // DUAL_X_CARRIAGE | #endif // DUAL_X_CARRIAGE | ||||||
| @@ -680,9 +612,7 @@ void tool_change(const uint8_t tmp_extruder, const float fr_mm_s/*=0.0*/, bool n | |||||||
|  |  | ||||||
|     if (!no_move && !all_axes_homed()) { |     if (!no_move && !all_axes_homed()) { | ||||||
|       no_move = true; |       no_move = true; | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPGM("No move on toolchange"); | ||||||
|         if (DEBUGGING(LEVELING)) SERIAL_ECHOLNPGM("No move on toolchange"); |  | ||||||
|       #endif |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     #if HAS_LCD_MENU |     #if HAS_LCD_MENU | ||||||
| @@ -777,10 +707,7 @@ void tool_change(const uint8_t tmp_extruder, const float fr_mm_s/*=0.0*/, bool n | |||||||
|         move_nozzle_servo(tmp_extruder); |         move_nozzle_servo(tmp_extruder); | ||||||
|       #endif |       #endif | ||||||
|  |  | ||||||
|       #if ENABLED(DEBUG_LEVELING_FEATURE) |       if (DEBUGGING(LEVELING)) DEBUG_ECHOLNPAIR("Offset Tool XY by { ", xdiff, ", ", ydiff, ", ", zdiff, " }"); | ||||||
|         if (DEBUGGING(LEVELING)) |  | ||||||
|           SERIAL_ECHOLNPAIR("Offset Tool XY by { ", xdiff, ", ", ydiff, ", ", zdiff, " }"); |  | ||||||
|       #endif |  | ||||||
|  |  | ||||||
|       // The newly-selected extruder XY is actually at... |       // The newly-selected extruder XY is actually at... | ||||||
|       current_position[X_AXIS] += xdiff; |       current_position[X_AXIS] += xdiff; | ||||||
| @@ -802,9 +729,7 @@ void tool_change(const uint8_t tmp_extruder, const float fr_mm_s/*=0.0*/, bool n | |||||||
|  |  | ||||||
|       // Return to position and lower again |       // Return to position and lower again | ||||||
|       if (safe_to_move && !no_move && IsRunning()) { |       if (safe_to_move && !no_move && IsRunning()) { | ||||||
|         #if ENABLED(DEBUG_LEVELING_FEATURE) |  | ||||||
|         if (DEBUGGING(LEVELING)) DEBUG_POS("Move back", destination); |         if (DEBUGGING(LEVELING)) DEBUG_POS("Move back", destination); | ||||||
|         #endif |  | ||||||
|  |  | ||||||
|         #if ENABLED(SINGLENOZZLE) |         #if ENABLED(SINGLENOZZLE) | ||||||
|           #if FAN_COUNT > 0 |           #if FAN_COUNT > 0 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user