diff --git a/firmware/console/status_loop.cpp b/firmware/console/status_loop.cpp index 4ded6b32b7..6740a22b5c 100644 --- a/firmware/console/status_loop.cpp +++ b/firmware/console/status_loop.cpp @@ -68,8 +68,6 @@ #include "max31855.h" #endif -extern Engine engine; - // this 'true' value is needed for simulator static volatile bool fullLog = true; int warningEnabled = TRUE; @@ -305,14 +303,14 @@ void updateDevConsoleState(Engine *engine) { * that would be 'show fuel for rpm 3500 maf 4.0' */ -static void showFuelInfo2(float rpm, float engineLoad) { +static void showFuelInfo2(float rpm, float engineLoad, Engine *engine) { float baseFuelMs = getBaseTableFuel(engineConfiguration, (int) rpm, engineLoad); scheduleMsg(&logger2, "algo=%s/pump=%s", getEngine_load_mode_e(engineConfiguration->algorithm), boolToString(getOutputPinValue(FUEL_PUMP_RELAY))); - scheduleMsg(&logger2, "cranking fuel: %f", getCrankingFuel(&engine)); + scheduleMsg(&logger2, "cranking fuel: %f", getCrankingFuel(engine)); - if (engine.rpmCalculator->isRunning()) { + if (engine->rpmCalculator->isRunning()) { float iatCorrection = getIatCorrection(engineConfiguration, getIntakeAirTemperature(engineConfiguration2)); float cltCorrection = getCltCorrection(engineConfiguration, getCoolantTemperature(engineConfiguration2)); float injectorLag = getInjectorLag(engineConfiguration, getVBatt()); @@ -322,13 +320,13 @@ static void showFuelInfo2(float rpm, float engineLoad) { scheduleMsg(&logger2, "iatCorrection=%f cltCorrection=%f injectorLag=%f", iatCorrection, cltCorrection, injectorLag); - float value = getRunningFuel(baseFuelMs, &engine, (int) rpm); + float value = getRunningFuel(baseFuelMs, engine, (int) rpm); scheduleMsg(&logger2, "injection pulse width: %f", value); } } -static void showFuelInfo(void) { - showFuelInfo2((float) getRpm(), getEngineLoad()); +static void showFuelInfo(Engine *engine) { + showFuelInfo2((float) getRpmE(engine), getEngineLoadT(engine), engine); } #endif /* EFI_PROD_CODE */ @@ -412,7 +410,7 @@ static void tsStatusThread(Engine *engine) { } } -void initStatusLoop(void) { +void initStatusLoop(Engine *engine) { #if EFI_PROD_CODE || EFI_SIMULATOR initLoggingExt(&logger, "status loop", LOGGING_BUFFER, sizeof(LOGGING_BUFFER)); #endif /* EFI_PROD_CODE || EFI_SIMULATOR */ @@ -424,8 +422,8 @@ void initStatusLoop(void) { #if EFI_PROD_CODE initLogging(&logger2, "main event handler"); - addConsoleActionFF("fuelinfo2", showFuelInfo2); - addConsoleAction("fuelinfo", showFuelInfo); + addConsoleActionFFP("fuelinfo2", (VoidFloatFloatVoidPtr)showFuelInfo2, engine); + addConsoleActionP("fuelinfo", (VoidPtr)showFuelInfo, engine); addConsoleAction("status", printStatus); #endif /* EFI_PROD_CODE */ diff --git a/firmware/console/status_loop.h b/firmware/console/status_loop.h index cefe32d0c9..010f39a171 100644 --- a/firmware/console/status_loop.h +++ b/firmware/console/status_loop.h @@ -14,6 +14,7 @@ void updateDevConsoleState(Engine *engine); void printSensors(Engine *engine); void printState(Engine *engine, int currentCkpEventCounter); void startStatusThreads(Engine *engine); +void initStatusLoop(Engine *engine); #endif /* __cplusplus */ @@ -22,7 +23,6 @@ extern "C" { #endif /* __cplusplus */ -void initStatusLoop(void); bool getFullLog(void); void setFullLog(int value); void sayOsHello(void); diff --git a/firmware/rusefi.cpp b/firmware/rusefi.cpp index 4969602d87..3798c4c6c6 100644 --- a/firmware/rusefi.cpp +++ b/firmware/rusefi.cpp @@ -168,7 +168,7 @@ void runRusEfi(void) { */ initHardware(&logging, &engine); - initStatusLoop(); + initStatusLoop(&engine); /** * Now let's initialize actual engine control logic * todo: should we initialize some? most? controllers before hardware? diff --git a/firmware/util/cli_registry.c b/firmware/util/cli_registry.c index edc9eb405a..4faa6bf62a 100644 --- a/firmware/util/cli_registry.c +++ b/firmware/util/cli_registry.c @@ -313,7 +313,7 @@ void handleActionWithParameter(TokenCallback *current, char *parameter) { return; } - if (current->parameterType == FLOAT_FLOAT_PARAMETER) { + if (current->parameterType == FLOAT_FLOAT_PARAMETER || current->parameterType == FLOAT_FLOAT_PARAMETER_P) { int spaceIndex = findEndOfToken(parameter); if (spaceIndex == -1) return; @@ -321,8 +321,13 @@ void handleActionWithParameter(TokenCallback *current, char *parameter) { float value1 = atoff(parameter); parameter += spaceIndex + 1; float value2 = atoff(parameter); - VoidFloatFloat callbackS = (VoidFloatFloat) current->callback; - (*callbackS)(value1, value2); + if (current->parameterType == FLOAT_FLOAT_PARAMETER) { + VoidFloatFloat callbackS = (VoidFloatFloat) current->callback; + (*callbackS)(value1, value2); + } else { + VoidFloatFloatVoidPtr callbackS = (VoidFloatFloatVoidPtr) current->callback; + (*callbackS)(value1, value2, current->param); + } return; } diff --git a/win32_functional_tests/simulator/rusEfiFunctionalTest.cpp b/win32_functional_tests/simulator/rusEfiFunctionalTest.cpp index 3638624820..c39c00eb4b 100644 --- a/win32_functional_tests/simulator/rusEfiFunctionalTest.cpp +++ b/win32_functional_tests/simulator/rusEfiFunctionalTest.cpp @@ -73,7 +73,7 @@ void rusEfiFunctionalTest(void) { initFakeBoard(); - initStatusLoop(); + initStatusLoop(&engine); initDataStructures(engineConfiguration); engine.engineConfiguration = engineConfiguration;