|
@ -175,7 +175,7 @@ |
|
|
* M112 - Emergency stop. |
|
|
* M112 - Emergency stop. |
|
|
* M113 - Get or set the timeout interval for Host Keepalive "busy" messages. (Requires HOST_KEEPALIVE_FEATURE) |
|
|
* M113 - Get or set the timeout interval for Host Keepalive "busy" messages. (Requires HOST_KEEPALIVE_FEATURE) |
|
|
* M114 - Report current position. |
|
|
* M114 - Report current position. |
|
|
* M115 - Report capabilities. |
|
|
* M115 - Report capabilities. (Extended capabilities requires EXTENDED_CAPABILITIES_REPORT) |
|
|
* M117 - Display a message on the controller screen. (Requires an LCD) |
|
|
* M117 - Display a message on the controller screen. (Requires an LCD) |
|
|
* M119 - Report endstops status. |
|
|
* M119 - Report endstops status. |
|
|
* M120 - Enable endstops detection. |
|
|
* M120 - Enable endstops detection. |
|
@ -188,6 +188,7 @@ |
|
|
* M145 - Set heatup values for materials on the LCD. H<hotend> B<bed> F<fan speed> for S<material> (0=PLA, 1=ABS) |
|
|
* M145 - Set heatup values for materials on the LCD. H<hotend> B<bed> F<fan speed> for S<material> (0=PLA, 1=ABS) |
|
|
* M149 - Set temperature units. (Requires TEMPERATURE_UNITS_SUPPORT) |
|
|
* M149 - Set temperature units. (Requires TEMPERATURE_UNITS_SUPPORT) |
|
|
* M150 - Set BlinkM Color R<red> U<green> B<blue>. Values 0-255. (Requires BLINKM) |
|
|
* M150 - Set BlinkM Color R<red> U<green> B<blue>. Values 0-255. (Requires BLINKM) |
|
|
|
|
|
* M155 - Auto-report temperatures with interval of S<seconds>. (Requires AUTO_REPORT_TEMPERATURES) |
|
|
* M163 - Set a single proportion for a mixing extruder. (Requires MIXING_EXTRUDER) |
|
|
* M163 - Set a single proportion for a mixing extruder. (Requires MIXING_EXTRUDER) |
|
|
* M164 - Save the mix as a virtual extruder. (Requires MIXING_EXTRUDER and MIXING_VIRTUAL_TOOLS) |
|
|
* M164 - Save the mix as a virtual extruder. (Requires MIXING_EXTRUDER and MIXING_VIRTUAL_TOOLS) |
|
|
* M165 - Set the proportions for a mixing extruder. Use parameters ABCDHI to set the mixing factors. (Requires MIXING_EXTRUDER) |
|
|
* M165 - Set the proportions for a mixing extruder. Use parameters ABCDHI to set the mixing factors. (Requires MIXING_EXTRUDER) |
|
@ -214,6 +215,8 @@ |
|
|
* M226 - Wait until a pin is in a given state: "M226 P<pin> S<state>" |
|
|
* M226 - Wait until a pin is in a given state: "M226 P<pin> S<state>" |
|
|
* M240 - Trigger a camera to take a photograph. (Requires CHDK or PHOTOGRAPH_PIN) |
|
|
* M240 - Trigger a camera to take a photograph. (Requires CHDK or PHOTOGRAPH_PIN) |
|
|
* M250 - Set LCD contrast: "M250 C<contrast>" (0-63). (Requires LCD support) |
|
|
* M250 - Set LCD contrast: "M250 C<contrast>" (0-63). (Requires LCD support) |
|
|
|
|
|
* M260 - i2c Send Data (Requires EXPERIMENTAL_I2CBUS) |
|
|
|
|
|
* M261 - i2c Request Data (Requires EXPERIMENTAL_I2CBUS) |
|
|
* M280 - Set servo position absolute: "M280 P<index> S<angle|µs>". (Requires servos) |
|
|
* M280 - Set servo position absolute: "M280 P<index> S<angle|µs>". (Requires servos) |
|
|
* M300 - Play beep sound S<frequency Hz> P<duration ms> |
|
|
* M300 - Play beep sound S<frequency Hz> P<duration ms> |
|
|
* M301 - Set PID parameters P I and D. (Requires PIDTEMP) |
|
|
* M301 - Set PID parameters P I and D. (Requires PIDTEMP) |
|
@ -865,11 +868,20 @@ void setup_homepin(void) { |
|
|
#if HAS_CASE_LIGHT |
|
|
#if HAS_CASE_LIGHT |
|
|
|
|
|
|
|
|
void setup_case_light() { |
|
|
void setup_case_light() { |
|
|
#if ENABLED(CASE_LIGHT_DEFAULT_ON) |
|
|
digitalWrite(CASE_LIGHT_PIN, |
|
|
OUT_WRITE(CASE_LIGHT_PIN, HIGH); |
|
|
#if ENABLED(CASE_LIGHT_DEFAULT_ON) |
|
|
#else |
|
|
255 |
|
|
OUT_WRITE(CASE_LIGHT_PIN, LOW); |
|
|
#else |
|
|
#endif |
|
|
0 |
|
|
|
|
|
#endif |
|
|
|
|
|
); |
|
|
|
|
|
analogWrite(CASE_LIGHT_PIN, |
|
|
|
|
|
#if ENABLED(CASE_LIGHT_DEFAULT_ON) |
|
|
|
|
|
255 |
|
|
|
|
|
#else |
|
|
|
|
|
0 |
|
|
|
|
|
#endif |
|
|
|
|
|
); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
#endif |
|
|
#endif |
|
@ -5141,6 +5153,31 @@ inline void gcode_M105() { |
|
|
SERIAL_EOL; |
|
|
SERIAL_EOL; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(AUTO_REPORT_TEMPERATURES) && (HAS_TEMP_HOTEND || HAS_TEMP_BED) |
|
|
|
|
|
|
|
|
|
|
|
static uint8_t auto_report_temp_interval; |
|
|
|
|
|
static millis_t next_temp_report_ms; |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* M155: Set temperature auto-report interval. M155 S<seconds> |
|
|
|
|
|
*/ |
|
|
|
|
|
inline void gcode_M155() { |
|
|
|
|
|
if (code_seen('S')) { |
|
|
|
|
|
auto_report_temp_interval = code_value_byte(); |
|
|
|
|
|
NOMORE(auto_report_temp_interval, 60); |
|
|
|
|
|
next_temp_report_ms = millis() + 1000UL * auto_report_temp_interval; |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
inline void auto_report_temperatures() { |
|
|
|
|
|
if (auto_report_temp_interval && ELAPSED(millis(), next_temp_report_ms)) { |
|
|
|
|
|
next_temp_report_ms = millis() + 1000UL * auto_report_temp_interval; |
|
|
|
|
|
print_heaterstates(); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#endif // AUTO_REPORT_TEMPERATURES
|
|
|
|
|
|
|
|
|
#if FAN_COUNT > 0 |
|
|
#if FAN_COUNT > 0 |
|
|
|
|
|
|
|
|
/**
|
|
|
/**
|
|
@ -5751,7 +5788,71 @@ inline void gcode_M114() { report_current_position(); } |
|
|
* M115: Capabilities string |
|
|
* M115: Capabilities string |
|
|
*/ |
|
|
*/ |
|
|
inline void gcode_M115() { |
|
|
inline void gcode_M115() { |
|
|
SERIAL_PROTOCOLPGM(MSG_M115_REPORT); |
|
|
SERIAL_PROTOCOLLNPGM(MSG_M115_REPORT); |
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(EXTENDED_CAPABILITIES_REPORT) |
|
|
|
|
|
|
|
|
|
|
|
// EEPROM (M500, M501)
|
|
|
|
|
|
SERIAL_PROTOCOLPGM("Cap:"); |
|
|
|
|
|
#if ENABLED(EEPROM_SETTINGS) |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("EEPROM:1"); |
|
|
|
|
|
#else |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("EEPROM:0"); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
// AUTOREPORT_TEMP (M155)
|
|
|
|
|
|
SERIAL_PROTOCOLPGM("Cap:"); |
|
|
|
|
|
#if ENABLED(AUTO_REPORT_TEMPERATURES) |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("AUTOREPORT_TEMP:1"); |
|
|
|
|
|
#else |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("AUTOREPORT_TEMP:0"); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
// PROGRESS (M530 S L, M531 <file>, M532 X L)
|
|
|
|
|
|
SERIAL_PROTOCOLPGM("Cap:"); |
|
|
|
|
|
SERIAL_PROTOCOLPGM("PROGRESS:0"); |
|
|
|
|
|
|
|
|
|
|
|
// AUTOLEVEL (G29)
|
|
|
|
|
|
SERIAL_PROTOCOLPGM("Cap:"); |
|
|
|
|
|
#if HAS_ABL |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("AUTOLEVEL:1"); |
|
|
|
|
|
#else |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("AUTOLEVEL:0"); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
// Z_PROBE (G30)
|
|
|
|
|
|
SERIAL_PROTOCOLPGM("Cap:"); |
|
|
|
|
|
#if HAS_BED_PROBE |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("Z_PROBE:1"); |
|
|
|
|
|
#else |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("Z_PROBE:0"); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
// SOFTWARE_POWER (G30)
|
|
|
|
|
|
SERIAL_PROTOCOLPGM("Cap:"); |
|
|
|
|
|
#if HAS_POWER_SWITCH |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("SOFTWARE_POWER:1"); |
|
|
|
|
|
#else |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("SOFTWARE_POWER:0"); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
// TOGGLE_LIGHTS (M355)
|
|
|
|
|
|
SERIAL_PROTOCOLPGM("Cap:"); |
|
|
|
|
|
#if HAS_CASE_LIGHT |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("TOGGLE_LIGHTS:1"); |
|
|
|
|
|
#else |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("TOGGLE_LIGHTS:0"); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
// EMERGENCY_PARSER (M108, M112, M410)
|
|
|
|
|
|
SERIAL_PROTOCOLPGM("Cap:"); |
|
|
|
|
|
#if ENABLED(EMERGENCY_PARSER) |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("EMERGENCY_PARSER:1"); |
|
|
|
|
|
#else |
|
|
|
|
|
SERIAL_PROTOCOLLNPGM("EMERGENCY_PARSER:0"); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
|
|
|
#endif // EXTENDED_CAPABILITIES_REPORT
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
/**
|
|
|
/**
|
|
@ -5791,59 +5892,6 @@ inline void gcode_M121() { endstops.enable_globally(false); } |
|
|
|
|
|
|
|
|
#endif // BLINKM
|
|
|
#endif // BLINKM
|
|
|
|
|
|
|
|
|
#if ENABLED(EXPERIMENTAL_I2CBUS) |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* M155: Send data to a I2C slave device |
|
|
|
|
|
* |
|
|
|
|
|
* This is a PoC, the formating and arguments for the GCODE will |
|
|
|
|
|
* change to be more compatible, the current proposal is: |
|
|
|
|
|
* |
|
|
|
|
|
* M155 A<slave device address base 10> ; Sets the I2C slave address the data will be sent to |
|
|
|
|
|
* |
|
|
|
|
|
* M155 B<byte-1 value in base 10> |
|
|
|
|
|
* M155 B<byte-2 value in base 10> |
|
|
|
|
|
* M155 B<byte-3 value in base 10> |
|
|
|
|
|
* |
|
|
|
|
|
* M155 S1 ; Send the buffered data and reset the buffer |
|
|
|
|
|
* M155 R1 ; Reset the buffer without sending data |
|
|
|
|
|
* |
|
|
|
|
|
*/ |
|
|
|
|
|
inline void gcode_M155() { |
|
|
|
|
|
// Set the target address
|
|
|
|
|
|
if (code_seen('A')) i2c.address(code_value_byte()); |
|
|
|
|
|
|
|
|
|
|
|
// Add a new byte to the buffer
|
|
|
|
|
|
if (code_seen('B')) i2c.addbyte(code_value_byte()); |
|
|
|
|
|
|
|
|
|
|
|
// Flush the buffer to the bus
|
|
|
|
|
|
if (code_seen('S')) i2c.send(); |
|
|
|
|
|
|
|
|
|
|
|
// Reset and rewind the buffer
|
|
|
|
|
|
else if (code_seen('R')) i2c.reset(); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* M156: Request X bytes from I2C slave device |
|
|
|
|
|
* |
|
|
|
|
|
* Usage: M156 A<slave device address base 10> B<number of bytes> |
|
|
|
|
|
*/ |
|
|
|
|
|
inline void gcode_M156() { |
|
|
|
|
|
if (code_seen('A')) i2c.address(code_value_byte()); |
|
|
|
|
|
|
|
|
|
|
|
uint8_t bytes = code_seen('B') ? code_value_byte() : 1; |
|
|
|
|
|
|
|
|
|
|
|
if (i2c.addr && bytes && bytes <= TWIBUS_BUFFER_SIZE) { |
|
|
|
|
|
i2c.relay(bytes); |
|
|
|
|
|
} |
|
|
|
|
|
else { |
|
|
|
|
|
SERIAL_ERROR_START; |
|
|
|
|
|
SERIAL_ERRORLN("Bad i2c request"); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#endif // EXPERIMENTAL_I2CBUS
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
/**
|
|
|
* M200: Set filament diameter and set E axis units to cubic units |
|
|
* M200: Set filament diameter and set E axis units to cubic units |
|
|
* |
|
|
* |
|
@ -6190,6 +6238,59 @@ inline void gcode_M226() { |
|
|
} // code_seen('P')
|
|
|
} // code_seen('P')
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(EXPERIMENTAL_I2CBUS) |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* M260: Send data to a I2C slave device |
|
|
|
|
|
* |
|
|
|
|
|
* This is a PoC, the formating and arguments for the GCODE will |
|
|
|
|
|
* change to be more compatible, the current proposal is: |
|
|
|
|
|
* |
|
|
|
|
|
* M260 A<slave device address base 10> ; Sets the I2C slave address the data will be sent to |
|
|
|
|
|
* |
|
|
|
|
|
* M260 B<byte-1 value in base 10> |
|
|
|
|
|
* M260 B<byte-2 value in base 10> |
|
|
|
|
|
* M260 B<byte-3 value in base 10> |
|
|
|
|
|
* |
|
|
|
|
|
* M260 S1 ; Send the buffered data and reset the buffer |
|
|
|
|
|
* M260 R1 ; Reset the buffer without sending data |
|
|
|
|
|
* |
|
|
|
|
|
*/ |
|
|
|
|
|
inline void gcode_M260() { |
|
|
|
|
|
// Set the target address
|
|
|
|
|
|
if (code_seen('A')) i2c.address(code_value_byte()); |
|
|
|
|
|
|
|
|
|
|
|
// Add a new byte to the buffer
|
|
|
|
|
|
if (code_seen('B')) i2c.addbyte(code_value_byte()); |
|
|
|
|
|
|
|
|
|
|
|
// Flush the buffer to the bus
|
|
|
|
|
|
if (code_seen('S')) i2c.send(); |
|
|
|
|
|
|
|
|
|
|
|
// Reset and rewind the buffer
|
|
|
|
|
|
else if (code_seen('R')) i2c.reset(); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
* M261: Request X bytes from I2C slave device |
|
|
|
|
|
* |
|
|
|
|
|
* Usage: M261 A<slave device address base 10> B<number of bytes> |
|
|
|
|
|
*/ |
|
|
|
|
|
inline void gcode_M261() { |
|
|
|
|
|
if (code_seen('A')) i2c.address(code_value_byte()); |
|
|
|
|
|
|
|
|
|
|
|
uint8_t bytes = code_seen('B') ? code_value_byte() : 1; |
|
|
|
|
|
|
|
|
|
|
|
if (i2c.addr && bytes && bytes <= TWIBUS_BUFFER_SIZE) { |
|
|
|
|
|
i2c.relay(bytes); |
|
|
|
|
|
} |
|
|
|
|
|
else { |
|
|
|
|
|
SERIAL_ERROR_START; |
|
|
|
|
|
SERIAL_ERRORLN("Bad i2c request"); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#endif // EXPERIMENTAL_I2CBUS
|
|
|
|
|
|
|
|
|
#if HAS_SERVOS |
|
|
#if HAS_SERVOS |
|
|
|
|
|
|
|
|
/**
|
|
|
/**
|
|
@ -7099,33 +7200,30 @@ inline void gcode_M907() { |
|
|
#endif // HAS_MICROSTEPS
|
|
|
#endif // HAS_MICROSTEPS
|
|
|
|
|
|
|
|
|
#if HAS_CASE_LIGHT |
|
|
#if HAS_CASE_LIGHT |
|
|
|
|
|
|
|
|
/**
|
|
|
/**
|
|
|
* M355: Turn case lights on/off |
|
|
* M355: Turn case lights on/off and set brightness |
|
|
* |
|
|
|
|
|
* S<int> change state on/off or sets PWM |
|
|
|
|
|
* |
|
|
* |
|
|
|
|
|
* S<bool> Turn case light on or off |
|
|
|
|
|
* P<byte> Set case light brightness (PWM pin required) |
|
|
*/ |
|
|
*/ |
|
|
inline void gcode_M355() { |
|
|
inline void gcode_M355() { |
|
|
|
|
|
static bool case_light_on |
|
|
|
|
|
#if ENABLED(CASE_LIGHT_DEFAULT_ON) |
|
|
|
|
|
= true |
|
|
|
|
|
#else |
|
|
|
|
|
; |
|
|
|
|
|
#endif |
|
|
|
|
|
static uint8_t case_light_brightness = 255; |
|
|
|
|
|
if (code_seen('P')) case_light_brightness = code_value_byte(); |
|
|
if (code_seen('S')) { |
|
|
if (code_seen('S')) { |
|
|
SERIAL_ECHO_START; |
|
|
case_light_on = code_value_bool(); |
|
|
SERIAL_ECHOPGM("Case lights "); |
|
|
digitalWrite(CASE_LIGHT_PIN, case_light_on ? HIGH : LOW); |
|
|
byte light_pwm = code_value_byte(); |
|
|
analogWrite(CASE_LIGHT_PIN, case_light_on ? case_light_brightness : 0); |
|
|
switch (light_pwm) { |
|
|
|
|
|
case 0: // Disable lights
|
|
|
|
|
|
SERIAL_ECHOPGM("off"); |
|
|
|
|
|
break; |
|
|
|
|
|
case 1: // Enable lights
|
|
|
|
|
|
light_pwm = 255; |
|
|
|
|
|
SERIAL_ECHOPGM("on"); |
|
|
|
|
|
break; |
|
|
|
|
|
default: // Enable lights PWM
|
|
|
|
|
|
SERIAL_ECHOPAIR("set to: ", (int)map(light_pwm, 0, 255, 0, 100)); |
|
|
|
|
|
SERIAL_CHAR('%'); |
|
|
|
|
|
break; |
|
|
|
|
|
} |
|
|
|
|
|
analogWrite(CASE_LIGHT_PIN, light_pwm); |
|
|
|
|
|
SERIAL_EOL; |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
SERIAL_ECHO_START; |
|
|
|
|
|
SERIAL_ECHOPGM("Case lights "); |
|
|
|
|
|
case_light_on ? SERIAL_ECHOLNPGM("on") : SERIAL_ECHOLNPGM("off"); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
#endif // HAS_CASE_LIGHT
|
|
|
#endif // HAS_CASE_LIGHT
|
|
@ -7846,6 +7944,12 @@ void process_next_command() { |
|
|
KEEPALIVE_STATE(NOT_BUSY); |
|
|
KEEPALIVE_STATE(NOT_BUSY); |
|
|
return; // "ok" already printed
|
|
|
return; // "ok" already printed
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(AUTO_REPORT_TEMPERATURES) && (HAS_TEMP_HOTEND || HAS_TEMP_BED) |
|
|
|
|
|
case 155: // M155: Set temperature auto-report interval
|
|
|
|
|
|
gcode_M155(); |
|
|
|
|
|
break; |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
case 109: // M109: Wait for hotend temperature to reach target
|
|
|
case 109: // M109: Wait for hotend temperature to reach target
|
|
|
gcode_M109(); |
|
|
gcode_M109(); |
|
|
break; |
|
|
break; |
|
@ -7956,18 +8060,6 @@ void process_next_command() { |
|
|
|
|
|
|
|
|
#endif // BLINKM
|
|
|
#endif // BLINKM
|
|
|
|
|
|
|
|
|
#if ENABLED(EXPERIMENTAL_I2CBUS) |
|
|
|
|
|
|
|
|
|
|
|
case 155: // M155: Send data to an i2c slave
|
|
|
|
|
|
gcode_M155(); |
|
|
|
|
|
break; |
|
|
|
|
|
|
|
|
|
|
|
case 156: // M156: Request data from an i2c slave
|
|
|
|
|
|
gcode_M156(); |
|
|
|
|
|
break; |
|
|
|
|
|
|
|
|
|
|
|
#endif //EXPERIMENTAL_I2CBUS
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(MIXING_EXTRUDER) |
|
|
#if ENABLED(MIXING_EXTRUDER) |
|
|
case 163: // M163: Set a component weight for mixing extruder
|
|
|
case 163: // M163: Set a component weight for mixing extruder
|
|
|
gcode_M163(); |
|
|
gcode_M163(); |
|
@ -8090,6 +8182,18 @@ void process_next_command() { |
|
|
break; |
|
|
break; |
|
|
#endif // HAS_LCD_CONTRAST
|
|
|
#endif // HAS_LCD_CONTRAST
|
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(EXPERIMENTAL_I2CBUS) |
|
|
|
|
|
|
|
|
|
|
|
case 260: // M260: Send data to an i2c slave
|
|
|
|
|
|
gcode_M260(); |
|
|
|
|
|
break; |
|
|
|
|
|
|
|
|
|
|
|
case 261: // M261: Request data from an i2c slave
|
|
|
|
|
|
gcode_M261(); |
|
|
|
|
|
break; |
|
|
|
|
|
|
|
|
|
|
|
#endif // EXPERIMENTAL_I2CBUS
|
|
|
|
|
|
|
|
|
#if ENABLED(PREVENT_COLD_EXTRUSION) |
|
|
#if ENABLED(PREVENT_COLD_EXTRUSION) |
|
|
case 302: // M302: Allow cold extrudes (set the minimum extrude temperature)
|
|
|
case 302: // M302: Allow cold extrudes (set the minimum extrude temperature)
|
|
|
gcode_M302(); |
|
|
gcode_M302(); |
|
@ -9669,7 +9773,13 @@ void idle( |
|
|
#endif |
|
|
#endif |
|
|
) { |
|
|
) { |
|
|
lcd_update(); |
|
|
lcd_update(); |
|
|
|
|
|
|
|
|
host_keepalive(); |
|
|
host_keepalive(); |
|
|
|
|
|
|
|
|
|
|
|
#if ENABLED(AUTO_REPORT_TEMPERATURES) && (HAS_TEMP_HOTEND || HAS_TEMP_BED) |
|
|
|
|
|
auto_report_temperatures(); |
|
|
|
|
|
#endif |
|
|
|
|
|
|
|
|
manage_inactivity( |
|
|
manage_inactivity( |
|
|
#if ENABLED(FILAMENT_CHANGE_FEATURE) |
|
|
#if ENABLED(FILAMENT_CHANGE_FEATURE) |
|
|
no_stepper_sleep |
|
|
no_stepper_sleep |
|
|