Rewrote rewipe implementation (T2251)

- On Hibiscus, a missed probe will trigger the following recovery sequence:
   - Rehome
   - X axis leveling
   - Reprobe (from 1st point).

- On other printers, this FW will revert the old behavior of probing from
  the 1st point after a rewipe (rather than continuing from where it failed).
master
Marcio Teixeira 7 years ago
parent ca4a51a3d3
commit 42e596172e

@ -13,7 +13,7 @@
* got disabled. * got disabled.
*/ */
#define LULZBOT_FW_VERSION ".26" // Change this with each update #define LULZBOT_FW_VERSION ".27" // Change this with each update
#if ( \ #if ( \
!defined(LULZBOT_Gladiola_Mini) && \ !defined(LULZBOT_Gladiola_Mini) && \
@ -1516,12 +1516,16 @@
/*************************** REWIPE FUNCTIONALITY *******************************/ /*************************** REWIPE FUNCTIONALITY *******************************/
#define LULZBOT_NUM_REWIPES 3 #define LULZBOT_NUM_REWIPES 3
#define LULZBOT_NOZZLE_CLEAN_GOBACK_DISABLE
#if defined(LULZBOT_IS_TAZ) #if defined(LULZBOT_IS_TAZ)
#define LULZBOT_BED_PROBE_MIN 0 // Limit on pushing into the bed #define LULZBOT_BED_PROBE_MIN 0 // Limit on pushing into the bed
#else defined(LULZBOT_IS_MINI) #else defined(LULZBOT_IS_MINI)
#define LULZBOT_BED_PROBE_MIN -4 // Limit on pushing into the bed #define LULZBOT_BED_PROBE_MIN -4 // Limit on pushing into the bed
#endif #endif
#define LULZBOT_PROBE_Z_WITH_REWIPE(speed) if (do_probe_move(LULZBOT_BED_PROBE_MIN, Z_PROBE_SPEED_FAST)) return NAN;
#if defined(LULZBOT_USE_PRE_GLADIOLA_G29_WORKAROUND) #if defined(LULZBOT_USE_PRE_GLADIOLA_G29_WORKAROUND)
// workaround for older minis where G29 shifts the coordinate system // workaround for older minis where G29 shifts the coordinate system
#define LULZBOT_REHOME_BEFORE_REWIPE \ #define LULZBOT_REHOME_BEFORE_REWIPE \
@ -1534,10 +1538,29 @@
#define LULZBOT_REHOME_BEFORE_REWIPE #define LULZBOT_REHOME_BEFORE_REWIPE
#endif #endif
#define LULZBOT_PROBE_Z_WITH_REWIPE(speed) \ #if defined(LULZBOT_USE_Z_BELT)
/* do_probe_move returns true when it fails to hit an endstop, meaning we need to rewipe */ \ #define LULZBOT_REWIPE_GCODE LULZBOT_MENU_AXIS_LEVELING_GCODE "\nG12 P0 S12 T0"
for(int rewipes = 0; do_probe_move(LULZBOT_BED_PROBE_MIN, speed); rewipes++) { \ #else
if(rewipes >= LULZBOT_NUM_REWIPES) { /* max of tries */ \ #define LULZBOT_REWIPE_GCODE "G0 Z10\nG12 P0 S12 T0"
#endif
#define LULZBOT_PROBE_RETRY_COUNTER_DECL int reprobe_retries_left = LULZBOT_NUM_REWIPES;
#define LULZBOT_G29_WITH_RETRY \
{ \
LULZBOT_ENABLE_PROBE_PINS(true); \
gcode_G29(); \
if(planner.leveling_active) { \
/* Probe succeeded */ \
reprobe_retries_left = LULZBOT_NUM_REWIPES; \
} else if(reprobe_retries_left > 0) { \
/* Probe failed, but we still have retries left */ \
reprobe_retries_left--; \
SERIAL_ERRORLNPGM(MSG_REWIPE); \
LCD_MESSAGEPGM(MSG_REWIPE); \
enqueue_and_echo_commands_P(PSTR(LULZBOT_REWIPE_GCODE "\nG29")); \
} else { \
/* Probe failed; no retries left */ \
SERIAL_ERRORLNPGM("PROBE FAIL CLEAN NOZZLE"); /* cura listens for this message specifically */ \ SERIAL_ERRORLNPGM("PROBE FAIL CLEAN NOZZLE"); /* cura listens for this message specifically */ \
LCD_MESSAGEPGM(MSG_ERR_PROBING_FAILED); /* use a more friendly message on the LCD */ \ LCD_MESSAGEPGM(MSG_ERR_PROBING_FAILED); /* use a more friendly message on the LCD */ \
BUZZ(25, 880); BUZZ(50, 0); /* play tone */ \ BUZZ(25, 880); BUZZ(50, 0); /* play tone */ \
@ -1549,14 +1572,11 @@
sync_plan_position_e(); \ sync_plan_position_e(); \
stepper.synchronize(); \ stepper.synchronize(); \
kill(PSTR(MSG_ERR_PROBING_FAILED)); /* stop print job */ \ kill(PSTR(MSG_ERR_PROBING_FAILED)); /* stop print job */ \
return NAN; /* abort the leveling in progress */ \
} \ } \
SERIAL_ERRORLNPGM(MSG_REWIPE); \ LULZBOT_ENABLE_PROBE_PINS(false); \
LCD_MESSAGEPGM(MSG_REWIPE); \
do_blocking_move_to_z(10, MMM_TO_MMS(speed)); /* raise nozzle */ \
Nozzle::clean(0, 12, 0, 0); /* wipe nozzle */ \
} }
/******************************** MOTOR CURRENTS *******************************/ /******************************** MOTOR CURRENTS *******************************/
// Values for XYZ vary by printer model, values for E vary by toolhead. // Values for XYZ vary by printer model, values for E vary by toolhead.

@ -1275,7 +1275,7 @@
#define NOZZLE_CLEAN_CIRCLE_MIDDLE NOZZLE_CLEAN_START_POINT #define NOZZLE_CLEAN_CIRCLE_MIDDLE NOZZLE_CLEAN_START_POINT
// Moves the nozzle to the initial position // Moves the nozzle to the initial position
#define NOZZLE_CLEAN_GOBACK //#define NOZZLE_CLEAN_GOBACK LULZBOT_NOZZLE_CLEAN_GOBACK_DISABLE
#endif #endif
/** /**

@ -360,6 +360,8 @@
#include "AO_FT810_UI_Screens.h" #include "AO_FT810_UI_Screens.h"
#endif #endif
LULZBOT_PROBE_RETRY_COUNTER_DECL
bool Running = true; bool Running = true;
uint8_t marlin_debug_flags = DEBUG_NONE; uint8_t marlin_debug_flags = DEBUG_NONE;
@ -2232,11 +2234,7 @@ static void clean_up_after_endstop_or_probe_move() {
// Double-probing does a fast probe followed by a slow probe // Double-probing does a fast probe followed by a slow probe
#if MULTIPLE_PROBING == 2 #if MULTIPLE_PROBING == 2
// Do a first probe at the fast speed // Do a first probe at the fast speed
#if defined(LULZBOT_PROBE_Z_WITH_REWIPE) if (do_probe_move(LULZBOT_BED_PROBE_MIN, Z_PROBE_SPEED_FAST)) return NAN;
LULZBOT_PROBE_Z_WITH_REWIPE(Z_PROBE_SPEED_FAST);
#else
if (do_probe_move(-10, Z_PROBE_SPEED_FAST)) return NAN;
#endif
float first_probe_z = current_position[Z_AXIS]; float first_probe_z = current_position[Z_AXIS];
@ -11812,9 +11810,11 @@ void process_parsed_command() {
#if HAS_LEVELING #if HAS_LEVELING
case 29: // G29 Detailed Z probe, probes the bed at 3 or more points, case 29: // G29 Detailed Z probe, probes the bed at 3 or more points,
// or provides access to the UBL System if enabled. // or provides access to the UBL System if enabled.
LULZBOT_ENABLE_PROBE_PINS(true); #if defined(LULZBOT_G29_WITH_RETRY)
LULZBOT_G29_WITH_RETRY
#else
gcode_G29(); gcode_G29();
LULZBOT_ENABLE_PROBE_PINS(false); #endif
break; break;
#endif // HAS_LEVELING #endif // HAS_LEVELING

Loading…
Cancel
Save