2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
2020-03-30 15:29:42 -07:00
|
|
|
#include "proxy_sensor.h"
|
|
|
|
#include "functional_sensor.h"
|
2020-04-02 05:55:21 -07:00
|
|
|
#include "redundant_sensor.h"
|
2021-04-05 12:57:03 -07:00
|
|
|
#include "redundant_ford_tps.h"
|
2021-10-04 14:18:08 -07:00
|
|
|
#include "fallback_sensor.h"
|
2021-03-04 19:39:20 -08:00
|
|
|
#include "Lps25Sensor.h"
|
2020-08-24 05:10:58 -07:00
|
|
|
#include "linear_func.h"
|
|
|
|
#include "resistance_func.h"
|
|
|
|
#include "thermistor_func.h"
|
2021-10-04 14:18:08 -07:00
|
|
|
#include "identity_func.h"
|
2020-03-30 15:29:42 -07:00
|
|
|
|
2021-04-18 17:02:32 -07:00
|
|
|
void ProxySensor::showInfo(const char* sensorName) const {
|
|
|
|
efiPrintf("Sensor \"%s\" proxied from sensor \"%s\"", sensorName, getSensorName(m_proxiedSensor));
|
2020-03-30 15:29:42 -07:00
|
|
|
}
|
|
|
|
|
2021-04-18 17:02:32 -07:00
|
|
|
void FunctionalSensor::showInfo(const char* sensorName) const {
|
2020-03-30 15:29:42 -07:00
|
|
|
const auto [valid, value] = get();
|
2021-04-18 17:02:32 -07:00
|
|
|
efiPrintf("Sensor \"%s\": Raw value: %.2f Valid: %s Converted value %.2f", sensorName, m_rawValue, boolToString(valid), value);
|
2020-03-30 22:07:08 -07:00
|
|
|
|
|
|
|
// now print out the underlying function's info
|
|
|
|
if (auto func = m_function) {
|
2021-04-18 17:02:32 -07:00
|
|
|
func->showInfo(m_rawValue);
|
2020-03-30 22:07:08 -07:00
|
|
|
}
|
2020-03-30 15:29:42 -07:00
|
|
|
}
|
2020-03-31 20:21:05 -07:00
|
|
|
|
|
|
|
#if EFI_CAN_SUPPORT
|
|
|
|
#include "can_sensor.h"
|
|
|
|
|
2021-04-18 17:02:32 -07:00
|
|
|
void CanSensorBase::showInfo(const char* sensorName) const {
|
2020-03-31 20:21:05 -07:00
|
|
|
const auto [valid, value] = get();
|
2021-04-18 17:02:32 -07:00
|
|
|
efiPrintf("CAN Sensor \"%s\": valid: %s value: %.2f", sensorName, boolToString(valid), value);
|
2020-03-31 20:21:05 -07:00
|
|
|
}
|
2020-04-02 05:55:21 -07:00
|
|
|
#endif // EFI_CAN_SUPPORT
|
|
|
|
|
2021-04-18 17:02:32 -07:00
|
|
|
void RedundantSensor::showInfo(const char* sensorName) const {
|
|
|
|
efiPrintf("Sensor \"%s\" is redundant combining \"%s\" and \"%s\"", sensorName, getSensorName(m_first), getSensorName(m_second));
|
2020-08-24 05:10:58 -07:00
|
|
|
}
|
|
|
|
|
2021-04-18 17:02:32 -07:00
|
|
|
void RedundantFordTps::showInfo(const char* sensorName) const {
|
|
|
|
efiPrintf("Sensor \"%s\" is Ford-type redundant TPS combining \"%s\" and \"%s\"", sensorName, getSensorName(m_first), getSensorName(m_second));
|
2021-04-05 12:57:03 -07:00
|
|
|
}
|
|
|
|
|
2021-10-04 14:18:08 -07:00
|
|
|
void FallbackSensor::showInfo(const char* sensorName) const {
|
|
|
|
efiPrintf("Sensor \"%s\" is fallback sensor with primary \"%s\" and fallback \"%s\"", sensorName, getSensorName(m_primary), getSensorName(m_fallback));
|
|
|
|
}
|
|
|
|
|
2021-04-18 17:02:32 -07:00
|
|
|
void RpmCalculator::showInfo(const char* /*sensorName*/) const {
|
|
|
|
efiPrintf("RPM sensor: stopped: %d spinning up: %d cranking: %d running: %d rpm: %f",
|
2020-09-05 15:49:42 -07:00
|
|
|
isStopped(),
|
|
|
|
isSpinningUp(),
|
|
|
|
isCranking(),
|
|
|
|
isRunning(),
|
|
|
|
get().value_or(0)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2021-04-18 17:02:32 -07:00
|
|
|
void Lps25Sensor::showInfo(const char* sensorName) const {
|
|
|
|
efiPrintf("%s: LPS25 baro %.2f kPa", sensorName, get().Value);
|
2021-03-04 19:39:20 -08:00
|
|
|
}
|
|
|
|
|
2021-04-18 17:02:32 -07:00
|
|
|
void LinearFunc::showInfo(float testRawValue) const {
|
|
|
|
efiPrintf(" Linear function slope: %.2f offset: %.2f min: %.1f max: %.1f", m_a, m_b, m_minOutput, m_maxOutput);
|
2020-08-24 05:10:58 -07:00
|
|
|
const auto [valid, value] = convert(testRawValue);
|
2021-04-18 17:02:32 -07:00
|
|
|
efiPrintf(" raw value %.2f converts to %.2f valid: %s", testRawValue, value, boolToString(valid));
|
2020-08-24 05:10:58 -07:00
|
|
|
}
|
|
|
|
|
2021-04-18 17:02:32 -07:00
|
|
|
void ResistanceFunc::showInfo(float testInputValue) const {
|
2020-08-24 05:10:58 -07:00
|
|
|
const auto result = convert(testInputValue);
|
2021-04-18 17:02:32 -07:00
|
|
|
efiPrintf(" %.2f volts -> %.1f ohms with supply voltage %.2f and pullup %.1f.", testInputValue, result.Value, m_supplyVoltage, m_pullupResistor);
|
2020-08-24 05:10:58 -07:00
|
|
|
}
|
|
|
|
|
2021-04-18 17:02:32 -07:00
|
|
|
void ThermistorFunc::showInfo(float testInputValue) const {
|
2020-08-24 05:10:58 -07:00
|
|
|
const auto [valid, value] = convert(testInputValue);
|
2021-04-18 17:02:32 -07:00
|
|
|
efiPrintf(" %.1f ohms -> valid: %s. %.1f deg C", testInputValue, boolToString(valid), value);
|
2020-04-02 05:55:21 -07:00
|
|
|
}
|
2021-10-04 14:18:08 -07:00
|
|
|
|
|
|
|
void IdentityFunction::showInfo(float /*testInputValue*/) const {
|
|
|
|
efiPrintf(" Identity function passes along value.");
|
|
|
|
}
|