Fix mintemp/maxtemp monitoring for thermocouples

2.0.x
Scott Lahteine 5 years ago committed by Scott Lahteine
parent de8fee6aea
commit c28e08c849

@ -2194,14 +2194,18 @@ void Temperature::readings_ready() {
temp_chamber.acc = 0; temp_chamber.acc = 0;
#endif #endif
int constexpr temp_dir[] = { static constexpr int8_t temp_dir[] = {
#if ENABLED(HEATER_0_USES_MAX6675) #if ENABLED(HEATER_0_USES_MAX6675)
0 0
#else #else
TEMPDIR(0) TEMPDIR(0)
#endif #endif
#if HOTENDS > 1 #if HOTENDS > 1
#if ENABLED(HEATER_1_USES_MAX6675)
, 0
#else
, TEMPDIR(1) , TEMPDIR(1)
#endif
#if HOTENDS > 2 #if HOTENDS > 2
, TEMPDIR(2) , TEMPDIR(2)
#if HOTENDS > 3 #if HOTENDS > 3
@ -2221,12 +2225,14 @@ void Temperature::readings_ready() {
if (grace_period) return; if (grace_period) return;
for (uint8_t e = 0; e < COUNT(temp_dir); e++) { for (uint8_t e = 0; e < COUNT(temp_dir); e++) {
const int16_t tdir = temp_dir[e], rawtemp = temp_hotend[e].raw * tdir; const int8_t tdir = temp_dir[e];
const bool heater_on = (temp_hotend[e].target > 0) if (tdir) {
const int16_t rawtemp = temp_hotend[e].raw * tdir; // normal direction, +rawtemp, else -rawtemp
const bool heater_on = (temp_hotend[e].target > 0
#if ENABLED(PIDTEMP) #if ENABLED(PIDTEMP)
|| (temp_hotend[e].soft_pwm_amount > 0) || temp_hotend[e].soft_pwm_amount > 0
#endif #endif
; );
if (rawtemp > temp_range[e].raw_max * tdir) max_temp_error(e); if (rawtemp > temp_range[e].raw_max * tdir) max_temp_error(e);
if (heater_on && rawtemp < temp_range[e].raw_min * tdir && !is_preheating(e)) { if (heater_on && rawtemp < temp_range[e].raw_min * tdir && !is_preheating(e)) {
#ifdef MAX_CONSECUTIVE_LOW_TEMPERATURE_ERROR_ALLOWED #ifdef MAX_CONSECUTIVE_LOW_TEMPERATURE_ERROR_ALLOWED
@ -2239,6 +2245,7 @@ void Temperature::readings_ready() {
consecutive_low_temperature_error[e] = 0; consecutive_low_temperature_error[e] = 0;
#endif #endif
} }
}
#if HAS_HEATED_BED #if HAS_HEATED_BED
#if TEMPDIR(BED) < 0 #if TEMPDIR(BED) < 0

Loading…
Cancel
Save