2021-11-24 04:47:51 -08:00
|
|
|
#include "pch.h"
|
|
|
|
|
|
|
|
#include "main_relay.h"
|
|
|
|
|
|
|
|
void MainRelayController::onSlowCallback() {
|
|
|
|
isBenchTest = engine->isInMainRelayBench();
|
|
|
|
|
|
|
|
#if EFI_MAIN_RELAY_CONTROL
|
2022-02-01 21:45:11 -08:00
|
|
|
hasIgnitionVoltage = Sensor::getOrZero(SensorType::BatteryVoltage) > 5;
|
|
|
|
|
|
|
|
if (hasIgnitionVoltage) {
|
|
|
|
m_lastIgnitionTime.reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
delayedShutoffRequested = engine->module<MainRelayController>()->needsDelayedShutoff();
|
|
|
|
|
|
|
|
// Query whether any engine modules want to keep the lights on
|
|
|
|
// todo: fix this amazing C++ lambda magic
|
|
|
|
// delayedShutoffRequested = engine->engineModules.aggregate([](auto& m, bool prev) { return m->needsDelayedShutoff() | prev; }, false);
|
|
|
|
// TODO: delayed shutoff timeout?
|
|
|
|
|
|
|
|
mainRelayState = isBenchTest | hasIgnitionVoltage | delayedShutoffRequested;
|
2021-11-24 04:47:51 -08:00
|
|
|
#else // not EFI_MAIN_RELAY_CONTROL
|
|
|
|
mainRelayState = !isBenchTest;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
enginePins.mainRelay.setValue(mainRelayState);
|
|
|
|
}
|
2021-12-07 18:28:04 -08:00
|
|
|
|
2022-02-01 21:45:11 -08:00
|
|
|
bool MainRelayController::needsDelayedShutoff() {
|
|
|
|
// Prevent main relay from turning off if we had igniton voltage in the past 1 second
|
|
|
|
// 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
|
|
|
}
|