2021-11-24 04:47:51 -08:00
|
|
|
#include "pch.h"
|
|
|
|
|
|
|
|
#include "main_relay.h"
|
|
|
|
|
|
|
|
void MainRelayController::onSlowCallback() {
|
|
|
|
#if EFI_MAIN_RELAY_CONTROL
|
2023-12-12 11:10:57 -08:00
|
|
|
#if defined(IGN_KEY_DIVIDER)
|
|
|
|
if (isAdcChannelValid(engineConfiguration->ignKeyAdcChannel)) {
|
|
|
|
hasIgnitionVoltage = Sensor::getOrZero(SensorType::IgnKeyVoltage) > 5;
|
|
|
|
} else
|
|
|
|
#endif // IGN_KEY_DIVIDER
|
2023-12-10 08:52:39 -08:00
|
|
|
if (engineConfiguration->ignitionKeyDigitalPin != Gpio::Unassigned) {
|
|
|
|
// separate digital input pin just for main relay logic since it's preferred to read voltage from main relay
|
|
|
|
// key-on is usually a bit smaller voltage than main relay but sometimes even 1v off!
|
|
|
|
hasIgnitionVoltage = efiReadPin(engineConfiguration->ignitionKeyDigitalPin);
|
|
|
|
} else {
|
|
|
|
hasIgnitionVoltage = Sensor::getOrZero(SensorType::BatteryVoltage) > 5;
|
|
|
|
}
|
2022-02-01 21:45:11 -08:00
|
|
|
|
|
|
|
if (hasIgnitionVoltage) {
|
|
|
|
m_lastIgnitionTime.reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
// Query whether any engine modules want to keep the lights on
|
2022-02-02 11:57:19 -08:00
|
|
|
delayedShutoffRequested = engine->engineModules.aggregate([](auto& m, bool prev) { return m.needsDelayedShutoff() | prev; }, false);
|
|
|
|
|
2022-02-01 21:45:11 -08:00
|
|
|
// TODO: delayed shutoff timeout?
|
|
|
|
|
2023-10-25 07:22:45 -07:00
|
|
|
mainRelayState = hasIgnitionVoltage | delayedShutoffRequested;
|
2021-11-24 04:47:51 -08:00
|
|
|
#else // not EFI_MAIN_RELAY_CONTROL
|
2023-10-25 07:22:45 -07:00
|
|
|
mainRelayState = true;
|
2021-11-24 04:47:51 -08:00
|
|
|
#endif
|
|
|
|
|
2023-06-15 08:46:28 -07:00
|
|
|
enginePins.mainRelay.setValue("mr", mainRelayState);
|
2021-11-24 04:47:51 -08:00
|
|
|
}
|
2021-12-07 18:28:04 -08:00
|
|
|
|
2022-02-01 21:45:11 -08:00
|
|
|
bool MainRelayController::needsDelayedShutoff() {
|
2023-12-10 08:52:39 -08:00
|
|
|
// Prevent main relay from turning off if we had ignition voltage in the past 1 second
|
2022-02-01 21:45:11 -08:00
|
|
|
// This avoids accidentally killing the car during a transient, for example
|
|
|
|
// right when the starter is engaged.
|
|
|
|
return !m_lastIgnitionTime.hasElapsedSec(1);
|
2021-12-07 18:28:04 -08:00
|
|
|
}
|