|
@ -171,7 +171,7 @@ static float analog2tempBed(int raw); |
|
|
static void updateTemperaturesFromRawValues(); |
|
|
static void updateTemperaturesFromRawValues(); |
|
|
|
|
|
|
|
|
#ifdef WATCH_TEMP_PERIOD |
|
|
#ifdef WATCH_TEMP_PERIOD |
|
|
int watch_start_temp[EXTRUDERS] = { 0 }; |
|
|
int watch_target_temp[EXTRUDERS] = { 0 }; |
|
|
millis_t watch_heater_next_ms[EXTRUDERS] = { 0 }; |
|
|
millis_t watch_heater_next_ms[EXTRUDERS] = { 0 }; |
|
|
#endif |
|
|
#endif |
|
|
|
|
|
|
|
@ -625,11 +625,12 @@ void manage_heater() { |
|
|
// Is it time to check this extruder's heater?
|
|
|
// Is it time to check this extruder's heater?
|
|
|
if (watch_heater_next_ms[e] && ms > watch_heater_next_ms[e]) { |
|
|
if (watch_heater_next_ms[e] && ms > watch_heater_next_ms[e]) { |
|
|
// Has it failed to increase enough?
|
|
|
// Has it failed to increase enough?
|
|
|
if (degHotend(e) < watch_start_temp[e] + WATCH_TEMP_INCREASE) { |
|
|
if (degHotend(e) < watch_target_temp[e]) { |
|
|
// Stop!
|
|
|
// Stop!
|
|
|
_temp_error(e, MSG_HEATING_FAILED, MSG_HEATING_FAILED_LCD); |
|
|
_temp_error(e, MSG_HEATING_FAILED, MSG_HEATING_FAILED_LCD); |
|
|
} |
|
|
} |
|
|
else { |
|
|
else { |
|
|
|
|
|
// Only check once per M104/M109
|
|
|
watch_heater_next_ms[e] = 0; |
|
|
watch_heater_next_ms[e] = 0; |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
@ -997,24 +998,24 @@ void tp_init() { |
|
|
#endif //BED_MAXTEMP
|
|
|
#endif //BED_MAXTEMP
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
/**
|
|
|
#ifdef WATCH_TEMP_PERIOD |
|
|
* Start Heating Sanity Check for hotends that are below |
|
|
/**
|
|
|
* their target temperature by a configurable margin. |
|
|
* Start Heating Sanity Check for hotends that are below |
|
|
* This is called when the temperature is set. (M104, M109) |
|
|
* their target temperature by a configurable margin. |
|
|
*/ |
|
|
* This is called when the temperature is set. (M104, M109) |
|
|
void setWatch() { |
|
|
*/ |
|
|
#ifdef WATCH_TEMP_PERIOD |
|
|
void start_watching_heaters() { |
|
|
millis_t ms = millis() + WATCH_TEMP_PERIOD; |
|
|
millis_t ms = millis() + WATCH_TEMP_PERIOD; |
|
|
for (int e = 0; e < EXTRUDERS; e++) { |
|
|
for (int e = 0; e < EXTRUDERS; e++) { |
|
|
if (degHotend(e) < degTargetHotend(e) - (WATCH_TEMP_INCREASE * 2)) { |
|
|
if (degHotend(e) < degTargetHotend(e) - (WATCH_TEMP_INCREASE * 2)) { |
|
|
watch_start_temp[e] = degHotend(e); |
|
|
watch_target_temp[e] = degHotend(e) + WATCH_TEMP_INCREASE; |
|
|
watch_heater_next_ms[e] = ms; |
|
|
watch_heater_next_ms[e] = ms; |
|
|
|
|
|
} |
|
|
|
|
|
else |
|
|
|
|
|
watch_heater_next_ms[e] = 0; |
|
|
} |
|
|
} |
|
|
else |
|
|
} |
|
|
watch_heater_next_ms[e] = 0; |
|
|
#endif |
|
|
} |
|
|
|
|
|
#endif |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
#if HAS_HEATER_THERMAL_PROTECTION || HAS_BED_THERMAL_PROTECTION |
|
|
#if HAS_HEATER_THERMAL_PROTECTION || HAS_BED_THERMAL_PROTECTION |
|
|
|
|
|
|
|
|