|
|
@ -110,6 +110,7 @@
|
|
|
|
// Call gcode file : "M32 P !filename#" and return to caller file after finishing (similar to #include).
|
|
|
|
// Call gcode file : "M32 P !filename#" and return to caller file after finishing (similar to #include).
|
|
|
|
// The '#' is necessary when calling from within sd files, as it stops buffer prereading
|
|
|
|
// The '#' is necessary when calling from within sd files, as it stops buffer prereading
|
|
|
|
// M42 - Change pin status via gcode Use M42 Px Sy to set pin x to value y, when omitting Px the onboard led will be used.
|
|
|
|
// M42 - Change pin status via gcode Use M42 Px Sy to set pin x to value y, when omitting Px the onboard led will be used.
|
|
|
|
|
|
|
|
// M48 - Measure Z_Probe repeatability. M48 [n # of points] [X position] [Y position] [V_erboseness #] [E_ngage Probe] [L # of legs of travel]
|
|
|
|
// M80 - Turn on Power Supply
|
|
|
|
// M80 - Turn on Power Supply
|
|
|
|
// M81 - Turn off Power Supply
|
|
|
|
// M81 - Turn off Power Supply
|
|
|
|
// M82 - Set E codes absolute (default)
|
|
|
|
// M82 - Set E codes absolute (default)
|
|
|
@ -2569,13 +2570,7 @@ inline void gcode_G92() {
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
inline void gcode_M17() {
|
|
|
|
inline void gcode_M17() {
|
|
|
|
LCD_MESSAGEPGM(MSG_NO_MOVE);
|
|
|
|
LCD_MESSAGEPGM(MSG_NO_MOVE);
|
|
|
|
enable_x();
|
|
|
|
enable_all_steppers();
|
|
|
|
enable_y();
|
|
|
|
|
|
|
|
enable_z();
|
|
|
|
|
|
|
|
enable_e0();
|
|
|
|
|
|
|
|
enable_e1();
|
|
|
|
|
|
|
|
enable_e2();
|
|
|
|
|
|
|
|
enable_e3();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef SDSUPPORT
|
|
|
|
#ifdef SDSUPPORT
|
|
|
@ -3055,26 +3050,29 @@ inline void gcode_M104() {
|
|
|
|
inline void gcode_M105() {
|
|
|
|
inline void gcode_M105() {
|
|
|
|
if (setTargetedHotend(105)) return;
|
|
|
|
if (setTargetedHotend(105)) return;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#if HAS_TEMP_0 || HAS_TEMP_BED
|
|
|
|
|
|
|
|
SERIAL_PROTOCOLPGM("ok");
|
|
|
|
#if HAS_TEMP_0
|
|
|
|
#if HAS_TEMP_0
|
|
|
|
SERIAL_PROTOCOLPGM("ok T:");
|
|
|
|
SERIAL_PROTOCOLPGM(" T:");
|
|
|
|
SERIAL_PROTOCOL_F(degHotend(tmp_extruder),1);
|
|
|
|
SERIAL_PROTOCOL_F(degHotend(tmp_extruder), 1);
|
|
|
|
SERIAL_PROTOCOLPGM(" /");
|
|
|
|
SERIAL_PROTOCOLPGM(" /");
|
|
|
|
SERIAL_PROTOCOL_F(degTargetHotend(tmp_extruder),1);
|
|
|
|
SERIAL_PROTOCOL_F(degTargetHotend(tmp_extruder), 1);
|
|
|
|
|
|
|
|
#endif
|
|
|
|
#if HAS_TEMP_BED
|
|
|
|
#if HAS_TEMP_BED
|
|
|
|
SERIAL_PROTOCOLPGM(" B:");
|
|
|
|
SERIAL_PROTOCOLPGM(" B:");
|
|
|
|
SERIAL_PROTOCOL_F(degBed(),1);
|
|
|
|
SERIAL_PROTOCOL_F(degBed(), 1);
|
|
|
|
SERIAL_PROTOCOLPGM(" /");
|
|
|
|
SERIAL_PROTOCOLPGM(" /");
|
|
|
|
SERIAL_PROTOCOL_F(degTargetBed(),1);
|
|
|
|
SERIAL_PROTOCOL_F(degTargetBed(), 1);
|
|
|
|
#endif // HAS_TEMP_BED
|
|
|
|
#endif
|
|
|
|
for (int8_t cur_extruder = 0; cur_extruder < EXTRUDERS; ++cur_extruder) {
|
|
|
|
for (int8_t e = 0; e < EXTRUDERS; ++e) {
|
|
|
|
SERIAL_PROTOCOLPGM(" T");
|
|
|
|
SERIAL_PROTOCOLPGM(" T");
|
|
|
|
SERIAL_PROTOCOL(cur_extruder);
|
|
|
|
SERIAL_PROTOCOL(e);
|
|
|
|
SERIAL_PROTOCOLPGM(":");
|
|
|
|
SERIAL_PROTOCOLPGM(":");
|
|
|
|
SERIAL_PROTOCOL_F(degHotend(cur_extruder),1);
|
|
|
|
SERIAL_PROTOCOL_F(degHotend(e), 1);
|
|
|
|
SERIAL_PROTOCOLPGM(" /");
|
|
|
|
SERIAL_PROTOCOLPGM(" /");
|
|
|
|
SERIAL_PROTOCOL_F(degTargetHotend(cur_extruder),1);
|
|
|
|
SERIAL_PROTOCOL_F(degTargetHotend(e), 1);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#else // !HAS_TEMP_0
|
|
|
|
#else // !HAS_TEMP_0 && !HAS_TEMP_BED
|
|
|
|
SERIAL_ERROR_START;
|
|
|
|
SERIAL_ERROR_START;
|
|
|
|
SERIAL_ERRORLNPGM(MSG_ERR_NO_THERMISTORS);
|
|
|
|
SERIAL_ERRORLNPGM(MSG_ERR_NO_THERMISTORS);
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
@ -3112,7 +3110,7 @@ inline void gcode_M105() {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#if HAS_FAN
|
|
|
|
#if HAS_FAN
|
|
|
@ -3127,7 +3125,7 @@ inline void gcode_M105() {
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
inline void gcode_M107() { fanSpeed = 0; }
|
|
|
|
inline void gcode_M107() { fanSpeed = 0; }
|
|
|
|
|
|
|
|
|
|
|
|
#endif //FAN_PIN
|
|
|
|
#endif // HAS_FAN
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* M109: Wait for extruder(s) to reach temperature
|
|
|
|
* M109: Wait for extruder(s) to reach temperature
|
|
|
@ -3185,10 +3183,10 @@ inline void gcode_M109() {
|
|
|
|
SERIAL_PROTOCOLLN( timetemp );
|
|
|
|
SERIAL_PROTOCOLLN( timetemp );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
else {
|
|
|
|
SERIAL_PROTOCOLLN( "?" );
|
|
|
|
SERIAL_PROTOCOLLNPGM("?");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
#else
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
timetemp = millis();
|
|
|
|
timetemp = millis();
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -3240,7 +3238,7 @@ inline void gcode_M109() {
|
|
|
|
SERIAL_PROTOCOL((int)active_extruder);
|
|
|
|
SERIAL_PROTOCOL((int)active_extruder);
|
|
|
|
SERIAL_PROTOCOLPGM(" B:");
|
|
|
|
SERIAL_PROTOCOLPGM(" B:");
|
|
|
|
SERIAL_PROTOCOL_F(degBed(), 1);
|
|
|
|
SERIAL_PROTOCOL_F(degBed(), 1);
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
manage_heater();
|
|
|
|
manage_heater();
|
|
|
|
manage_inactivity();
|
|
|
|
manage_inactivity();
|
|
|
@ -3441,27 +3439,26 @@ inline void gcode_M114() {
|
|
|
|
SERIAL_PROTOCOLPGM(" Z:");
|
|
|
|
SERIAL_PROTOCOLPGM(" Z:");
|
|
|
|
SERIAL_PROTOCOL(float(st_get_position(Z_AXIS))/axis_steps_per_unit[Z_AXIS]);
|
|
|
|
SERIAL_PROTOCOL(float(st_get_position(Z_AXIS))/axis_steps_per_unit[Z_AXIS]);
|
|
|
|
|
|
|
|
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef SCARA
|
|
|
|
#ifdef SCARA
|
|
|
|
SERIAL_PROTOCOLPGM("SCARA Theta:");
|
|
|
|
SERIAL_PROTOCOLPGM("SCARA Theta:");
|
|
|
|
SERIAL_PROTOCOL(delta[X_AXIS]);
|
|
|
|
SERIAL_PROTOCOL(delta[X_AXIS]);
|
|
|
|
SERIAL_PROTOCOLPGM(" Psi+Theta:");
|
|
|
|
SERIAL_PROTOCOLPGM(" Psi+Theta:");
|
|
|
|
SERIAL_PROTOCOL(delta[Y_AXIS]);
|
|
|
|
SERIAL_PROTOCOL(delta[Y_AXIS]);
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
|
|
|
|
|
|
|
|
SERIAL_PROTOCOLPGM("SCARA Cal - Theta:");
|
|
|
|
SERIAL_PROTOCOLPGM("SCARA Cal - Theta:");
|
|
|
|
SERIAL_PROTOCOL(delta[X_AXIS]+home_offset[X_AXIS]);
|
|
|
|
SERIAL_PROTOCOL(delta[X_AXIS]+home_offset[X_AXIS]);
|
|
|
|
SERIAL_PROTOCOLPGM(" Psi+Theta (90):");
|
|
|
|
SERIAL_PROTOCOLPGM(" Psi+Theta (90):");
|
|
|
|
SERIAL_PROTOCOL(delta[Y_AXIS]-delta[X_AXIS]-90+home_offset[Y_AXIS]);
|
|
|
|
SERIAL_PROTOCOL(delta[Y_AXIS]-delta[X_AXIS]-90+home_offset[Y_AXIS]);
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
|
|
|
|
|
|
|
|
SERIAL_PROTOCOLPGM("SCARA step Cal - Theta:");
|
|
|
|
SERIAL_PROTOCOLPGM("SCARA step Cal - Theta:");
|
|
|
|
SERIAL_PROTOCOL(delta[X_AXIS]/90*axis_steps_per_unit[X_AXIS]);
|
|
|
|
SERIAL_PROTOCOL(delta[X_AXIS]/90*axis_steps_per_unit[X_AXIS]);
|
|
|
|
SERIAL_PROTOCOLPGM(" Psi+Theta:");
|
|
|
|
SERIAL_PROTOCOLPGM(" Psi+Theta:");
|
|
|
|
SERIAL_PROTOCOL((delta[Y_AXIS]-delta[X_AXIS])/90*axis_steps_per_unit[Y_AXIS]);
|
|
|
|
SERIAL_PROTOCOL((delta[Y_AXIS]-delta[X_AXIS])/90*axis_steps_per_unit[Y_AXIS]);
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL; SERIAL_EOL;
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -3907,7 +3904,7 @@ inline void gcode_M226() {
|
|
|
|
SERIAL_PROTOCOL(servo_index);
|
|
|
|
SERIAL_PROTOCOL(servo_index);
|
|
|
|
SERIAL_PROTOCOL(": ");
|
|
|
|
SERIAL_PROTOCOL(": ");
|
|
|
|
SERIAL_PROTOCOL(servos[servo_index].read());
|
|
|
|
SERIAL_PROTOCOL(servos[servo_index].read());
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -3975,7 +3972,7 @@ inline void gcode_M226() {
|
|
|
|
//Kc does not have scaling applied above, or in resetting defaults
|
|
|
|
//Kc does not have scaling applied above, or in resetting defaults
|
|
|
|
SERIAL_PROTOCOL(PID_PARAM(Kc, e));
|
|
|
|
SERIAL_PROTOCOL(PID_PARAM(Kc, e));
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
else {
|
|
|
|
SERIAL_ECHO_START;
|
|
|
|
SERIAL_ECHO_START;
|
|
|
@ -4000,7 +3997,7 @@ inline void gcode_M226() {
|
|
|
|
SERIAL_PROTOCOL(unscalePID_i(bedKi));
|
|
|
|
SERIAL_PROTOCOL(unscalePID_i(bedKi));
|
|
|
|
SERIAL_PROTOCOL(" d:");
|
|
|
|
SERIAL_PROTOCOL(" d:");
|
|
|
|
SERIAL_PROTOCOL(unscalePID_d(bedKd));
|
|
|
|
SERIAL_PROTOCOL(unscalePID_d(bedKd));
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endif // PIDTEMPBED
|
|
|
|
#endif // PIDTEMPBED
|
|
|
@ -4050,7 +4047,7 @@ inline void gcode_M226() {
|
|
|
|
if (code_seen('C')) lcd_setcontrast(code_value_long() & 0x3F);
|
|
|
|
if (code_seen('C')) lcd_setcontrast(code_value_long() & 0x3F);
|
|
|
|
SERIAL_PROTOCOLPGM("lcd contrast value: ");
|
|
|
|
SERIAL_PROTOCOLPGM("lcd contrast value: ");
|
|
|
|
SERIAL_PROTOCOL(lcd_contrast);
|
|
|
|
SERIAL_PROTOCOL(lcd_contrast);
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#endif // DOGLCD
|
|
|
|
#endif // DOGLCD
|
|
|
@ -4323,7 +4320,7 @@ inline void gcode_M503() {
|
|
|
|
zprobe_zoffset = -value; // compare w/ line 278 of ConfigurationStore.cpp
|
|
|
|
zprobe_zoffset = -value; // compare w/ line 278 of ConfigurationStore.cpp
|
|
|
|
SERIAL_ECHO_START;
|
|
|
|
SERIAL_ECHO_START;
|
|
|
|
SERIAL_ECHOLNPGM(MSG_ZPROBE_ZOFFSET " " MSG_OK);
|
|
|
|
SERIAL_ECHOLNPGM(MSG_ZPROBE_ZOFFSET " " MSG_OK);
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
else {
|
|
|
|
SERIAL_ECHO_START;
|
|
|
|
SERIAL_ECHO_START;
|
|
|
@ -4332,14 +4329,14 @@ inline void gcode_M503() {
|
|
|
|
SERIAL_ECHO(Z_PROBE_OFFSET_RANGE_MIN);
|
|
|
|
SERIAL_ECHO(Z_PROBE_OFFSET_RANGE_MIN);
|
|
|
|
SERIAL_ECHOPGM(MSG_Z_MAX);
|
|
|
|
SERIAL_ECHOPGM(MSG_Z_MAX);
|
|
|
|
SERIAL_ECHO(Z_PROBE_OFFSET_RANGE_MAX);
|
|
|
|
SERIAL_ECHO(Z_PROBE_OFFSET_RANGE_MAX);
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
else {
|
|
|
|
SERIAL_ECHO_START;
|
|
|
|
SERIAL_ECHO_START;
|
|
|
|
SERIAL_ECHOLNPGM(MSG_ZPROBE_ZOFFSET " : ");
|
|
|
|
SERIAL_ECHOLNPGM(MSG_ZPROBE_ZOFFSET " : ");
|
|
|
|
SERIAL_ECHO(-zprobe_zoffset);
|
|
|
|
SERIAL_ECHO(-zprobe_zoffset);
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -5693,7 +5690,17 @@ void handle_status_leds(void) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
void disable_all_axes() {
|
|
|
|
void enable_all_steppers() {
|
|
|
|
|
|
|
|
enable_x();
|
|
|
|
|
|
|
|
enable_y();
|
|
|
|
|
|
|
|
enable_z();
|
|
|
|
|
|
|
|
enable_e0();
|
|
|
|
|
|
|
|
enable_e1();
|
|
|
|
|
|
|
|
enable_e2();
|
|
|
|
|
|
|
|
enable_e3();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void disable_all_steppers() {
|
|
|
|
disable_x();
|
|
|
|
disable_x();
|
|
|
|
disable_y();
|
|
|
|
disable_y();
|
|
|
|
disable_z();
|
|
|
|
disable_z();
|
|
|
@ -5721,7 +5728,7 @@ void manage_inactivity(bool ignore_stepper_queue/*=false*/) {
|
|
|
|
|
|
|
|
|
|
|
|
if (stepper_inactive_time && ms > previous_millis_cmd + stepper_inactive_time
|
|
|
|
if (stepper_inactive_time && ms > previous_millis_cmd + stepper_inactive_time
|
|
|
|
&& !ignore_stepper_queue && !blocks_queued())
|
|
|
|
&& !ignore_stepper_queue && !blocks_queued())
|
|
|
|
disable_all_axes();
|
|
|
|
disable_all_steppers();
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef CHDK //Check if pin should be set to LOW after M240 set it to HIGH
|
|
|
|
#ifdef CHDK //Check if pin should be set to LOW after M240 set it to HIGH
|
|
|
|
if (chdkActive && ms > chdkHigh + CHDK_DELAY) {
|
|
|
|
if (chdkActive && ms > chdkHigh + CHDK_DELAY) {
|
|
|
@ -5809,7 +5816,7 @@ void kill()
|
|
|
|
cli(); // Stop interrupts
|
|
|
|
cli(); // Stop interrupts
|
|
|
|
disable_heater();
|
|
|
|
disable_heater();
|
|
|
|
|
|
|
|
|
|
|
|
disable_all_axes();
|
|
|
|
disable_all_steppers();
|
|
|
|
|
|
|
|
|
|
|
|
#if HAS_POWER_SWITCH
|
|
|
|
#if HAS_POWER_SWITCH
|
|
|
|
pinMode(PS_ON_PIN, INPUT);
|
|
|
|
pinMode(PS_ON_PIN, INPUT);
|
|
|
|