rusefi/firmware/controllers/bench_test.cpp

600 lines
15 KiB
C++
Raw Normal View History

2015-07-10 06:01:56 -07:00
/**
* @file bench_test.cpp
* @brief Utility methods related to bench testing.
2015-07-10 06:01:56 -07:00
*
*
* @date Sep 8, 2013
2020-01-13 18:57:43 -08:00
* @author Andrey Belomutskiy, (c) 2012-2020
2015-07-10 06:01:56 -07:00
*
* This file is part of rusEfi - see http://rusefi.com
*
* rusEfi is free software; you can redistribute it and/or modify it under the terms of
* the GNU General Public License as published by the Free Software Foundation; either
* version 3 of the License, or (at your option) any later version.
*
* rusEfi is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without
* even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with this program.
* If not, see <http://www.gnu.org/licenses/>.
*/
#include "pch.h"
2015-07-10 06:01:56 -07:00
static bool isRunningBench = false;
2023-09-06 05:16:45 -07:00
static OutputPin *outputOnTheBenchTest = nullptr;
bool isRunningBenchTest() {
return isRunningBench;
}
2023-09-06 05:16:45 -07:00
const OutputPin *getOutputOnTheBenchTest() {
return outputOnTheBenchTest;
}
2019-04-12 19:07:03 -07:00
#if EFI_ENGINE_CONTROL
#if !EFI_UNIT_TEST
2015-07-10 06:01:56 -07:00
#include "flash_main.h"
#include "bench_test.h"
2015-07-10 06:01:56 -07:00
#include "main_trigger_callback.h"
#include "periodic_thread_controller.h"
#include "electronic_throttle.h"
#include "electronic_throttle_impl.h"
2020-03-24 16:50:04 -07:00
#include "malfunction_central.h"
#include "trigger_emulator_algo.h"
2023-09-06 05:16:45 -07:00
#include "vvt.h"
2021-03-11 19:42:59 -08:00
#include "microsecond_timer.h"
2019-09-05 07:30:27 -07:00
#if EFI_WIDEBAND_FIRMWARE_UPDATE
#include "rusefi_wideband.h"
2021-03-11 19:42:59 -08:00
#endif // EFI_WIDEBAND_FIRMWARE_UPDATE
#if EFI_PROD_CODE
#include "rusefi.h"
2019-08-03 16:58:38 -07:00
#include "mpu_util.h"
#endif /* EFI_PROD_CODE */
2015-07-10 06:01:56 -07:00
2019-09-05 07:30:27 -07:00
#if (BOARD_TLE8888_COUNT > 0)
#include "gpio/tle8888.h"
2021-03-11 19:42:59 -08:00
#endif // BOARD_TLE8888_COUNT
2019-09-05 07:30:27 -07:00
static scheduling_s benchSchedStart;
static scheduling_s benchSchedEnd;
#define BENCH_MSG "bench"
2022-01-03 16:57:34 -08:00
static void benchOn(OutputPin* output) {
output->setValue(BENCH_MSG, true, /*isForce*/ true);
}
2022-01-03 16:57:34 -08:00
static void benchOff(OutputPin* output) {
#if EFI_PROD_CODE && (BOARD_EXT_GPIOCHIPS > 0)
static char pin_error[64];
brain_pin_diag_e diag = output->getDiag();
2022-01-03 13:46:15 -08:00
if (diag == PIN_INVALID) {
efiPrintf("No Diag on this pin");
2022-01-03 11:21:54 -08:00
} else {
pinDiag2string(pin_error, sizeof(pin_error), diag);
efiPrintf("Diag says %s", pin_error);
}
2022-01-03 13:46:15 -08:00
#endif // EFI_PROD_CODE
output->setValue(BENCH_MSG, false, /*isForce*/ true);
}
static void runBench(OutputPin *output, float onTimeMs, float offTimeMs, int count) {
int onTimeUs = MS2US(maxF(0.1, onTimeMs));
int offTimeUs = MS2US(maxF(0.1, offTimeMs));
if (onTimeUs > TOO_FAR_INTO_FUTURE_US) {
firmwareError(ObdCode::CUSTOM_ERR_BENCH_PARAM, "onTime above limit %dus", TOO_FAR_INTO_FUTURE_US);
return;
}
efiPrintf("Running bench: ON_TIME=%d us OFF_TIME=%d us Counter=%d", onTimeUs, offTimeUs, count);
efiPrintf("output on %s", hwPortname(output->brainPin));
2015-07-10 06:01:56 -07:00
isRunningBench = true;
2023-09-06 05:16:45 -07:00
outputOnTheBenchTest = output;
2023-08-03 17:18:20 -07:00
for (int i = 0; isRunningBench && i < count; i++) {
engine->outputChannels.testBenchIter = i;
efitick_t nowNt = getTimeNowNt();
// start in a short time so the scheduler can precisely schedule the start event
efitick_t startTime = nowNt + US2NT(50);
efitick_t endTime = startTime + US2NT(onTimeUs);
// Schedule both events
engine->executor.scheduleByTimestampNt("bstart", &benchSchedStart, startTime, {benchOn, output});
engine->executor.scheduleByTimestampNt("bend", &benchSchedEnd, endTime, {benchOff, output});
// Wait one full cycle time for the event + delay to happen
chThdSleepMicroseconds(onTimeUs + offTimeUs);
2015-07-10 06:01:56 -07:00
}
/* last */
engine->outputChannels.testBenchIter++;
2022-01-03 11:21:54 -08:00
efiPrintf("Done!");
2023-09-06 05:16:45 -07:00
outputOnTheBenchTest = nullptr;
2015-07-10 06:01:56 -07:00
isRunningBench = false;
}
2023-10-12 09:55:25 -07:00
// todo: migrate to smarter getOutputOnTheBenchTest() approach?
2017-07-24 16:38:00 -07:00
static volatile bool isBenchTestPending = false;
static bool widebandUpdatePending = false;
2023-04-12 19:44:57 -07:00
static float onTimeMs;
static float offTimeMs;
2015-07-10 06:01:56 -07:00
static int count;
static OutputPin* pinX;
static chibios_rt::CounterSemaphore benchSemaphore(0);
static void pinbench(float p_ontimeMs, float p_offtimeMs, int iterations,
OutputPin* pinParam)
{
2023-04-12 19:44:57 -07:00
onTimeMs = p_ontimeMs;
offTimeMs = p_offtimeMs;
#if EFI_SIMULATOR
count = maxI(2, iterations);
#else
count = iterations;
#endif // EFI_SIMULATOR
2015-07-10 06:01:56 -07:00
pinX = pinParam;
// let's signal bench thread to wake up
isBenchTestPending = true;
benchSemaphore.signal();
2015-07-10 06:01:56 -07:00
}
2023-08-03 17:18:20 -07:00
static void cancelBenchTest() {
isRunningBench = false;
}
/*==========================================================================*/
static void doRunFuelInjBench(size_t humanIndex, float onTimeMs, float offTimeMs, int count) {
2023-04-28 18:01:08 -07:00
if (humanIndex < 1 || humanIndex > engineConfiguration->cylindersCount) {
efiPrintf("Invalid index: %d", humanIndex);
2016-03-14 21:01:37 -07:00
return;
}
pinbench(onTimeMs, offTimeMs, count,
&enginePins.injectors[humanIndex - 1]);
2016-03-14 21:01:37 -07:00
}
static void doRunSparkBench(size_t humanIndex, float onTime, float offTime, int count) {
2023-04-28 18:01:08 -07:00
if (humanIndex < 1 || humanIndex > engineConfiguration->cylindersCount) {
efiPrintf("Invalid index: %d", humanIndex);
return;
}
pinbench(onTime, offTime, count, &enginePins.coils[humanIndex - 1]);
}
static void doRunSolenoidBench(size_t humanIndex, float onTime, float offTime, int count) {
if (humanIndex < 1 || humanIndex > TCU_SOLENOID_COUNT) {
efiPrintf("Invalid index: %d", humanIndex);
return;
}
pinbench(onTime, offTime, count, &enginePins.tcuSolenoids[humanIndex - 1]);
}
static void doRunBenchTestLuaOutput(size_t humanIndex, float onTimeMs, float offTimeMs, int count) {
2022-04-23 14:15:34 -07:00
if (humanIndex < 1 || humanIndex > LUA_PWM_COUNT) {
efiPrintf("Invalid index: %d", humanIndex);
return;
}
pinbench(onTimeMs, offTimeMs, count,
&enginePins.luaOutputPins[humanIndex - 1]);
}
2015-07-10 06:01:56 -07:00
/**
* cylinder #2, 5ms ON, 1000ms OFF, repeat 3 times
* fuelInjBenchExt 2 5 1000 3
*/
static void fuelInjBenchExt(float humanIndex, float onTimeMs, float offTimeMs, float count) {
doRunFuelInjBench((int)humanIndex, onTimeMs, offTimeMs, (int)count);
}
/**
* fuelbench 5 1000 2
*/
2023-04-12 19:44:57 -07:00
static void fuelInjBench(float onTimeMs, float offTimeMs, float count) {
fuelInjBenchExt(1, onTimeMs, offTimeMs, count);
}
/**
* sparkbench2 1 5 1000 2
*/
static void sparkBenchExt(float humanIndex, float onTime, float offTimeMs, float count) {
doRunSparkBench((int)humanIndex, onTime, offTimeMs, (int)count);
}
/**
* sparkbench 5 400 2
* 5 ms ON, 400 ms OFF, two times
2015-07-10 06:01:56 -07:00
*/
2023-04-12 19:44:57 -07:00
static void sparkBench(float onTime, float offTimeMs, float count) {
sparkBenchExt(1, onTime, offTimeMs, count);
2015-07-10 06:01:56 -07:00
}
/**
* solenoid #2, 1000ms ON, 1000ms OFF, repeat 3 times
* tcusolbench 2 1000 1000 3
*/
static void tcuSolenoidBench(float humanIndex, float onTime, float offTimeMs, float count) {
doRunSolenoidBench((int)humanIndex, onTime, offTimeMs, (int)count);
}
/**
* channel #1, 5ms ON, 1000ms OFF, repeat 3 times
* fsiobench2 1 5 1000 3
*/
static void luaOutBench2(float humanIndex, float onTime, float offTimeMs, float count) {
doRunBenchTestLuaOutput((int)humanIndex, onTime, offTimeMs, (int)count);
}
2023-04-12 19:44:57 -07:00
static void fanBenchExt(float onTimeMs) {
pinbench(onTimeMs, 100.0, 1, &enginePins.fanRelay);
2017-07-24 17:40:01 -07:00
}
2023-09-06 05:16:45 -07:00
void fanBench() {
2023-10-10 18:29:27 -07:00
fanBenchExt(BENCH_FAN_DURATION);
2015-07-10 06:01:56 -07:00
}
2023-09-06 05:16:45 -07:00
void fan2Bench() {
pinbench(3000.0, 100.0, 1, &enginePins.fanRelay2);
2021-06-23 14:16:11 -07:00
}
2019-01-13 16:41:39 -08:00
/**
* we are blinking for 16 seconds so that one can click the button and walk around to see the light blinking
*/
2023-09-06 05:16:45 -07:00
void milBench() {
pinbench(500.0, 500.0, 16, &enginePins.checkEnginePin);
2015-07-10 06:01:56 -07:00
}
2023-09-06 05:16:45 -07:00
void starterRelayBench() {
2023-10-16 13:04:21 -07:00
pinbench(BENCH_STARTER_DURATION, 100.0, 1, &enginePins.starterControl);
2020-03-29 14:21:17 -07:00
}
static void fuelPumpBenchExt(float durationMs) {
pinbench(durationMs, 100.0, 1,
&enginePins.fuelPumpRelay);
2016-01-07 18:02:35 -08:00
}
2023-09-06 05:16:45 -07:00
void acRelayBench() {
2023-10-16 13:04:21 -07:00
pinbench(BENCH_AC_RELAY_DURATION, 100.0, 1, &enginePins.acRelay);
2019-09-14 14:56:17 -07:00
}
2023-09-06 05:16:45 -07:00
static void mainRelayBench() {
2021-01-10 20:46:50 -08:00
// main relay is usually "ON" via FSIO thus bench testing that one is pretty unusual
engine->mainRelayBenchStart.reset();
}
2023-09-06 05:16:45 -07:00
static void hpfpValveBench() {
pinbench(engineConfiguration->benchTestOnTime, engineConfiguration->benchTestOffTime, engineConfiguration->benchTestCount,
&enginePins.hpfpValve);
2020-11-21 21:09:36 -08:00
}
2023-09-06 05:16:45 -07:00
void fuelPumpBench() {
2023-10-10 18:29:27 -07:00
fuelPumpBenchExt(BENCH_FUEL_PUMP_DURATION);
2015-07-10 06:01:56 -07:00
}
2023-09-06 05:16:45 -07:00
static void vvtValveBench(int vvtIndex) {
#if EFI_VVT_PID
pinbench(engineConfiguration->benchTestOnTime, engineConfiguration->benchTestOffTime, engineConfiguration->benchTestCount,
getVvtOutputPin(vvtIndex));
#endif // EFI_VVT_PID
}
class BenchController : public ThreadController<UTILITY_THREAD_STACK_SIZE> {
2019-02-10 20:54:41 -08:00
public:
BenchController() : ThreadController("BenchTest", PRIO_BENCH_TEST) { }
2019-02-10 20:54:41 -08:00
private:
void ThreadTask() override {
while (true) {
benchSemaphore.wait();
2023-06-30 11:10:05 -07:00
assertStackVoid("Bench", ObdCode::STACK_USAGE_MISC, EXPECTED_REMAINING_STACK);
if (isBenchTestPending) {
isBenchTestPending = false;
runBench(pinX, onTimeMs, offTimeMs, count);
}
if (widebandUpdatePending) {
#if EFI_WIDEBAND_FIRMWARE_UPDATE && EFI_CAN_SUPPORT
updateWidebandFirmware();
#endif
widebandUpdatePending = false;
}
}
2015-07-10 06:01:56 -07:00
}
2019-02-10 20:54:41 -08:00
};
static BenchController instance;
2015-07-10 06:01:56 -07:00
2023-10-08 12:14:42 -07:00
void handleBenchCategory(uint16_t index) {
switch(index) {
2023-09-06 05:16:45 -07:00
case BENCH_VVT0_VALVE:
vvtValveBench(0);
return;
case BENCH_VVT1_VALVE:
vvtValveBench(1);
return;
case BENCH_VVT2_VALVE:
vvtValveBench(2);
return;
case BENCH_VVT3_VALVE:
vvtValveBench(3);
return;
case BENCH_MAIN_RELAY:
mainRelayBench();
return;
case BENCH_HPFP_VALVE:
2020-11-21 21:13:55 -08:00
hpfpValveBench();
return;
case BENCH_FUEL_PUMP:
// cmd_test_fuel_pump
fuelPumpBench();
return;
case BENCH_STARTER_ENABLE_RELAY:
starterRelayBench();
return;
case BENCH_CHECK_ENGINE_LIGHT:
// cmd_test_check_engine_light
milBench();
return;
case BENCH_AC_COMPRESSOR_RELAY:
acRelayBench();
return;
case BENCH_FAN_RELAY:
fanBench();
return;
2021-11-11 17:27:45 -08:00
case BENCH_IDLE_VALVE:
// cmd_test_idle_valve
#if EFI_IDLE_CONTROL
startIdleBench();
#endif /* EFI_IDLE_CONTROL */
return;
case BENCH_FAN_RELAY_2:
2021-06-23 14:16:11 -07:00
fan2Bench();
return;
2023-08-03 17:18:20 -07:00
case BENCH_CANCEL:
cancelBenchTest();
return;
default:
criticalError("Unexpected bench function %d", index);
}
}
2019-04-23 20:20:14 -07:00
static void handleCommandX14(uint16_t index) {
2023-03-02 20:33:47 -08:00
// todo: define ts_14_command magic constants and use those in rusefi.input file!
2019-04-23 20:20:14 -07:00
switch (index) {
case TS_GRAB_TPS_CLOSED:
2019-04-29 22:21:09 -07:00
grabTPSIsClosed();
return;
case TS_GRAB_TPS_WOT:
2019-04-29 22:21:09 -07:00
grabTPSIsWideOpen();
return;
2019-09-05 07:30:27 -07:00
// case 4: tps2_closed
// case 5: tps2_wot
case TS_GRAB_PEDAL_UP:
2019-04-30 15:46:39 -07:00
grabPedalIsUp();
return;
case TS_GRAB_PEDAL_WOT:
2019-04-30 15:46:39 -07:00
grabPedalIsWideOpen();
return;
case TS_RESET_TLE8888:
2019-09-05 07:30:27 -07:00
#if (BOARD_TLE8888_COUNT > 0)
Tle8888 big update 1 (#1892) * smart gpio: fix tle8888 direct pin mapping for MRE * MRE: use TLE8888 pins instead of MCU gpios that drives TLE8888 * TLE8888: cleanup * TLE8888: do not reset driver private data on WD/undervoltage reset * TLE8888: diagnostic updates * TLE8888 driver: BIG driver rework * TLE8888: check SPI answers for abnormal states Reply with other than requested register can be a sign of: -Power-On-Reset, then OpStat0 will be replyed -WatchDog reset, then FWDStat1 will be replyed -Invalid communication frame, then Diag0 will be replyed Keep tracking last accessed register and check with the next reply. * TLE8888: debug clean-up * TLE8888: implement spi array write This reduce CS inactive state time between two consequent accesses from 8.8 uS to 1.4 uS * TLE8888: fix PP outputs in OD mode * TLE8888: cleanup register definitions * TLE8888: run separate driver thread for each chip instance Calculating poll interval for few chips become more complex, avoid this running thread for each device. * TLE8888: fix cypress and kinetic compilation Both platforms define its own MAX and cause redifination error if common.h is included in driver. * MRE: update mapping.yaml and fix direct pin mapping for TLE8888 * TLE8888: diagnnostic: disable switch off in case of overcurrent For all output, use current limiting instead * TLE8888: check for overvoltage on OUT8..OUT13 * TLE8888: add TODO note about how to recover from failure condition Currently TLE8888 automaticly recovers only from overcurrent and (may be) overtemperature conditions. Short to bat cause output disable (bit in OECONFIG is reset) and needs driver/host intervention. * TLE8888: save few bytes of RAM * TLE8888: Lada Kalina is test mule for IDLE stepper on TLE8888 Don't forget to enable PP mode for TLE8888 outputs 21..24: uncomment line 1087 in tle8888.c * TLE8888: reorder code, cleanup * TLE8888: mode all debug/statisctic to per-chip struct * TLE8888: rework poll interval calculation * MRE: use TLE8888 pins instead of MCU gpios that drives TLE8888 #2
2020-10-23 09:25:30 -07:00
tle8888_req_init();
2019-09-05 07:30:27 -07:00
#endif
return;
2023-03-02 20:33:47 -08:00
case TS_WRITE_FLASH:
// cmd_write_config
#if EFI_INTERNAL_FLASH
writeToFlashNow();
#endif /* EFI_INTERNAL_FLASH */
return;
#if EFI_EMULATE_POSITION_SENSORS
case 0xD:
enableTriggerStimulator();
return;
case 0xF:
disableTriggerStimulator();
return;
case 0x13:
enableExternalTriggerStimulator();
return;
#endif // EFI_EMULATE_POSITION_SENSORS
#if EFI_ELECTRONIC_THROTTLE_BODY
case TS_ETB_RESET:
#if EFI_PROD_CODE
etbPidReset();
#endif
return;
case 0xE:
etbAutocal(0);
return;
case 0x11:
etbAutocal(1);
return;
case 0xC:
engine->etbAutoTune = true;
return;
case 0x10:
engine->etbAutoTune = false;
2020-07-26 15:24:02 -07:00
#if EFI_TUNER_STUDIO
engine->outputChannels.calibrationMode = (uint8_t)TsCalMode::None;
2020-07-26 15:24:02 -07:00
#endif // EFI_TUNER_STUDIO
return;
#endif
case 0x12:
widebandUpdatePending = true;
benchSemaphore.signal();
return;
2021-08-10 04:11:41 -07:00
case 0x15:
2021-08-10 04:29:55 -07:00
#if EFI_PROD_CODE
2021-08-10 04:11:41 -07:00
extern bool burnWithoutFlash;
burnWithoutFlash = true;
2021-08-10 04:29:55 -07:00
#endif // EFI_PROD_CODE
2021-08-10 04:11:41 -07:00
return;
default:
criticalError("Unexpected bench x14 %d", index);
2019-04-23 20:20:14 -07:00
}
}
extern bool rebootForPresetPending;
static void fatalErrorForPresetApply() {
rebootForPresetPending = true;
firmwareError(ObdCode::OBD_PCM_Processor_Fault,
"\n\nTo complete preset apply:\n"
" 1. Close TunerStudio\n"
" 2. Power cycle ECU\n"
" 3. Open TunerStudio and reconnect\n\n");
}
2019-03-12 17:33:13 -07:00
void executeTSCommand(uint16_t subsystem, uint16_t index) {
efiPrintf("IO test subsystem=%d index=%d", subsystem, index);
2016-03-14 20:01:43 -07:00
bool running = !engine->rpmCalculator.isStopped();
switch (subsystem) {
case TS_CLEAR_WARNINGS:
clearWarnings();
break;
case TS_DEBUG_MODE:
engineConfiguration->debugMode = (debug_mode_e)index;
break;
case TS_IGNITION_CATEGORY:
if (!running) {
doRunSparkBench(index, engineConfiguration->benchTestOnTime,
engineConfiguration->benchTestOffTime, engineConfiguration->benchTestCount);
}
break;
case TS_INJECTOR_CATEGORY:
if (!running) {
doRunFuelInjBench(index, engineConfiguration->benchTestOnTime,
engineConfiguration->benchTestOffTime, engineConfiguration->benchTestCount);
}
break;
2022-08-24 09:02:22 -07:00
case TS_SOLENOID_CATEGORY:
if (!running) {
doRunSolenoidBench(index, 1000.0,
1000.0, engineConfiguration->benchTestCount);
}
break;
2022-08-24 09:02:22 -07:00
case TS_LUA_OUTPUT_CATEGORY:
if (!running) {
doRunBenchTestLuaOutput(index, 4.0,
engineConfiguration->benchTestOffTime, engineConfiguration->benchTestCount);
}
break;
case TS_X14:
2019-04-23 20:20:14 -07:00
handleCommandX14(index);
break;
#if defined(EFI_WIDEBAND_FIRMWARE_UPDATE) && EFI_CAN_SUPPORT
2022-08-24 09:02:22 -07:00
case TS_WIDEBAND:
setWidebandOffset(index);
break;
#endif // EFI_WIDEBAND_FIRMWARE_UPDATE && EFI_CAN_SUPPORT
2022-08-24 09:02:22 -07:00
case TS_BENCH_CATEGORY:
handleBenchCategory(index);
break;
case TS_SET_ENGINE_TYPE:
fatalErrorForPresetApply();
2019-01-20 19:17:06 -08:00
setEngineType(index);
break;
case TS_SET_DEFAULT_ENGINE:
fatalErrorForPresetApply();
2023-06-18 08:05:44 -07:00
setEngineType((int)DEFAULT_ENGINE_TYPE);
break;
case 0x79:
2019-01-05 20:33:04 -08:00
scheduleStopEngine();
break;
case 0xba:
2023-05-24 06:58:22 -07:00
#if EFI_DFU_JUMP
jump_to_bootloader();
2023-05-24 06:58:22 -07:00
#endif /* EFI_DFU_JUMP */
break;
case 0xbb:
2019-06-23 06:46:14 -07:00
#if EFI_PROD_CODE
rebootNow();
#endif /* EFI_PROD_CODE */
break;
#if EFI_USE_OPENBLT
case 0xbc:
/* Jump to OpenBLT if present */
jump_to_openblt();
break;
#endif
default:
criticalError("Unexpected bench subsystem %d %d", subsystem, index);
2016-03-14 21:01:37 -07:00
}
2016-03-14 20:01:43 -07:00
}
2022-01-03 00:35:26 -08:00
void onConfigurationChangeBenchTest() {
// default values if configuration was not specified
if (engineConfiguration->benchTestOnTime == 0) {
engineConfiguration->benchTestOnTime = 4;
}
if (engineConfiguration->benchTestOffTime < 5) {
engineConfiguration->benchTestOffTime = 500;
}
if (engineConfiguration->benchTestCount < 1) {
engineConfiguration->benchTestCount = 3;
}
2022-01-03 00:35:26 -08:00
}
void initBenchTest() {
2015-07-10 06:01:56 -07:00
addConsoleAction("fuelpumpbench", fuelPumpBench);
addConsoleActionF("fuelpumpbench2", fuelPumpBenchExt);
addConsoleActionFFF(CMD_FUEL_BENCH, fuelInjBench);
addConsoleActionFFFF("fuelbench2", fuelInjBenchExt);
addConsoleActionFFF(CMD_SPARK_BENCH, sparkBench);
addConsoleActionFFFF("sparkbench2", sparkBenchExt);
addConsoleActionFFFF("tcusolbench", tcuSolenoidBench);
2021-06-23 14:16:11 -07:00
addConsoleAction(CMD_AC_RELAY_BENCH, acRelayBench);
2021-06-23 14:16:11 -07:00
addConsoleAction(CMD_FAN_BENCH, fanBench);
addConsoleAction(CMD_FAN2_BENCH, fan2Bench);
addConsoleActionF("fanbench2", fanBenchExt);
2021-01-10 17:30:08 -08:00
addConsoleAction("mainrelaybench", mainRelayBench);
#if EFI_WIDEBAND_FIRMWARE_UPDATE && EFI_CAN_SUPPORT
addConsoleAction("update_wideband", []() { widebandUpdatePending = true; });
addConsoleActionI("set_wideband_index", [](int index) { setWidebandOffset(index); });
#endif // EFI_WIDEBAND_FIRMWARE_UPDATE && EFI_CAN_SUPPORT
2015-07-10 06:01:56 -07:00
2020-08-19 18:05:08 -07:00
addConsoleAction(CMD_STARTER_BENCH, starterRelayBench);
addConsoleAction(CMD_MIL_BENCH, milBench);
2020-11-21 21:47:43 -08:00
addConsoleAction(CMD_HPFP_BENCH, hpfpValveBench);
2015-07-10 06:01:56 -07:00
addConsoleActionFFFF("luabench2", luaOutBench2);
2022-07-21 12:17:32 -07:00
instance.start();
2022-01-03 00:35:26 -08:00
onConfigurationChangeBenchTest();
2015-07-10 06:01:56 -07:00
}
#endif /* EFI_UNIT_TEST */
2015-07-10 06:01:56 -07:00
#endif