heater: Enforce min/max_temp in heater.set_temp()

Raise an error if the user requests a temperate outside the configured
min/max_temp range.

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2017-02-21 10:48:42 -05:00
parent 566699f68a
commit 47f1d377f5
2 changed files with 16 additions and 3 deletions

View File

@ -191,7 +191,11 @@ class GCodeParser:
def set_temp(self, heater, params, wait=False): def set_temp(self, heater, params, wait=False):
print_time = self.toolhead.get_last_move_time() print_time = self.toolhead.get_last_move_time()
temp = float(params.get('S', '0')) temp = float(params.get('S', '0'))
heater.set_temp(print_time, temp) try:
heater.set_temp(print_time, temp)
except heater.error, e:
self.respond_error(str(e))
return
if wait: if wait:
self.bg_temp(heater) self.bg_temp(heater)
# Individual command handlers # Individual command handlers

View File

@ -21,7 +21,11 @@ MAX_HEAT_TIME = 5.0
AMBIENT_TEMP = 25. AMBIENT_TEMP = 25.
PWM_MAX = 255 PWM_MAX = 255
class error(Exception):
pass
class PrinterHeater: class PrinterHeater:
error = error
def __init__(self, printer, config): def __init__(self, printer, config):
self.printer = printer self.printer = printer
self.config = config self.config = config
@ -29,6 +33,8 @@ class PrinterHeater:
self.thermistor_c = config.getchoice('thermistor_type', Thermistors) self.thermistor_c = config.getchoice('thermistor_type', Thermistors)
self.pullup_r = config.getfloat('pullup_resistor', 4700.) self.pullup_r = config.getfloat('pullup_resistor', 4700.)
self.min_extrude_temp = config.getfloat('min_extrude_temp', 170.) self.min_extrude_temp = config.getfloat('min_extrude_temp', 170.)
self.min_temp = self.config.getfloat('min_temp')
self.max_temp = self.config.getfloat('max_temp')
self.can_extrude = (self.min_extrude_temp <= 0.) self.can_extrude = (self.min_extrude_temp <= 0.)
self.lock = threading.Lock() self.lock = threading.Lock()
self.last_temp = 0. self.last_temp = 0.
@ -50,8 +56,8 @@ class PrinterHeater:
self.mcu_pwm = self.printer.mcu.create_pwm( self.mcu_pwm = self.printer.mcu.create_pwm(
heater_pin, 0, MAX_HEAT_TIME) heater_pin, 0, MAX_HEAT_TIME)
self.mcu_adc = self.printer.mcu.create_adc(thermistor_pin) self.mcu_adc = self.printer.mcu.create_adc(thermistor_pin)
min_adc = self.calc_adc(self.config.getfloat('max_temp')) min_adc = self.calc_adc(self.max_temp)
max_adc = self.calc_adc(self.config.getfloat('min_temp')) max_adc = self.calc_adc(self.min_temp)
self.mcu_adc.set_minmax( self.mcu_adc.set_minmax(
SAMPLE_TIME, SAMPLE_COUNT, minval=min_adc, maxval=max_adc) SAMPLE_TIME, SAMPLE_COUNT, minval=min_adc, maxval=max_adc)
self.mcu_adc.set_adc_callback(REPORT_TIME, self.adc_callback) self.mcu_adc.set_adc_callback(REPORT_TIME, self.adc_callback)
@ -102,6 +108,9 @@ class PrinterHeater:
#logging.debug("temp: %.3f %f = %f" % (read_time, read_value, temp)) #logging.debug("temp: %.3f %f = %f" % (read_time, read_value, temp))
# External commands # External commands
def set_temp(self, print_time, degrees): def set_temp(self, print_time, degrees):
if degrees and (degrees < self.min_temp or degrees > self.max_temp):
raise error("Requested temperature (%.1f) out of range (%.1f:%.1f)"
% (degrees, self.min_temp, self.max_temp))
with self.lock: with self.lock:
self.target_temp = degrees self.target_temp = degrees
def get_temp(self): def get_temp(self):