rusefi/firmware/controllers/bench_test.cpp

685 lines
18 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;
}
#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;
#if EFI_SIMULATOR
static int savedPinToggleCounter = 0;
static uint32_t savedDurationsInStateMs[2] = { 0, 0 };
#endif // EFI_SIMULATOR
#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();
if (diag == PIN_UNKNOWN) {
2022-01-03 13:46:15 -08:00
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, bool swapOnOff) {
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, {(swapOnOff ? benchOff : benchOn), output});
engine->executor.scheduleByTimestampNt("bend", &benchSchedEnd, endTime, {(swapOnOff ? benchOn : 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
#if EFI_SIMULATOR
// save the current counters and durations after the test while the pin is still controlled
savedPinToggleCounter = output->pinToggleCounter;
savedDurationsInStateMs[0] = output->durationsInStateMs[0];
savedDurationsInStateMs[1] = output->durationsInStateMs[1];
#endif // EFI_SIMULATOR
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;
static float globalOnTimeMs;
static float globalOffTimeMs;
static int globalCount;
2015-07-10 06:01:56 -07:00
static OutputPin* pinX;
static bool swapOnOff = false;
2015-07-10 06:01:56 -07:00
static chibios_rt::CounterSemaphore benchSemaphore(0);
static void pinbench(float ontimeMs, float offtimeMs, int iterations,
OutputPin* pinParam, bool p_swapOnOff = false)
{
globalOnTimeMs = ontimeMs;
globalOffTimeMs = offtimeMs;
#if EFI_SIMULATOR
globalCount = maxI(2, iterations);
#else
globalCount = iterations;
#endif // EFI_SIMULATOR
2015-07-10 06:01:56 -07:00
pinX = pinParam;
swapOnOff = p_swapOnOff;
// 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
pinbench(BENCH_MAIN_RELAY_DURATION, 100.0, 1, &enginePins.mainRelay, true);
}
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
2023-11-10 16:09:04 -08:00
pinbench(BENCH_VVT_DURATION, 100.0, 1, getVvtOutputPin(vvtIndex));
2023-09-06 05:16:45 -07:00
#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, globalOnTimeMs, globalOffTimeMs, globalCount, swapOnOff);
}
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-18 17:13:35 -07:00
static void auxOutBench(int index) {
// todo!
}
2023-10-31 05:56:16 -07:00
#if EFI_HD_ACR
static void hdAcrBench(int index) {
OutputPin* pin = index == 0 ? &enginePins.harleyAcr : &enginePins.harleyAcr2;
pinbench(BENCH_AC_RELAY_DURATION, 100.0, 1, pin);
}
#endif // EFI_HD_ACR
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;
2023-10-18 17:13:35 -07:00
case BENCH_AUXOUT0:
auxOutBench(0);
return;
case BENCH_AUXOUT1:
auxOutBench(1);
return;
case BENCH_AUXOUT2:
auxOutBench(2);
return;
case BENCH_AUXOUT3:
auxOutBench(3);
return;
case BENCH_AUXOUT4:
auxOutBench(4);
return;
case BENCH_AUXOUT5:
auxOutBench(5);
return;
case BENCH_AUXOUT6:
auxOutBench(6);
return;
case BENCH_AUXOUT7:
auxOutBench(7);
return;
2023-10-31 05:56:16 -07:00
#if EFI_HD_ACR
case HD_ACR:
hdAcrBench(0);
return;
case HD_ACR2:
hdAcrBench(1);
return;
#endif // EFI_HD_ACR
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_MAIN_RELAY:
mainRelayBench();
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);
}
}
int getSavedBenchTestPinStates(uint32_t durationsInStateMs[2]) {
#if EFI_SIMULATOR
durationsInStateMs[0] = savedDurationsInStateMs[0];
durationsInStateMs[1] = savedDurationsInStateMs[1];
return savedPinToggleCounter;
#else
2023-12-01 18:49:22 -08:00
UNUSED(durationsInStateMs);
return 0;
#endif // EFI_SIMULATOR
}
2019-04-23 20:20:14 -07:00
static void handleCommandX14(uint16_t index) {
// todo: define ts_14_command magic constants and use those in tunerstudio.template.ini 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:
2024-01-03 05:34:17 -08:00
#if (BOARD_TLE8888_COUNT > 0)
tle8888_req_init();
#endif
2024-01-03 04:37:00 -08:00
return;
case TS_RESET_MC33810:
2024-03-15 18:04:46 -07:00
#if EFI_PROD_CODE && (BOARD_MC33810_COUNT > 0)
2024-01-03 05:34:17 -08:00
mc33810_req_init();
#endif
2019-09-05 07:30:27 -07:00
return;
2023-03-02 20:33:47 -08:00
case TS_WRITE_FLASH:
// cmd_write_config
2024-01-03 05:34:17 -08:00
#if (EFI_STORAGE_INT_FLASH == TRUE) || (EFI_STORAGE_MFS == TRUE)
writeToFlashNow();
#endif /* (EFI_STORAGE_INT_FLASH == TRUE) || (EFI_STORAGE_MFS == TRUE) */
return;
2024-01-03 05:34:17 -08:00
case TS_TRIGGER_STIMULATOR_ENABLE:
#if EFI_EMULATE_POSITION_SENSORS == TRUE
enableTriggerStimulator();
#endif /* EFI_EMULATE_POSITION_SENSORS == TRUE */
return;
2024-01-03 05:34:17 -08:00
case TS_TRIGGER_STIMULATOR_DISABLE:
#if EFI_EMULATE_POSITION_SENSORS == TRUE
disableTriggerStimulator();
#endif /* EFI_EMULATE_POSITION_SENSORS == TRUE */
return;
2024-01-03 05:34:17 -08:00
case TS_EXTERNAL_TRIGGER_STIMULATOR_ENABLE:
#if EFI_EMULATE_POSITION_SENSORS == TRUE
enableExternalTriggerStimulator();
#endif /* EFI_EMULATE_POSITION_SENSORS == TRUE */
return;
case TS_ETB_RESET:
2024-01-03 05:34:17 -08:00
#if EFI_ELECTRONIC_THROTTLE_BODY == TRUE
#if EFI_PROD_CODE
etbPidReset();
#endif
#endif /* EFI_ELECTRONIC_THROTTLE_BODY == TRUE */
return;
case TS_ETB_AUTOCAL_0:
#if EFI_ELECTRONIC_THROTTLE_BODY == TRUE
etbAutocal(0);
#endif /* EFI_ELECTRONIC_THROTTLE_BODY == TRUE */
return;
case TS_ETB_AUTOCAL_1:
#if EFI_ELECTRONIC_THROTTLE_BODY == TRUE
etbAutocal(1);
#endif /* EFI_ELECTRONIC_THROTTLE_BODY == TRUE */
return;
case TS_ETB_START_AUTOTUNE:
#if EFI_ELECTRONIC_THROTTLE_BODY == TRUE
engine->etbAutoTune = true;
#endif /* EFI_ELECTRONIC_THROTTLE_BODY == TRUE */
return;
case TS_ETB_STOP_AUTOTUNE:
#if EFI_ELECTRONIC_THROTTLE_BODY == TRUE
engine->etbAutoTune = false;
#if EFI_TUNER_STUDIO
engine->outputChannels.calibrationMode = (uint8_t)TsCalMode::None;
#endif // EFI_TUNER_STUDIO
#endif /* EFI_ELECTRONIC_THROTTLE_BODY == TRUE */
return;
case TS_WIDEBAND_UPDATE:
widebandUpdatePending = true;
benchSemaphore.signal();
return;
2024-01-03 05:34:17 -08:00
case TS_BURN_WITHOUT_FLASH:
#if EFI_PROD_CODE
#if (EFI_STORAGE_INT_FLASH == TRUE) || (EFI_STORAGE_MFS == TRUE)
extern bool burnWithoutFlash;
burnWithoutFlash = true;
#endif /* (EFI_STORAGE_INT_FLASH == TRUE) || (EFI_STORAGE_MFS == TRUE) */
#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:
2024-03-15 18:04:46 -07:00
#if EFI_PROD_CODE && 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) {
2024-03-15 18:04:46 -07:00
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 */