Starter relay + Hardcoded 'FSIO' + simulator fix (#1032)
* Starter Relay: gui + built-in FSIO impl. * Hardcoded 'FSIO' replacement for RAM-limited boards * fix simulator
This commit is contained in:
parent
8a8a398c70
commit
1808642af1
|
@ -134,9 +134,11 @@ void startAuxPins(void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void stopAuxPins(void) {
|
void stopAuxPins(void) {
|
||||||
|
#if EFI_PROD_CODE
|
||||||
for (int i = 0;i < AUX_PID_COUNT;i++) {
|
for (int i = 0;i < AUX_PID_COUNT;i++) {
|
||||||
brain_pin_markUnused(activeConfiguration.auxPidPins[i]);
|
brain_pin_markUnused(activeConfiguration.auxPidPins[i]);
|
||||||
}
|
}
|
||||||
|
#endif /* EFI_PROD_CODE */
|
||||||
}
|
}
|
||||||
|
|
||||||
void initAuxPid(Logging *sharedLogger) {
|
void initAuxPid(Logging *sharedLogger) {
|
||||||
|
|
|
@ -539,6 +539,7 @@ bool isIdleHardwareRestartNeeded() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void stopIdleHardware(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
void stopIdleHardware(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
||||||
|
#if EFI_PROD_CODE
|
||||||
brain_pin_markUnused(activeConfiguration.stepperEnablePin);
|
brain_pin_markUnused(activeConfiguration.stepperEnablePin);
|
||||||
brain_pin_markUnused(activeConfiguration.bc.idle.stepperStepPin);
|
brain_pin_markUnused(activeConfiguration.bc.idle.stepperStepPin);
|
||||||
brain_pin_markUnused(activeConfiguration.bc.idle.solenoidPin);
|
brain_pin_markUnused(activeConfiguration.bc.idle.solenoidPin);
|
||||||
|
@ -546,7 +547,7 @@ void stopIdleHardware(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
||||||
// brain_pin_markUnused(activeConfiguration.bc.idle.);
|
// brain_pin_markUnused(activeConfiguration.bc.idle.);
|
||||||
// brain_pin_markUnused(activeConfiguration.bc.idle.);
|
// brain_pin_markUnused(activeConfiguration.bc.idle.);
|
||||||
// brain_pin_markUnused(activeConfiguration.bc.idle.);
|
// brain_pin_markUnused(activeConfiguration.bc.idle.);
|
||||||
|
#endif /* EFI_PROD_CODE */
|
||||||
}
|
}
|
||||||
|
|
||||||
void initIdleHardware(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
void initIdleHardware(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
||||||
|
|
|
@ -121,7 +121,9 @@ void Engine::periodicSlowCallback(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
||||||
|
|
||||||
#if EFI_FSIO
|
#if EFI_FSIO
|
||||||
runFsio(PASS_ENGINE_PARAMETER_SIGNATURE);
|
runFsio(PASS_ENGINE_PARAMETER_SIGNATURE);
|
||||||
#endif /* EFI_PROD_CODE && EFI_FSIO */
|
#else
|
||||||
|
runHardcodedFsio(PASS_ENGINE_PARAMETER_SIGNATURE);
|
||||||
|
#endif /* EFI_FSIO */
|
||||||
|
|
||||||
cylinderCleanupControl(PASS_ENGINE_PARAMETER_SIGNATURE);
|
cylinderCleanupControl(PASS_ENGINE_PARAMETER_SIGNATURE);
|
||||||
|
|
||||||
|
|
|
@ -12,13 +12,13 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "global.h"
|
#include "global.h"
|
||||||
|
#include "fsio_impl.h"
|
||||||
|
#include "allsensors.h"
|
||||||
|
|
||||||
#if EFI_FSIO
|
#if EFI_FSIO
|
||||||
|
|
||||||
#include "os_access.h"
|
#include "os_access.h"
|
||||||
#include "fsio_impl.h"
|
|
||||||
#include "settings.h"
|
#include "settings.h"
|
||||||
#include "allsensors.h"
|
|
||||||
#include "rpm_calculator.h"
|
#include "rpm_calculator.h"
|
||||||
#include "efi_gpio.h"
|
#include "efi_gpio.h"
|
||||||
#include "pwm_generator_logic.h"
|
#include "pwm_generator_logic.h"
|
||||||
|
@ -102,6 +102,7 @@ static LEElement * acRelayLogic;
|
||||||
static LEElement * fuelPumpLogic;
|
static LEElement * fuelPumpLogic;
|
||||||
static LEElement * radiatorFanLogic;
|
static LEElement * radiatorFanLogic;
|
||||||
static LEElement * alternatorLogic;
|
static LEElement * alternatorLogic;
|
||||||
|
static LEElement * starterRelayLogic;
|
||||||
|
|
||||||
#if EFI_MAIN_RELAY_CONTROL
|
#if EFI_MAIN_RELAY_CONTROL
|
||||||
static LEElement * mainRelayLogic;
|
static LEElement * mainRelayLogic;
|
||||||
|
@ -464,6 +465,9 @@ void runFsio(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
||||||
enginePins.mainRelay.setValue(true);
|
enginePins.mainRelay.setValue(true);
|
||||||
#endif /* EFI_MAIN_RELAY_CONTROL */
|
#endif /* EFI_MAIN_RELAY_CONTROL */
|
||||||
|
|
||||||
|
if (CONFIGB(starterRelayPin) != GPIO_UNASSIGNED)
|
||||||
|
setPinState("starter_relay", &enginePins.starterRelay, starterRelayLogic PASS_ENGINE_PARAMETER_SUFFIX);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* o2 heater is off during cranking
|
* o2 heater is off during cranking
|
||||||
* todo: convert to FSIO?
|
* todo: convert to FSIO?
|
||||||
|
@ -673,6 +677,8 @@ void initFsioImpl(Logging *sharedLogger DECLARE_ENGINE_PARAMETER_SUFFIX) {
|
||||||
if (CONFIGB(mainRelayPin) != GPIO_UNASSIGNED)
|
if (CONFIGB(mainRelayPin) != GPIO_UNASSIGNED)
|
||||||
mainRelayLogic = sysPool.parseExpression(MAIN_RELAY_LOGIC);
|
mainRelayLogic = sysPool.parseExpression(MAIN_RELAY_LOGIC);
|
||||||
#endif /* EFI_MAIN_RELAY_CONTROL */
|
#endif /* EFI_MAIN_RELAY_CONTROL */
|
||||||
|
if (CONFIGB(starterRelayPin) != GPIO_UNASSIGNED)
|
||||||
|
starterRelayLogic = sysPool.parseExpression(STARTER_RELAY_LOGIC);
|
||||||
|
|
||||||
#if EFI_PROD_CODE
|
#if EFI_PROD_CODE
|
||||||
for (int i = 0; i < FSIO_COMMAND_COUNT; i++) {
|
for (int i = 0; i < FSIO_COMMAND_COUNT; i++) {
|
||||||
|
@ -724,5 +730,37 @@ void initFsioImpl(Logging *sharedLogger DECLARE_ENGINE_PARAMETER_SUFFIX) {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#else /* !EFI_FSIO */
|
||||||
|
|
||||||
|
EXTERN_ENGINE
|
||||||
|
;
|
||||||
|
extern EnginePins enginePins;
|
||||||
|
|
||||||
|
// "Limp-mode" implementation for some RAM-limited configs without FSIO
|
||||||
|
void runHardcodedFsio(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
||||||
|
// see MAIN_RELAY_LOGIC
|
||||||
|
if (CONFIGB(mainRelayPin) != GPIO_UNASSIGNED) {
|
||||||
|
enginePins.mainRelay.setValue((getTimeNowSeconds() < 2) || (getVBatt(PASS_ENGINE_PARAMETER_SIGNATURE) > 5) || engine->isInShutdownMode());
|
||||||
|
}
|
||||||
|
// see STARTER_RELAY_LOGIC
|
||||||
|
if (CONFIGB(starterRelayPin) != GPIO_UNASSIGNED) {
|
||||||
|
enginePins.starterRelay.setValue(engine->rpmCalculator.getRpm() < engineConfiguration->cranking.rpm);
|
||||||
|
}
|
||||||
|
// see FAN_CONTROL_LOGIC
|
||||||
|
if (CONFIGB(fanPin) != GPIO_UNASSIGNED) {
|
||||||
|
enginePins.fanRelay.setValue((enginePins.fanRelay.getLogicValue() && (getCoolantTemperature() > engineConfiguration->fanOffTemperature)) ||
|
||||||
|
(getCoolantTemperature() > engineConfiguration->fanOnTemperature) || engine->isCltBroken);
|
||||||
|
}
|
||||||
|
// see AC_RELAY_LOGIC
|
||||||
|
if (CONFIGB(acRelayPin) != GPIO_UNASSIGNED) {
|
||||||
|
enginePins.acRelay.setValue(getAcToggle(PASS_ENGINE_PARAMETER_SIGNATURE) && engine->rpmCalculator.getRpm() > 850);
|
||||||
|
}
|
||||||
|
// see FUEL_PUMP_LOGIC
|
||||||
|
if (CONFIGB(fuelPumpPin) != GPIO_UNASSIGNED) {
|
||||||
|
enginePins.fuelPumpRelay.setValue((getTimeNowSeconds() < engineConfiguration->startUpFuelPumpDuration) || (engine->rpmCalculator.getRpm() > 0));
|
||||||
|
}
|
||||||
|
|
||||||
|
enginePins.o2heater.setValue(engine->rpmCalculator.isRunning(PASS_ENGINE_PARAMETER_SIGNATURE));
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* EFI_FSIO */
|
#endif /* EFI_FSIO */
|
||||||
|
|
|
@ -39,6 +39,7 @@ void setFsioExpression(const char *indexStr, const char *quotedLine DECLARE_ENGI
|
||||||
float getFsioOutputValue(int index DECLARE_ENGINE_PARAMETER_SUFFIX);
|
float getFsioOutputValue(int index DECLARE_ENGINE_PARAMETER_SUFFIX);
|
||||||
void applyFsioConfiguration(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
void applyFsioConfiguration(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
||||||
void onConfigurationChangeFsioCallback(engine_configuration_s *previousConfiguration DECLARE_ENGINE_PARAMETER_SUFFIX);
|
void onConfigurationChangeFsioCallback(engine_configuration_s *previousConfiguration DECLARE_ENGINE_PARAMETER_SUFFIX);
|
||||||
|
void runHardcodedFsio(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
||||||
|
|
||||||
ValueProvider3D *getFSIOTable(int index);
|
ValueProvider3D *getFSIOTable(int index);
|
||||||
|
|
||||||
|
|
|
@ -115,6 +115,9 @@ static void printOutputs(const engine_configuration_s *engineConfiguration) {
|
||||||
scheduleMsg(&logger, "mainRelay: mode %s @ %s", getPin_output_mode_e(boardConfiguration->mainRelayPinMode),
|
scheduleMsg(&logger, "mainRelay: mode %s @ %s", getPin_output_mode_e(boardConfiguration->mainRelayPinMode),
|
||||||
hwPortname(boardConfiguration->mainRelayPin));
|
hwPortname(boardConfiguration->mainRelayPin));
|
||||||
|
|
||||||
|
scheduleMsg(&logger, "starterRelay: mode %s @ %s", getPin_output_mode_e(boardConfiguration->starterRelayPinMode),
|
||||||
|
hwPortname(boardConfiguration->starterRelayPin));
|
||||||
|
|
||||||
scheduleMsg(&logger, "alternator field: mode %s @ %s",
|
scheduleMsg(&logger, "alternator field: mode %s @ %s",
|
||||||
getPin_output_mode_e(boardConfiguration->alternatorControlPinMode),
|
getPin_output_mode_e(boardConfiguration->alternatorControlPinMode),
|
||||||
hwPortname(boardConfiguration->alternatorControlPin));
|
hwPortname(boardConfiguration->alternatorControlPin));
|
||||||
|
@ -696,6 +699,10 @@ static void setMainRelayPin(const char *pinName) {
|
||||||
setIndividualPin(pinName, &boardConfiguration->mainRelayPin, "main relay");
|
setIndividualPin(pinName, &boardConfiguration->mainRelayPin, "main relay");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void setStarterRelayPin(const char *pinName) {
|
||||||
|
setIndividualPin(pinName, &boardConfiguration->starterRelayPin, "starter relay");
|
||||||
|
}
|
||||||
|
|
||||||
static void setAlternatorPin(const char *pinName) {
|
static void setAlternatorPin(const char *pinName) {
|
||||||
setIndividualPin(pinName, &boardConfiguration->alternatorControlPin, "alternator");
|
setIndividualPin(pinName, &boardConfiguration->alternatorControlPin, "alternator");
|
||||||
}
|
}
|
||||||
|
@ -1431,6 +1438,7 @@ void initSettings(void) {
|
||||||
addConsoleActionS("set_alternator_pin", setAlternatorPin);
|
addConsoleActionS("set_alternator_pin", setAlternatorPin);
|
||||||
addConsoleActionS("set_idle_pin", setIdlePin);
|
addConsoleActionS("set_idle_pin", setIdlePin);
|
||||||
addConsoleActionS("set_main_relay_pin", setMainRelayPin);
|
addConsoleActionS("set_main_relay_pin", setMainRelayPin);
|
||||||
|
addConsoleActionS("set_starter_relay_pin", setStarterRelayPin);
|
||||||
|
|
||||||
#if HAL_USE_ADC
|
#if HAL_USE_ADC
|
||||||
addConsoleActionSS("set_analog_input_pin", setAnalogInputPin);
|
addConsoleActionSS("set_analog_input_pin", setAnalogInputPin);
|
||||||
|
|
|
@ -30,7 +30,7 @@ extern WaveChart waveChart;
|
||||||
|
|
||||||
// todo: clean this mess, this should become 'static'/private
|
// todo: clean this mess, this should become 'static'/private
|
||||||
EnginePins enginePins;
|
EnginePins enginePins;
|
||||||
extern LoggingWithStorage sharedLogger;
|
static Logging* logger;
|
||||||
|
|
||||||
pin_output_mode_e DEFAULT_OUTPUT = OM_DEFAULT;
|
pin_output_mode_e DEFAULT_OUTPUT = OM_DEFAULT;
|
||||||
|
|
||||||
|
@ -144,6 +144,7 @@ void EnginePins::unregisterPins() {
|
||||||
|
|
||||||
unregisterOutputIfPinOrModeChanged(alternatorPin, bc.alternatorControlPin, bc.alternatorControlPinMode);
|
unregisterOutputIfPinOrModeChanged(alternatorPin, bc.alternatorControlPin, bc.alternatorControlPinMode);
|
||||||
unregisterOutputIfPinOrModeChanged(mainRelay, bc.mainRelayPin, bc.mainRelayPinMode);
|
unregisterOutputIfPinOrModeChanged(mainRelay, bc.mainRelayPin, bc.mainRelayPinMode);
|
||||||
|
unregisterOutputIfPinOrModeChanged(starterRelay, bc.starterRelayPin, bc.starterRelayPinMode);
|
||||||
|
|
||||||
#endif /* EFI_PROD_CODE */
|
#endif /* EFI_PROD_CODE */
|
||||||
}
|
}
|
||||||
|
@ -264,7 +265,7 @@ bool NamedOutputPin::stop() {
|
||||||
#if EFI_GPIO_HARDWARE
|
#if EFI_GPIO_HARDWARE
|
||||||
if (isInitialized() && getLogicValue()) {
|
if (isInitialized() && getLogicValue()) {
|
||||||
setValue(false);
|
setValue(false);
|
||||||
scheduleMsg(&sharedLogger, "turning off %s", name);
|
scheduleMsg(logger, "turning off %s", name);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
#endif /* EFI_GPIO_HARDWARE */
|
#endif /* EFI_GPIO_HARDWARE */
|
||||||
|
@ -374,6 +375,7 @@ void initOutputPins(DECLARE_ENGINE_PARAMETER_SIGNATURE) {
|
||||||
enginePins.fuelPumpRelay.initPin("fuel pump relay", CONFIGB(fuelPumpPin), &CONFIGB(fuelPumpPinMode));
|
enginePins.fuelPumpRelay.initPin("fuel pump relay", CONFIGB(fuelPumpPin), &CONFIGB(fuelPumpPinMode));
|
||||||
|
|
||||||
enginePins.mainRelay.initPin("main relay", CONFIGB(mainRelayPin), &CONFIGB(mainRelayPinMode));
|
enginePins.mainRelay.initPin("main relay", CONFIGB(mainRelayPin), &CONFIGB(mainRelayPinMode));
|
||||||
|
enginePins.starterRelay.initPin("starter relay", CONFIGB(starterRelayPin), &CONFIGB(starterRelayPinMode));
|
||||||
|
|
||||||
enginePins.fanRelay.initPin("fan relay", CONFIGB(fanPin), &CONFIGB(fanPinMode));
|
enginePins.fanRelay.initPin("fan relay", CONFIGB(fanPin), &CONFIGB(fanPinMode));
|
||||||
enginePins.o2heater.initPin("o2 heater", CONFIGB(o2heaterPin));
|
enginePins.o2heater.initPin("o2 heater", CONFIGB(o2heaterPin));
|
||||||
|
@ -474,7 +476,7 @@ void OutputPin::initPin(const char *msg, brain_pin_e brainPin, const pin_output_
|
||||||
|
|
||||||
void OutputPin::unregisterOutput(brain_pin_e oldPin) {
|
void OutputPin::unregisterOutput(brain_pin_e oldPin) {
|
||||||
if (oldPin != GPIO_UNASSIGNED) {
|
if (oldPin != GPIO_UNASSIGNED) {
|
||||||
scheduleMsg(&sharedLogger, "unregistering %s", hwPortname(oldPin));
|
scheduleMsg(logger, "unregistering %s", hwPortname(oldPin));
|
||||||
#if EFI_GPIO_HARDWARE && EFI_PROD_CODE
|
#if EFI_GPIO_HARDWARE && EFI_PROD_CODE
|
||||||
brain_pin_markUnused(oldPin);
|
brain_pin_markUnused(oldPin);
|
||||||
port = nullptr;
|
port = nullptr;
|
||||||
|
@ -489,7 +491,8 @@ void OutputPin::unregisterOutput(brain_pin_e oldPin) {
|
||||||
ioportid_t errorLedPort;
|
ioportid_t errorLedPort;
|
||||||
ioportmask_t errorLedPin;
|
ioportmask_t errorLedPin;
|
||||||
|
|
||||||
void initPrimaryPins(void) {
|
void initPrimaryPins(Logging *sharedLogger) {
|
||||||
|
logger = sharedLogger;
|
||||||
#if EFI_PROD_CODE
|
#if EFI_PROD_CODE
|
||||||
enginePins.errorLedPin.initPin("led: ERROR status", LED_ERROR_BRAIN_PIN);
|
enginePins.errorLedPin.initPin("led: ERROR status", LED_ERROR_BRAIN_PIN);
|
||||||
errorLedPort = getHwPort("primary", LED_ERROR_BRAIN_PIN);
|
errorLedPort = getHwPort("primary", LED_ERROR_BRAIN_PIN);
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
#include "io_pins.h"
|
#include "io_pins.h"
|
||||||
#include "engine_configuration.h"
|
#include "engine_configuration.h"
|
||||||
|
|
||||||
void initPrimaryPins(void);
|
void initPrimaryPins(Logging *sharedLogger);
|
||||||
void initOutputPins(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
void initOutputPins(DECLARE_ENGINE_PARAMETER_SIGNATURE);
|
||||||
|
|
||||||
#if EFI_GPIO_HARDWARE
|
#if EFI_GPIO_HARDWARE
|
||||||
|
@ -124,6 +124,7 @@ public:
|
||||||
void stopInjectionPins();
|
void stopInjectionPins();
|
||||||
void stopIgnitionPins();
|
void stopIgnitionPins();
|
||||||
OutputPin mainRelay;
|
OutputPin mainRelay;
|
||||||
|
OutputPin starterRelay;
|
||||||
OutputPin fanRelay;
|
OutputPin fanRelay;
|
||||||
// see acRelayPin
|
// see acRelayPin
|
||||||
OutputPin acRelay;
|
OutputPin acRelay;
|
||||||
|
|
|
@ -68,7 +68,7 @@
|
||||||
// starter block using configurable parameter
|
// starter block using configurable parameter
|
||||||
|
|
||||||
// Human-readable: rpm < cranking_rpm
|
// Human-readable: rpm < cranking_rpm
|
||||||
#define STARTER_BLOCK "rpm cranking_rpm <"
|
#define STARTER_RELAY_LOGIC "rpm cranking_rpm <"
|
||||||
|
|
||||||
// Human-readable: fsio_table (3, rpm, map) / 100
|
// Human-readable: fsio_table (3, rpm, map) / 100
|
||||||
#define BOOST_CONTROLLER "3 rpm map fsio_table 100 /"
|
#define BOOST_CONTROLLER "3 rpm map fsio_table 100 /"
|
||||||
|
|
|
@ -46,7 +46,7 @@ RPM_ABOVE_6000_SOLENOID_80_DUTY=(rpm > 6000) * 0.8
|
||||||
RPM_BELOW_USER_SETTING_1=rpm < fsio_setting(1)
|
RPM_BELOW_USER_SETTING_1=rpm < fsio_setting(1)
|
||||||
|
|
||||||
# starter block using configurable parameter
|
# starter block using configurable parameter
|
||||||
STARTER_BLOCK=rpm < cranking_rpm
|
STARTER_RELAY_LOGIC=rpm < cranking_rpm
|
||||||
|
|
||||||
BOOST_CONTROLLER=fsio_table (3, rpm, map) / 100
|
BOOST_CONTROLLER=fsio_table (3, rpm, map) / 100
|
||||||
|
|
||||||
|
|
|
@ -419,7 +419,7 @@ void initHardware(Logging *l) {
|
||||||
/**
|
/**
|
||||||
* We need the LED_ERROR pin even before we read configuration
|
* We need the LED_ERROR pin even before we read configuration
|
||||||
*/
|
*/
|
||||||
initPrimaryPins();
|
initPrimaryPins(sharedLogger);
|
||||||
|
|
||||||
if (hasFirmwareError()) {
|
if (hasFirmwareError()) {
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -1084,6 +1084,7 @@ menuDialog = main
|
||||||
|
|
||||||
# Digital outputs
|
# Digital outputs
|
||||||
subMenu = mainRelay, "Main relay"
|
subMenu = mainRelay, "Main relay"
|
||||||
|
subMenu = starterRelay, "Starter relay"
|
||||||
subMenu = fuelPump, "Fuel rail"
|
subMenu = fuelPump, "Fuel rail"
|
||||||
subMenu = fanSetting, "Fan"
|
subMenu = fanSetting, "Fan"
|
||||||
subMenu = tachSettings, "Tachometer"
|
subMenu = tachSettings, "Tachometer"
|
||||||
|
@ -1652,6 +1653,8 @@ cmd_set_engine_type_default = "w\x00\x31\x00\x00"
|
||||||
field = "Fan Pin Mode", fanPinMode
|
field = "Fan Pin Mode", fanPinMode
|
||||||
field = "Main Relay Pin", mainRelayPin
|
field = "Main Relay Pin", mainRelayPin
|
||||||
field = "Main Relay Mode", mainRelayPinMode
|
field = "Main Relay Mode", mainRelayPinMode
|
||||||
|
field = "Starter Relay Pin", starterRelayPin
|
||||||
|
field = "Starter Relay Mode", starterRelayPinMode
|
||||||
field = "aux valve #1", auxValves1
|
field = "aux valve #1", auxValves1
|
||||||
field = "aux valve #2", auxValves2
|
field = "aux valve #2", auxValves2
|
||||||
|
|
||||||
|
@ -1995,6 +1998,10 @@ cmd_set_engine_type_default = "w\x00\x31\x00\x00"
|
||||||
field = "Pin", mainRelayPin
|
field = "Pin", mainRelayPin
|
||||||
field = "Pin mode", mainRelayPinMode
|
field = "Pin mode", mainRelayPinMode
|
||||||
|
|
||||||
|
dialog = starterRelay, "Starter relay output"
|
||||||
|
field = "Pin", starterRelayPin
|
||||||
|
field = "Pin mode", starterRelayPinMode
|
||||||
|
|
||||||
dialog = statusLeds, "Status LEDs"
|
dialog = statusLeds, "Status LEDs"
|
||||||
field = "Running status LED", runningLedPin
|
field = "Running status LED", runningLedPin
|
||||||
field = "TS communication status LED", communicationLedPin
|
field = "TS communication status LED", communicationLedPin
|
||||||
|
|
|
@ -228,7 +228,7 @@ TEST(fsio, testLogicExpressions) {
|
||||||
engine->fsioState.mockCrankingRpm = 200;
|
engine->fsioState.mockCrankingRpm = 200;
|
||||||
testExpression2(0, "rpm", 900, engine);
|
testExpression2(0, "rpm", 900, engine);
|
||||||
testExpression2(0, "cranking_rpm", 200, engine);
|
testExpression2(0, "cranking_rpm", 200, engine);
|
||||||
testExpression2(0, STARTER_BLOCK, 0, engine);
|
testExpression2(0, STARTER_RELAY_LOGIC, 0, engine);
|
||||||
testExpression2(0, "rpm cranking_rpm > ", 1, engine);
|
testExpression2(0, "rpm cranking_rpm > ", 1, engine);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue