add more copy and docs to Lua Scripting (#352)

This commit is contained in:
Nathan Schulte 2023-01-05 11:35:20 -06:00 committed by GitHub
parent d46ebdb7f4
commit 1a64999346
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 50 additions and 17 deletions

View File

@ -1,11 +1,24 @@
# Lua Scripting # Lua Scripting
## Introduction
rusEFI strives too offer users as much flexibility as possible, to provide a completely user-defined control strategy for both primary and auxiliary actuators. Historically, for many years rusEFI provided a mechanism called FSIO to do just that.
As of 2022, rusEFI has replaced FSIO with a popular open source [Lua scripting engine](https://en.wikipedia.org/wiki/Lua_(programming_language)) to provide this mechanism.
Since this page was last updated, rusEFI uses [Lua](https://www.lua.org/) version 5.4 ([v5.4.4](https://github.com/rusefi/lua/blob/master/lua.h#L19]).
## Basics ## Basics
A proper ECU has to offer users as much flexibility as possible, meaning a completely user-defined control strategy for both primary and auxiliary actuators. For many years rusEFI had FSIO to do just that. rusEFI provides a number of hooks to interface with the firmware and to manipulate its state and read/write the current configuration.
- Configurations can be accessed via the [`getCalibration()`](#getcalibrationname) hook, and manipulated via the [`setCalibration()`](#setcalibrationname) hook.
- Outputs from the firmware can be read via the [`getOutput()`](#getoutputname) hook, and altered via correspondingly named hooks i.e. `setOutputName()` where `OutputName` is name of the output, e.g. [`setClutchUpState()`](#setclutchupsattevalue). See also: [Outputs](#outputs).
- Inputs from sensors can be read directly; see [Inputs](#inputs).
- Aspects of the engine can be controled directly; see [Engine Control](#enginecontrol).
- Hooks for CAN bus communications; see [CAN bus](#canbus).
- Hooks to read values from SENT sensors; see [SENT protocol](#sentprotocol).
- A set of useful routines is provided; see [Utilities](#utilities).
As of 2022, rusEFI has replaced FSIO with a popular open source [Lua scripting engine](https://en.wikipedia.org/wiki/Lua_(programming_language))
We use [Lua](https://www.lua.org/) version 5.4.3
## Conventions ## Conventions
@ -14,7 +27,7 @@ We use [Lua](https://www.lua.org/) version 5.4.3
## Writing Your Script ## Writing Your Script
The entire Lua script is read at startup, then a function called `onTick` is called periodically by rusEFI. The entire Lua script is read at startup, then a script function called `onTick` is called periodically by rusEFI.
Here is a simple script you can run to illustrate this behavior: Here is a simple script you can run to illustrate this behavior:
@ -39,7 +52,7 @@ function onTick()
end end
``` ```
## Function Reference ## Hooks/Function Reference
### User Settings ### User Settings
@ -65,11 +78,11 @@ Use setAcRequestState to tell rusEFI about CAN-based A/C request.
'setIgnDisabled' function for all kinds of cranking safety systems 'setIgnDisabled' function for all kinds of cranking safety systems
#### ``setAcDisabled(value)`` #### `setAcDisabled(value)`
Disable/suppress A/C functionality regardless of what and how enables it, an override kind of deal. Disable/suppress A/C functionality regardless of what and how enables it, an override kind of deal.
#### ``getTimeSinceAcToggleMs`` #### `getTimeSinceAcToggleMs()`
#### `getCalibration(name)` #### `getCalibration(name)`
@ -81,7 +94,7 @@ For complete list of possible parameter values see [https://github.com/rusefi/ru
Sets specified calibration setting to specified value. Fires calibration change event depending on needEvent parameter. Sets specified calibration setting to specified value. Fires calibration change event depending on needEvent parameter.
For example ``setCalibration("cranking.rpm", 900, false)`` For example `setCalibration("cranking.rpm", 900, false)`
#### `findSetting(name, defaultValue)` #### `findSetting(name, defaultValue)`
@ -94,31 +107,41 @@ different people, also useful while Lua script editing is available only in TS.
### Engine Control ### Engine Control
#### `stopEngine` #### `stopEngine()`
#### `setSparkSkipRatio` #### `setSparkSkipRatio(ratio)`
setSparkSkipRatio(0) to skip 0% of the ignition events, i.e. no skipping setSparkSkipRatio(0) to skip 0% of the ignition events, i.e. no skipping
setSparkSkipRatio(0.5) would skip half of ignition events. We never skip two consecutive ignitions. setSparkSkipRatio(0.5) would skip half of ignition events. We never skip two consecutive ignitions.
#### `setIdleAdd` #### `setIdleAdd(percent)`
#### `setFuelAdd` Percent to add to idle (incl. open loop).
#### `setFuelAdd(amount)`
Sorry not finished :( Sorry not finished :(
#### `setFuelMult` Amount of fuel mass to add to injection, scaled by fuel multiplier ([`setFuelMult()`](#setfuelmultmultiplier)); initially 0.
#### `setFuelMult(coeff)`
Sorry not finished :( Sorry not finished :(
#### `setBoostAdd` Amount to scale added fuel mass by; initially 1.0;
#### `setBoostTargetAdd(amount)`
Additive for closed loop target boost pressure. Additive for closed loop target boost pressure.
#### `setBoostMult` #### `setBoostTargetMult(coeff)`
Multiplier for closed loop target boost pressure. Multiplier for closed loop target boost pressure.
#### `setBoostDutyAdd(amount)`
Additive for open loop target boost pressure.
#### `setTimingAdd(angle)` #### `setTimingAdd(angle)`
todo add details but ready to test! todo add details but ready to test!
@ -127,9 +150,9 @@ todo add details but ready to test!
todo add details but ready to test! todo add details but ready to test!
#### `setEtbAdd(extraEtb)` #### `setEtbAdd(percent)`
extraEtb `10` for 10% percent: e.g. `10` for 10%
### CAN bus ### CAN bus
@ -175,6 +198,16 @@ function onCanRx(bus, id, dlc, data)
end end
``` ```
### SENT protocol
#### `getSentValue(index)`
TODO: document parameters, response
#### `getSentValues(index)`
TODO: document parameters, response
### Utility ### Utility
#### `print(msg)` #### `print(msg)`