From e1fb48f9a997b123445024257ced5919daab583c Mon Sep 17 00:00:00 2001 From: rusefillc Date: Tue, 19 Nov 2024 19:07:59 -0500 Subject: [PATCH] LUA script size severely limited #7085 only:uaefi --- firmware/config/boards/hellen/uaefi/board.mk | 2 + firmware/controllers/lua/lua_hooks.cpp | 67 ++++++++------------ unit_tests/tests/lua/test_lua_vin.cpp | 18 ------ 3 files changed, 28 insertions(+), 59 deletions(-) diff --git a/firmware/config/boards/hellen/uaefi/board.mk b/firmware/config/boards/hellen/uaefi/board.mk index 57bf34995d..bf11821d62 100644 --- a/firmware/config/boards/hellen/uaefi/board.mk +++ b/firmware/config/boards/hellen/uaefi/board.mk @@ -30,6 +30,8 @@ include $(BOARDS_DIR)/hellen/hellen-common100.mk # we do not have much Lua RAM, let's drop some fancy functions DDEFS += -DWITH_LUA_CONSUMPTION=FALSE +DDEFS += -DWITH_LUA_PID=FALSE +DDEFS += -DWITH_LUA_STOP_ENGINE=FALSE DDEFS += $(PRIMARY_COMMUNICATION_PORT_USART2) diff --git a/firmware/controllers/lua/lua_hooks.cpp b/firmware/controllers/lua/lua_hooks.cpp index 5a27a8f3ab..b480d3ad4d 100644 --- a/firmware/controllers/lua/lua_hooks.cpp +++ b/firmware/controllers/lua/lua_hooks.cpp @@ -631,29 +631,11 @@ int lua_canRxAddMask(lua_State* l) { } #endif // EFI_CAN_SUPPORT -static int lua_vincpy(lua_State* l) { - luaL_checktype(l, 1, LUA_TTABLE); - size_t sourceIndex = luaL_checknumber(l, 2); - size_t destinationIndex = luaL_checknumber(l, 3); - size_t size = luaL_checknumber(l, 4); - for (size_t i = 0;ivinNumber[sourceIndex + i]); - lua_rawseti(l, 1, destinationIndex + i); - } - return 0; -} - PUBLIC_API_WEAK void boardConfigureLuaHooks(lua_State* lState) { } void configureRusefiLuaHooks(lua_State* lState) { boardConfigureLuaHooks(lState); - LuaClass biQuard(lState, "Biquad"); - biQuard - .ctor() - .fun("filter", &LuaBiQuad::filter) - .fun("configureLowpass", &LuaBiQuad::configureLowpass); - LuaClass luaTimer(lState, "Timer"); luaTimer .ctor() @@ -668,6 +650,17 @@ void configureRusefiLuaHooks(lua_State* lState) { .fun("setTimeout", &LuaSensor::setTimeout) .fun("invalidate", &LuaSensor::invalidate); +#ifndef WITH_LUA_PID +#define WITH_LUA_PID TRUE +#endif + +#if WITH_LUA_PID + LuaClass biQuard(lState, "Biquad"); + biQuard + .ctor() + .fun("filter", &LuaBiQuad::filter) + .fun("configureLowpass", &LuaBiQuad::configureLowpass); + LuaClass luaPid(lState, "Pid"); luaPid .ctor() @@ -683,6 +676,7 @@ void configureRusefiLuaHooks(lua_State* lState) { .fun("setDerivativeFilterLoss", &LuaIndustrialPid::setDerivativeFilterLoss) .fun("setAntiwindupFreq", &LuaIndustrialPid::setAntiwindupFreq) .fun("reset", &LuaIndustrialPid::reset); +#endif configureRusefiLuaUtilHooks(lState); @@ -694,7 +688,7 @@ void configureRusefiLuaHooks(lua_State* lState) { }); #endif // EFI_PROD_CODE && EFI_SHAFT_POSITION_INPUT lua_register(lState, "vin", lua_vin); - lua_register(lState, "vincpy", lua_vincpy); + lua_register(lState, "getAuxAnalog", lua_getAuxAnalog); lua_register(lState, "getSensorByIndex", lua_getSensorByIndex); lua_register(lState, "getSensor", lua_getSensorByName); @@ -718,6 +712,10 @@ void configureRusefiLuaHooks(lua_State* lState) { lua_pushnumber(l, engine->module()->getConsumptionGramPerSecond()); return 1; }); + lua_register(lState, "resetOdometer", [](lua_State*) { + engine->module()->reset(); + return 0; + }); #endif // EFI_VEHICLE_SPEED lua_register(lState, "table3d", [](lua_State* l) { auto humanTableIdx = luaL_checkinteger(l, 1); @@ -887,12 +885,12 @@ void configureRusefiLuaHooks(lua_State* lState) { return 0; }); -#endif // EFI_ELECTRONIC_THROTTLE_BODY -#if EFI_PROD_CODE lua_register(lState, "setEtbDisabled", [](lua_State* l) { engine->engineState.lua.luaDisableEtb = lua_toboolean(l, 1); return 0; }); +#endif // EFI_ELECTRONIC_THROTTLE_BODY +#if EFI_PROD_CODE lua_register(lState, "setIgnDisabled", [](lua_State* l) { engine->engineState.lua.luaIgnCut = lua_toboolean(l, 1); return 0; @@ -996,19 +994,6 @@ void configureRusefiLuaHooks(lua_State* lState) { return 1; }); -#if EFI_VEHICLE_SPEED - lua_register(lState, "getCurrentGear", [](lua_State* l) { - lua_pushinteger(l, Sensor::getOrZero(SensorType::DetectedGear)); - return 1; - }); - - lua_register(lState, "getRpmInGear", [](lua_State* l) { - auto idx = luaL_checkinteger(l, 1); - lua_pushinteger(l, engine->module()->getRpmInGear(idx)); - return 1; - }); -#endif // EFI_VEHICLE_SPEED - #if !EFI_UNIT_TEST lua_register(lState, "startPwm", lua_startPwm); lua_register(lState, "setPwmDuty", lua_setPwmDuty); @@ -1023,6 +1008,12 @@ void configureRusefiLuaHooks(lua_State* lState) { lua_register(lState, "setAirmass", lua_setAirmass); #endif // EFI_ENGINE_CONTROL + +#ifndef WITH_LUA_STOP_ENGINE +#define WITH_LUA_STOP_ENGINE TRUE +#endif + +#if WITH_LUA_STOP_ENGINE lua_register(lState, "isFirmwareError", [](lua_State* l) { lua_pushboolean(l, hasFirmwareError()); return 1; @@ -1043,6 +1034,7 @@ void configureRusefiLuaHooks(lua_State* lState) { return 1; }); #endif // EFI_SHAFT_POSITION_INPUT +#endif // WITH_LUA_STOP_ENGINE #if EFI_CAN_SUPPORT lua_register(lState, "canRxAdd", lua_canRxAdd); @@ -1054,13 +1046,6 @@ void configureRusefiLuaHooks(lua_State* lState) { lua_register(lState, "txCan", lua_txCan); #endif -#if EFI_VEHICLE_SPEED - lua_register(lState, "resetOdometer", [](lua_State*) { - engine->module()->reset(); - return 0; - }); -#endif // EFI_VEHICLE_SPEED - #if EFI_PROD_CODE && HW_HELLEN lua_register(lState, "hellenEnablePower", [](lua_State*) { hellenEnableEn("Lua"); diff --git a/unit_tests/tests/lua/test_lua_vin.cpp b/unit_tests/tests/lua/test_lua_vin.cpp index 430e81a767..571e5135ee 100644 --- a/unit_tests/tests/lua/test_lua_vin.cpp +++ b/unit_tests/tests/lua/test_lua_vin.cpp @@ -21,21 +21,3 @@ TEST(LuaVin, Test) { EXPECT_NEAR_M3(testLuaReturnsNumberOrNil(realdata).value_or(0), 0x47); } - -TEST(LuaVinCpy, Test) { - EngineTestHelper eth(engine_type_e::TEST_CRANK_ENGINE); - - strcpy(engineConfiguration->vinNumber, "GM123"); - - const char* realdata = ARRAY_EQUALS PRINT_ARRAY R"( - - function testFunc() - data = {0, 0, 0, 0, 0} - vincpy(data, 2, 1, 3); - print(arrayToString(data)) - expected = { 0x31, 0x32, 0x33, 0x00, 0x00 } - return equals(data, expected) - end)"; - - EXPECT_NEAR_M3(testLuaReturnsNumberOrNil(realdata).value_or(0), 0); -}