2021-07-25 22:05:17 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2021-10-24 05:37:04 -07:00
|
|
|
#include "rusefi_lua.h"
|
2021-04-28 19:41:25 -07:00
|
|
|
#include "lua_hooks.h"
|
|
|
|
|
2021-07-15 21:49:14 -07:00
|
|
|
#include "fuel_math.h"
|
|
|
|
#include "airmass.h"
|
|
|
|
#include "lua_airmass.h"
|
2021-12-13 16:46:41 -08:00
|
|
|
#include "value_lookup.h"
|
2022-08-21 12:22:22 -07:00
|
|
|
#include "can_filter.h"
|
2021-12-08 12:35:39 -08:00
|
|
|
#if EFI_CAN_SUPPORT || EFI_UNIT_TEST
|
2021-07-16 11:06:26 -07:00
|
|
|
#include "can_msg_tx.h"
|
2021-12-08 12:35:39 -08:00
|
|
|
#endif // EFI_CAN_SUPPORT
|
2021-08-21 21:00:20 -07:00
|
|
|
#include "settings.h"
|
2021-09-03 17:21:39 -07:00
|
|
|
#include <new>
|
2021-11-12 19:10:05 -08:00
|
|
|
|
|
|
|
// We don't want to try and use the STL on a microcontroller
|
|
|
|
#define LUAAA_WITHOUT_CPP_STDLIB
|
2021-09-03 17:21:39 -07:00
|
|
|
#include "luaaa.hpp"
|
2021-11-02 20:27:48 -07:00
|
|
|
#include "lua_hooks_util.h"
|
2021-09-03 17:21:39 -07:00
|
|
|
using namespace luaaa;
|
2021-04-29 19:22:04 -07:00
|
|
|
|
2022-07-14 04:52:58 -07:00
|
|
|
#include "script_impl.h"
|
2022-10-28 16:51:56 -07:00
|
|
|
#include "trigger_emulator_algo.h"
|
2021-04-29 19:22:04 -07:00
|
|
|
|
2022-04-16 18:23:37 -07:00
|
|
|
#if EFI_PROD_CODE
|
|
|
|
#include "electronic_throttle_impl.h"
|
2022-10-22 19:46:37 -07:00
|
|
|
#endif // EFI_PROD_CODE
|
|
|
|
|
|
|
|
#if EFI_SENT_SUPPORT
|
|
|
|
#include "sent.h"
|
|
|
|
#endif // EFI_SENT_SUPPORT
|
2022-04-16 18:23:37 -07:00
|
|
|
|
2022-10-04 18:12:51 -07:00
|
|
|
static int lua_vin(lua_State* l) {
|
|
|
|
auto zeroBasedCharIndex = luaL_checkinteger(l, 1);
|
2022-10-05 15:26:12 -07:00
|
|
|
if (zeroBasedCharIndex < 0 || zeroBasedCharIndex > VIN_NUMBER_SIZE) {
|
|
|
|
lua_pushnil(l);
|
|
|
|
} else {
|
|
|
|
char value = engineConfiguration->vinNumber[zeroBasedCharIndex];
|
|
|
|
lua_pushnumber(l, value);
|
|
|
|
}
|
2022-10-04 18:12:51 -07:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2021-08-21 21:00:20 -07:00
|
|
|
static int lua_readpin(lua_State* l) {
|
|
|
|
auto msg = luaL_checkstring(l, 1);
|
2021-08-21 22:41:54 -07:00
|
|
|
#if EFI_PROD_CODE
|
2021-08-31 08:37:43 -07:00
|
|
|
brain_pin_e pin = parseBrainPin(msg);
|
2022-04-28 14:32:39 -07:00
|
|
|
if (!isBrainPinValid(pin)) {
|
2021-08-31 08:37:43 -07:00
|
|
|
lua_pushnil(l);
|
|
|
|
} else {
|
|
|
|
int physicalValue = palReadPad(getHwPort("read", pin), getHwPin("read", pin));
|
|
|
|
lua_pushnumber(l, physicalValue);
|
|
|
|
}
|
2021-08-21 21:00:20 -07:00
|
|
|
#endif
|
2021-08-31 08:37:43 -07:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2021-09-02 07:46:15 -07:00
|
|
|
static int getSensor(lua_State* l, SensorType type) {
|
|
|
|
auto result = Sensor::get(type);
|
2021-04-28 19:41:25 -07:00
|
|
|
|
|
|
|
if (result) {
|
|
|
|
// return value if valid
|
|
|
|
lua_pushnumber(l, result.Value);
|
|
|
|
} else {
|
|
|
|
// return nil if invalid
|
|
|
|
lua_pushnil(l);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2021-09-02 07:46:15 -07:00
|
|
|
static int lua_getAuxAnalog(lua_State* l) {
|
2021-11-10 16:24:17 -08:00
|
|
|
// todo: shall we use HUMAN_INDEX since UI goes from 1 and Lua loves going from 1?
|
2021-11-14 13:29:46 -08:00
|
|
|
auto zeroBasedSensorIndex = luaL_checkinteger(l, 1);
|
2021-09-02 07:46:15 -07:00
|
|
|
|
2022-09-19 09:32:45 -07:00
|
|
|
auto type = static_cast<SensorType>(zeroBasedSensorIndex + static_cast<int>(SensorType::AuxAnalog1));
|
2021-09-02 07:46:15 -07:00
|
|
|
|
|
|
|
return getSensor(l, type);
|
|
|
|
}
|
|
|
|
|
2021-10-21 11:33:59 -07:00
|
|
|
static int lua_getSensorByIndex(lua_State* l) {
|
2021-11-14 13:29:46 -08:00
|
|
|
auto zeroBasedSensorIndex = luaL_checkinteger(l, 1);
|
2021-09-02 07:46:15 -07:00
|
|
|
|
2021-11-14 13:29:46 -08:00
|
|
|
return getSensor(l, static_cast<SensorType>(zeroBasedSensorIndex));
|
2021-09-02 07:46:15 -07:00
|
|
|
}
|
|
|
|
|
2022-07-27 02:41:21 -07:00
|
|
|
static SensorType findSensorByName(lua_State* l, const char* name) {
|
|
|
|
SensorType type = findSensorTypeByName(name);
|
|
|
|
|
|
|
|
if (l && type == SensorType::Invalid) {
|
|
|
|
luaL_error(l, "Invalid sensor type: %s", name);
|
|
|
|
}
|
|
|
|
|
|
|
|
return type;
|
|
|
|
}
|
|
|
|
|
2021-10-21 11:33:59 -07:00
|
|
|
static int lua_getSensorByName(lua_State* l) {
|
|
|
|
auto sensorName = luaL_checklstring(l, 1, nullptr);
|
2022-07-27 02:41:21 -07:00
|
|
|
SensorType type = findSensorByName(l, sensorName);
|
2021-10-21 11:33:59 -07:00
|
|
|
|
|
|
|
return getSensor(l, type);
|
|
|
|
}
|
|
|
|
|
2021-04-29 19:22:04 -07:00
|
|
|
static int lua_getSensorRaw(lua_State* l) {
|
2021-11-14 13:29:46 -08:00
|
|
|
auto zeroBasedSensorIndex = luaL_checkinteger(l, 1);
|
2021-04-29 19:22:04 -07:00
|
|
|
|
2021-11-14 13:29:46 -08:00
|
|
|
lua_pushnumber(l, Sensor::getRaw(static_cast<SensorType>(zeroBasedSensorIndex)));
|
2021-04-29 19:22:04 -07:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int lua_hasSensor(lua_State* l) {
|
2021-11-14 13:29:46 -08:00
|
|
|
auto zeroBasedSensorIndex = luaL_checkinteger(l, 1);
|
2021-04-29 19:22:04 -07:00
|
|
|
|
2021-11-14 13:29:46 -08:00
|
|
|
lua_pushboolean(l, Sensor::hasSensor(static_cast<SensorType>(zeroBasedSensorIndex)));
|
2021-04-29 19:22:04 -07:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
2022-07-08 23:59:47 -07:00
|
|
|
/**
|
|
|
|
* @return number of elements
|
|
|
|
*/
|
2021-11-22 11:19:19 -08:00
|
|
|
static uint32_t getArray(lua_State* l, int paramIndex, uint8_t *data, uint32_t size) {
|
|
|
|
uint32_t result = 0;
|
|
|
|
|
|
|
|
luaL_checktype(l, paramIndex, LUA_TTABLE);
|
|
|
|
while (true) {
|
|
|
|
lua_pushnumber(l, result + 1);
|
|
|
|
auto elementType = lua_gettable(l, paramIndex);
|
|
|
|
auto val = lua_tonumber(l, -1);
|
|
|
|
lua_pop(l, 1);
|
|
|
|
|
|
|
|
if (elementType == LUA_TNIL) {
|
|
|
|
// we're done, this is the end of the array.
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (elementType != LUA_TNUMBER) {
|
|
|
|
// We're not at the end, but this isn't a number!
|
|
|
|
luaL_error(l, "Unexpected data at position %d: %s", result, lua_tostring(l, -1));
|
|
|
|
}
|
|
|
|
|
|
|
|
// This element is valid, increment DLC
|
|
|
|
result++;
|
|
|
|
|
|
|
|
if (result > size) {
|
|
|
|
luaL_error(l, "Input array longer than buffer");
|
|
|
|
}
|
|
|
|
|
|
|
|
data[result - 1] = val;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2021-12-08 12:35:39 -08:00
|
|
|
#if EFI_CAN_SUPPORT || EFI_UNIT_TEST
|
2022-08-21 20:48:10 -07:00
|
|
|
|
|
|
|
static int validateCanChannelAndConvertFromHumanIntoZeroIndex(lua_State* l) {
|
|
|
|
lua_Integer channel = luaL_checkinteger(l, 1);
|
2021-07-16 11:06:26 -07:00
|
|
|
// TODO: support multiple channels
|
2022-08-21 20:48:10 -07:00
|
|
|
luaL_argcheck(l, channel == 1 || channel == 2, 1, "only buses 1 and 2 currently supported");
|
|
|
|
return channel - HUMAN_OFFSET;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int lua_txCan(lua_State* l) {
|
|
|
|
auto bus = validateCanChannelAndConvertFromHumanIntoZeroIndex(l);
|
2021-07-16 11:06:26 -07:00
|
|
|
|
|
|
|
auto id = luaL_checkinteger(l, 2);
|
|
|
|
auto ext = luaL_checkinteger(l, 3);
|
|
|
|
|
|
|
|
// Check that ID is valid based on std vs. ext
|
|
|
|
if (ext == 0) {
|
|
|
|
luaL_argcheck(l, id <= 0x7FF, 2, "ID specified is greater than max std ID");
|
|
|
|
} else {
|
|
|
|
luaL_argcheck(l, id <= 0x1FFF'FFFF, 2, "ID specified is greater than max ext ID");
|
|
|
|
}
|
|
|
|
|
|
|
|
// conform ext parameter to true/false
|
2022-05-09 13:49:23 -07:00
|
|
|
CanTxMessage msg(CanCategory::LUA, id, 8, ext == 0 ? false : true);
|
2022-08-21 20:48:10 -07:00
|
|
|
msg.busIndex = bus;
|
2021-07-16 11:06:26 -07:00
|
|
|
|
|
|
|
// Unfortunately there is no way to inspect the length of a table,
|
|
|
|
// so we have to just iterate until we run out of numbers
|
|
|
|
uint8_t dlc = 0;
|
|
|
|
|
2021-11-22 11:19:19 -08:00
|
|
|
// todo: reduce code duplication with getArray
|
|
|
|
luaL_checktype(l, 4, LUA_TTABLE);
|
2021-07-16 11:06:26 -07:00
|
|
|
while (true) {
|
|
|
|
lua_pushnumber(l, dlc + 1);
|
|
|
|
auto elementType = lua_gettable(l, 4);
|
2021-10-28 05:18:56 -07:00
|
|
|
auto val = lua_tonumber(l, -1);
|
2021-07-16 11:06:26 -07:00
|
|
|
lua_pop(l, 1);
|
|
|
|
|
|
|
|
if (elementType == LUA_TNIL) {
|
|
|
|
// we're done, this is the end of the array.
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (elementType != LUA_TNUMBER) {
|
|
|
|
// We're not at the end, but this isn't a number!
|
|
|
|
luaL_error(l, "Unexpected CAN data at position %d: %s", dlc, lua_tostring(l, -1));
|
|
|
|
}
|
|
|
|
|
|
|
|
// This element is valid, increment DLC
|
|
|
|
dlc++;
|
|
|
|
|
|
|
|
if (dlc > 8) {
|
|
|
|
luaL_error(l, "CAN frame length cannot be longer than 8");
|
|
|
|
}
|
|
|
|
|
|
|
|
msg[dlc - 1] = val;
|
|
|
|
}
|
|
|
|
|
|
|
|
msg.setDlc(dlc);
|
|
|
|
|
|
|
|
// no return value
|
|
|
|
return 0;
|
|
|
|
}
|
2021-12-08 12:35:39 -08:00
|
|
|
#endif // EFI_CAN_SUPPORT
|
2021-07-16 11:06:26 -07:00
|
|
|
|
2021-07-15 21:49:14 -07:00
|
|
|
static LuaAirmass luaAirmass;
|
|
|
|
|
|
|
|
AirmassModelBase& getLuaAirmassModel() {
|
|
|
|
return luaAirmass;
|
|
|
|
}
|
|
|
|
|
2021-04-29 19:22:04 -07:00
|
|
|
#if !EFI_UNIT_TEST
|
2021-05-20 16:01:17 -07:00
|
|
|
static SimplePwm pwms[LUA_PWM_COUNT];
|
|
|
|
|
|
|
|
struct P {
|
|
|
|
SimplePwm& pwm;
|
|
|
|
lua_Integer idx;
|
|
|
|
};
|
|
|
|
|
|
|
|
static P luaL_checkPwmIndex(lua_State* l, int pos) {
|
|
|
|
auto channel = luaL_checkinteger(l, pos);
|
|
|
|
|
2022-08-21 20:48:10 -07:00
|
|
|
// todo: what a mess :( CAN buses start at 1 and PWM channels start at 0 :(
|
2021-05-20 16:01:17 -07:00
|
|
|
// Ensure channel is valid
|
2021-11-14 07:56:38 -08:00
|
|
|
if (channel < 0 || channel >= LUA_PWM_COUNT) {
|
2021-05-20 16:01:17 -07:00
|
|
|
luaL_error(l, "setPwmDuty invalid channel %d", channel);
|
|
|
|
}
|
|
|
|
|
|
|
|
return { pwms[channel], channel };
|
|
|
|
}
|
|
|
|
|
|
|
|
static int lua_startPwm(lua_State* l) {
|
|
|
|
auto p = luaL_checkPwmIndex(l, 1);
|
|
|
|
auto freq = luaL_checknumber(l, 2);
|
2021-11-08 17:48:59 -08:00
|
|
|
auto duty = luaL_checknumber(l, 3);
|
2021-05-20 16:01:17 -07:00
|
|
|
|
|
|
|
// clamp to 1..1000 hz
|
|
|
|
freq = clampF(1, freq, 1000);
|
|
|
|
|
|
|
|
startSimplePwmExt(
|
|
|
|
&p.pwm, "lua", &engine->executor,
|
2022-08-24 10:20:14 -07:00
|
|
|
engineConfiguration->luaOutputPins[p.idx], &enginePins.luaOutputPins[p.idx],
|
2021-05-20 16:01:17 -07:00
|
|
|
freq, duty
|
|
|
|
);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2021-06-28 05:39:03 -07:00
|
|
|
void luaDeInitPins() {
|
|
|
|
// Simply de-init all pins - when the script runs again, they will be re-init'd
|
2022-08-24 10:20:14 -07:00
|
|
|
for (size_t i = 0; i < efi::size(enginePins.luaOutputPins); i++) {
|
|
|
|
enginePins.luaOutputPins[i].deInit();
|
2021-06-28 05:39:03 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-05-20 16:01:17 -07:00
|
|
|
static int lua_setPwmDuty(lua_State* l) {
|
|
|
|
auto p = luaL_checkPwmIndex(l, 1);
|
|
|
|
auto duty = luaL_checknumber(l, 2);
|
|
|
|
|
|
|
|
// clamp to 0..1
|
|
|
|
duty = clampF(0, duty, 1);
|
|
|
|
|
|
|
|
p.pwm.setSimplePwmDutyCycle(duty);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int lua_setPwmFreq(lua_State* l) {
|
|
|
|
auto p = luaL_checkPwmIndex(l, 1);
|
|
|
|
auto freq = luaL_checknumber(l, 2);
|
|
|
|
|
|
|
|
// clamp to 1..1000 hz
|
|
|
|
freq = clampF(1, freq, 1000);
|
|
|
|
|
|
|
|
p.pwm.setFrequency(freq);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2021-04-29 19:22:04 -07:00
|
|
|
static int lua_fan(lua_State* l) {
|
|
|
|
lua_pushboolean(l, enginePins.fanRelay.getLogicValue());
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int lua_getDigital(lua_State* l) {
|
|
|
|
auto idx = luaL_checkinteger(l, 1);
|
|
|
|
|
|
|
|
bool state = false;
|
|
|
|
|
|
|
|
switch (idx) {
|
2022-06-28 23:37:24 -07:00
|
|
|
case 0: state = engine->engineState.clutchDownState; break;
|
2022-08-25 19:24:35 -07:00
|
|
|
case 1: state = engine->engineState.clutchUpState; break;
|
|
|
|
case 2: state = engine->engineState.brakePedalState; break;
|
2022-05-09 03:12:17 -07:00
|
|
|
case 3: state = engine->module<AcController>().unmock().acButtonState; break;
|
2021-04-29 19:22:04 -07:00
|
|
|
default:
|
|
|
|
// Return nil to indicate invalid parameter
|
|
|
|
lua_pushnil(l);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
lua_pushboolean(l, state);
|
|
|
|
return 1;
|
|
|
|
}
|
2021-05-04 07:05:39 -07:00
|
|
|
|
|
|
|
static int lua_setDebug(lua_State* l) {
|
|
|
|
// wrong debug mode, ignore
|
2021-11-17 00:54:21 -08:00
|
|
|
if (engineConfiguration->debugMode != DBG_LUA) {
|
2021-05-04 07:05:39 -07:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
auto idx = luaL_checkinteger(l, 1);
|
|
|
|
auto val = luaL_checknumber(l, 2);
|
|
|
|
|
|
|
|
// invalid index, ignore
|
|
|
|
if (idx < 1 || idx > 7) {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2021-12-07 17:18:47 -08:00
|
|
|
auto firstDebugField = &engine->outputChannels.debugFloatField1;
|
2021-05-04 07:05:39 -07:00
|
|
|
firstDebugField[idx - 1] = val;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2021-05-29 14:54:36 -07:00
|
|
|
|
2021-07-15 21:49:14 -07:00
|
|
|
static auto lua_getAirmassResolveMode(lua_State* l) {
|
|
|
|
if (lua_gettop(l) == 0) {
|
|
|
|
// zero args, return configured mode
|
2021-11-17 00:54:21 -08:00
|
|
|
return engineConfiguration->fuelAlgorithm;
|
2021-07-15 21:49:14 -07:00
|
|
|
} else {
|
|
|
|
return static_cast<engine_load_mode_e>(luaL_checkinteger(l, 1));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static int lua_getAirmass(lua_State* l) {
|
|
|
|
auto airmassMode = lua_getAirmassResolveMode(l);
|
|
|
|
auto airmass = getAirmassModel(airmassMode);
|
|
|
|
|
|
|
|
if (!airmass) {
|
|
|
|
return luaL_error(l, "null airmass");
|
|
|
|
}
|
|
|
|
|
2021-10-05 16:59:07 -07:00
|
|
|
auto rpm = Sensor::getOrZero(SensorType::Rpm);
|
2021-07-15 21:49:14 -07:00
|
|
|
auto result = airmass->getAirmass(rpm).CylinderAirmass;
|
|
|
|
|
|
|
|
lua_pushnumber(l, result);
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int lua_setAirmass(lua_State* l) {
|
|
|
|
float airmass = luaL_checknumber(l, 1);
|
|
|
|
float engineLoadPercent = luaL_checknumber(l, 2);
|
|
|
|
|
|
|
|
airmass = clampF(0, airmass, 10);
|
|
|
|
engineLoadPercent = clampF(0, engineLoadPercent, 1000);
|
|
|
|
|
|
|
|
luaAirmass.setAirmass({airmass, engineLoadPercent});
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2021-10-24 05:37:04 -07:00
|
|
|
#endif // EFI_UNIT_TEST
|
2021-10-23 21:18:28 -07:00
|
|
|
|
2022-07-27 02:41:21 -07:00
|
|
|
// TODO: PR this back in to https://github.com/gengyong/luaaa
|
|
|
|
namespace LUAAA_NS {
|
|
|
|
template<typename TCLASS, typename ...ARGS>
|
|
|
|
struct PlacementConstructorCaller<TCLASS, lua_State*, ARGS...>
|
|
|
|
{
|
|
|
|
// this speciailization passes the Lua state to the constructor as first argument, as it shouldn't
|
|
|
|
// participate in the index generation as it's not a normal parameter passed via the Lua stack.
|
|
|
|
|
|
|
|
static TCLASS * Invoke(lua_State * state, void * mem)
|
|
|
|
{
|
|
|
|
return InvokeImpl(state, mem, typename make_indices<sizeof...(ARGS)>::type());
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
template<std::size_t ...Ns>
|
|
|
|
static TCLASS * InvokeImpl(lua_State * state, void * mem, indices<Ns...>)
|
|
|
|
{
|
|
|
|
(void)state;
|
|
|
|
return new(mem) TCLASS(state, LuaStack<ARGS>::get(state, Ns + 1)...);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2021-11-13 00:18:16 -08:00
|
|
|
struct LuaSensor final : public StoredValueSensor {
|
2022-07-27 02:41:21 -07:00
|
|
|
LuaSensor() : LuaSensor(nullptr, "Invalid") { }
|
2021-10-22 13:36:29 -07:00
|
|
|
|
|
|
|
~LuaSensor() {
|
|
|
|
unregister();
|
|
|
|
}
|
|
|
|
|
2022-07-27 02:41:21 -07:00
|
|
|
LuaSensor(lua_State* l, const char* name)
|
|
|
|
: StoredValueSensor(findSensorByName(l, name), MS2NT(100))
|
2021-10-22 13:36:29 -07:00
|
|
|
{
|
2022-07-27 02:41:21 -07:00
|
|
|
// do a soft collision check to avoid a fatal error from the hard check in Register()
|
|
|
|
if (l && Sensor::hasSensor(type())) {
|
|
|
|
luaL_error(l, "Tried to create a Lua sensor of type %s, but one was already registered.", getSensorName());
|
|
|
|
} else {
|
|
|
|
Register();
|
|
|
|
efiPrintf("LUA registered sensor of type %s", getSensorName());
|
|
|
|
}
|
2021-10-22 13:36:29 -07:00
|
|
|
}
|
|
|
|
|
2022-10-26 06:29:04 -07:00
|
|
|
bool isRedundant() const override {
|
|
|
|
return m_isRedundant;
|
|
|
|
}
|
|
|
|
|
2022-11-06 17:08:25 -08:00
|
|
|
// do we need method defined exactly on LuaSensor for Luaa to be happy?
|
|
|
|
void setTimeout(int timeoutMs) override {
|
|
|
|
StoredValueSensor::setTimeout(timeoutMs);
|
|
|
|
}
|
|
|
|
|
2022-10-26 06:29:04 -07:00
|
|
|
void setRedundant(bool value) {
|
|
|
|
m_isRedundant = value;
|
|
|
|
}
|
|
|
|
|
2021-10-22 13:36:29 -07:00
|
|
|
void set(float value) {
|
|
|
|
setValidValue(value, getTimeNowNt());
|
|
|
|
}
|
|
|
|
|
|
|
|
void invalidate() {
|
|
|
|
StoredValueSensor::invalidate();
|
|
|
|
}
|
|
|
|
|
|
|
|
void showInfo(const char*) const {}
|
2022-10-26 06:29:04 -07:00
|
|
|
private:
|
|
|
|
bool m_isRedundant = false;
|
2021-10-22 13:36:29 -07:00
|
|
|
};
|
|
|
|
|
2021-11-13 00:18:16 -08:00
|
|
|
struct LuaPid final {
|
|
|
|
LuaPid() = default;
|
|
|
|
|
|
|
|
LuaPid(float kp, float ki, float kd, float min, float max)
|
2021-11-07 06:49:47 -08:00
|
|
|
: m_pid(&m_params)
|
|
|
|
{
|
2021-11-13 00:18:16 -08:00
|
|
|
m_params.pFactor = kp;
|
|
|
|
m_params.iFactor = ki;
|
|
|
|
m_params.dFactor = kd;
|
2021-11-07 06:49:47 -08:00
|
|
|
|
|
|
|
m_params.offset = 0;
|
|
|
|
m_params.periodMs = 0;
|
2021-11-13 00:18:16 -08:00
|
|
|
m_params.minValue = min;
|
|
|
|
m_params.maxValue = max;
|
2021-11-07 06:49:47 -08:00
|
|
|
|
|
|
|
m_lastUpdate.reset();
|
|
|
|
}
|
|
|
|
|
2021-11-13 00:18:16 -08:00
|
|
|
float get(float target, float input) {
|
2021-11-07 06:49:47 -08:00
|
|
|
#if EFI_UNIT_TEST
|
|
|
|
extern int timeNowUs;
|
|
|
|
// this is how we avoid zero dt
|
|
|
|
timeNowUs += 1000;
|
|
|
|
#endif
|
2021-11-13 00:18:16 -08:00
|
|
|
|
2021-11-07 06:49:47 -08:00
|
|
|
float dt = m_lastUpdate.getElapsedSecondsAndReset(getTimeNowNt());
|
|
|
|
|
|
|
|
return m_pid.getOutput(target, input, dt);
|
|
|
|
}
|
|
|
|
|
2022-07-14 13:41:50 -07:00
|
|
|
void setOffset(float offset) {
|
|
|
|
m_params.offset = offset;
|
|
|
|
reset();
|
|
|
|
}
|
|
|
|
|
2021-11-07 06:49:47 -08:00
|
|
|
void reset() {
|
|
|
|
m_pid.reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
Pid m_pid;
|
|
|
|
Timer m_lastUpdate;
|
|
|
|
pid_s m_params;
|
|
|
|
};
|
|
|
|
|
2022-07-27 23:27:18 -07:00
|
|
|
static bool isFunction(lua_State* l, int idx) {
|
|
|
|
return lua_type(l, idx) == LUA_TFUNCTION;
|
|
|
|
}
|
|
|
|
|
|
|
|
int getLuaFunc(lua_State* l) {
|
|
|
|
if (!isFunction(l, 1)) {
|
|
|
|
return luaL_error(l, "expected function");
|
|
|
|
} else {
|
|
|
|
return luaL_ref(l, LUA_REGISTRYINDEX);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#if EFI_CAN_SUPPORT
|
|
|
|
int lua_canRxAdd(lua_State* l) {
|
|
|
|
uint32_t eid;
|
|
|
|
|
|
|
|
// defaults if not passed
|
2022-08-21 12:22:22 -07:00
|
|
|
int bus = ANY_BUS;
|
2022-08-21 19:46:49 -07:00
|
|
|
int callback = NO_CALLBACK;
|
2022-07-27 23:27:18 -07:00
|
|
|
|
|
|
|
switch (lua_gettop(l)) {
|
|
|
|
case 1:
|
|
|
|
// handle canRxAdd(id)
|
|
|
|
eid = luaL_checkinteger(l, 1);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 2:
|
|
|
|
if (isFunction(l, 2)) {
|
|
|
|
// handle canRxAdd(id, callback)
|
|
|
|
eid = luaL_checkinteger(l, 1);
|
|
|
|
lua_remove(l, 1);
|
|
|
|
callback = getLuaFunc(l);
|
|
|
|
} else {
|
|
|
|
// handle canRxAdd(bus, id)
|
2022-08-21 20:48:10 -07:00
|
|
|
bus = validateCanChannelAndConvertFromHumanIntoZeroIndex(l);
|
2022-07-27 23:27:18 -07:00
|
|
|
eid = luaL_checkinteger(l, 2);
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
// handle canRxAdd(bus, id, callback)
|
2022-08-21 20:48:10 -07:00
|
|
|
bus = validateCanChannelAndConvertFromHumanIntoZeroIndex(l);
|
2022-07-27 23:27:18 -07:00
|
|
|
eid = luaL_checkinteger(l, 2);
|
|
|
|
lua_remove(l, 1);
|
|
|
|
lua_remove(l, 1);
|
|
|
|
callback = getLuaFunc(l);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return luaL_error(l, "Wrong number of arguments to canRxAdd. Got %d, expected 1, 2, or 3.");
|
|
|
|
}
|
|
|
|
|
2022-08-21 12:22:22 -07:00
|
|
|
addLuaCanRxFilter(eid, FILTER_SPECIFIC, bus, callback);
|
2022-07-27 23:27:18 -07:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int lua_canRxAddMask(lua_State* l) {
|
|
|
|
uint32_t eid;
|
|
|
|
uint32_t mask;
|
|
|
|
|
|
|
|
// defaults if not passed
|
2022-08-21 12:22:22 -07:00
|
|
|
int bus = ANY_BUS;
|
2022-08-21 19:46:49 -07:00
|
|
|
int callback = NO_CALLBACK;
|
2022-07-27 23:27:18 -07:00
|
|
|
|
|
|
|
switch (lua_gettop(l)) {
|
|
|
|
case 2:
|
|
|
|
// handle canRxAddMask(id, mask)
|
|
|
|
eid = luaL_checkinteger(l, 1);
|
|
|
|
mask = luaL_checkinteger(l, 2);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 3:
|
|
|
|
if (isFunction(l, 3)) {
|
|
|
|
// handle canRxAddMask(id, mask, callback)
|
|
|
|
eid = luaL_checkinteger(l, 1);
|
|
|
|
mask = luaL_checkinteger(l, 2);
|
|
|
|
lua_remove(l, 1);
|
|
|
|
lua_remove(l, 1);
|
|
|
|
callback = getLuaFunc(l);
|
|
|
|
} else {
|
|
|
|
// handle canRxAddMask(bus, id, mask)
|
2022-08-21 20:48:10 -07:00
|
|
|
bus = validateCanChannelAndConvertFromHumanIntoZeroIndex(l);
|
2022-07-27 23:27:18 -07:00
|
|
|
eid = luaL_checkinteger(l, 2);
|
|
|
|
mask = luaL_checkinteger(l, 3);
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
// handle canRxAddMask(bus, id, mask, callback)
|
2022-08-21 20:48:10 -07:00
|
|
|
bus = validateCanChannelAndConvertFromHumanIntoZeroIndex(l);
|
2022-07-27 23:27:18 -07:00
|
|
|
eid = luaL_checkinteger(l, 2);
|
|
|
|
mask = luaL_checkinteger(l, 3);
|
|
|
|
lua_remove(l, 1);
|
|
|
|
lua_remove(l, 1);
|
|
|
|
lua_remove(l, 1);
|
|
|
|
callback = getLuaFunc(l);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return luaL_error(l, "Wrong number of arguments to canRxAddMask. Got %d, expected 2, 3, or 4.");
|
|
|
|
}
|
|
|
|
|
|
|
|
addLuaCanRxFilter(eid, mask, bus, callback);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#endif // EFI_CAN_SUPPORT
|
|
|
|
|
2021-04-28 19:41:25 -07:00
|
|
|
void configureRusefiLuaHooks(lua_State* l) {
|
2021-09-03 17:21:39 -07:00
|
|
|
LuaClass<Timer> luaTimer(l, "Timer");
|
|
|
|
luaTimer
|
|
|
|
.ctor()
|
|
|
|
.fun("reset", static_cast<void (Timer::*)() >(&Timer::reset ))
|
|
|
|
.fun("getElapsedSeconds", static_cast<float(Timer::*)()const>(&Timer::getElapsedSeconds));
|
|
|
|
|
2021-10-22 13:36:29 -07:00
|
|
|
LuaClass<LuaSensor> luaSensor(l, "Sensor");
|
|
|
|
luaSensor
|
2022-07-27 02:41:21 -07:00
|
|
|
.ctor<lua_State*, const char*>()
|
2021-10-22 13:36:29 -07:00
|
|
|
.fun("set", &LuaSensor::set)
|
2022-10-26 06:29:04 -07:00
|
|
|
.fun("setRedundant", &LuaSensor::setRedundant)
|
|
|
|
.fun("setTimeout", &LuaSensor::setTimeout)
|
2021-10-22 13:36:29 -07:00
|
|
|
.fun("invalidate", &LuaSensor::invalidate);
|
|
|
|
|
2021-11-07 06:49:47 -08:00
|
|
|
LuaClass<LuaPid> luaPid(l, "Pid");
|
|
|
|
luaPid
|
2021-11-13 00:18:16 -08:00
|
|
|
.ctor<float, float, float, float, float>()
|
2021-11-07 06:49:47 -08:00
|
|
|
.fun("get", &LuaPid::get)
|
2022-07-14 13:41:50 -07:00
|
|
|
.fun("setOffset", &LuaPid::setOffset)
|
2021-11-13 00:18:16 -08:00
|
|
|
.fun("reset", &LuaPid::reset);
|
2021-11-07 06:49:47 -08:00
|
|
|
|
2021-11-02 20:27:48 -07:00
|
|
|
configureRusefiLuaUtilHooks(l);
|
|
|
|
|
2021-08-31 09:32:05 -07:00
|
|
|
lua_register(l, "readPin", lua_readpin);
|
2022-10-04 18:12:51 -07:00
|
|
|
lua_register(l, "vin", lua_vin);
|
2021-09-01 04:47:25 -07:00
|
|
|
lua_register(l, "getAuxAnalog", lua_getAuxAnalog);
|
2021-10-21 11:33:59 -07:00
|
|
|
lua_register(l, "getSensorByIndex", lua_getSensorByIndex);
|
|
|
|
lua_register(l, "getSensor", lua_getSensorByName);
|
2021-04-29 19:22:04 -07:00
|
|
|
lua_register(l, "getSensorRaw", lua_getSensorRaw);
|
|
|
|
lua_register(l, "hasSensor", lua_hasSensor);
|
2022-07-14 04:27:58 -07:00
|
|
|
lua_register(l, "table3d", [](lua_State* l) {
|
|
|
|
auto humanTableIdx = luaL_checkinteger(l, 1);
|
|
|
|
auto x = luaL_checknumber(l, 2);
|
|
|
|
auto y = luaL_checknumber(l, 3);
|
|
|
|
|
|
|
|
// index table, compute table lookup
|
|
|
|
auto result = getscriptTable(humanTableIdx - HUMAN_OFFSET)->getValue(x, y);
|
|
|
|
|
|
|
|
lua_pushnumber(l, result);
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
|
|
|
|
lua_register(l, "curve", [](lua_State* l) {
|
|
|
|
// index starting from 1
|
|
|
|
auto humanCurveIdx = luaL_checkinteger(l, 1);
|
|
|
|
auto x = luaL_checknumber(l, 2);
|
|
|
|
|
|
|
|
auto result = getCurveValue(humanCurveIdx - HUMAN_OFFSET, x);
|
|
|
|
|
|
|
|
lua_pushnumber(l, result);
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
|
2022-10-22 19:46:37 -07:00
|
|
|
#if EFI_SENT_SUPPORT
|
|
|
|
lua_register(l, "getSentValue",
|
|
|
|
[](lua_State* l) {
|
2022-10-26 03:42:14 -07:00
|
|
|
auto humanIndex = luaL_checkinteger(l, 1);
|
2022-10-22 19:46:37 -07:00
|
|
|
auto value = getSentValue(humanIndex - 1);
|
|
|
|
lua_pushnumber(l, value);
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
#endif // EFI_SENT_SUPPORT
|
|
|
|
|
2022-02-06 15:46:09 -08:00
|
|
|
#if EFI_LAUNCH_CONTROL
|
2021-11-16 10:15:12 -08:00
|
|
|
lua_register(l, "setSparkSkipRatio", [](lua_State* l) {
|
|
|
|
auto targetSkipRatio = luaL_checknumber(l, 1);
|
|
|
|
engine->softSparkLimiter.setTargetSkipRatio(targetSkipRatio);
|
|
|
|
return 1;
|
|
|
|
});
|
2022-02-06 15:46:09 -08:00
|
|
|
#endif // EFI_LAUNCH_CONTROL
|
2021-11-16 10:15:12 -08:00
|
|
|
|
2022-10-29 18:26:42 -07:00
|
|
|
#if !EFI_UNIT_TEST
|
2022-10-28 16:51:56 -07:00
|
|
|
lua_register(l, "selfStimulateRPM", [](lua_State* l) {
|
|
|
|
auto rpm = luaL_checkinteger(l, 1);
|
|
|
|
if (rpm < 1) {
|
|
|
|
disableTriggerStimulator();
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
if (!engine->triggerCentral.directSelfStimulation) {
|
|
|
|
enableTriggerStimulator();
|
|
|
|
}
|
|
|
|
setTriggerEmulatorRPM(rpm);
|
|
|
|
return 0;
|
|
|
|
});
|
2022-10-29 18:26:42 -07:00
|
|
|
#endif // EFI_UNIT_TEST
|
2022-10-28 16:51:56 -07:00
|
|
|
|
2022-10-17 17:01:46 -07:00
|
|
|
/**
|
|
|
|
* same exact could be accomplished via LuaSensor just with more API
|
|
|
|
*/
|
|
|
|
lua_register(l, "setLuaGauge", [](lua_State* l) {
|
|
|
|
auto index = luaL_checkinteger(l, 1) - 1;
|
|
|
|
auto value = luaL_checknumber(l, 2);
|
|
|
|
if (index < 0 || index >= LUA_GAUGE_COUNT)
|
|
|
|
return 0;
|
|
|
|
extern StoredValueSensor luaGauges[LUA_GAUGE_COUNT];
|
|
|
|
luaGauges[index].setValidValue(value, getTimeNowNt());
|
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
|
2021-12-07 07:35:52 -08:00
|
|
|
lua_register(l, "enableCanTx", [](lua_State* l) {
|
|
|
|
engine->allowCanTx = lua_toboolean(l, 1);
|
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
|
2022-10-26 09:46:50 -07:00
|
|
|
#if EFI_PROD_CODE
|
2022-10-26 09:17:14 -07:00
|
|
|
lua_register(l, "restartEtb", [](lua_State* l) {
|
|
|
|
// this is about Lua sensor acting in place of real analog PPS sensor
|
|
|
|
// todo: smarter implementation
|
2022-10-26 14:33:10 -07:00
|
|
|
doInitElectronicThrottle();
|
2022-10-26 09:17:14 -07:00
|
|
|
return 0;
|
|
|
|
});
|
2022-10-26 09:46:50 -07:00
|
|
|
#endif // EFI_PROD_CODE
|
2022-10-26 09:17:14 -07:00
|
|
|
|
2021-11-22 11:19:19 -08:00
|
|
|
lua_register(l, "crc8_j1850", [](lua_State* l) {
|
|
|
|
uint8_t data[8];
|
|
|
|
uint32_t length = getArray(l, 1, data, sizeof(data));
|
|
|
|
auto trimLength = luaL_checkinteger(l, 2);
|
|
|
|
int crc = crc8(data, minI(length, trimLength));
|
|
|
|
|
|
|
|
lua_pushnumber(l, crc);
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
|
2022-07-14 11:04:21 -07:00
|
|
|
#if EFI_BOOST_CONTROL
|
2022-07-14 10:03:08 -07:00
|
|
|
lua_register(l, "setBoostAdd", [](lua_State* l) {
|
|
|
|
engine->boostController.luaTargetAdd = luaL_checknumber(l, 1);
|
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
lua_register(l, "setBoostMult", [](lua_State* l) {
|
|
|
|
engine->boostController.luaTargetMult = luaL_checknumber(l, 1);
|
|
|
|
return 0;
|
|
|
|
});
|
2022-07-14 11:04:21 -07:00
|
|
|
#endif // EFI_BOOST_CONTROL
|
2022-08-20 21:32:34 -07:00
|
|
|
lua_register(l, "setIdleAdd", [](lua_State* l) {
|
|
|
|
engine->module<IdleController>().unmock().luaAdd = luaL_checknumber(l, 1);
|
|
|
|
return 0;
|
|
|
|
});
|
2022-07-14 10:03:08 -07:00
|
|
|
lua_register(l, "setTimingAdd", [](lua_State* l) {
|
|
|
|
engine->ignitionState.luaTimingAdd = luaL_checknumber(l, 1);
|
|
|
|
return 0;
|
|
|
|
});
|
2021-12-01 20:28:44 -08:00
|
|
|
lua_register(l, "setTimingMult", [](lua_State* l) {
|
2022-04-16 18:03:50 -07:00
|
|
|
engine->ignitionState.luaTimingMult = luaL_checknumber(l, 1);
|
2021-12-01 20:28:44 -08:00
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
lua_register(l, "setFuelAdd", [](lua_State* l) {
|
2022-06-29 20:34:00 -07:00
|
|
|
engine->engineState.lua.fuelAdd = luaL_checknumber(l, 1);
|
2021-12-01 20:28:44 -08:00
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
lua_register(l, "setFuelMult", [](lua_State* l) {
|
2022-06-30 17:07:27 -07:00
|
|
|
engine->engineState.lua.fuelMult = luaL_checknumber(l, 1);
|
2021-12-01 20:28:44 -08:00
|
|
|
return 0;
|
|
|
|
});
|
2022-04-16 18:23:37 -07:00
|
|
|
#if EFI_PROD_CODE
|
2021-12-01 22:02:56 -08:00
|
|
|
lua_register(l, "setEtbAdd", [](lua_State* l) {
|
2022-04-16 18:03:50 -07:00
|
|
|
auto luaAdjustment = luaL_checknumber(l, 1);
|
2022-07-09 19:46:28 -07:00
|
|
|
|
|
|
|
setEtbLuaAdjustment(luaAdjustment);
|
|
|
|
|
2021-12-01 22:02:56 -08:00
|
|
|
return 0;
|
|
|
|
});
|
2022-04-16 18:23:37 -07:00
|
|
|
#endif // EFI_PROD_CODE
|
2021-10-24 05:37:04 -07:00
|
|
|
|
2021-12-15 17:35:49 -08:00
|
|
|
lua_register(l, "setClutchUpState", [](lua_State* l) {
|
2022-06-29 20:34:00 -07:00
|
|
|
engine->engineState.lua.clutchUpState = lua_toboolean(l, 1);
|
2021-12-15 17:35:49 -08:00
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
|
|
|
|
lua_register(l, "setBrakePedalState", [](lua_State* l) {
|
2022-06-29 20:34:00 -07:00
|
|
|
engine->engineState.lua.brakePedalState = lua_toboolean(l, 1);
|
2021-12-15 17:35:49 -08:00
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
|
2022-07-07 21:51:53 -07:00
|
|
|
lua_register(l, "setAcRequestState", [](lua_State* l) {
|
|
|
|
engine->engineState.lua.acRequestState = lua_toboolean(l, 1);
|
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
|
2021-12-14 20:16:05 -08:00
|
|
|
lua_register(l, "getCalibration", [](lua_State* l) {
|
|
|
|
auto propertyName = luaL_checklstring(l, 1, nullptr);
|
|
|
|
auto result = getConfigValueByName(propertyName);
|
2021-11-11 18:38:49 -08:00
|
|
|
lua_pushnumber(l, result);
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
|
2021-12-15 17:11:08 -08:00
|
|
|
lua_register(l, "getOutput", [](lua_State* l) {
|
|
|
|
auto propertyName = luaL_checklstring(l, 1, nullptr);
|
|
|
|
auto result = getOutputValueByName(propertyName);
|
|
|
|
lua_pushnumber(l, result);
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
|
2022-04-16 13:39:52 -07:00
|
|
|
#if EFI_SHAFT_POSITION_INPUT
|
2022-01-04 20:15:03 -08:00
|
|
|
lua_register(l, "getEngineState", [](lua_State* l) {
|
|
|
|
spinning_state_e state = engine->rpmCalculator.getState();
|
|
|
|
int luaStateCode;
|
|
|
|
if (state == STOPPED) {
|
|
|
|
luaStateCode = 0;
|
|
|
|
} else if (state == RUNNING) {
|
|
|
|
luaStateCode = 2;
|
|
|
|
} else {
|
2022-01-04 20:17:26 -08:00
|
|
|
// spinning-up or cranking
|
2022-01-04 20:15:03 -08:00
|
|
|
luaStateCode = 1;
|
|
|
|
}
|
|
|
|
lua_pushnumber(l, luaStateCode);
|
|
|
|
return 1;
|
|
|
|
});
|
2022-04-16 13:39:52 -07:00
|
|
|
#endif //EFI_SHAFT_POSITION_INPUT
|
2022-01-04 20:15:03 -08:00
|
|
|
|
2021-12-14 20:16:05 -08:00
|
|
|
lua_register(l, "setCalibration", [](lua_State* l) {
|
2021-12-13 16:46:41 -08:00
|
|
|
auto propertyName = luaL_checklstring(l, 1, nullptr);
|
2021-12-14 20:16:05 -08:00
|
|
|
auto value = luaL_checknumber(l, 2);
|
|
|
|
auto incrementVersion = lua_toboolean(l, 3);
|
|
|
|
setConfigValueByName(propertyName, value);
|
|
|
|
if (incrementVersion) {
|
2021-12-15 10:25:09 -08:00
|
|
|
incrementGlobalConfigurationVersion();
|
2021-12-14 20:16:05 -08:00
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
|
2022-04-08 18:28:38 -07:00
|
|
|
lua_register(l, "setAcDisabled", [](lua_State* l) {
|
|
|
|
auto value = lua_toboolean(l, 1);
|
|
|
|
engine->module<AcController>().unmock().isDisabledByLua = value;
|
|
|
|
return 0;
|
|
|
|
});
|
2022-04-08 22:23:00 -07:00
|
|
|
lua_register(l, "getTimeSinceAcToggleMs", [](lua_State* l) {
|
|
|
|
int result = US2MS(getTimeNowUs()) - engine->module<AcController>().unmock().acSwitchLastChangeTimeMs;
|
|
|
|
lua_pushnumber(l, result);
|
|
|
|
return 1;
|
|
|
|
});
|
2022-04-08 18:28:38 -07:00
|
|
|
|
2022-07-07 20:16:56 -07:00
|
|
|
#if EFI_VEHICLE_SPEED
|
|
|
|
lua_register(l, "getCurrentGear", [](lua_State* l) {
|
|
|
|
lua_pushinteger(l, engine->module<GearDetector>()->getCurrentGear());
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
|
|
|
|
lua_register(l, "getRpmInGear", [](lua_State* l) {
|
|
|
|
auto idx = luaL_checkinteger(l, 1);
|
|
|
|
lua_pushinteger(l, engine->module<GearDetector>()->getRpmInGear(idx));
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
#endif // EFI_VEHICLE_SPEED
|
|
|
|
|
2021-12-14 20:16:05 -08:00
|
|
|
#if !EFI_UNIT_TEST
|
|
|
|
lua_register(l, "startPwm", lua_startPwm);
|
|
|
|
lua_register(l, "setPwmDuty", lua_setPwmDuty);
|
|
|
|
lua_register(l, "setPwmFreq", lua_setPwmFreq);
|
|
|
|
|
|
|
|
lua_register(l, "getFan", lua_fan);
|
|
|
|
lua_register(l, "getDigital", lua_getDigital);
|
|
|
|
lua_register(l, "setDebug", lua_setDebug);
|
|
|
|
lua_register(l, "getAirmass", lua_getAirmass);
|
|
|
|
lua_register(l, "setAirmass", lua_setAirmass);
|
|
|
|
|
2022-01-31 15:37:42 -08:00
|
|
|
lua_register(l, "stopEngine", [](lua_State*) {
|
2021-12-14 20:16:05 -08:00
|
|
|
doScheduleStopEngine();
|
|
|
|
return 0;
|
|
|
|
});
|
|
|
|
|
|
|
|
lua_register(l, "getTimeSinceTriggerEventMs", [](lua_State* l) {
|
2022-01-17 18:43:30 -08:00
|
|
|
int result = engine->triggerCentral.m_lastEventTimer.getElapsedUs() / 1000;
|
2021-12-13 16:46:41 -08:00
|
|
|
lua_pushnumber(l, result);
|
|
|
|
return 1;
|
|
|
|
});
|
|
|
|
|
2021-12-14 20:16:05 -08:00
|
|
|
|
2021-11-13 05:20:30 -08:00
|
|
|
#if EFI_CAN_SUPPORT
|
2022-07-27 23:27:18 -07:00
|
|
|
lua_register(l, "canRxAdd", lua_canRxAdd);
|
|
|
|
lua_register(l, "canRxAddMask", lua_canRxAddMask);
|
2021-10-24 05:37:04 -07:00
|
|
|
#endif // EFI_CAN_SUPPORT
|
|
|
|
#endif // not EFI_UNIT_TEST
|
2022-10-28 16:31:17 -07:00
|
|
|
|
|
|
|
#if EFI_CAN_SUPPORT || EFI_UNIT_TEST
|
|
|
|
lua_register(l, "txCan", lua_txCan);
|
|
|
|
#endif
|
2021-04-28 19:41:25 -07:00
|
|
|
}
|