limp ClearReason
This commit is contained in:
parent
d3721823ba
commit
9b38a7d445
|
@ -261,7 +261,8 @@ uint16_t rpmAcceleration;dRPM;"RPM/s",1, 0, 0, 0, 0
|
|||
|
||||
int16_t autoscale m_requested_pump;"DI: Pump Angle";"deg",{1/@@PACK_MULT_ANGLE@@}, 0, 0, 0, 0
|
||||
int16_t autoscale boostControlTarget;"Pump Angle";"deg",{1/@@PACK_MULT_PRESSURE@@}, 0, 0, 0, 0
|
||||
int16_t autoscale unusedHere1111;"Pump Angle";"deg",{1/@@PACK_MULT_PRESSURE@@}, 0, 0, 0, 0
|
||||
int8_t sparkCutReason;"Spark Cut Code";"code",1, 0, 0, 0, 0
|
||||
int8_t fuelCutReason;"Fuel Cut Code";"code",1, 0, 0, 0, 0
|
||||
float fuel_requested_percent;"DI: fuel_requested_percent";"v", 1, 0, 0, 100, 0
|
||||
float fuel_requested_percent_pi;"DI: fuel_requested_percent_pi";"v", 1, 0, 0, 100, 0
|
||||
float m_I_sum_percent;"DI: m_I_sum_percent";"v", 1, 0, 0, 100, 0
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
// this section was generated automatically by rusEFI tool ConfigDefinition.jar based on (unknown script) console/binary/output_channels.txt Wed Jan 05 06:47:26 UTC 2022
|
||||
// this section was generated automatically by rusEFI tool ConfigDefinition.jar based on (unknown script) console/binary/output_channels.txt Sat Jan 08 21:38:58 EST 2022
|
||||
// by class com.rusefi.output.CHeaderConsumer
|
||||
// begin
|
||||
#pragma once
|
||||
|
@ -864,11 +864,17 @@ struct ts_outputs_s {
|
|||
*/
|
||||
scaled_channel<int16_t, 30, 1> boostControlTarget = (int16_t)0;
|
||||
/**
|
||||
* "Pump Angle"
|
||||
deg
|
||||
* "Spark Cut Code"
|
||||
code
|
||||
* offset 338
|
||||
*/
|
||||
scaled_channel<int16_t, 30, 1> unusedHere1111 = (int16_t)0;
|
||||
int8_t sparkCutReason = (int8_t)0;
|
||||
/**
|
||||
* "Fuel Cut Code"
|
||||
code
|
||||
* offset 339
|
||||
*/
|
||||
int8_t fuelCutReason = (int8_t)0;
|
||||
/**
|
||||
* "DI: fuel_requested_percent"
|
||||
v
|
||||
|
@ -920,79 +926,79 @@ struct ts_outputs_s {
|
|||
bool launchActivatePinState : 1 {};
|
||||
/**
|
||||
offset 468 bit 7 */
|
||||
bool unusedBit_178_7 : 1 {};
|
||||
bool unusedBit_179_7 : 1 {};
|
||||
/**
|
||||
offset 468 bit 8 */
|
||||
bool unusedBit_178_8 : 1 {};
|
||||
bool unusedBit_179_8 : 1 {};
|
||||
/**
|
||||
offset 468 bit 9 */
|
||||
bool unusedBit_178_9 : 1 {};
|
||||
bool unusedBit_179_9 : 1 {};
|
||||
/**
|
||||
offset 468 bit 10 */
|
||||
bool unusedBit_178_10 : 1 {};
|
||||
bool unusedBit_179_10 : 1 {};
|
||||
/**
|
||||
offset 468 bit 11 */
|
||||
bool unusedBit_178_11 : 1 {};
|
||||
bool unusedBit_179_11 : 1 {};
|
||||
/**
|
||||
offset 468 bit 12 */
|
||||
bool unusedBit_178_12 : 1 {};
|
||||
bool unusedBit_179_12 : 1 {};
|
||||
/**
|
||||
offset 468 bit 13 */
|
||||
bool unusedBit_178_13 : 1 {};
|
||||
bool unusedBit_179_13 : 1 {};
|
||||
/**
|
||||
offset 468 bit 14 */
|
||||
bool unusedBit_178_14 : 1 {};
|
||||
bool unusedBit_179_14 : 1 {};
|
||||
/**
|
||||
offset 468 bit 15 */
|
||||
bool unusedBit_178_15 : 1 {};
|
||||
bool unusedBit_179_15 : 1 {};
|
||||
/**
|
||||
offset 468 bit 16 */
|
||||
bool unusedBit_178_16 : 1 {};
|
||||
bool unusedBit_179_16 : 1 {};
|
||||
/**
|
||||
offset 468 bit 17 */
|
||||
bool unusedBit_178_17 : 1 {};
|
||||
bool unusedBit_179_17 : 1 {};
|
||||
/**
|
||||
offset 468 bit 18 */
|
||||
bool unusedBit_178_18 : 1 {};
|
||||
bool unusedBit_179_18 : 1 {};
|
||||
/**
|
||||
offset 468 bit 19 */
|
||||
bool unusedBit_178_19 : 1 {};
|
||||
bool unusedBit_179_19 : 1 {};
|
||||
/**
|
||||
offset 468 bit 20 */
|
||||
bool unusedBit_178_20 : 1 {};
|
||||
bool unusedBit_179_20 : 1 {};
|
||||
/**
|
||||
offset 468 bit 21 */
|
||||
bool unusedBit_178_21 : 1 {};
|
||||
bool unusedBit_179_21 : 1 {};
|
||||
/**
|
||||
offset 468 bit 22 */
|
||||
bool unusedBit_178_22 : 1 {};
|
||||
bool unusedBit_179_22 : 1 {};
|
||||
/**
|
||||
offset 468 bit 23 */
|
||||
bool unusedBit_178_23 : 1 {};
|
||||
bool unusedBit_179_23 : 1 {};
|
||||
/**
|
||||
offset 468 bit 24 */
|
||||
bool unusedBit_178_24 : 1 {};
|
||||
bool unusedBit_179_24 : 1 {};
|
||||
/**
|
||||
offset 468 bit 25 */
|
||||
bool unusedBit_178_25 : 1 {};
|
||||
bool unusedBit_179_25 : 1 {};
|
||||
/**
|
||||
offset 468 bit 26 */
|
||||
bool unusedBit_178_26 : 1 {};
|
||||
bool unusedBit_179_26 : 1 {};
|
||||
/**
|
||||
offset 468 bit 27 */
|
||||
bool unusedBit_178_27 : 1 {};
|
||||
bool unusedBit_179_27 : 1 {};
|
||||
/**
|
||||
offset 468 bit 28 */
|
||||
bool unusedBit_178_28 : 1 {};
|
||||
bool unusedBit_179_28 : 1 {};
|
||||
/**
|
||||
offset 468 bit 29 */
|
||||
bool unusedBit_178_29 : 1 {};
|
||||
bool unusedBit_179_29 : 1 {};
|
||||
/**
|
||||
offset 468 bit 30 */
|
||||
bool unusedBit_178_30 : 1 {};
|
||||
bool unusedBit_179_30 : 1 {};
|
||||
/**
|
||||
offset 468 bit 31 */
|
||||
bool unusedBit_178_31 : 1 {};
|
||||
bool unusedBit_179_31 : 1 {};
|
||||
/**
|
||||
* offset 472
|
||||
*/
|
||||
|
@ -1190,4 +1196,4 @@ struct ts_outputs_s {
|
|||
};
|
||||
|
||||
// end
|
||||
// this section was generated automatically by rusEFI tool ConfigDefinition.jar based on (unknown script) console/binary/output_channels.txt Wed Jan 05 06:47:26 UTC 2022
|
||||
// this section was generated automatically by rusEFI tool ConfigDefinition.jar based on (unknown script) console/binary/output_channels.txt Sat Jan 08 21:38:58 EST 2022
|
||||
|
|
|
@ -656,8 +656,8 @@ static void updateFlags() {
|
|||
engine->outputChannels.isFanOn = enginePins.fanRelay.getLogicValue();
|
||||
engine->outputChannels.isFan2On = enginePins.fanRelay2.getLogicValue();
|
||||
engine->outputChannels.isO2HeaterOn = enginePins.o2heater.getLogicValue();
|
||||
engine->outputChannels.isIgnitionEnabledIndicator = engine->limpManager.allowIgnition();
|
||||
engine->outputChannels.isInjectionEnabledIndicator = engine->limpManager.allowInjection();
|
||||
engine->outputChannels.isIgnitionEnabledIndicator = engine->limpManager.allowIgnition().value;
|
||||
engine->outputChannels.isInjectionEnabledIndicator = engine->limpManager.allowInjection().value;
|
||||
engine->outputChannels.isCylinderCleanupActivated = engine->isCylinderCleanupMode;
|
||||
|
||||
#if EFI_LAUNCH_CONTROL
|
||||
|
|
|
@ -398,8 +398,13 @@ void mainTriggerCallback(uint32_t trgEventIndex, efitick_t edgeTimestamp) {
|
|||
return;
|
||||
}
|
||||
|
||||
bool limitedSpark = !engine->limpManager.allowIgnition();
|
||||
bool limitedFuel = !engine->limpManager.allowInjection();
|
||||
LimpState limitedSparkState = engine->limpManager.allowIgnition();
|
||||
engine->outputChannels.sparkCutReason = (int8_t)limitedSparkState.reason;
|
||||
bool limitedSpark = !limitedSparkState.value;
|
||||
|
||||
LimpState limitedFuelState = engine->limpManager.allowInjection();
|
||||
engine->outputChannels.fuelCutReason = (int8_t)limitedFuelState.reason;
|
||||
bool limitedFuel = !limitedFuelState.value;
|
||||
|
||||
#if EFI_LAUNCH_CONTROL
|
||||
if (engine->launchController.isLaunchCondition && !limitedSpark && !limitedFuel) {
|
||||
|
|
|
@ -9,23 +9,23 @@ void LimpManager::updateState(int rpm, efitick_t nowNt) {
|
|||
// User-configured hard RPM limit
|
||||
if (rpm > engineConfiguration->rpmHardLimit) {
|
||||
if (engineConfiguration->cutFuelOnHardLimit) {
|
||||
allowFuel.clear();
|
||||
allowFuel.clear(ClearReason::HardLimit);
|
||||
}
|
||||
|
||||
if (engineConfiguration->cutSparkOnHardLimit) {
|
||||
allowSpark.clear();
|
||||
allowSpark.clear(ClearReason::HardLimit);
|
||||
}
|
||||
}
|
||||
|
||||
// Force fuel limiting on the fault rev limit
|
||||
if (rpm > m_faultRevLimit) {
|
||||
allowFuel.clear();
|
||||
allowFuel.clear(ClearReason::FaultRevLimit);
|
||||
}
|
||||
|
||||
// Limit fuel only on boost pressure (limiting spark bends valves)
|
||||
if (engineConfiguration->boostCutPressure != 0) {
|
||||
if (Sensor::getOrZero(SensorType::Map) > engineConfiguration->boostCutPressure) {
|
||||
allowFuel.clear();
|
||||
allowFuel.clear(ClearReason::BoostCut);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -51,7 +51,7 @@ void LimpManager::updateState(int rpm, efitick_t nowNt) {
|
|||
|
||||
// If time is up, the sensor works, and no pressure, kill the engine.
|
||||
if (isTimedOut && !m_hadOilPressureAfterStart) {
|
||||
allowFuel.clear();
|
||||
allowFuel.clear(ClearReason::OilPressure);
|
||||
}
|
||||
}
|
||||
} else {
|
||||
|
@ -63,7 +63,7 @@ void LimpManager::updateState(int rpm, efitick_t nowNt) {
|
|||
/**
|
||||
* todo: we need explicit clarification on why do we cut fuel but do not cut spark here!
|
||||
*/
|
||||
allowFuel.clear();
|
||||
allowFuel.clear(ClearReason::StopRequested);
|
||||
}
|
||||
|
||||
if (!engine->isMainRelayEnabled()) {
|
||||
|
@ -79,15 +79,15 @@ todo AndreiKA this change breaks 22 unit tests?
|
|||
}
|
||||
|
||||
void LimpManager::etbProblem() {
|
||||
m_allowEtb.clear();
|
||||
m_allowEtb.clear(ClearReason::EtbProblem);
|
||||
setFaultRevLimit(1500);
|
||||
}
|
||||
|
||||
void LimpManager::fatalError() {
|
||||
m_allowEtb.clear();
|
||||
m_allowIgnition.clear();
|
||||
m_allowInjection.clear();
|
||||
m_allowTriggerInput.clear();
|
||||
m_allowEtb.clear(ClearReason::Fatal);
|
||||
m_allowIgnition.clear(ClearReason::Fatal);
|
||||
m_allowInjection.clear(ClearReason::Fatal);
|
||||
m_allowTriggerInput.clear(ClearReason::Fatal);
|
||||
|
||||
setFaultRevLimit(0);
|
||||
}
|
||||
|
@ -106,10 +106,22 @@ bool LimpManager::allowTriggerInput() const {
|
|||
return m_allowTriggerInput;
|
||||
}
|
||||
|
||||
bool LimpManager::allowInjection() const {
|
||||
return m_transientAllowInjection && m_allowInjection;
|
||||
LimpState LimpManager::allowInjection() const {
|
||||
if (!m_allowInjection) {
|
||||
return {false, m_allowInjection.clearReason};
|
||||
}
|
||||
if (!m_transientAllowInjection) {
|
||||
return {false, ClearReason::Fatal};
|
||||
}
|
||||
return {true, ClearReason::None};
|
||||
}
|
||||
|
||||
bool LimpManager::allowIgnition() const {
|
||||
return m_transientAllowIgnition && m_allowIgnition;
|
||||
LimpState LimpManager::allowIgnition() const {
|
||||
if (!m_allowIgnition) {
|
||||
return {false, m_allowIgnition.clearReason};
|
||||
}
|
||||
if (!m_transientAllowIgnition) {
|
||||
return {false, ClearReason::Fatal};
|
||||
}
|
||||
return {true, ClearReason::None};
|
||||
}
|
||||
|
|
|
@ -4,24 +4,52 @@
|
|||
|
||||
#include <cstdint>
|
||||
|
||||
enum class ClearReason : uint8_t {
|
||||
None, // 0
|
||||
Fatal,
|
||||
Settings,
|
||||
HardLimit,
|
||||
FaultRevLimit,
|
||||
BoostCut, // 5
|
||||
OilPressure,
|
||||
StopRequested,
|
||||
EtbProblem,
|
||||
};
|
||||
|
||||
// Only allows clearing the value, but never resetting it.
|
||||
class Clearable {
|
||||
public:
|
||||
Clearable() : m_value(true) {}
|
||||
Clearable(bool value) : m_value(value) {}
|
||||
Clearable(bool value) : m_value(value) {
|
||||
if (!m_value) {
|
||||
clearReason = ClearReason::Settings;
|
||||
}
|
||||
}
|
||||
|
||||
void clear() {
|
||||
void clear(ClearReason clearReason) {
|
||||
m_value = false;
|
||||
this->clearReason = clearReason;
|
||||
}
|
||||
|
||||
operator bool() const {
|
||||
return m_value;
|
||||
}
|
||||
|
||||
ClearReason clearReason = ClearReason::None;
|
||||
private:
|
||||
bool m_value = true;
|
||||
};
|
||||
|
||||
struct LimpState {
|
||||
const bool value;
|
||||
const ClearReason reason;
|
||||
|
||||
// Implicit conversion operator to bool, so you can do things like if (myResult) { ... }
|
||||
constexpr explicit operator bool() const {
|
||||
return value;
|
||||
}
|
||||
};
|
||||
|
||||
class LimpManager {
|
||||
public:
|
||||
// This is called from periodicFastCallback to update internal state
|
||||
|
@ -30,8 +58,8 @@ public:
|
|||
// Other subsystems call these APIs to determine their behavior
|
||||
bool allowElectronicThrottle() const;
|
||||
|
||||
bool allowInjection() const;
|
||||
bool allowIgnition() const;
|
||||
LimpState allowInjection() const;
|
||||
LimpState allowIgnition() const;
|
||||
|
||||
bool allowTriggerInput() const;
|
||||
|
||||
|
|
|
@ -316,6 +316,10 @@ float getOutputValueByName(const char *name) {
|
|||
return engine->outputChannels.m_requested_pump;
|
||||
if (strEqualCaseInsensitive(name, "boostControlTarget"))
|
||||
return engine->outputChannels.boostControlTarget;
|
||||
if (strEqualCaseInsensitive(name, "sparkCutReason"))
|
||||
return engine->outputChannels.sparkCutReason;
|
||||
if (strEqualCaseInsensitive(name, "fuelCutReason"))
|
||||
return engine->outputChannels.fuelCutReason;
|
||||
if (strEqualCaseInsensitive(name, "fuel_requested_percent"))
|
||||
return engine->outputChannels.fuel_requested_percent;
|
||||
if (strEqualCaseInsensitive(name, "fuel_requested_percent_pi"))
|
||||
|
|
|
@ -1064,6 +1064,7 @@ gaugeCategory = VVT
|
|||
vvtTargets4Gauge = vvtTargets4, @@GAUGE_NAME_VVT_TARGET_B2E@@, "deg", -60, 60, -60, -60, 60, 60, 0, 0
|
||||
|
||||
gaugeCategory = Ignition
|
||||
sparkCutReasonGauge = sparkCutReason,"Spark Cut Code", "code", 0.0,0.0, 0.0,0.0, 0.0,0.0, 0,0
|
||||
ignadvGauge = ignitionAdvance, "Ignition timing", "degrees", -100, 100, -999, -999, 999, 999, 1, 1
|
||||
dwellGauge = sparkDwellValue, "Dwell", "mSec", 0, 10, 0.5, 1.0, 6.0, 8.0, 1, 1
|
||||
coilDutyCycleGauge = coilDutyCycle, @@GAUGE_NAME_DWELL_DUTY@@, "%", 0, 110, 0, 0, 90, 100, 1, 1
|
||||
|
@ -1077,6 +1078,7 @@ gaugeCategory = Acceleration Enrichment
|
|||
|
||||
gaugeCategory = Fueling
|
||||
;Name Var Title Units Lo Hi LoD LoW HiW HiD vd ld
|
||||
fuelCutReasonGauge = fuelCutReason,"Fuel Cut Code", "code", 0.0,0.0, 0.0,0.0, 0.0,0.0, 0,0
|
||||
tChargeGauge = tCharge, @@GAUGE_NAME_FUEL_CHARGE_TEMP@@, "C", -40, 140, -15, 1, 95, 110, 1, 1
|
||||
baroCorrectionGauge = baroCorrection,@@GAUGE_NAME_FUEL_BARO_CORR@@, "ratio", 0.5, 1.5, 0.6, 0.7, 1.3, 1.4, 1, 1
|
||||
crankingFuelGauge = crankingFuelMs, @@GAUGE_NAME_FUEL_CRANKING@@, "mg", 0, 100, 0, 0, 100, 100, 3, 1
|
||||
|
|
Loading…
Reference in New Issue