custom-board-bundle-sample-.../unit_tests/engine_test_helper.cpp

103 lines
4.0 KiB
C++
Raw Normal View History

2015-07-10 06:01:56 -07:00
/**
* @file engine_test_helper.cpp
*
* @date Jun 26, 2014
* @author Andrey Belomutskiy, (c) 2012-2014
*/
#include "engine_test_helper.h"
#include "stddef.h"
#include "trigger_decoder.h"
#include "speed_density.h"
#include "fuel_math.h"
2016-03-11 08:03:18 -08:00
#include "accel_enrichment.h"
2016-08-26 14:02:37 -07:00
#include "thermistors.h"
2016-08-26 15:02:39 -07:00
#include "advance_map.h"
2016-11-07 19:02:21 -08:00
#include "event_queue.h"
2015-07-10 06:01:56 -07:00
extern int timeNow;
2016-11-03 20:02:58 -07:00
extern EnginePins enginePins;
2016-11-07 19:02:21 -08:00
extern EventQueue schedulingQueue;
extern int warningCounter;
2015-07-10 06:01:56 -07:00
EngineTestHelper::EngineTestHelper(engine_type_e engineType) : engine (&persistentConfig) {
ec = &persistentConfig.engineConfiguration;
2016-11-07 19:02:21 -08:00
warningCounter = 0;
2015-07-10 06:01:56 -07:00
2016-11-07 19:02:21 -08:00
schedulingQueue.clear();
2016-11-01 06:02:29 -07:00
enginePins.reset();
2016-09-03 16:02:42 -07:00
2015-07-10 06:01:56 -07:00
engineConfiguration = ec;
board_configuration_s * boardConfiguration = &engineConfiguration->bc;
persistent_config_s *config = &persistentConfig;
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, -40, 1.5);
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, -30, 1.5);
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, -20, 1.42);
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, -10, 1.36);
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, 0, 1.28);
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, 10, 1.19);
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, 20, 1.12);
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, 30, 1.10);
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, 40, 1.06);
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, 50, 1.06);
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, 60, 1.03);
setTableValue(config->cltFuelCorrBins, config->cltFuelCorr, CLT_CURVE_SIZE, 70, 1.01);
Engine *engine = &this->engine;
prepareFuelMap(PASS_ENGINE_PARAMETER_F);
2016-03-11 08:03:18 -08:00
initAccelEnrichment(NULL PASS_ENGINE_PARAMETER);
2015-07-10 06:01:56 -07:00
initSpeedDensity(PASS_ENGINE_PARAMETER_F);
resetConfigurationExt(NULL, engineType PASS_ENGINE_PARAMETER);
prepareShapes(PASS_ENGINE_PARAMETER_F);
engine->engineConfiguration->mafAdcChannel = (adc_channel_e)TEST_MAF_CHANNEL;
2016-08-26 14:02:37 -07:00
initThermistors(NULL PASS_ENGINE_PARAMETER);
// this is needed to have valid CLT and IAT.
engine->updateSlowSensors(PASS_ENGINE_PARAMETER_F);
2016-08-26 15:02:39 -07:00
prepareTimingMap(PASS_ENGINE_PARAMETER_F);
2016-08-26 17:03:06 -07:00
engine_configuration_s *engineConfiguration = engine->engineConfiguration;
2017-03-01 19:18:25 -08:00
engine->triggerCentral.triggerShape.initializeTriggerShape(NULL PASS_ENGINE_PARAMETER);
2016-08-26 17:03:06 -07:00
engine->triggerCentral.addEventListener(rpmShaftPositionCallback, "rpm reporter", engine);
2016-08-26 20:02:24 -07:00
engine->triggerCentral.addEventListener(mainTriggerCallback, "main loop", engine);
2015-07-10 06:01:56 -07:00
}
2016-08-27 16:02:43 -07:00
void EngineTestHelper::firePrimaryTriggerRise() {
board_configuration_s * boardConfiguration = &engine.engineConfiguration->bc;
engine.triggerCentral.handleShaftSignal(SHAFT_PRIMARY_RISING, &engine, engine.engineConfiguration, &persistentConfig, boardConfiguration);
}
void EngineTestHelper::firePrimaryTriggerFall() {
board_configuration_s * boardConfiguration = &engine.engineConfiguration->bc;
engine.triggerCentral.handleShaftSignal(SHAFT_PRIMARY_FALLING, &engine, engine.engineConfiguration, &persistentConfig, boardConfiguration);
}
2016-08-26 15:02:39 -07:00
void EngineTestHelper::fireTriggerEvents2(int count, int duration) {
2016-01-24 22:02:55 -08:00
for (int i = 0; i < count; i++) {
2016-08-26 15:02:39 -07:00
timeNow += duration;
2016-08-27 16:02:43 -07:00
firePrimaryTriggerRise();
2016-08-26 15:02:39 -07:00
timeNow += duration;
2016-08-27 16:02:43 -07:00
firePrimaryTriggerFall();
2015-07-10 06:01:56 -07:00
}
}
2016-08-26 15:02:39 -07:00
void EngineTestHelper::fireTriggerEvents(int count) {
fireTriggerEvents2(count, 5000); // 5ms
}
2016-08-26 17:03:06 -07:00
void EngineTestHelper::applyTriggerShape() {
2015-07-10 06:01:56 -07:00
Engine *engine = &this->engine;
engine_configuration_s *engineConfiguration = engine->engineConfiguration;
persistent_config_s *config = engine->config;
board_configuration_s *boardConfiguration = &engineConfiguration->bc;
2017-03-01 19:18:25 -08:00
engine->triggerCentral.triggerShape.initializeTriggerShape(NULL PASS_ENGINE_PARAMETER);
2015-07-10 06:01:56 -07:00
2016-09-14 20:03:47 -07:00
incrementGlobalConfigurationVersion(PASS_ENGINE_PARAMETER_F);
2015-07-10 06:01:56 -07:00
}