rusefi-full/firmware/controllers/trigger/decoders/trigger_bmw.cpp

75 lines
1.5 KiB
C++
Raw Normal View History

2015-07-10 06:01:56 -07:00
/**
* @file trigger_bmw.cpp
*
* @date May 11, 2014
2018-01-20 17:55:31 -08:00
* @author Andrey Belomutskiy, (c) 2012-2018
2015-07-10 06:01:56 -07:00
*/
#include "trigger_bmw.h"
static inline float addPair(TriggerWaveform *s, float a, float w) {
2018-12-25 08:51:49 -08:00
s->addEvent720(a, T_SECONDARY, TV_RISE);
2015-07-10 06:01:56 -07:00
a += w;
2018-12-25 08:51:49 -08:00
s->addEvent720(a, T_SECONDARY, TV_FALL);
2015-07-10 06:01:56 -07:00
a += w;
return a;
}
void configureMiniCooperTriggerWaveform(TriggerWaveform *s) {
2015-10-29 11:02:52 -07:00
s->initialize(FOUR_STROKE_CAM_SENSOR, true);
2015-07-10 06:01:56 -07:00
// s->initialState[0] = 1;
float w = 360.0 / 121;
float a = w / 2;
2018-12-25 08:51:49 -08:00
s->addEvent720(a, T_SECONDARY, TV_FALL);
2015-07-10 06:01:56 -07:00
a += w;
for (int i = 0; i <= 22; i++) {
2018-12-25 08:51:49 -08:00
a = addPair(s, a, w);
2015-07-10 06:01:56 -07:00
}
a += 3 * w;
float firstGapAngle = a;
/* may be */UNUSED(firstGapAngle);
2015-07-10 06:01:56 -07:00
2018-12-25 08:51:49 -08:00
s->addEvent720(a, T_SECONDARY, TV_RISE);
2015-07-10 06:01:56 -07:00
a += 3 * w;
2018-12-25 08:51:49 -08:00
s->addEvent720(a, T_SECONDARY, TV_FALL);
2015-07-10 06:01:56 -07:00
a += w;
for (int i = 0; i < 36; i++) {
2018-12-25 08:51:49 -08:00
a = addPair(s, a, w);
2015-07-10 06:01:56 -07:00
}
2018-12-25 08:51:49 -08:00
s->addEvent720(376, T_PRIMARY, TV_RISE);
2015-07-10 06:01:56 -07:00
for (int i = 0; i < 21; i++) {
2018-12-25 08:51:49 -08:00
a = addPair(s, a, w);
2015-07-10 06:01:56 -07:00
}
a += 3 * w;
2018-07-25 20:03:04 -07:00
efiAssertVoid(CUSTOM_ERR_6584, absF(firstGapAngle + 360 - a) < 0.1, "shape constraint");
2015-07-10 06:01:56 -07:00
2018-12-25 08:51:49 -08:00
s->addEvent720(a, T_SECONDARY, TV_RISE);
2015-07-10 06:01:56 -07:00
a += 3 * w;
2018-12-25 08:51:49 -08:00
s->addEvent720(a, T_SECONDARY, TV_FALL);
2015-07-10 06:01:56 -07:00
a += w;
for (int i = 0; i < 33; i++) {
2018-12-25 08:51:49 -08:00
a = addPair(s, a, w);
2015-07-10 06:01:56 -07:00
}
2018-07-25 20:03:04 -07:00
efiAssertVoid(CUSTOM_ERR_6585, absF(720 - w / 2 - a) < 0.1, "shape constraint");
2018-12-25 08:51:49 -08:00
s->addEvent720(a, T_SECONDARY, TV_RISE);
2015-07-10 06:01:56 -07:00
2018-12-25 08:51:49 -08:00
s->addEvent720(720.0, T_PRIMARY, TV_FALL);
2015-07-10 06:01:56 -07:00
/**
* With just one tooth on camshaft synchronization is not needed
*/
s->isSynchronizationNeeded = false;
2016-06-13 23:01:37 -07:00
s->useOnlyPrimaryForSync = true;
2015-07-10 06:01:56 -07:00
}