🚑️ Fix thermal conditionals, structure
This commit is contained in:
parent
f99732ba75
commit
dadd7516b5
@ -2549,13 +2549,13 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Thermal protection
|
// Thermal protection
|
||||||
#if BOTH(HAS_HEATED_BED, THERMAL_PROTECTION_BED)
|
#if !HAS_HEATED_BED
|
||||||
#define HAS_THERMALLY_PROTECTED_BED 1
|
#undef THERMAL_PROTECTION_BED
|
||||||
#endif
|
#endif
|
||||||
#if ENABLED(THERMAL_PROTECTION_HOTENDS) && WATCH_TEMP_PERIOD > 0
|
#if ENABLED(THERMAL_PROTECTION_HOTENDS) && WATCH_TEMP_PERIOD > 0
|
||||||
#define WATCH_HOTENDS 1
|
#define WATCH_HOTENDS 1
|
||||||
#endif
|
#endif
|
||||||
#if HAS_THERMALLY_PROTECTED_BED && WATCH_BED_TEMP_PERIOD > 0
|
#if ENABLED(THERMAL_PROTECTION_BED) && WATCH_BED_TEMP_PERIOD > 0
|
||||||
#define WATCH_BED 1
|
#define WATCH_BED 1
|
||||||
#endif
|
#endif
|
||||||
#if BOTH(HAS_HEATED_CHAMBER, THERMAL_PROTECTION_CHAMBER) && WATCH_CHAMBER_TEMP_PERIOD > 0
|
#if BOTH(HAS_HEATED_CHAMBER, THERMAL_PROTECTION_CHAMBER) && WATCH_CHAMBER_TEMP_PERIOD > 0
|
||||||
@ -2567,7 +2567,7 @@
|
|||||||
#if (ENABLED(THERMAL_PROTECTION_HOTENDS) || !EXTRUDERS) \
|
#if (ENABLED(THERMAL_PROTECTION_HOTENDS) || !EXTRUDERS) \
|
||||||
&& (ENABLED(THERMAL_PROTECTION_BED) || !HAS_HEATED_BED) \
|
&& (ENABLED(THERMAL_PROTECTION_BED) || !HAS_HEATED_BED) \
|
||||||
&& (ENABLED(THERMAL_PROTECTION_CHAMBER) || !HAS_HEATED_CHAMBER) \
|
&& (ENABLED(THERMAL_PROTECTION_CHAMBER) || !HAS_HEATED_CHAMBER) \
|
||||||
&& (ENABLED(THERMAL_PROTECTION_COOLER) || !HAS_COOLER)
|
&& (ENABLED(THERMAL_PROTECTION_COOLER) || !HAS_COOLER)
|
||||||
#define THERMALLY_SAFE 1
|
#define THERMALLY_SAFE 1
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -1444,7 +1444,7 @@ void Temperature::manage_heater() {
|
|||||||
|
|
||||||
TERN_(HEATER_IDLE_HANDLER, heater_idle[IDLE_INDEX_BED].update(ms));
|
TERN_(HEATER_IDLE_HANDLER, heater_idle[IDLE_INDEX_BED].update(ms));
|
||||||
|
|
||||||
#if HAS_THERMALLY_PROTECTED_BED
|
#if ENABLED(THERMAL_PROTECTION_BED)
|
||||||
tr_state_machine[RUNAWAY_IND_BED].run(temp_bed.celsius, temp_bed.target, H_BED, THERMAL_PROTECTION_BED_PERIOD, THERMAL_PROTECTION_BED_HYSTERESIS);
|
tr_state_machine[RUNAWAY_IND_BED].run(temp_bed.celsius, temp_bed.target, H_BED, THERMAL_PROTECTION_BED_PERIOD, THERMAL_PROTECTION_BED_HYSTERESIS);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -2570,20 +2570,14 @@ void Temperature::init() {
|
|||||||
);
|
);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if HEATER_IDLE_HANDLER
|
// If the heater idle timeout expires, restart
|
||||||
// If the heater idle timeout expires, restart
|
if (TERN0(HEATER_IDLE_HANDLER, heater_idle[idle_index].timed_out)) {
|
||||||
if (heater_idle[idle_index].timed_out) {
|
state = TRInactive;
|
||||||
state = TRInactive;
|
running_temp = 0;
|
||||||
running_temp = 0;
|
}
|
||||||
}
|
else if (running_temp != target) { // If the target temperature changes, restart
|
||||||
else
|
running_temp = target;
|
||||||
#endif
|
state = target > 0 ? TRFirstHeating : TRInactive;
|
||||||
{
|
|
||||||
// If the target temperature changes, restart
|
|
||||||
if (running_temp != target) {
|
|
||||||
running_temp = target;
|
|
||||||
state = target > 0 ? TRFirstHeating : TRInactive;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (state) {
|
switch (state) {
|
||||||
@ -2596,7 +2590,7 @@ void Temperature::init() {
|
|||||||
state = TRStable;
|
state = TRStable;
|
||||||
|
|
||||||
// While the temperature is stable watch for a bad temperature
|
// While the temperature is stable watch for a bad temperature
|
||||||
case TRStable:
|
case TRStable: {
|
||||||
|
|
||||||
#if ENABLED(ADAPTIVE_FAN_SLOWING)
|
#if ENABLED(ADAPTIVE_FAN_SLOWING)
|
||||||
if (adaptive_fan_slowing && heater_id >= 0) {
|
if (adaptive_fan_slowing && heater_id >= 0) {
|
||||||
@ -2614,13 +2608,17 @@ void Temperature::init() {
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
const millis_t now = millis();
|
||||||
|
|
||||||
if (current >= running_temp - hysteresis_degc) {
|
if (current >= running_temp - hysteresis_degc) {
|
||||||
timer = millis() + SEC_TO_MS(period_seconds);
|
timer = now + SEC_TO_MS(period_seconds);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
else if (PENDING(millis(), timer)) break;
|
else if (PENDING(now, timer)) break;
|
||||||
state = TRRunaway;
|
state = TRRunaway;
|
||||||
|
|
||||||
|
} // fall through
|
||||||
|
|
||||||
case TRRunaway:
|
case TRRunaway:
|
||||||
TERN_(HAS_DWIN_E3V2_BASIC, DWIN_Popup_Temperature(0));
|
TERN_(HAS_DWIN_E3V2_BASIC, DWIN_Popup_Temperature(0));
|
||||||
_temp_error(heater_id, FPSTR(str_t_thermal_runaway), GET_TEXT_F(MSG_THERMAL_RUNAWAY));
|
_temp_error(heater_id, FPSTR(str_t_thermal_runaway), GET_TEXT_F(MSG_THERMAL_RUNAWAY));
|
||||||
|
@ -1009,7 +1009,7 @@ class Temperature {
|
|||||||
static void min_temp_error(const heater_id_t e);
|
static void min_temp_error(const heater_id_t e);
|
||||||
static void max_temp_error(const heater_id_t e);
|
static void max_temp_error(const heater_id_t e);
|
||||||
|
|
||||||
#define HAS_THERMAL_PROTECTION ANY(THERMAL_PROTECTION_HOTENDS, THERMAL_PROTECTION_CHAMBER, HAS_THERMALLY_PROTECTED_BED, THERMAL_PROTECTION_COOLER)
|
#define HAS_THERMAL_PROTECTION ANY(THERMAL_PROTECTION_HOTENDS, THERMAL_PROTECTION_CHAMBER, THERMAL_PROTECTION_BED, THERMAL_PROTECTION_COOLER)
|
||||||
|
|
||||||
#if HAS_THERMAL_PROTECTION
|
#if HAS_THERMAL_PROTECTION
|
||||||
|
|
||||||
@ -1021,7 +1021,7 @@ class Temperature {
|
|||||||
REPEAT(HOTENDS, _RUNAWAY_IND_E)
|
REPEAT(HOTENDS, _RUNAWAY_IND_E)
|
||||||
#undef _RUNAWAY_IND_E
|
#undef _RUNAWAY_IND_E
|
||||||
#endif
|
#endif
|
||||||
OPTARG(HAS_THERMALLY_PROTECTED_BED, RUNAWAY_IND_BED)
|
OPTARG(THERMAL_PROTECTION_BED, RUNAWAY_IND_BED)
|
||||||
OPTARG(THERMAL_PROTECTION_CHAMBER, RUNAWAY_IND_CHAMBER)
|
OPTARG(THERMAL_PROTECTION_CHAMBER, RUNAWAY_IND_CHAMBER)
|
||||||
OPTARG(THERMAL_PROTECTION_COOLER, RUNAWAY_IND_COOLER)
|
OPTARG(THERMAL_PROTECTION_COOLER, RUNAWAY_IND_COOLER)
|
||||||
, NR_HEATER_RUNAWAY
|
, NR_HEATER_RUNAWAY
|
||||||
@ -1029,9 +1029,9 @@ class Temperature {
|
|||||||
|
|
||||||
// Convert the given heater_id_t to runaway state array index
|
// Convert the given heater_id_t to runaway state array index
|
||||||
static RunawayIndex runaway_index_for_id(const int8_t heater_id) {
|
static RunawayIndex runaway_index_for_id(const int8_t heater_id) {
|
||||||
TERN_(HAS_THERMALLY_PROTECTED_CHAMBER, if (heater_id == H_CHAMBER) return RUNAWAY_IND_CHAMBER);
|
TERN_(THERMAL_PROTECTION_CHAMBER, if (heater_id == H_CHAMBER) return RUNAWAY_IND_CHAMBER);
|
||||||
TERN_(HAS_THERMALLY_PROTECTED_CHAMBER, if (heater_id == H_COOLER) return RUNAWAY_IND_COOLER);
|
TERN_(THERMAL_PROTECTION_COOLER, if (heater_id == H_COOLER) return RUNAWAY_IND_COOLER);
|
||||||
TERN_(HAS_THERMALLY_PROTECTED_BED, if (heater_id == H_BED) return RUNAWAY_IND_BED);
|
TERN_(THERMAL_PROTECTION_BED, if (heater_id == H_BED) return RUNAWAY_IND_BED);
|
||||||
return (RunawayIndex)_MAX(heater_id, 0);
|
return (RunawayIndex)_MAX(heater_id, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user