2021-07-25 22:05:17 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2020-04-07 13:07:09 -07:00
|
|
|
#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));
|
2021-11-21 17:35:03 -08:00
|
|
|
static FunctionalSensor aux2(SensorType::AuxTemp2, MS2NT(10));
|
2020-04-07 13:07:09 -07:00
|
|
|
|
|
|
|
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) {
|
2023-04-11 17:01:34 -07:00
|
|
|
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-01-07 17:37:15 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
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) {
|
2020-04-07 13:07:09 -07:00
|
|
|
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);
|
2021-01-07 17:37:15 -08:00
|
|
|
|
2023-06-10 13:36:03 -07:00
|
|
|
p.thermistor.get<resist>().configure(5.0f, cfg.bias_resistor, isPulldown);
|
2020-04-07 13:07:09 -07:00
|
|
|
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,
|
2020-04-07 13:07:09 -07:00
|
|
|
FuncPair &p,
|
|
|
|
ThermistorConf &config,
|
2023-06-10 13:36:03 -07:00
|
|
|
bool isLinear,
|
|
|
|
bool isPulldown) {
|
2021-01-09 12:13:43 -08:00
|
|
|
// nothing to do if no channel
|
|
|
|
if (!isAdcChannelValid(config.adcChannel)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-04-07 13:07:09 -07:00
|
|
|
// Configure the conversion function for this sensor
|
2023-06-10 13:36:03 -07:00
|
|
|
sensor.setFunction(configureTempSensorFunction(msg, config.config, p, isLinear, isPulldown));
|
2020-04-07 13:07:09 -07:00
|
|
|
}
|
|
|
|
|
2021-10-14 15:07:35 -07:00
|
|
|
static void configureTempSensor(const char *msg,
|
|
|
|
FunctionalSensor &sensor,
|
2020-04-07 13:07:09 -07:00
|
|
|
FuncPair &p,
|
|
|
|
ThermistorConf &config,
|
2023-06-10 13:36:03 -07:00
|
|
|
bool isLinear,
|
|
|
|
bool isPulldown = false) {
|
2020-04-07 13:07:09 -07:00
|
|
|
auto channel = config.adcChannel;
|
|
|
|
|
|
|
|
// Only register if we have a sensor
|
2021-01-05 13:02:20 -08:00
|
|
|
if (!isAdcChannelValid(channel)) {
|
2020-04-07 13:07:09 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2023-06-10 13:36:03 -07:00
|
|
|
configTherm(msg, sensor, p, config, isLinear, isPulldown);
|
2020-04-07 13:07:09 -07:00
|
|
|
|
|
|
|
// Register & subscribe
|
2020-12-06 12:00:30 -08:00
|
|
|
AdcSubscription::SubscribeSensor(sensor, channel, 2);
|
|
|
|
sensor.Register();
|
2020-04-07 13:07:09 -07:00
|
|
|
}
|
|
|
|
|
2021-11-16 01:15:29 -08:00
|
|
|
void initThermistors() {
|
2021-11-17 00:54:21 -08:00
|
|
|
if (!engineConfiguration->consumeObdSensors) {
|
2021-10-14 15:07:35 -07:00
|
|
|
configureTempSensor("clt",
|
|
|
|
clt,
|
2020-04-07 13:07:09 -07:00
|
|
|
fclt,
|
2021-11-17 00:54:21 -08:00
|
|
|
engineConfiguration->clt,
|
2023-06-10 13:36:03 -07:00
|
|
|
engineConfiguration->useLinearCltSensor,
|
|
|
|
engineConfiguration->cltSensorPulldown);
|
2020-04-07 13:07:09 -07:00
|
|
|
|
2021-10-14 15:07:35 -07:00
|
|
|
configureTempSensor("iat",
|
|
|
|
iat,
|
2020-04-07 13:07:09 -07:00
|
|
|
fiat,
|
2021-11-17 00:54:21 -08:00
|
|
|
engineConfiguration->iat,
|
2023-06-10 13:36:03 -07:00
|
|
|
engineConfiguration->useLinearIatSensor,
|
|
|
|
engineConfiguration->iatSensorPulldown);
|
2020-09-03 20:27:53 -07:00
|
|
|
}
|
2020-04-07 13:07:09 -07:00
|
|
|
|
2021-10-14 15:07:35 -07:00
|
|
|
configureTempSensor("aux1",
|
|
|
|
aux1,
|
2020-04-07 13:07:09 -07:00
|
|
|
faux1,
|
2021-11-17 00:54:21 -08:00
|
|
|
engineConfiguration->auxTempSensor1,
|
2020-04-07 13:07:09 -07:00
|
|
|
false);
|
|
|
|
|
2021-10-14 15:07:35 -07:00
|
|
|
configureTempSensor("aux2",
|
|
|
|
aux2,
|
2020-04-07 13:07:09 -07:00
|
|
|
faux2,
|
2021-11-17 00:54:21 -08:00
|
|
|
engineConfiguration->auxTempSensor2,
|
2020-04-07 13:07:09 -07:00
|
|
|
false);
|
|
|
|
}
|
|
|
|
|
2021-08-24 13:41:16 -07:00
|
|
|
void deinitThermistors() {
|
2023-01-06 05:09:17 -08:00
|
|
|
AdcSubscription::UnsubscribeSensor(clt, engineConfiguration->clt.adcChannel);
|
|
|
|
AdcSubscription::UnsubscribeSensor(iat, engineConfiguration->iat.adcChannel);
|
|
|
|
AdcSubscription::UnsubscribeSensor(aux1, engineConfiguration->auxTempSensor1.adcChannel);
|
|
|
|
AdcSubscription::UnsubscribeSensor(aux2, engineConfiguration->auxTempSensor2.adcChannel);
|
2020-04-07 13:07:09 -07:00
|
|
|
}
|