From 677d5888ed96b0f46674a5b559151e8410d86a89 Mon Sep 17 00:00:00 2001 From: rusefi Date: Sun, 12 Jul 2020 18:11:10 -0400 Subject: [PATCH] EFI_IDLE_INCREMENTAL_PID_CIC should be a runtime parameter #806 --- firmware/console/binary/tunerstudio.cpp | 12 +------ .../controllers/actuators/idle_thread.cpp | 35 +++++++++++-------- firmware/controllers/actuators/idle_thread.h | 1 + .../java/com/rusefi/server/UserDetails.java | 0 .../com/rusefi/tools/online/ProxyClient.java | 4 +++ 5 files changed, 26 insertions(+), 26 deletions(-) rename {java_tools/proxy_server => java_console/shared_io}/src/main/java/com/rusefi/server/UserDetails.java (100%) create mode 100644 java_console/shared_io/src/main/java/com/rusefi/tools/online/ProxyClient.java diff --git a/firmware/console/binary/tunerstudio.cpp b/firmware/console/binary/tunerstudio.cpp index cd82b062c1..ebe0970982 100644 --- a/firmware/console/binary/tunerstudio.cpp +++ b/firmware/console/binary/tunerstudio.cpp @@ -95,16 +95,6 @@ #if EFI_TUNER_STUDIO - -#ifndef EFI_IDLE_CONTROL - #if EFI_IDLE_PID_CIC - extern PidCic idlePid; - #else - extern Pid idlePid; - #endif /* EFI_IDLE_PID_CIC */ -#endif /* EFI_IDLE_CONTROL */ - - EXTERN_ENGINE; extern persistent_config_container_s persistentState; @@ -298,7 +288,7 @@ static const void * getStructAddr(int structId) { #ifndef EFI_IDLE_CONTROL case LDS_IDLE_PID_STATE_INDEX: - return static_cast(&idlePid); + return static_cast(getIdlePid()); #endif /* EFI_IDLE_CONTROL */ default: diff --git a/firmware/controllers/actuators/idle_thread.cpp b/firmware/controllers/actuators/idle_thread.cpp index e56791ba18..98dfe46b47 100644 --- a/firmware/controllers/actuators/idle_thread.cpp +++ b/firmware/controllers/actuators/idle_thread.cpp @@ -72,7 +72,8 @@ static bool mightResetPid = false; #if EFI_IDLE_PID_CIC // Use new PID with CIC integrator -PidCic idlePid; +static PidCic idlePid; + #else class PidWithOverrides : public PidIndustrial { @@ -106,15 +107,19 @@ public: } }; -PidWithOverrides idlePid; +static PidWithOverrides idlePid; #endif /* EFI_IDLE_PID_CIC */ +Pid * getIdlePid() { + return &idlePid; +} + float getIdlePidOffset() { - return idlePid.getOffset(); + return getIdlePid()->getOffset(); } float getIdlePidMinValue() { - return idlePid.getMinValue(); + return getIdlePid()->getMinValue(); } // todo: extract interface for idle valve hardware, with solenoid and stepper implementations? @@ -176,7 +181,7 @@ static void showIdleInfo(void) { } if (engineConfiguration->idleMode == IM_AUTO) { - idlePid.showPidStatus(logger, "idle"); + getIdlePid()->showPidStatus(logger, "idle"); } } @@ -342,9 +347,9 @@ static percent_t automaticIdleController(float tpsPos DECLARE_ENGINE_PARAMETER_S if (rpm < targetRpm) errorAmpCoef += (float)CONFIG(pidExtraForLowRpm) / PERCENT_MULT; // If errorAmpCoef > 1.0, then PID thinks that RPM is lower than it is, and controls IAC more aggressively - idlePid.setErrorAmplification(errorAmpCoef); + getIdlePid()->setErrorAmplification(errorAmpCoef); - percent_t newValue = idlePid.getOutput(targetRpm, rpm); + percent_t newValue = getIdlePid()->getOutput(targetRpm, rpm); engine->engineState.idle.idleState = PID_VALUE; // the state of PID has been changed, so we might reset it now, but only when needed (see idlePidDeactivationTpsThreshold) @@ -395,8 +400,8 @@ static percent_t automaticIdleController(float tpsPos DECLARE_ENGINE_PARAMETER_S * @see stepper.cpp */ - idlePid.iTermMin = engineConfiguration->idlerpmpid_iTermMin; - idlePid.iTermMax = engineConfiguration->idlerpmpid_iTermMax; + getIdlePid()->iTermMin = engineConfiguration->idlerpmpid_iTermMin; + getIdlePid()->iTermMax = engineConfiguration->idlerpmpid_iTermMax; SensorResult tps = Sensor::get(SensorType::DriverThrottleIntent); @@ -405,11 +410,11 @@ static percent_t automaticIdleController(float tpsPos DECLARE_ENGINE_PARAMETER_S if (engineConfiguration->isVerboseIAC && engine->engineState.isAutomaticIdle) { scheduleMsg(logger, "Idle state %s%s", getIdle_state_e(engine->engineState.idle.idleState), (prettyClose ? " pretty close" : "")); - idlePid.showPidStatus(logger, "idle"); + getIdlePid()->showPidStatus(logger, "idle"); } if (shouldResetPid) { - idlePid.reset(); + getIdlePid()->reset(); // alternatorPidResetCounter++; shouldResetPid = false; } @@ -506,7 +511,7 @@ static percent_t automaticIdleController(float tpsPos DECLARE_ENGINE_PARAMETER_S if (engineConfiguration->idleMode == IM_AUTO) { #if EFI_TUNER_STUDIO // see also tsOutputChannels->idlePosition - idlePid.postState(&tsOutputChannels, 1000000); + getIdlePid()->postState(&tsOutputChannels, 1000000); tsOutputChannels.debugIntField4 = engine->engineState.idle.idleState; #endif /* EFI_TUNER_STUDIO */ } else { @@ -533,7 +538,7 @@ static percent_t automaticIdleController(float tpsPos DECLARE_ENGINE_PARAMETER_S IdleController idleControllerInstance; static void applyPidSettings(DECLARE_ENGINE_PARAMETER_SIGNATURE) { - idlePid.updateFactors(engineConfiguration->idleRpmPid.pFactor, engineConfiguration->idleRpmPid.iFactor, engineConfiguration->idleRpmPid.dFactor); + getIdlePid()->updateFactors(engineConfiguration->idleRpmPid.pFactor, engineConfiguration->idleRpmPid.iFactor, engineConfiguration->idleRpmPid.dFactor); iacPidMultMap.init(CONFIG(iacPidMultTable), CONFIG(iacPidMultLoadBins), CONFIG(iacPidMultRpmBins)); } @@ -550,7 +555,7 @@ void setDefaultIdleParameters(DECLARE_CONFIG_PARAMETER_SIGNATURE) { #if ! EFI_UNIT_TEST void onConfigurationChangeIdleCallback(engine_configuration_s *previousConfiguration) { - shouldResetPid = !idlePid.isSame(&previousConfiguration->idleRpmPid); + shouldResetPid = !getIdlePid()->isSame(&previousConfiguration->idleRpmPid); idleSolenoidOpen.setFrequency(CONFIG(idle).solenoidFrequency); idleSolenoidClose.setFrequency(CONFIG(idle).solenoidFrequency); } @@ -706,7 +711,7 @@ void startIdleThread(Logging*sharedLogger DECLARE_ENGINE_PARAMETER_SUFFIX) { logger = sharedLogger; INJECT_ENGINE_REFERENCE(&idleControllerInstance); - idlePid.initPidClass(&engineConfiguration->idleRpmPid); + getIdlePid()->initPidClass(&engineConfiguration->idleRpmPid); #if ! EFI_UNIT_TEST // todo: we still have to explicitly init all hardware on start in addition to handling configuration change via diff --git a/firmware/controllers/actuators/idle_thread.h b/firmware/controllers/actuators/idle_thread.h index ee4b6c4668..359ae00a9c 100644 --- a/firmware/controllers/actuators/idle_thread.h +++ b/firmware/controllers/actuators/idle_thread.h @@ -37,4 +37,5 @@ void initIdleHardware(DECLARE_ENGINE_PARAMETER_SIGNATURE); bool isIdleHardwareRestartNeeded(); void onConfigurationChangeIdleCallback(engine_configuration_s *previousConfiguration); float getIdlePidOffset(); +Pid * getIdlePid(); float getIdlePidMinValue(); diff --git a/java_tools/proxy_server/src/main/java/com/rusefi/server/UserDetails.java b/java_console/shared_io/src/main/java/com/rusefi/server/UserDetails.java similarity index 100% rename from java_tools/proxy_server/src/main/java/com/rusefi/server/UserDetails.java rename to java_console/shared_io/src/main/java/com/rusefi/server/UserDetails.java diff --git a/java_console/shared_io/src/main/java/com/rusefi/tools/online/ProxyClient.java b/java_console/shared_io/src/main/java/com/rusefi/tools/online/ProxyClient.java new file mode 100644 index 0000000000..21ddfebf90 --- /dev/null +++ b/java_console/shared_io/src/main/java/com/rusefi/tools/online/ProxyClient.java @@ -0,0 +1,4 @@ +package com.rusefi.tools.online; + +public class ProxyClient { +}