From a7c97b350822d0b8d99a82ad22f8e2a3bddf6a1d Mon Sep 17 00:00:00 2001 From: rusefillc Date: Tue, 3 Nov 2020 12:28:13 -0500 Subject: [PATCH] Output pin init/deinit needs a linked list #1803 --- firmware/controllers/system/efi_gpio.cpp | 14 ++++---------- 1 file changed, 4 insertions(+), 10 deletions(-) diff --git a/firmware/controllers/system/efi_gpio.cpp b/firmware/controllers/system/efi_gpio.cpp index 1b8cd84461..f8cb00812f 100644 --- a/firmware/controllers/system/efi_gpio.cpp +++ b/firmware/controllers/system/efi_gpio.cpp @@ -201,12 +201,6 @@ void EnginePins::unregisterPins() { output.initPin(name, CONFIG(pin), &CONFIG(pinMode)); \ } -#define initIfPinChanged(output, name, pin) \ - if (isConfigurationChanged(pin)) { \ - output.initPin(name, CONFIG(pin)); \ - } - - void EnginePins::startPins(DECLARE_ENGINE_PARAMETER_SIGNATURE) { #if EFI_ENGINE_CONTROL startInjectionPins(); @@ -223,11 +217,11 @@ void EnginePins::startPins(DECLARE_ENGINE_PARAMETER_SIGNATURE) { initIfPinOrModeChanged(acRelay, "A/C relay", acRelayPin, acRelayPinMode); // todo: should we move this code closer to the fuel pump logic? initIfPinOrModeChanged(fuelPumpRelay, "Fuel pump", fuelPumpPin, fuelPumpPinMode); - initIfPinChanged(boostPin, "Boost", boostControlPin); + initIfPinOrModeChanged(boostPin, "Boost", boostControlPin, boostControlPinMode); - initIfPinChanged(idleSolenoidPin, "Idle Valve", idle.solenoidPin); - initIfPinChanged(secondIdleSolenoidPin, "Idle Valve#2", secondSolenoidPin); - initIfPinChanged(alternatorPin, "Alternator control", alternatorControlPin); + initIfPinOrModeChanged(idleSolenoidPin, "Idle Valve", idle.solenoidPin, idle.solenoidPinMode); + initIfPinOrModeChanged(secondIdleSolenoidPin, "Idle Valve#2", secondSolenoidPin, idle.solenoidPinMode); + initIfPinOrModeChanged(alternatorPin, "Alternator control", alternatorControlPin, alternatorControlPinMode); initIfPinOrModeChanged(triggerDecoderErrorPin, "led: trigger debug", triggerErrorPin, triggerErrorPinMode);