Fix PARKING_EXTRUDER homing with solenoid (#20473)
This commit is contained in:
		| @@ -290,6 +290,10 @@ void GcodeSuite::G28() { | ||||
|     #if DISABLED(DELTA) || ENABLED(DELTA_HOME_TO_SAFE_ZONE) | ||||
|       const uint8_t old_tool_index = active_extruder; | ||||
|     #endif | ||||
|     // PARKING_EXTRUDER homing requires different handling of movement / solenoid activation, depending on the side of homing | ||||
|     #if ENABLED(PARKING_EXTRUDER) | ||||
|       const bool pe_final_change_must_unpark = parking_extruder_unpark_after_homing(old_tool_index, X_HOME_DIR + 1 == old_tool_index * 2); | ||||
|     #endif | ||||
|     tool_change(0, true); | ||||
|   #endif | ||||
|  | ||||
| @@ -443,7 +447,7 @@ void GcodeSuite::G28() { | ||||
|  | ||||
|   // Restore the active tool after homing | ||||
|   #if HAS_MULTI_HOTEND && (DISABLED(DELTA) || ENABLED(DELTA_HOME_TO_SAFE_ZONE)) | ||||
|     tool_change(old_tool_index, NONE(PARKING_EXTRUDER, DUAL_X_CARRIAGE));   // Do move if one of these | ||||
|     tool_change(old_tool_index, TERN(PARKING_EXTRUDER, !pe_final_change_must_unpark, DISABLED(DUAL_X_CARRIAGE)));   // Do move if one of these | ||||
|   #endif | ||||
|  | ||||
|   #if HAS_HOMING_CURRENT | ||||
|   | ||||
| @@ -61,16 +61,10 @@ void GcodeSuite::T(const int8_t tool_index) { | ||||
|     } | ||||
|   #endif | ||||
|  | ||||
|   #if EXTRUDERS < 2 | ||||
|  | ||||
|     tool_change(tool_index); | ||||
|  | ||||
|   #else | ||||
|  | ||||
|     tool_change( | ||||
|       tool_index, | ||||
|       (tool_index == active_extruder) || parser.boolval('S') | ||||
|     ); | ||||
|  | ||||
|   #endif | ||||
|   tool_change(tool_index | ||||
|     #if HAS_MULTI_EXTRUDER | ||||
|       ,  TERN(PARKING_EXTRUDER, false, tool_index == active_extruder) // For PARKING_EXTRUDER motion is decided in tool_change() | ||||
|       || parser.boolval('S') | ||||
|     #endif | ||||
|   ); | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user