2020-04-26 11:06:28 -07:00
|
|
|
|
2021-07-25 22:05:17 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2020-04-26 11:06:28 -07:00
|
|
|
#include "gppwm_channel.h"
|
|
|
|
|
|
|
|
#include "table_helper.h"
|
2023-03-07 05:45:17 -08:00
|
|
|
#include <rusefi/expected.h>
|
2020-04-26 11:06:28 -07:00
|
|
|
|
2021-11-16 01:15:29 -08:00
|
|
|
expected<float> readGppwmChannel(gppwm_channel_e channel) {
|
2020-04-26 11:06:28 -07:00
|
|
|
switch (channel) {
|
2022-09-16 13:04:03 -07:00
|
|
|
case GPPWM_Zero:
|
|
|
|
return 0;
|
2023-02-06 04:53:31 -08:00
|
|
|
case GPPWM_Rpm:
|
|
|
|
return Sensor::get(SensorType::Rpm);
|
2020-04-26 11:06:28 -07:00
|
|
|
case GPPWM_Tps:
|
|
|
|
return Sensor::get(SensorType::Tps1);
|
2021-03-29 05:57:37 -07:00
|
|
|
case GPPWM_Map:
|
2020-12-30 05:43:49 -08:00
|
|
|
return Sensor::get(SensorType::Map);
|
2020-04-26 11:06:28 -07:00
|
|
|
case GPPWM_Clt:
|
|
|
|
return Sensor::get(SensorType::Clt);
|
|
|
|
case GPPWM_Iat:
|
|
|
|
return Sensor::get(SensorType::Iat);
|
2022-10-17 18:21:23 -07:00
|
|
|
case GPPWM_LuaGauge1:
|
|
|
|
return Sensor::get(SensorType::LuaGauge1);
|
|
|
|
case GPPWM_LuaGauge2:
|
|
|
|
return Sensor::get(SensorType::LuaGauge2);
|
2020-07-23 02:51:08 -07:00
|
|
|
case GPPWM_FuelLoad:
|
2021-11-16 01:15:29 -08:00
|
|
|
return getFuelingLoad();
|
2020-07-23 02:51:08 -07:00
|
|
|
case GPPWM_IgnLoad:
|
2021-11-16 01:15:29 -08:00
|
|
|
return getIgnitionLoad();
|
2021-03-29 05:57:37 -07:00
|
|
|
case GPPWM_AuxTemp1:
|
|
|
|
return Sensor::get(SensorType::AuxTemp1);
|
|
|
|
case GPPWM_AuxTemp2:
|
|
|
|
return Sensor::get(SensorType::AuxTemp2);
|
2021-05-28 00:38:45 -07:00
|
|
|
case GPPWM_AccelPedal:
|
|
|
|
return Sensor::get(SensorType::AcceleratorPedal);
|
2021-07-31 18:20:19 -07:00
|
|
|
case GPPWM_Vbatt:
|
|
|
|
return Sensor::get(SensorType::BatteryVoltage);
|
2022-12-17 11:43:51 -08:00
|
|
|
#if EFI_SHAFT_POSITION_INPUT
|
2022-09-16 13:04:03 -07:00
|
|
|
case GPPWM_VVT_1I:
|
|
|
|
return engine->triggerCentral.getVVTPosition(/*bankIndex*/0, /*camIndex*/0);
|
|
|
|
case GPPWM_VVT_1E:
|
|
|
|
return engine->triggerCentral.getVVTPosition(/*bankIndex*/0, /*camIndex*/1);
|
|
|
|
case GPPWM_VVT_2I:
|
|
|
|
return engine->triggerCentral.getVVTPosition(/*bankIndex*/1, /*camIndex*/0);
|
|
|
|
case GPPWM_VVT_2E:
|
|
|
|
return engine->triggerCentral.getVVTPosition(/*bankIndex*/1, /*camIndex*/1);
|
2022-12-17 11:43:51 -08:00
|
|
|
#else
|
|
|
|
case GPPWM_VVT_1I:
|
|
|
|
case GPPWM_VVT_1E:
|
|
|
|
case GPPWM_VVT_2I:
|
|
|
|
case GPPWM_VVT_2E:
|
|
|
|
return 0;
|
|
|
|
#endif // EFI_SHAFT_POSITION_INPUT
|
2022-09-16 13:04:03 -07:00
|
|
|
case GPPWM_EthanolPercent:
|
|
|
|
return Sensor::get(SensorType::FuelEthanolPercent);
|
|
|
|
case GPPWM_AuxLinear1:
|
|
|
|
return Sensor::get(SensorType::AuxLinear1);
|
|
|
|
case GPPWM_AuxLinear2:
|
|
|
|
return Sensor::get(SensorType::AuxLinear2);
|
2022-09-17 18:38:06 -07:00
|
|
|
case GPPWM_GppwmOutput1:
|
|
|
|
return (float)engine->outputChannels.gppwmOutput[0];
|
|
|
|
case GPPWM_GppwmOutput2:
|
|
|
|
return (float)engine->outputChannels.gppwmOutput[1];
|
|
|
|
case GPPWM_GppwmOutput3:
|
|
|
|
return (float)engine->outputChannels.gppwmOutput[2];
|
|
|
|
case GPPWM_GppwmOutput4:
|
|
|
|
return (float)engine->outputChannels.gppwmOutput[3];
|
2023-03-31 22:29:36 -07:00
|
|
|
case GPPWM_DetectedGear:
|
2023-04-30 07:18:24 -07:00
|
|
|
#if EFI_VEHICLE_SPEED
|
2023-04-01 23:08:06 -07:00
|
|
|
return Sensor::get(SensorType::DetectedGear);
|
2023-04-30 07:18:24 -07:00
|
|
|
#else
|
|
|
|
return 0;
|
2023-04-29 22:49:21 -07:00
|
|
|
#endif // EFI_VEHICLE_SPEED
|
2020-04-26 11:06:28 -07:00
|
|
|
}
|
2021-03-29 05:57:37 -07:00
|
|
|
|
|
|
|
return unexpected;
|
2020-04-26 11:06:28 -07:00
|
|
|
}
|
|
|
|
|
2022-09-17 18:38:06 -07:00
|
|
|
float GppwmChannel::setOutput(float result) {
|
2020-04-26 11:06:28 -07:00
|
|
|
// Not init yet, nothing to do.
|
2020-06-11 17:43:26 -07:00
|
|
|
if (!m_config) {
|
2022-09-17 18:38:06 -07:00
|
|
|
return result;
|
2020-04-26 11:06:28 -07:00
|
|
|
}
|
2020-06-11 17:43:26 -07:00
|
|
|
|
|
|
|
if (m_usePwm) {
|
2023-04-11 17:01:34 -07:00
|
|
|
efiAssert(ObdCode::OBD_PCM_Processor_Fault, m_usePwm, "m_usePwm null", 0);
|
2020-06-11 17:43:26 -07:00
|
|
|
m_pwm->setSimplePwmDutyCycle(clampF(0, result / 100.0f, 1));
|
2022-09-17 18:38:06 -07:00
|
|
|
|
|
|
|
return result;
|
2020-06-11 17:43:26 -07:00
|
|
|
} else {
|
2023-04-11 17:01:34 -07:00
|
|
|
efiAssert(ObdCode::OBD_PCM_Processor_Fault, m_output, "m_output null", 0);
|
2021-09-06 04:58:17 -07:00
|
|
|
if (m_config->offBelowDuty > m_config->onAboveDuty) {
|
2023-04-11 17:01:34 -07:00
|
|
|
firmwareError(ObdCode::CUSTOM_ERR_6122, "You can't have off below %d greater than on above %d",
|
2021-09-05 17:16:57 -07:00
|
|
|
m_config->offBelowDuty,
|
2021-09-05 17:18:14 -07:00
|
|
|
m_config->onAboveDuty);
|
2021-09-05 17:16:57 -07:00
|
|
|
}
|
2020-04-26 11:06:28 -07:00
|
|
|
// Apply hysteresis with provided values
|
|
|
|
if (m_state && result < m_config->offBelowDuty) {
|
|
|
|
m_state = false;
|
|
|
|
} else if (!m_state && result > m_config->onAboveDuty) {
|
|
|
|
m_state = true;
|
|
|
|
}
|
|
|
|
|
2020-06-11 17:43:26 -07:00
|
|
|
m_output->setValue(m_state);
|
2022-09-17 18:38:06 -07:00
|
|
|
|
|
|
|
// Return the actual output value with hysteresis
|
|
|
|
return m_state ? 100 : 0;
|
2020-04-26 11:06:28 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-07-01 06:21:18 -07:00
|
|
|
void GppwmChannel::init(bool usePwm, IPwm* pwm, OutputPin* outputPin, const ValueProvider3D* table, const gppwm_channel* config) {
|
2020-04-26 11:06:28 -07:00
|
|
|
m_usePwm = usePwm;
|
|
|
|
m_pwm = pwm;
|
2020-06-11 17:43:26 -07:00
|
|
|
m_output = outputPin;
|
2020-04-26 11:06:28 -07:00
|
|
|
m_table = table;
|
|
|
|
m_config = config;
|
|
|
|
}
|
|
|
|
|
2023-02-06 04:53:31 -08:00
|
|
|
GppwmResult GppwmChannel::getOutput() const {
|
|
|
|
expected<float> xAxisValue = readGppwmChannel(m_config->rpmAxis);
|
|
|
|
expected<float> yAxisValue = readGppwmChannel(m_config->loadAxis);
|
|
|
|
|
|
|
|
GppwmResult result { (float)m_config->dutyIfError, xAxisValue.value_or(0), yAxisValue.value_or(0) };
|
2020-04-26 11:06:28 -07:00
|
|
|
|
|
|
|
// If we couldn't get load axis value, fall back on error value
|
2023-02-06 04:53:31 -08:00
|
|
|
if (!xAxisValue || !yAxisValue) {
|
|
|
|
return result;
|
2020-04-26 11:06:28 -07:00
|
|
|
}
|
|
|
|
|
2023-02-06 04:53:31 -08:00
|
|
|
float resultVal = m_table->getValue(xAxisValue.Value, yAxisValue.Value);
|
2020-04-26 11:06:28 -07:00
|
|
|
|
2023-02-06 04:53:31 -08:00
|
|
|
if (cisnan(result.Result)) {
|
|
|
|
return result;
|
2020-04-26 11:06:28 -07:00
|
|
|
}
|
|
|
|
|
2023-02-06 04:53:31 -08:00
|
|
|
result.Result = resultVal;
|
2020-04-26 11:06:28 -07:00
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2023-02-06 04:53:31 -08:00
|
|
|
GppwmResult GppwmChannel::update() {
|
2020-04-26 11:06:28 -07:00
|
|
|
// Without a config, nothing to do.
|
|
|
|
if (!m_config) {
|
2023-02-06 04:53:31 -08:00
|
|
|
return {};
|
2020-04-26 11:06:28 -07:00
|
|
|
}
|
|
|
|
|
2023-02-06 04:53:31 -08:00
|
|
|
auto output = getOutput();
|
|
|
|
output.Result = setOutput(output.Result);
|
|
|
|
|
|
|
|
return output;
|
2020-04-26 11:06:28 -07:00
|
|
|
}
|