|
|
@ -111,33 +111,24 @@ static volatile bool temp_meas_ready = false;
|
|
|
|
unsigned long watchmillis = 0;
|
|
|
|
unsigned long watchmillis = 0;
|
|
|
|
#endif //WATCHPERIOD
|
|
|
|
#endif //WATCHPERIOD
|
|
|
|
|
|
|
|
|
|
|
|
// Init min and max temp with extreme values to prevent false errors during startup
|
|
|
|
|
|
|
|
static int minttemp[EXTRUDERS] = { 0 };
|
|
|
|
|
|
|
|
static int maxttemp[EXTRUDERS] = { 16383 }; // the first value used for all
|
|
|
|
|
|
|
|
static int bed_minttemp = 0;
|
|
|
|
|
|
|
|
static int bed_maxttemp = 16383;
|
|
|
|
|
|
|
|
static void *heater_ttbl_map[EXTRUDERS] = { (void *)heater_0_temptable
|
|
|
|
|
|
|
|
#if EXTRUDERS > 1
|
|
|
|
|
|
|
|
, (void *)heater_1_temptable
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if EXTRUDERS > 2
|
|
|
|
|
|
|
|
, (void *)heater_2_temptable
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if EXTRUDERS > 3
|
|
|
|
#if EXTRUDERS > 3
|
|
|
|
#error Unsupported number of extruders
|
|
|
|
# error Unsupported number of extruders
|
|
|
|
#endif
|
|
|
|
#elif EXTRUDERS > 2
|
|
|
|
};
|
|
|
|
# define ARRAY_BY_EXTRUDERS(v1, v2, v3) { v1, v2, v3 }
|
|
|
|
static int heater_ttbllen_map[EXTRUDERS] = { heater_0_temptable_len
|
|
|
|
#elif EXTRUDERS > 1
|
|
|
|
#if EXTRUDERS > 1
|
|
|
|
# define ARRAY_BY_EXTRUDERS(v1, v2, v3) { v1, v2 }
|
|
|
|
, heater_1_temptable_len
|
|
|
|
#else
|
|
|
|
#endif
|
|
|
|
# define ARRAY_BY_EXTRUDERS(v1, v2, v3) { v1 }
|
|
|
|
#if EXTRUDERS > 2
|
|
|
|
|
|
|
|
, heater_2_temptable_len
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if EXTRUDERS > 3
|
|
|
|
|
|
|
|
#error Unsupported number of extruders
|
|
|
|
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
// Init min and max temp with extreme values to prevent false errors during startup
|
|
|
|
|
|
|
|
static int minttemp[EXTRUDERS] = ARRAY_BY_EXTRUDERS(0, 0, 0);
|
|
|
|
|
|
|
|
static int maxttemp[EXTRUDERS] = ARRAY_BY_EXTRUDERS(16383, 16383, 16383); // the first value used for all
|
|
|
|
|
|
|
|
static int bed_minttemp = 0;
|
|
|
|
|
|
|
|
static int bed_maxttemp = 16383;
|
|
|
|
|
|
|
|
static void *heater_ttbl_map[EXTRUDERS] = ARRAY_BY_EXTRUDERS((void *)heater_0_temptable, (void *)heater_1_temptable, (void *)heater_2_temptable);
|
|
|
|
|
|
|
|
static int heater_ttbllen_map[EXTRUDERS] = ARRAY_BY_EXTRUDERS(heater_0_temptable_len, heater_1_temptable_len, heater_2_temptable_len);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//===========================================================================
|
|
|
|
//===========================================================================
|
|
|
|
//============================= functions ============================
|
|
|
|
//============================= functions ============================
|
|
|
@ -820,6 +811,9 @@ void max_temp_error(uint8_t e) {
|
|
|
|
SERIAL_ERRORLN((int)e);
|
|
|
|
SERIAL_ERRORLN((int)e);
|
|
|
|
SERIAL_ERRORLNPGM(": Extruder switched off. MAXTEMP triggered !");
|
|
|
|
SERIAL_ERRORLNPGM(": Extruder switched off. MAXTEMP triggered !");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifndef BOGUS_TEMPERATURE_FAILSAFE_OVERRIDE
|
|
|
|
|
|
|
|
Stop();
|
|
|
|
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void min_temp_error(uint8_t e) {
|
|
|
|
void min_temp_error(uint8_t e) {
|
|
|
@ -829,6 +823,9 @@ void min_temp_error(uint8_t e) {
|
|
|
|
SERIAL_ERRORLN((int)e);
|
|
|
|
SERIAL_ERRORLN((int)e);
|
|
|
|
SERIAL_ERRORLNPGM(": Extruder switched off. MINTEMP triggered !");
|
|
|
|
SERIAL_ERRORLNPGM(": Extruder switched off. MINTEMP triggered !");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifndef BOGUS_TEMPERATURE_FAILSAFE_OVERRIDE
|
|
|
|
|
|
|
|
Stop();
|
|
|
|
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void bed_max_temp_error(void) {
|
|
|
|
void bed_max_temp_error(void) {
|
|
|
@ -839,16 +836,19 @@ void bed_max_temp_error(void) {
|
|
|
|
SERIAL_ERROR_START;
|
|
|
|
SERIAL_ERROR_START;
|
|
|
|
SERIAL_ERRORLNPGM("Temperature heated bed switched off. MAXTEMP triggered !!");
|
|
|
|
SERIAL_ERRORLNPGM("Temperature heated bed switched off. MAXTEMP triggered !!");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifndef BOGUS_TEMPERATURE_FAILSAFE_OVERRIDE
|
|
|
|
|
|
|
|
Stop();
|
|
|
|
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#define HEAT_INTERVAL 250
|
|
|
|
|
|
|
|
#ifdef HEATER_0_USES_MAX6675
|
|
|
|
#ifdef HEATER_0_USES_MAX6675
|
|
|
|
|
|
|
|
#define MAX6675_HEAT_INTERVAL 250
|
|
|
|
long max6675_previous_millis = -HEAT_INTERVAL;
|
|
|
|
long max6675_previous_millis = -HEAT_INTERVAL;
|
|
|
|
int max6675_temp = 2000;
|
|
|
|
int max6675_temp = 2000;
|
|
|
|
|
|
|
|
|
|
|
|
int read_max6675()
|
|
|
|
int read_max6675()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (millis() - max6675_previous_millis < HEAT_INTERVAL)
|
|
|
|
if (millis() - max6675_previous_millis < MAX6675_HEAT_INTERVAL)
|
|
|
|
return max6675_temp;
|
|
|
|
return max6675_temp;
|
|
|
|
|
|
|
|
|
|
|
|
max6675_previous_millis = millis();
|
|
|
|
max6675_previous_millis = millis();
|
|
|
@ -1077,20 +1077,10 @@ ISR(TIMER0_COMPB_vect)
|
|
|
|
if(current_raw[e] >= maxttemp[e]) {
|
|
|
|
if(current_raw[e] >= maxttemp[e]) {
|
|
|
|
target_raw[e] = 0;
|
|
|
|
target_raw[e] = 0;
|
|
|
|
max_temp_error(e);
|
|
|
|
max_temp_error(e);
|
|
|
|
#ifndef BOGUS_TEMPERATURE_FAILSAFE_OVERRIDE
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Stop();;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(current_raw[e] <= minttemp[e]) {
|
|
|
|
if(current_raw[e] <= minttemp[e]) {
|
|
|
|
target_raw[e] = 0;
|
|
|
|
target_raw[e] = 0;
|
|
|
|
min_temp_error(e);
|
|
|
|
min_temp_error(e);
|
|
|
|
#ifndef BOGUS_TEMPERATURE_FAILSAFE_OVERRIDE
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
Stop();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -1098,7 +1088,6 @@ ISR(TIMER0_COMPB_vect)
|
|
|
|
if(current_raw_bed >= bed_maxttemp) {
|
|
|
|
if(current_raw_bed >= bed_maxttemp) {
|
|
|
|
target_raw_bed = 0;
|
|
|
|
target_raw_bed = 0;
|
|
|
|
bed_max_temp_error();
|
|
|
|
bed_max_temp_error();
|
|
|
|
Stop();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
}
|
|
|
|