2018-03-22 10:37:34 -07:00
|
|
|
/*
|
2019-10-16 13:46:34 -07:00
|
|
|
* @file test_fuelCut.cpp
|
2018-03-22 10:37:34 -07:00
|
|
|
*
|
2019-10-16 13:46:34 -07:00
|
|
|
* @date Mar 22, 2018
|
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2019
|
2018-03-22 10:37:34 -07:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "engine_math.h"
|
2019-01-15 18:36:13 -08:00
|
|
|
#include "engine_test_helper.h"
|
2018-03-22 10:37:34 -07:00
|
|
|
#include "event_queue.h"
|
|
|
|
#include "tps.h"
|
2019-01-19 19:09:37 -08:00
|
|
|
#include "fsio_impl.h"
|
2018-03-22 10:37:34 -07:00
|
|
|
|
2019-01-08 19:10:54 -08:00
|
|
|
TEST(fuelCut, coasting) {
|
2018-03-22 10:37:34 -07:00
|
|
|
printf("*************************************************** testCoastingFuelCut\r\n");
|
|
|
|
|
2019-01-19 19:09:37 -08:00
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
2018-03-22 10:37:34 -07:00
|
|
|
|
|
|
|
// configure coastingFuelCut
|
|
|
|
engineConfiguration->bc.coastingFuelCutEnabled = true;
|
|
|
|
engineConfiguration->coastingFuelCutRpmLow = 1300;
|
|
|
|
engineConfiguration->coastingFuelCutRpmHigh = 1500;
|
|
|
|
engineConfiguration->coastingFuelCutTps = 2;
|
|
|
|
engineConfiguration->coastingFuelCutClt = 30;
|
2018-06-23 06:32:41 -07:00
|
|
|
engineConfiguration->coastingFuelCutMap = 100;
|
2018-03-22 10:37:34 -07:00
|
|
|
// set cranking threshold
|
|
|
|
engineConfiguration->cranking.rpm = 999;
|
|
|
|
// configure TPS
|
2019-01-04 21:57:09 -08:00
|
|
|
engineConfiguration->tpsMin = 0;
|
|
|
|
engineConfiguration->tpsMax = 10;
|
2018-03-22 10:37:34 -07:00
|
|
|
|
|
|
|
// basic engine setup
|
|
|
|
setupSimpleTestEngineWithMafAndTT_ONE_trigger(ð);
|
|
|
|
|
|
|
|
// mock CLT - just above threshold ('hot engine')
|
|
|
|
float hotClt = engine->sensors.clt = engineConfiguration->coastingFuelCutClt + 1;
|
|
|
|
// mock TPS - throttle is opened
|
2019-05-27 12:56:12 -07:00
|
|
|
setMockTpsAdc(6 PASS_ENGINE_PARAMETER_SUFFIX);
|
2018-03-22 10:37:34 -07:00
|
|
|
// set 'running' RPM - just above RpmHigh threshold
|
|
|
|
engine->rpmCalculator.mockRpm = engineConfiguration->coastingFuelCutRpmHigh + 1;
|
|
|
|
// 'advance' time (amount doesn't matter)
|
2019-01-10 20:15:24 -08:00
|
|
|
eth.moveTimeForwardUs(1000);
|
2018-03-22 10:37:34 -07:00
|
|
|
|
|
|
|
const float normalInjDuration = 1.5f;
|
|
|
|
/*
|
|
|
|
* We need to pass through all rpm changes (high-mid-low-mid-high) because of state-machine
|
|
|
|
*/
|
|
|
|
|
|
|
|
// process
|
|
|
|
eth.engine.periodicFastCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
// this is normal injection mode (the throttle is opened), no fuel cut-off
|
|
|
|
assertEqualsM("inj dur#1 norm", normalInjDuration, ENGINE(injectionDuration));
|
|
|
|
|
|
|
|
// 'releasing' the throttle
|
2019-05-27 12:56:12 -07:00
|
|
|
setMockTpsAdc(0 PASS_ENGINE_PARAMETER_SUFFIX);
|
2018-03-22 10:37:34 -07:00
|
|
|
eth.engine.periodicFastCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
// Fuel cut-off is enabled now
|
|
|
|
assertEqualsM("inj dur#2 cut", 0.0f, ENGINE(injectionDuration));
|
|
|
|
|
|
|
|
// Now drop the CLT below threshold
|
|
|
|
engine->sensors.clt = engineConfiguration->coastingFuelCutClt - 1;
|
|
|
|
eth.engine.periodicFastCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
// Fuel cut-off should be diactivated - the engine is 'cold'
|
|
|
|
assertEqualsM("inj dur#3 clt", normalInjDuration, ENGINE(injectionDuration));
|
|
|
|
|
|
|
|
// restore CLT
|
|
|
|
engine->sensors.clt = hotClt;
|
|
|
|
// And set RPM - somewhere between RpmHigh and RpmLow threshold
|
|
|
|
engine->rpmCalculator.mockRpm = (engineConfiguration->coastingFuelCutRpmHigh + engineConfiguration->coastingFuelCutRpmLow) / 2;
|
|
|
|
eth.engine.periodicFastCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
// Fuel cut-off is enabled - nothing should change
|
|
|
|
assertEqualsM("inj dur#4 mid", normalInjDuration, ENGINE(injectionDuration));
|
|
|
|
|
|
|
|
// Now drop RPM just below RpmLow threshold
|
|
|
|
engine->rpmCalculator.mockRpm = engineConfiguration->coastingFuelCutRpmLow - 1;
|
|
|
|
eth.engine.periodicFastCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
// Fuel cut-off is now disabled (the engine is idling)
|
|
|
|
assertEqualsM("inj dur#5 idle", normalInjDuration, ENGINE(injectionDuration));
|
|
|
|
|
|
|
|
// Now change RPM just below RpmHigh threshold
|
|
|
|
engine->rpmCalculator.mockRpm = engineConfiguration->coastingFuelCutRpmHigh - 1;
|
|
|
|
eth.engine.periodicFastCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
// Fuel cut-off is still disabled
|
|
|
|
assertEqualsM("inj dur#6 mid", normalInjDuration, ENGINE(injectionDuration));
|
|
|
|
|
|
|
|
// Now set RPM just above RpmHigh threshold
|
|
|
|
engine->rpmCalculator.mockRpm = engineConfiguration->coastingFuelCutRpmHigh + 1;
|
|
|
|
eth.engine.periodicFastCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
// Fuel cut-off is active again!
|
|
|
|
assertEqualsM("inj dur#7 cut", 0.0f, ENGINE(injectionDuration));
|
|
|
|
}
|
2019-01-19 19:09:37 -08:00
|
|
|
|
|
|
|
|
|
|
|
TEST(fuelCut, criticalEngineTemperature) {
|
|
|
|
WITH_ENGINE_TEST_HELPER(TEST_ENGINE);
|
|
|
|
|
|
|
|
setupSimpleTestEngineWithMafAndTT_ONE_trigger(ð);
|
|
|
|
|
|
|
|
engineConfiguration->useFSIO5ForCriticalIssueEngineStop = true;
|
2019-05-03 15:41:43 -07:00
|
|
|
setFsio(MAGIC_OFFSET_FOR_CRITICAL_ENGINE, GPIOD_7, TOO_HOT_LOGIC PASS_CONFIG_PARAMETER_SUFFIX);
|
2019-01-19 19:09:37 -08:00
|
|
|
applyFsioConfiguration(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
// we need some non-zero time as getTimeNow() which would become stopEngineRequestTimeNt
|
|
|
|
eth.moveTimeForwardUs(1000);
|
|
|
|
|
|
|
|
engine->rpmCalculator.mockRpm = 2000;
|
|
|
|
eth.engine.periodicFastCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
eth.engine.periodicSlowCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
ASSERT_EQ(engine->stopEngineRequestTimeNt, 0);
|
|
|
|
|
|
|
|
ASSERT_FALSE(engine->stopEngineRequestTimeNt > 0);
|
|
|
|
|
|
|
|
engine->sensors.mockClt = 200; // 200C is really hot!
|
|
|
|
eth.engine.periodicFastCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
eth.engine.periodicSlowCallback(PASS_ENGINE_PARAMETER_SIGNATURE);
|
|
|
|
|
|
|
|
ASSERT_TRUE(engine->stopEngineRequestTimeNt > 0);
|
|
|
|
}
|
2019-09-24 15:39:26 -07:00
|
|
|
|
|
|
|
|
|
|
|
TEST(fuel, injectorFlowCorrection) {
|
|
|
|
|
|
|
|
|
|
|
|
}
|