From ea46db500f6f59fcefe6273ae104fb3fde2bce23 Mon Sep 17 00:00:00 2001 From: Matthew Kennedy Date: Wed, 22 Nov 2023 19:35:40 -0800 Subject: [PATCH] set valid bit only when nernst voltage is well controlled --- firmware/can.cpp | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/firmware/can.cpp b/firmware/can.cpp index 4f20b73..65b7218 100644 --- a/firmware/can.cpp +++ b/firmware/can.cpp @@ -144,6 +144,8 @@ void SendRusefiFormat(uint8_t ch) const auto& sampler = GetSampler(ch); const auto& heater = GetHeaterController(ch); + float nernstDc = sampler.GetNernstDc(); + { CanTxTyped frame(baseAddress + 0); @@ -153,7 +155,9 @@ void SendRusefiFormat(uint8_t ch) uint16_t lambda = GetLambda(ch) * 10000; frame.get().Lambda = lambda; frame.get().TemperatureC = sampler.GetSensorTemperature(); - frame.get().Valid = heater.IsRunningClosedLoop() ? 0x01 : 0x00; + bool heaterClosedLoop = heater.IsRunningClosedLoop(); + bool nernstValid = nernstDc > (NERNST_TARGET - 0.1f) && nernstDc < (NERNST_TARGET + 0.1f); + frame.get().Valid = (heaterClosedLoop && nernstValid) ? 0x01 : 0x00; } { @@ -162,7 +166,7 @@ void SendRusefiFormat(uint8_t ch) CanTxTyped frame(baseAddress + 1); frame.get().Esr = esr; - frame.get().NernstDc = sampler.GetNernstDc() * 1000; + frame.get().NernstDc = nernstDc * 1000; frame.get().PumpDuty = GetPumpOutputDuty(ch) * 255; frame.get().Status = GetCurrentFault(ch); frame.get().HeaterDuty = GetHeaterDuty(ch) * 255;