rusefi/firmware/init/sensor/init_thermistors.cpp

124 lines
3.4 KiB
C++
Raw Normal View History

#include "pch.h"
#include "adc_subscription.h"
#include "functional_sensor.h"
#include "func_chain.h"
#include "linear_func.h"
#include "resistance_func.h"
#include "thermistor_func.h"
using resist = ResistanceFunc;
using therm = ThermistorFunc;
// Each one could be either linear or thermistor
struct FuncPair {
LinearFunc linear;
FuncChain<resist, therm> thermistor;
};
static CCM_OPTIONAL FunctionalSensor clt(SensorType::Clt, MS2NT(10));
static CCM_OPTIONAL FunctionalSensor iat(SensorType::Iat, MS2NT(10));
static CCM_OPTIONAL FunctionalSensor aux1(SensorType::AuxTemp1, MS2NT(10));
static FunctionalSensor aux2(SensorType::AuxTemp2, MS2NT(10));
static FuncPair fclt, fiat, faux1, faux2;
2021-10-14 15:07:35 -07:00
static void validateThermistorConfig(const char *msg, thermistor_conf_s& cfg) {
2021-05-06 10:58:01 -07:00
if (cfg.tempC_1 >= cfg.tempC_2 ||
cfg.tempC_2 >= cfg.tempC_3) {
firmwareError(ObdCode::OBD_ThermistorConfig, "Invalid thermistor %s configuration: please check that temperatures are in the ascending order %f %f %f",
2021-10-14 15:07:35 -07:00
msg,
2021-05-06 10:58:01 -07:00
cfg.tempC_1,
cfg.tempC_2,
cfg.tempC_3);
}
}
2021-10-14 15:07:35 -07:00
static SensorConverter& configureTempSensorFunction(const char *msg,
2023-06-10 13:36:03 -07:00
thermistor_conf_s& cfg, FuncPair& p, bool isLinear, bool isPulldown) {
if (isLinear) {
p.linear.configure(cfg.resistance_1, cfg.tempC_1, cfg.resistance_2, cfg.tempC_2, -50, 250);
return p.linear;
} else /* sensor is thermistor */ {
2021-10-14 15:07:35 -07:00
validateThermistorConfig(msg, cfg);
2023-06-10 13:36:03 -07:00
p.thermistor.get<resist>().configure(5.0f, cfg.bias_resistor, isPulldown);
p.thermistor.get<therm>().configure(cfg);
return p.thermistor;
}
}
2021-10-14 15:07:35 -07:00
static void configTherm(const char *msg,
FunctionalSensor &sensor,
FuncPair &p,
ThermistorConf &config,
2023-06-10 13:36:03 -07:00
bool isLinear,
bool isPulldown) {
// nothing to do if no channel
if (!isAdcChannelValid(config.adcChannel)) {
return;
}
// Configure the conversion function for this sensor
2023-06-10 13:36:03 -07:00
sensor.setFunction(configureTempSensorFunction(msg, config.config, p, isLinear, isPulldown));
}
2021-10-14 15:07:35 -07:00
static void configureTempSensor(const char *msg,
FunctionalSensor &sensor,
FuncPair &p,
ThermistorConf &config,
2023-06-10 13:36:03 -07:00
bool isLinear,
bool isPulldown = false) {
auto channel = config.adcChannel;
// Only register if we have a sensor
if (!isAdcChannelValid(channel)) {
return;
}
2023-06-10 13:36:03 -07:00
configTherm(msg, sensor, p, config, isLinear, isPulldown);
// Register & subscribe
AdcSubscription::SubscribeSensor(sensor, channel, 2);
sensor.Register();
}
void initThermistors() {
if (!engineConfiguration->consumeObdSensors) {
2021-10-14 15:07:35 -07:00
configureTempSensor("clt",
clt,
fclt,
engineConfiguration->clt,
2023-06-10 13:36:03 -07:00
engineConfiguration->useLinearCltSensor,
engineConfiguration->cltSensorPulldown);
2021-10-14 15:07:35 -07:00
configureTempSensor("iat",
iat,
fiat,
engineConfiguration->iat,
2023-06-10 13:36:03 -07:00
engineConfiguration->useLinearIatSensor,
engineConfiguration->iatSensorPulldown);
2020-09-03 20:27:53 -07:00
}
2021-10-14 15:07:35 -07:00
configureTempSensor("aux1",
aux1,
faux1,
engineConfiguration->auxTempSensor1,
false);
2021-10-14 15:07:35 -07:00
configureTempSensor("aux2",
aux2,
faux2,
engineConfiguration->auxTempSensor2,
false);
}
void deinitThermistors() {
AdcSubscription::UnsubscribeSensor(clt, engineConfiguration->clt.adcChannel);
AdcSubscription::UnsubscribeSensor(iat, engineConfiguration->iat.adcChannel);
AdcSubscription::UnsubscribeSensor(aux1, engineConfiguration->auxTempSensor1.adcChannel);
AdcSubscription::UnsubscribeSensor(aux2, engineConfiguration->auxTempSensor2.adcChannel);
}