|
|
@ -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)
|
|
|
@ -1814,7 +1815,7 @@ inline void gcode_G28() {
|
|
|
|
// Raise Z before homing any other axes
|
|
|
|
// Raise Z before homing any other axes
|
|
|
|
if (home_all_axis || homeZ) {
|
|
|
|
if (home_all_axis || homeZ) {
|
|
|
|
destination[Z_AXIS] = -Z_RAISE_BEFORE_HOMING * home_dir(Z_AXIS); // Set destination away from bed
|
|
|
|
destination[Z_AXIS] = -Z_RAISE_BEFORE_HOMING * home_dir(Z_AXIS); // Set destination away from bed
|
|
|
|
feedrate = max_feedrate[Z_AXIS];
|
|
|
|
feedrate = max_feedrate[Z_AXIS] * 60;
|
|
|
|
line_to_destination();
|
|
|
|
line_to_destination();
|
|
|
|
st_synchronize();
|
|
|
|
st_synchronize();
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -1947,7 +1948,7 @@ inline void gcode_G28() {
|
|
|
|
current_position[Z_AXIS] = 0;
|
|
|
|
current_position[Z_AXIS] = 0;
|
|
|
|
plan_set_position(cpx, cpy, 0, current_position[E_AXIS]);
|
|
|
|
plan_set_position(cpx, cpy, 0, current_position[E_AXIS]);
|
|
|
|
destination[Z_AXIS] = -Z_RAISE_BEFORE_HOMING * home_dir(Z_AXIS); // Set destination away from bed
|
|
|
|
destination[Z_AXIS] = -Z_RAISE_BEFORE_HOMING * home_dir(Z_AXIS); // Set destination away from bed
|
|
|
|
feedrate = max_feedrate[Z_AXIS];
|
|
|
|
feedrate = max_feedrate[Z_AXIS] * 60; // max_feedrate is in mm/s. line_to_destination is feedrate/60.
|
|
|
|
line_to_destination();
|
|
|
|
line_to_destination();
|
|
|
|
st_synchronize();
|
|
|
|
st_synchronize();
|
|
|
|
HOMEAXIS(Z);
|
|
|
|
HOMEAXIS(Z);
|
|
|
@ -2571,13 +2572,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
|
|
|
@ -3060,26 +3055,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(target_extruder),1);
|
|
|
|
SERIAL_PROTOCOL_F(degHotend(tmp_extruder), 1);
|
|
|
|
SERIAL_PROTOCOLPGM(" /");
|
|
|
|
SERIAL_PROTOCOLPGM(" /");
|
|
|
|
SERIAL_PROTOCOL_F(degTargetHotend(target_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_PROTOCOLCHAR(':');
|
|
|
|
SERIAL_PROTOCOLCHAR(':');
|
|
|
|
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
|
|
|
@ -3117,7 +3115,7 @@ inline void gcode_M105() {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
SERIAL_PROTOCOLLN("");
|
|
|
|
SERIAL_EOL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#if HAS_FAN
|
|
|
|
#if HAS_FAN
|
|
|
@ -3132,7 +3130,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
|
|
|
@ -3191,10 +3189,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();
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -3246,7 +3244,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();
|
|
|
@ -3447,27 +3445,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
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -3909,7 +3906,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;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -3977,7 +3974,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;
|
|
|
@ -4002,7 +3999,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
|
|
|
@ -4052,7 +4049,7 @@ inline void gcode_M226() {
|
|
|
|
if (code_seen('C')) lcd_setcontrast(code_value_short() & 0x3F);
|
|
|
|
if (code_seen('C')) lcd_setcontrast(code_value_short() & 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
|
|
|
@ -4325,7 +4322,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;
|
|
|
@ -4334,14 +4331,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;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -5700,7 +5697,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();
|
|
|
@ -5728,7 +5735,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) {
|
|
|
@ -5816,7 +5823,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);
|
|
|
|