auto-sync
This commit is contained in:
parent
2087946a21
commit
0568963a68
|
@ -387,6 +387,7 @@ static void setBit(const char *offsetStr, const char *bitStr, const char *valueS
|
||||||
* this response is part of dev console API
|
* this response is part of dev console API
|
||||||
*/
|
*/
|
||||||
scheduleMsg(&logger, "bit @%d/%d is %d", offset, bit, value);
|
scheduleMsg(&logger, "bit @%d/%d is %d", offset, bit, value);
|
||||||
|
applyNewConfiguration();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void setShort(const int offset, const int value) {
|
static void setShort(const int offset, const int value) {
|
||||||
|
@ -395,6 +396,7 @@ static void setShort(const int offset, const int value) {
|
||||||
uint16_t *ptr = (uint16_t *) (&((char *) engineConfiguration)[offset]);
|
uint16_t *ptr = (uint16_t *) (&((char *) engineConfiguration)[offset]);
|
||||||
*ptr = (uint16_t) value;
|
*ptr = (uint16_t) value;
|
||||||
getShort(offset);
|
getShort(offset);
|
||||||
|
applyNewConfiguration();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void getBit(int offset, int bit) {
|
static void getBit(int offset, int bit) {
|
||||||
|
@ -425,6 +427,7 @@ static void setInt(const int offset, const int value) {
|
||||||
int *ptr = (int *) (&((char *) engineConfiguration)[offset]);
|
int *ptr = (int *) (&((char *) engineConfiguration)[offset]);
|
||||||
*ptr = value;
|
*ptr = value;
|
||||||
getInt(offset);
|
getInt(offset);
|
||||||
|
applyNewConfiguration();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void getFloat(int offset) {
|
static void getFloat(int offset) {
|
||||||
|
@ -533,7 +536,6 @@ void initEngineContoller(Logging *sharedLogger DECLARE_ENGINE_PARAMETER_S) {
|
||||||
|
|
||||||
#if (EFI_PROD_CODE && EFI_ENGINE_CONTROL) || defined(__DOXYGEN__)
|
#if (EFI_PROD_CODE && EFI_ENGINE_CONTROL) || defined(__DOXYGEN__)
|
||||||
initInjectorCentral();
|
initInjectorCentral();
|
||||||
initIgnitionCentral();
|
|
||||||
/**
|
/**
|
||||||
* This has to go after 'initInjectorCentral' and 'initInjectorCentral' in order to
|
* This has to go after 'initInjectorCentral' and 'initInjectorCentral' in order to
|
||||||
* properly detect un-assigned output pins
|
* properly detect un-assigned output pins
|
||||||
|
|
|
@ -43,14 +43,6 @@ static int is_injector_enabled[MAX_INJECTOR_COUNT];
|
||||||
|
|
||||||
extern engine_pins_s enginePins;
|
extern engine_pins_s enginePins;
|
||||||
|
|
||||||
void initIgnitionCentral(void) {
|
|
||||||
for (int i = 0; i < engineConfiguration->specs.cylindersCount; i++) {
|
|
||||||
NamedOutputPin *output = &enginePins.coils[i];
|
|
||||||
outputPinRegisterExt2(output->name, output, boardConfiguration->ignitionPins[i],
|
|
||||||
&boardConfiguration->ignitionPinMode);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool_t isRunningBenchTest(void) {
|
bool_t isRunningBenchTest(void) {
|
||||||
return isRunningBench;
|
return isRunningBench;
|
||||||
}
|
}
|
||||||
|
@ -216,11 +208,40 @@ static msg_t benchThread(int param) {
|
||||||
|
|
||||||
extern engine_configuration_s activeConfiguration;
|
extern engine_configuration_s activeConfiguration;
|
||||||
|
|
||||||
|
static void unregister(brain_pin_e currentPin, OutputPin *output) {
|
||||||
|
if (currentPin == GPIO_UNASSIGNED)
|
||||||
|
return;
|
||||||
|
scheduleMsg(&logger, "unregistering %s", hwPortname(currentPin));
|
||||||
|
unmarkPin(currentPin);
|
||||||
|
output->unregister();
|
||||||
|
}
|
||||||
|
|
||||||
|
void stopIgnitionPins(void) {
|
||||||
|
for (int i = 0; i < IGNITION_PIN_COUNT; i++) {
|
||||||
|
NamedOutputPin *output = &enginePins.injectors[i];
|
||||||
|
brain_pin_e currentPin = activeConfiguration.bc.ignitionPins[i];
|
||||||
|
if (engineConfiguration->bc.ignitionPins[i] != currentPin) {
|
||||||
|
unregister(currentPin, output);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void stopInjectionPins(void) {
|
void stopInjectionPins(void) {
|
||||||
for (int i = 0; i < INJECTION_PIN_COUNT; i++) {
|
for (int i = 0; i < INJECTION_PIN_COUNT; i++) {
|
||||||
NamedOutputPin *output = &enginePins.injectors[i];
|
NamedOutputPin *output = &enginePins.injectors[i];
|
||||||
if (engineConfiguration->bc.injectionPins[i] != activeConfiguration.bc.injectionPins[i]) {
|
brain_pin_e currentPin = activeConfiguration.bc.injectionPins[i];
|
||||||
// unmarkPin
|
if (engineConfiguration->bc.injectionPins[i] != currentPin) {
|
||||||
|
unregister(currentPin, output);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void startIgnitionPins(void) {
|
||||||
|
for (int i = 0; i < engineConfiguration->specs.cylindersCount; i++) {
|
||||||
|
NamedOutputPin *output = &enginePins.coils[i];
|
||||||
|
if (boardConfiguration->ignitionPins[i] != activeConfiguration.bc.ignitionPins[i]) {
|
||||||
|
outputPinRegisterExt2(output->name, output, boardConfiguration->ignitionPins[i],
|
||||||
|
&boardConfiguration->ignitionPinMode);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -245,7 +266,7 @@ void initInjectorCentral(void) {
|
||||||
}
|
}
|
||||||
|
|
||||||
startInjectionPins();
|
startInjectionPins();
|
||||||
|
startIgnitionPins();
|
||||||
|
|
||||||
printStatus();
|
printStatus();
|
||||||
addConsoleActionII("injector", setInjectorEnabled);
|
addConsoleActionII("injector", setInjectorEnabled);
|
||||||
|
|
|
@ -17,7 +17,6 @@
|
||||||
void fanBench(void);
|
void fanBench(void);
|
||||||
void fuelPumpBench(void);
|
void fuelPumpBench(void);
|
||||||
void initInjectorCentral(void);
|
void initInjectorCentral(void);
|
||||||
void initIgnitionCentral(void);
|
|
||||||
bool_t isRunningBenchTest(void);
|
bool_t isRunningBenchTest(void);
|
||||||
int isInjectorEnabled(int cylinderId);
|
int isInjectorEnabled(int cylinderId);
|
||||||
void assertCylinderId(int cylinderId, const char *msg);
|
void assertCylinderId(int cylinderId, const char *msg);
|
||||||
|
|
|
@ -603,6 +603,7 @@ static void setIgnitionPin(const char *indexStr, const char *pinName) {
|
||||||
}
|
}
|
||||||
scheduleMsg(&logger, "setting ignition pin[%d] to %s please save&restart", index, hwPortname(pin));
|
scheduleMsg(&logger, "setting ignition pin[%d] to %s please save&restart", index, hwPortname(pin));
|
||||||
boardConfiguration->ignitionPins[index] = pin;
|
boardConfiguration->ignitionPins[index] = pin;
|
||||||
|
applyNewConfiguration();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void setIndividualPin(const char *pinName, brain_pin_e *targetPin, const char *name) {
|
static void setIndividualPin(const char *pinName, brain_pin_e *targetPin, const char *name) {
|
||||||
|
@ -613,6 +614,7 @@ static void setIndividualPin(const char *pinName, brain_pin_e *targetPin, const
|
||||||
}
|
}
|
||||||
scheduleMsg(&logger, "setting %s pin to %s please save&restart", name, hwPortname(pin));
|
scheduleMsg(&logger, "setting %s pin to %s please save&restart", name, hwPortname(pin));
|
||||||
*targetPin = pin;
|
*targetPin = pin;
|
||||||
|
applyNewConfiguration();
|
||||||
}
|
}
|
||||||
|
|
||||||
// set_idle_pin none
|
// set_idle_pin none
|
||||||
|
@ -648,6 +650,7 @@ static void setInjectionPin(const char *indexStr, const char *pinName) {
|
||||||
}
|
}
|
||||||
scheduleMsg(&logger, "setting injection pin[%d] to %s please save&restart", index, hwPortname(pin));
|
scheduleMsg(&logger, "setting injection pin[%d] to %s please save&restart", index, hwPortname(pin));
|
||||||
boardConfiguration->injectionPins[index] = pin;
|
boardConfiguration->injectionPins[index] = pin;
|
||||||
|
applyNewConfiguration();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void setTriggerInputPin(const char *indexStr, const char *pinName) {
|
static void setTriggerInputPin(const char *indexStr, const char *pinName) {
|
||||||
|
@ -662,6 +665,7 @@ static void setTriggerInputPin(const char *indexStr, const char *pinName) {
|
||||||
}
|
}
|
||||||
scheduleMsg(&logger, "setting trigger pin[%d] to %s please save&restart", index, hwPortname(pin));
|
scheduleMsg(&logger, "setting trigger pin[%d] to %s please save&restart", index, hwPortname(pin));
|
||||||
boardConfiguration->triggerInputPins[index] = pin;
|
boardConfiguration->triggerInputPins[index] = pin;
|
||||||
|
applyNewConfiguration();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void setTriggerSimulatorMode(const char *indexStr, const char *modeCode) {
|
static void setTriggerSimulatorMode(const char *indexStr, const char *modeCode) {
|
||||||
|
@ -687,6 +691,7 @@ static void setEgtCSPin(const char *indexStr, const char *pinName, board_configu
|
||||||
}
|
}
|
||||||
scheduleMsg(&logger, "setting EGT CS pin[%d] to %s please save&restart", index, hwPortname(pin));
|
scheduleMsg(&logger, "setting EGT CS pin[%d] to %s please save&restart", index, hwPortname(pin));
|
||||||
boardConfiguration->max31855_cs[index] = pin;
|
boardConfiguration->max31855_cs[index] = pin;
|
||||||
|
applyNewConfiguration();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void setTriggerSimulatorPin(const char *indexStr, const char *pinName) {
|
static void setTriggerSimulatorPin(const char *indexStr, const char *pinName) {
|
||||||
|
@ -700,6 +705,7 @@ static void setTriggerSimulatorPin(const char *indexStr, const char *pinName) {
|
||||||
}
|
}
|
||||||
scheduleMsg(&logger, "setting trigger simulator pin[%d] to %s please save&restart", index, hwPortname(pin));
|
scheduleMsg(&logger, "setting trigger simulator pin[%d] to %s please save&restart", index, hwPortname(pin));
|
||||||
boardConfiguration->triggerSimulatorPins[index] = pin;
|
boardConfiguration->triggerSimulatorPins[index] = pin;
|
||||||
|
applyNewConfiguration();
|
||||||
}
|
}
|
||||||
|
|
||||||
#if HAL_USE_ADC || defined(__DOXYGEN__)
|
#if HAL_USE_ADC || defined(__DOXYGEN__)
|
||||||
|
@ -727,6 +733,7 @@ static void setAnalogInputPin(const char *sensorStr, const char *pinName) {
|
||||||
engineConfiguration->tpsAdcChannel = channel;
|
engineConfiguration->tpsAdcChannel = channel;
|
||||||
scheduleMsg(&logger, "setting TPS to %s/%d", pinName, channel);
|
scheduleMsg(&logger, "setting TPS to %s/%d", pinName, channel);
|
||||||
}
|
}
|
||||||
|
applyNewConfiguration();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -51,8 +51,14 @@ bool_t OutputPin::getLogicValue() {
|
||||||
return currentLogicValue;
|
return currentLogicValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void OutputPin::unregister() {
|
||||||
|
#if EFI_PROD_CODE || defined(__DOXYGEN__)
|
||||||
|
port = NULL;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
void OutputPin::setDefaultPinState(pin_output_mode_e *outputMode) {
|
void OutputPin::setDefaultPinState(pin_output_mode_e *outputMode) {
|
||||||
#if EFI_GPIO
|
#if EFI_GPIO || defined(__DOXYGEN__)
|
||||||
pin_output_mode_e mode = *outputMode;
|
pin_output_mode_e mode = *outputMode;
|
||||||
assertOMode(mode);
|
assertOMode(mode);
|
||||||
this->modePtr = outputMode;
|
this->modePtr = outputMode;
|
||||||
|
|
|
@ -25,6 +25,7 @@ public:
|
||||||
void setValue(int logicValue);
|
void setValue(int logicValue);
|
||||||
void setDefaultPinState(pin_output_mode_e *defaultState);
|
void setDefaultPinState(pin_output_mode_e *defaultState);
|
||||||
bool_t getLogicValue();
|
bool_t getLogicValue();
|
||||||
|
void unregister();
|
||||||
#if EFI_PROD_CODE || defined(__DOXYGEN__)
|
#if EFI_PROD_CODE || defined(__DOXYGEN__)
|
||||||
GPIO_TypeDef *port;
|
GPIO_TypeDef *port;
|
||||||
int pin;
|
int pin;
|
||||||
|
|
|
@ -17,6 +17,7 @@ public class SettingsTab {
|
||||||
panel.add(UiUtils.wrap(new EnumConfigField(Fields.triggerInputPins1, "trigger #1 input").getContent()));
|
panel.add(UiUtils.wrap(new EnumConfigField(Fields.triggerInputPins1, "trigger #1 input").getContent()));
|
||||||
panel.add(UiUtils.wrap(new EnumConfigField(Fields.triggerInputPins2, "trigger #2 input").getContent()));
|
panel.add(UiUtils.wrap(new EnumConfigField(Fields.triggerInputPins2, "trigger #2 input").getContent()));
|
||||||
// panel.add(UiUtils.wrap(new EnumConfigField(Fields.triggerInputPins3, "trigger #3 input").getContent()));
|
// panel.add(UiUtils.wrap(new EnumConfigField(Fields.triggerInputPins3, "trigger #3 input").getContent()));
|
||||||
|
panel.add(UiUtils.wrap(new EnumConfigField(Fields.injector1, "injector #1").getContent()));
|
||||||
|
|
||||||
panel.add(UiUtils.wrap(RecentCommands.createButton(new AtomicBoolean(), "writeconfig")));
|
panel.add(UiUtils.wrap(RecentCommands.createButton(new AtomicBoolean(), "writeconfig")));
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue