|
@ -9436,6 +9436,39 @@ inline void gcode_M503() { |
|
|
|
|
|
|
|
|
#endif // ADVANCED_PAUSE_FEATURE
|
|
|
#endif // ADVANCED_PAUSE_FEATURE
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(MK2_MULTIPLEXER) |
|
|
|
|
|
|
|
|
|
|
|
inline void select_multiplexed_stepper(const uint8_t e) { |
|
|
|
|
|
stepper.synchronize(); |
|
|
|
|
|
disable_e_steppers(); |
|
|
|
|
|
WRITE(E_MUX0_PIN, TEST(e, 0) ? HIGH : LOW); |
|
|
|
|
|
WRITE(E_MUX1_PIN, TEST(e, 1) ? HIGH : LOW); |
|
|
|
|
|
WRITE(E_MUX2_PIN, TEST(e, 2) ? HIGH : LOW); |
|
|
|
|
|
safe_delay(100); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* M702: Unload all extruders |
|
|
|
|
|
*/ |
|
|
|
|
|
inline void gcode_M702() { |
|
|
|
|
|
for (uint8_t s = 0; s < E_STEPPERS; s++) { |
|
|
|
|
|
select_multiplexed_stepper(e); |
|
|
|
|
|
// TODO: standard unload filament function
|
|
|
|
|
|
// MK2 firmware behavior:
|
|
|
|
|
|
// - Make sure temperature is high enough
|
|
|
|
|
|
// - Raise Z to at least 15 to make room
|
|
|
|
|
|
// - Extrude 1cm of filament in 1 second
|
|
|
|
|
|
// - Under 230C quickly purge ~12mm, over 230C purge ~10mm
|
|
|
|
|
|
// - Change E max feedrate to 80, eject the filament from the tube. Sync.
|
|
|
|
|
|
// - Restore E max feedrate to 50
|
|
|
|
|
|
} |
|
|
|
|
|
// Go back to the last active extruder
|
|
|
|
|
|
select_multiplexed_stepper(active_extruder); |
|
|
|
|
|
disable_e_steppers(); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#endif // MK2_MULTIPLEXER
|
|
|
|
|
|
|
|
|
#if ENABLED(DUAL_X_CARRIAGE) |
|
|
#if ENABLED(DUAL_X_CARRIAGE) |
|
|
|
|
|
|
|
|
/**
|
|
|
/**
|
|
@ -10257,15 +10290,24 @@ void tool_change(const uint8_t tmp_extruder, const float fr_mm_s/*=0.0*/, bool n |
|
|
UNUSED(fr_mm_s); |
|
|
UNUSED(fr_mm_s); |
|
|
UNUSED(no_move); |
|
|
UNUSED(no_move); |
|
|
|
|
|
|
|
|
// Set the new active extruder
|
|
|
#if ENABLED(SWITCHING_EXTRUDER) && !DONT_SWITCH |
|
|
active_extruder = tmp_extruder; |
|
|
|
|
|
|
|
|
|
|
|
#endif // HOTENDS <= 1
|
|
|
stepper.synchronize(); |
|
|
|
|
|
move_extruder_servo(tmp_extruder); |
|
|
|
|
|
|
|
|
|
|
|
#elif ENABLED(MK2_MULTIPLEXER) |
|
|
|
|
|
|
|
|
|
|
|
if (tmp_extruder >= E_STEPPERS) |
|
|
|
|
|
return invalid_extruder_error(tmp_extruder); |
|
|
|
|
|
|
|
|
|
|
|
select_multiplexed_stepper(tmp_extruder); |
|
|
|
|
|
|
|
|
#if ENABLED(SWITCHING_EXTRUDER) && !DONT_SWITCH |
|
|
|
|
|
move_extruder_servo(active_extruder); |
|
|
|
|
|
#endif |
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
#endif // HOTENDS <= 1
|
|
|
|
|
|
|
|
|
|
|
|
active_extruder = tmp_extruder; |
|
|
|
|
|
|
|
|
SERIAL_ECHO_START(); |
|
|
SERIAL_ECHO_START(); |
|
|
SERIAL_ECHOLNPAIR(MSG_ACTIVE_EXTRUDER, (int)active_extruder); |
|
|
SERIAL_ECHOLNPAIR(MSG_ACTIVE_EXTRUDER, (int)active_extruder); |
|
|
|
|
|
|
|
@ -11001,6 +11043,12 @@ void process_next_command() { |
|
|
break; |
|
|
break; |
|
|
#endif // DUAL_X_CARRIAGE
|
|
|
#endif // DUAL_X_CARRIAGE
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(MK2_MULTIPLEXER) |
|
|
|
|
|
case 702: // M702: Unload all extruders
|
|
|
|
|
|
gcode_M702(); |
|
|
|
|
|
break; |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
#if ENABLED(LIN_ADVANCE) |
|
|
#if ENABLED(LIN_ADVANCE) |
|
|
case 900: // M900: Set advance K factor.
|
|
|
case 900: // M900: Set advance K factor.
|
|
|
gcode_M900(); |
|
|
gcode_M900(); |
|
@ -12968,6 +13016,12 @@ void setup() { |
|
|
#endif |
|
|
#endif |
|
|
#endif |
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(MK2_MULTIPLEXER) |
|
|
|
|
|
SET_OUTPUT(E_MUX0_PIN); |
|
|
|
|
|
SET_OUTPUT(E_MUX1_PIN); |
|
|
|
|
|
SET_OUTPUT(E_MUX2_PIN); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
lcd_init(); |
|
|
lcd_init(); |
|
|
#if ENABLED(SHOW_BOOTSCREEN) |
|
|
#if ENABLED(SHOW_BOOTSCREEN) |
|
|
#if ENABLED(DOGLCD) |
|
|
#if ENABLED(DOGLCD) |
|
|