spi_temperature: Eliminate get_configs() callback

Those chips that require an spi init sequence can generate the message
directly in the chip specific class.

Also, don't send an spi init message for chips that are read-only.

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2018-07-24 15:10:10 -04:00
parent c52c398ae8
commit a084c38b41
1 changed files with 33 additions and 39 deletions

View File

@ -24,7 +24,7 @@ class error(Exception):
class SensorBase: class SensorBase:
error = error error = error
def __init__(self, config, chip_type): def __init__(self, config, chip_type, config_cmd=None):
self._callback = None self._callback = None
self.min_sample_value = self.max_sample_value = 0 self.min_sample_value = self.max_sample_value = 0
self._report_clock = 0 self._report_clock = 0
@ -41,7 +41,8 @@ class SensorBase:
"config_spi oid=%u bus=%u pin=%s" "config_spi oid=%u bus=%u pin=%s"
" mode=%u rate=%u shutdown_msg=" % ( " mode=%u rate=%u shutdown_msg=" % (
spi_oid, 0, pin, spi_mode, spi_speed)) spi_oid, 0, pin, spi_mode, spi_speed))
config_cmd = "".join("%02x" % b for b in self.get_configs()) if config_cmd is not None:
config_cmd = "".join("%02x" % b for b in config_cmd)
mcu.add_config_cmd("spi_send oid=%u data=%s" % ( mcu.add_config_cmd("spi_send oid=%u data=%s" % (
spi_oid, config_cmd), is_init=True) spi_oid, config_cmd), is_init=True)
# Reader chip configuration # Reader chip configuration
@ -134,27 +135,8 @@ MAX31856_MULT = 0.0078125
class MAX31856(SensorBase): class MAX31856(SensorBase):
def __init__(self, config): def __init__(self, config):
types = { SensorBase.__init__(self, config, TS_CHIP_MAX31856,
"B" : 0b0000, self.build_spi_init(config))
"E" : 0b0001,
"J" : 0b0010,
"K" : 0b0011,
"N" : 0b0100,
"R" : 0b0101,
"S" : 0b0110,
"T" : 0b0111,
}
self.tc_type = config.getchoice('tc_type', types, default="K")
self.use_50Hz_filter = config.getboolean('tc_use_50Hz_filter', False)
averages = {
"1" : MAX31856_CR1_AVGSEL1,
"2" : MAX31856_CR1_AVGSEL2,
"4" : MAX31856_CR1_AVGSEL4,
"8" : MAX31856_CR1_AVGSEL8,
"16" : MAX31856_CR1_AVGSEL16
}
self.average_count = config.getchoice('tc_averaging_count', averages, "1")
SensorBase.__init__(self, config, TS_CHIP_MAX31856)
def calc_temp(self, adc, fault): def calc_temp(self, adc, fault):
if fault & MAX31856_FAULT_CJRANGE: if fault & MAX31856_FAULT_CJRANGE:
raise self.error("Max31856: Cold Junction Range Fault") raise self.error("Max31856: Cold Junction Range Fault")
@ -182,16 +164,33 @@ class MAX31856(SensorBase):
adc = int( ( temp / MAX31856_MULT ) + 0.5 ) # convert to ADC value adc = int( ( temp / MAX31856_MULT ) + 0.5 ) # convert to ADC value
adc = adc << MAX31856_SCALE adc = adc << MAX31856_SCALE
return adc return adc
def get_configs(self): def build_spi_init(self, config):
cmds = [] cmds = []
value = MAX31856_CR0_AUTOCONVERT value = MAX31856_CR0_AUTOCONVERT
if self.use_50Hz_filter: if config.getboolean('tc_use_50Hz_filter', False):
value |= MAX31856_CR0_FILT50HZ value |= MAX31856_CR0_FILT50HZ
cmds.append(0x80 + MAX31856_CR0_REG) cmds.append(0x80 + MAX31856_CR0_REG)
cmds.append(value) cmds.append(value)
value = self.tc_type types = {
value |= self.average_count "B" : 0b0000,
"E" : 0b0001,
"J" : 0b0010,
"K" : 0b0011,
"N" : 0b0100,
"R" : 0b0101,
"S" : 0b0110,
"T" : 0b0111,
}
value = config.getchoice('tc_type', types, default="K")
averages = {
"1" : MAX31856_CR1_AVGSEL1,
"2" : MAX31856_CR1_AVGSEL2,
"4" : MAX31856_CR1_AVGSEL4,
"8" : MAX31856_CR1_AVGSEL8,
"16" : MAX31856_CR1_AVGSEL16
}
value |= config.getchoice('tc_averaging_count', averages, "1")
cmds.append(0x80 + MAX31856_CR1_REG) cmds.append(0x80 + MAX31856_CR1_REG)
cmds.append(value) cmds.append(value)
@ -229,8 +228,6 @@ class MAX31855(SensorBase):
adc = int( ( temp / MAX31855_MULT ) + 0.5 ) # convert to ADC value adc = int( ( temp / MAX31855_MULT ) + 0.5 ) # convert to ADC value
adc = adc << MAX31855_SCALE adc = adc << MAX31855_SCALE
return adc return adc
def get_configs(self):
return []
###################################################################### ######################################################################
@ -258,8 +255,6 @@ class MAX6675(SensorBase):
adc = int( ( temp / MAX6675_MULT ) + 0.5 ) # convert to ADC value adc = int( ( temp / MAX6675_MULT ) + 0.5 ) # convert to ADC value
adc = adc << MAX6675_SCALE adc = adc << MAX6675_SCALE
return adc return adc
def get_configs(self):
return []
###################################################################### ######################################################################
@ -298,9 +293,8 @@ class MAX31865(SensorBase):
def __init__(self, config): def __init__(self, config):
self.rtd_nominal_r = config.getint('rtd_nominal_r', 100) self.rtd_nominal_r = config.getint('rtd_nominal_r', 100)
self.reference_r = config.getfloat('rtd_reference_r', 430., above=0.) self.reference_r = config.getfloat('rtd_reference_r', 430., above=0.)
self.num_wires = config.getint('rtd_num_of_wires', 2) SensorBase.__init__(self, config, TS_CHIP_MAX31865,
self.use_50Hz_filter = config.getboolean('rtd_use_50Hz_filter', False) self.build_spi_init(config))
SensorBase.__init__(self, config, TS_CHIP_MAX31865)
def calc_temp(self, adc, fault): def calc_temp(self, adc, fault):
if fault & 0x80: if fault & 0x80:
raise self.error("Max31865 RTD input is disconnected") raise self.error("Max31865 RTD input is disconnected")
@ -333,13 +327,13 @@ class MAX31865(SensorBase):
adc = int( ( ( R_rtd * VAL_ADC_MAX ) / self.reference_r) + 0.5 ) adc = int( ( ( R_rtd * VAL_ADC_MAX ) / self.reference_r) + 0.5 )
adc = adc << 1 # Add fault bit adc = adc << 1 # Add fault bit
return adc return adc
def get_configs(self): def build_spi_init(self, config):
value = (MAX31865_CONFIG_BIAS | value = (MAX31865_CONFIG_BIAS |
MAX31865_CONFIG_MODEAUTO | MAX31865_CONFIG_MODEAUTO |
MAX31865_CONFIG_FAULTCLEAR) MAX31865_CONFIG_FAULTCLEAR)
if self.use_50Hz_filter: if config.getboolean('rtd_use_50Hz_filter', False):
value |= MAX31865_CONFIG_FILT50HZ value |= MAX31865_CONFIG_FILT50HZ
if self.num_wires == 3: if config.getint('rtd_num_of_wires', 2) == 3:
value |= MAX31865_CONFIG_3WIRE value |= MAX31865_CONFIG_3WIRE
cmd = 0x80 + MAX31865_CONFIG_REG cmd = 0x80 + MAX31865_CONFIG_REG
return [cmd, value] return [cmd, value]