2021-02-06 17:53:30 -08:00
|
|
|
/**
|
|
|
|
* @file test_all_triggers.cpp
|
|
|
|
*/
|
2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
2021-01-05 14:58:34 -08:00
|
|
|
|
2023-01-03 12:44:13 -08:00
|
|
|
// uncomment to test starting from specific trigger
|
|
|
|
//#define TEST_FROM_TRIGGER_ID ((int)TT_MAZDA_MIATA_NA)
|
2021-02-06 17:53:30 -08:00
|
|
|
// uncomment to test only newest trigger
|
|
|
|
//#define TEST_FROM_TRIGGER_ID ((int)TT_UNUSED - 1)
|
|
|
|
#define TEST_FROM_TRIGGER_ID 1
|
2021-01-05 14:58:34 -08:00
|
|
|
|
2023-01-03 12:44:13 -08:00
|
|
|
#define TEST_TO_TRIGGER_ID TT_UNUSED
|
|
|
|
// uncomment to test only one trigger
|
|
|
|
//#define TEST_TO_TRIGGER_ID (TEST_FROM_TRIGGER_ID + 1)
|
|
|
|
|
2021-01-05 14:58:34 -08:00
|
|
|
struct TriggerExportHelper
|
|
|
|
{
|
|
|
|
FILE* fp;
|
|
|
|
|
|
|
|
TriggerExportHelper() {
|
|
|
|
fp = fopen (TRIGGERS_FILE_NAME, "w+");
|
|
|
|
|
2022-03-14 10:11:10 -07:00
|
|
|
fprintf(fp, "# Generated by rusEFI unit test suite\n");
|
2021-01-05 14:58:34 -08:00
|
|
|
fprintf(fp, "# This file is used by TriggerImage tool\n");
|
|
|
|
fprintf(fp, "# See 'gen_trigger_images.bat'\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
~TriggerExportHelper() {
|
|
|
|
fclose(fp);
|
|
|
|
printf("All triggers exported to %s\n", TRIGGERS_FILE_NAME);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
static TriggerExportHelper exportHelper;
|
|
|
|
|
|
|
|
class AllTriggersFixture : public ::testing::TestWithParam<trigger_type_e> {
|
|
|
|
};
|
|
|
|
|
|
|
|
INSTANTIATE_TEST_SUITE_P(
|
|
|
|
Triggers,
|
|
|
|
AllTriggersFixture,
|
|
|
|
// Test all triggers from the first valid trigger thru the last
|
|
|
|
// (Skip index 0, that's custom toothed wheel which is covered by others)
|
2023-01-03 12:44:13 -08:00
|
|
|
::testing::Range((trigger_type_e)TEST_FROM_TRIGGER_ID, (trigger_type_e)TEST_TO_TRIGGER_ID)
|
2021-01-05 14:58:34 -08:00
|
|
|
);
|
|
|
|
|
|
|
|
extern bool printTriggerDebug;
|
|
|
|
extern bool printTriggerTrace;
|
|
|
|
|
|
|
|
TEST_P(AllTriggersFixture, TestTrigger) {
|
|
|
|
// handy debugging options
|
|
|
|
//printTriggerDebug = true;
|
|
|
|
//printTriggerTrace = true;
|
|
|
|
|
|
|
|
auto tt = GetParam();
|
|
|
|
auto fp = exportHelper.fp;
|
|
|
|
|
|
|
|
printf("Exporting %s\r\n", getTrigger_type_e(tt));
|
|
|
|
|
|
|
|
persistent_config_s pc;
|
2021-11-15 21:23:14 -08:00
|
|
|
memset(&pc, 0, sizeof(pc));
|
2021-02-16 13:58:54 -08:00
|
|
|
Engine e;
|
|
|
|
Engine* engine = &e;
|
2021-11-15 21:23:14 -08:00
|
|
|
EngineTestHelperBase base(engine, &pc.engineConfiguration, &pc);
|
2021-01-05 14:58:34 -08:00
|
|
|
|
2023-01-03 12:44:13 -08:00
|
|
|
#if EFI_UNIT_TEST
|
|
|
|
extern TriggerDecoderBase initState;
|
|
|
|
for (size_t i = 0;i<efi::size(initState.gapRatio);i++) {
|
2023-01-03 18:16:35 -08:00
|
|
|
initState.gapRatio[i] = NAN;
|
2023-01-03 12:44:13 -08:00
|
|
|
}
|
|
|
|
#endif // EFI_UNIT_TEST
|
|
|
|
|
2021-01-05 14:58:34 -08:00
|
|
|
engineConfiguration->trigger.type = tt;
|
2022-04-02 23:21:37 -07:00
|
|
|
setCamOperationMode();
|
2021-01-05 14:58:34 -08:00
|
|
|
|
|
|
|
TriggerWaveform *shape = &engine->triggerCentral.triggerShape;
|
|
|
|
TriggerFormDetails *triggerFormDetails = &engine->triggerCentral.triggerFormDetails;
|
2022-04-02 16:27:18 -07:00
|
|
|
engine->updateTriggerWaveform();
|
2021-01-05 14:58:34 -08:00
|
|
|
|
|
|
|
ASSERT_FALSE(shape->shapeDefinitionError) << "Trigger shapeDefinitionError";
|
|
|
|
|
|
|
|
fprintf(fp, "TRIGGERTYPE %d %d %s %.2f\n", tt, shape->getLength(), getTrigger_type_e(tt), shape->tdcPosition);
|
2022-04-03 14:56:47 -07:00
|
|
|
|
2022-04-03 09:22:47 -07:00
|
|
|
fprintf(fp, "%s=%s\n", TRIGGER_HARDCODED_OPERATION_MODE, shape->knownOperationMode ? "true" : "false");
|
2023-01-08 19:37:25 -08:00
|
|
|
operation_mode_e mode = shape->getWheelOperationMode();
|
|
|
|
bool isOneOfCrankShapes = mode == FOUR_STROKE_CRANK_SENSOR ||
|
|
|
|
mode == FOUR_STROKE_THREE_TIMES_CRANK_SENSOR ||
|
|
|
|
mode == FOUR_STROKE_SYMMETRICAL_CRANK_SENSOR ||
|
|
|
|
mode == FOUR_STROKE_TWELVE_TIMES_CRANK_SENSOR;
|
|
|
|
fprintf(fp, "%s=%s\n", TRIGGER_IS_CRANK_KEY, shape->knownOperationMode && isOneOfCrankShapes ? "true" : "false");
|
2022-04-03 14:56:47 -07:00
|
|
|
|
|
|
|
fprintf(fp, "%s=%s\n", TRIGGER_HAS_SECOND_CHANNEL, shape->needSecondTriggerInput ? "true" : "false");
|
|
|
|
fprintf(fp, "%s=%s\n", TRIGGER_IS_SECOND_WHEEL_CAM, shape->isSecondWheelCam ? "true" : "false");
|
2022-10-16 07:33:38 -07:00
|
|
|
fprintf(fp, "%s=%d\n", TRIGGER_CYCLE_DURATION, (int)shape->getCycleDuration());
|
2022-07-11 21:11:25 -07:00
|
|
|
fprintf(fp, "%s=%d\n", TRIGGER_GAPS_COUNT, shape->gapTrackingLength);
|
2023-01-08 19:30:45 -08:00
|
|
|
fprintf(fp, "%s=%d\n", TRIGGER_WITH_SYNC, shape->isSynchronizationNeeded);
|
2022-07-11 21:11:25 -07:00
|
|
|
for (int i = 0; i < shape->gapTrackingLength; i++) {
|
|
|
|
fprintf(fp, "%s.%d=%f\n", TRIGGER_GAP_FROM, i, shape->syncronizationRatioFrom[i]);
|
|
|
|
fprintf(fp, "%s.%d=%f\n", TRIGGER_GAP_TO, i, shape->syncronizationRatioTo[i]);
|
|
|
|
}
|
2022-05-31 07:45:32 -07:00
|
|
|
fprintf(fp, "# end of meta section\n");
|
2021-01-05 14:58:34 -08:00
|
|
|
|
|
|
|
for (size_t i = 0; i < shape->getLength(); i++) {
|
|
|
|
int triggerDefinitionCoordinate = (shape->getTriggerWaveformSynchPointIndex() + i) % shape->getSize();
|
|
|
|
|
2023-01-03 12:44:13 -08:00
|
|
|
fprintf(fp, "event %d %d %d %.2f %f\n",
|
2021-01-05 14:58:34 -08:00
|
|
|
i,
|
|
|
|
shape->triggerSignalIndeces[triggerDefinitionCoordinate],
|
|
|
|
shape->triggerSignalStates[triggerDefinitionCoordinate],
|
2023-01-03 12:44:13 -08:00
|
|
|
triggerFormDetails->eventAngles[i],
|
|
|
|
initState.gapRatio[i]
|
|
|
|
);
|
2021-01-05 14:58:34 -08:00
|
|
|
}
|
|
|
|
}
|