rusefi/firmware/controllers/limp_manager.h

158 lines
3.3 KiB
C
Raw Normal View History

#pragma once
2022-09-28 19:42:08 -07:00
#include "shutdown_controller.h"
#include <cstdint>
// Keep this list in sync with fuelIgnCutCodeList in rusefi.input!
2022-01-08 19:13:20 -08:00
enum class ClearReason : uint8_t {
None, // 0
Fatal,
Settings,
2022-01-08 19:52:28 -08:00
HardLimit, // 3
2022-01-08 19:13:20 -08:00
FaultRevLimit,
BoostCut, // 5
OilPressure,
2022-01-08 20:10:25 -08:00
StopRequested, // 7
EtbProblem, // 8
LaunchCut, // 9
InjectorDutyCycle, // 10
FloodClear, // 11
EnginePhase, // 12
KickStart, // 13
IgnitionOff, // 14
Lua,
// Keep this list in sync with fuelIgnCutCodeList in rusefi.input!
2022-09-28 19:42:08 -07:00
// todo: add a code generator between ClearReason and fuelIgnCutCodeList in rusefi.input
2022-01-08 19:13:20 -08:00
};
enum class TpsState : uint8_t {
None, // 0
EngineStopped,
TpsError,
PpsError, // 3
IntermittentTps,
PidJitter,
Lua, // 6
Manual,
NotConfigured,
Redundancy, // 9
IntermittentPps,
// keep this list in sync with etbCutCodeList in rusefi.input!
};
// Only allows clearing the value, but never resetting it.
class Clearable {
public:
Clearable() : m_value(true) {}
2022-01-08 19:13:20 -08:00
Clearable(bool value) : m_value(value) {
if (!m_value) {
clearReason = ClearReason::Settings;
}
}
2022-01-08 19:13:20 -08:00
void clear(ClearReason clearReason) {
if (m_value) {
m_value = false;
this->clearReason = clearReason;
}
}
operator bool() const {
return m_value;
}
2022-01-08 19:13:20 -08:00
ClearReason clearReason = ClearReason::None;
private:
bool m_value = true;
};
2022-01-08 19:13:20 -08:00
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 Hysteresis {
public:
// returns true if value > rising, false if value < falling, previous if falling < value < rising.
bool test(float value, float rising, float falling) {
if (value > rising) {
m_state = true;
} else if (value < falling) {
m_state = false;
}
return m_state;
}
private:
bool m_state = false;
};
class LimpManager : public EngineModule {
public:
2022-09-28 19:42:08 -07:00
ShutdownController shutdownController;
// This is called from periodicFastCallback to update internal state
void updateState(int rpm, efitick_t nowNt);
void onFastCallback() override;
void onIgnitionStateChanged(bool ignitionOn) override;
// Other subsystems call these APIs to determine their behavior
bool allowElectronicThrottle() const;
2022-01-08 19:13:20 -08:00
LimpState allowInjection() const;
LimpState allowIgnition() const;
bool allowTriggerInput() const;
void updateRevLimit(int rpm);
angle_t getLimitingTimingRetard() const;
float getLimitingFuelCorrection() const;
// Other subsystems call these APIs to indicate a problem has occurred
2022-11-27 15:17:08 -08:00
void reportEtbProblem();
void fatalError();
private:
void setFaultRevLimit(int limit);
Hysteresis m_revLimitHysteresis;
Hysteresis m_boostCutHysteresis;
Hysteresis m_injectorDutyCutHysteresis;
// Start with no fault rev limit
int32_t m_faultRevLimit = INT32_MAX;
Clearable m_allowEtb;
Clearable m_allowInjection;
Clearable m_allowIgnition;
Clearable m_allowTriggerInput;
2022-01-08 19:52:28 -08:00
Clearable m_transientAllowInjection = true;
Clearable m_transientAllowIgnition = true;
bool m_hadOilPressureAfterStart = false;
// Ignition switch state
bool m_ignitionOn = false;
angle_t m_timingRetard = 0;
float m_fuelCorrection = 1.0f;
// todo: migrate to engineState->desiredRpmLimit to get this variable logged
float m_revLimit;
float m_revLimitLow;
};
LimpManager * getLimpManager();