Extra insurance against endstop false positives (#11013)
This commit is contained in:
		| @@ -265,7 +265,7 @@ void Endstops::not_homing() { | ||||
|  | ||||
| // Enable / disable endstop z-probe checking | ||||
| #if HAS_BED_PROBE | ||||
|   void Endstops::enable_z_probe(bool onoff) { | ||||
|   void Endstops::enable_z_probe(const bool onoff) { | ||||
|     z_probe_enabled = onoff; | ||||
|  | ||||
|     #if ENABLED(ENDSTOP_INTERRUPTS_FEATURE) | ||||
| @@ -439,7 +439,7 @@ void Endstops::update() { | ||||
|   if (stepper.axis_is_moving(X_AXIS)) { | ||||
|     if (stepper.motor_direction(X_AXIS_HEAD)) { // -direction | ||||
|       #if HAS_X_MIN | ||||
|         #if ENABLED(X_DUAL_ENDSTOPS) | ||||
|         #if ENABLED(X_DUAL_ENDSTOPS) && X_HOME_DIR < 0 | ||||
|           UPDATE_ENDSTOP_BIT(X, MIN); | ||||
|           #if HAS_X2_MIN | ||||
|             UPDATE_ENDSTOP_BIT(X2, MIN); | ||||
| @@ -453,7 +453,7 @@ void Endstops::update() { | ||||
|     } | ||||
|     else { // +direction | ||||
|       #if HAS_X_MAX | ||||
|         #if ENABLED(X_DUAL_ENDSTOPS) | ||||
|         #if ENABLED(X_DUAL_ENDSTOPS) && X_HOME_DIR > 0 | ||||
|           UPDATE_ENDSTOP_BIT(X, MAX); | ||||
|           #if HAS_X2_MAX | ||||
|             UPDATE_ENDSTOP_BIT(X2, MAX); | ||||
| @@ -469,7 +469,7 @@ void Endstops::update() { | ||||
|  | ||||
|   if (stepper.axis_is_moving(Y_AXIS)) { | ||||
|     if (stepper.motor_direction(Y_AXIS_HEAD)) { // -direction | ||||
|       #if HAS_Y_MIN | ||||
|       #if HAS_Y_MIN && Y_HOME_DIR < 0 | ||||
|         #if ENABLED(Y_DUAL_ENDSTOPS) | ||||
|           UPDATE_ENDSTOP_BIT(Y, MIN); | ||||
|           #if HAS_Y2_MIN | ||||
| @@ -483,7 +483,7 @@ void Endstops::update() { | ||||
|       #endif | ||||
|     } | ||||
|     else { // +direction | ||||
|       #if HAS_Y_MAX | ||||
|       #if HAS_Y_MAX && Y_HOME_DIR > 0 | ||||
|         #if ENABLED(Y_DUAL_ENDSTOPS) | ||||
|           UPDATE_ENDSTOP_BIT(Y, MAX); | ||||
|           #if HAS_Y2_MAX | ||||
| @@ -501,19 +501,17 @@ void Endstops::update() { | ||||
|   if (stepper.axis_is_moving(Z_AXIS)) { | ||||
|     if (stepper.motor_direction(Z_AXIS_HEAD)) { // Z -direction. Gantry down, bed up. | ||||
|       #if HAS_Z_MIN | ||||
|         #if ENABLED(Z_DUAL_ENDSTOPS) | ||||
|         #if ENABLED(Z_DUAL_ENDSTOPS) && Z_HOME_DIR < 0 | ||||
|           UPDATE_ENDSTOP_BIT(Z, MIN); | ||||
|           #if HAS_Z2_MIN | ||||
|             UPDATE_ENDSTOP_BIT(Z2, MIN); | ||||
|           #else | ||||
|             COPY_BIT(live_state, Z_MIN, Z2_MIN); | ||||
|           #endif | ||||
|         #else | ||||
|           #if ENABLED(Z_MIN_PROBE_USES_Z_MIN_ENDSTOP_PIN) | ||||
|             if (z_probe_enabled) UPDATE_ENDSTOP_BIT(Z, MIN); | ||||
|           #else | ||||
|             UPDATE_ENDSTOP_BIT(Z, MIN); | ||||
|           #endif | ||||
|         #elif ENABLED(Z_MIN_PROBE_USES_Z_MIN_ENDSTOP_PIN) | ||||
|           if (z_probe_enabled) UPDATE_ENDSTOP_BIT(Z, MIN); | ||||
|         #elif Z_HOME_DIR < 0 | ||||
|           UPDATE_ENDSTOP_BIT(Z, MIN); | ||||
|         #endif | ||||
|       #endif | ||||
|  | ||||
| @@ -523,7 +521,7 @@ void Endstops::update() { | ||||
|       #endif | ||||
|     } | ||||
|     else { // Z +direction. Gantry up, bed down. | ||||
|       #if HAS_Z_MAX | ||||
|       #if HAS_Z_MAX && Z_HOME_DIR > 0 | ||||
|         // Check both Z dual endstops | ||||
|         #if ENABLED(Z_DUAL_ENDSTOPS) | ||||
|           UPDATE_ENDSTOP_BIT(Z, MAX); | ||||
| @@ -532,9 +530,8 @@ void Endstops::update() { | ||||
|           #else | ||||
|             COPY_BIT(live_state, Z_MAX, Z2_MAX); | ||||
|           #endif | ||||
|         // If this pin is not hijacked for the bed probe | ||||
|         // then it belongs to the Z endstop | ||||
|         #elif DISABLED(Z_MIN_PROBE_ENDSTOP) || Z_MAX_PIN != Z_MIN_PROBE_PIN | ||||
|           // If this pin isn't the bed probe it's the Z endstop | ||||
|           UPDATE_ENDSTOP_BIT(Z, MAX); | ||||
|         #endif | ||||
|       #endif | ||||
|   | ||||
| @@ -143,7 +143,7 @@ class Endstops { | ||||
|     // Enable / disable endstop z-probe checking | ||||
|     #if HAS_BED_PROBE | ||||
|       static volatile bool z_probe_enabled; | ||||
|       static void enable_z_probe(bool onoff=true); | ||||
|       static void enable_z_probe(const bool onoff=true); | ||||
|     #endif | ||||
|  | ||||
|     // Debugging of endstops | ||||
|   | ||||
		Reference in New Issue
	
	Block a user