GCC Code Coverage Report


Directory: ./
File: firmware/controllers/actuators/main_relay.cpp
Date: 2025-10-24 14:26:41
Coverage Exec Excl Total
Lines: 100.0% 39 0 39
Functions: 100.0% 33 0 33
Branches: 100.0% 4 0 4
Decisions: 100.0% 4 - 4

Line Branch Decision Exec Source
1 #include "pch.h"
2
3 #include "main_relay.h"
4 #include "ignition_controller.h"
5
6 1088 void MainRelayController::onSlowCallback() {
7 1088 hasIgnitionVoltage = isIgnVoltage();
8
9
2/2
✓ Branch 0 taken 86 times.
✓ Branch 1 taken 1002 times.
2/2
✓ Decision 'true' taken 86 times.
✓ Decision 'false' taken 1002 times.
1088 if (hasIgnitionVoltage) {
10 86 m_lastIgnitionTime.reset();
11 }
12
13 #if EFI_MAIN_RELAY_CONTROL
14
2/2
✓ Branch 0 taken 86 times.
✓ Branch 1 taken 1002 times.
2/2
✓ Decision 'true' taken 86 times.
✓ Decision 'false' taken 1002 times.
1088 if (hasIgnitionVoltage) {
15 86 delayedShutoffRequested = false;
16 } else {
17 // Query whether any engine modules want to keep the lights on
18 31062 delayedShutoffRequested = engine->engineModules.aggregate([](auto& m, bool prev) { return m.needsDelayedShutoff() | prev; }, false);
19 }
20 // TODO: delayed shutoff timeout?
21
22 mainRelayState = hasIgnitionVoltage | delayedShutoffRequested;
23 #else // not EFI_MAIN_RELAY_CONTROL
24 mainRelayState = true;
25 #endif
26
27 enginePins.mainRelay.setValue("mr", mainRelayState);
28 }
29
30 1002 bool MainRelayController::needsDelayedShutoff() {
31 // Prevent main relay from turning off if we had ignition voltage in the past 1 second
32 // This avoids accidentally killing the car during a transient, for example
33 // right when the starter is engaged.
34 1002 return !m_lastIgnitionTime.hasElapsedSec(1);
35 }
36