refactoring: type safety
This commit is contained in:
parent
23fc3f288d
commit
851e8e48d3
|
@ -11,10 +11,10 @@
|
||||||
#include "rusefi_enums.h"
|
#include "rusefi_enums.h"
|
||||||
#include "expected.h"
|
#include "expected.h"
|
||||||
|
|
||||||
typedef enum {
|
enum class TriggerValue : uint8_t {
|
||||||
TV_FALL = 0,
|
FALL = 0,
|
||||||
TV_RISE = 1
|
RISE = 1
|
||||||
} trigger_value_e;
|
};
|
||||||
|
|
||||||
// see also 'HW_EVENT_TYPES'
|
// see also 'HW_EVENT_TYPES'
|
||||||
typedef enum {
|
typedef enum {
|
||||||
|
@ -40,7 +40,7 @@ typedef enum {
|
||||||
#endif /* PWM_PHASE_MAX_COUNT */
|
#endif /* PWM_PHASE_MAX_COUNT */
|
||||||
#define PWM_PHASE_MAX_WAVE_PER_PWM 2
|
#define PWM_PHASE_MAX_WAVE_PER_PWM 2
|
||||||
|
|
||||||
typedef trigger_value_e pin_state_t;
|
typedef TriggerValue pin_state_t;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class represents multi-channel logical signals with shared time axis
|
* This class represents multi-channel logical signals with shared time axis
|
||||||
|
@ -83,7 +83,7 @@ public:
|
||||||
// todo: would be nice to get this asserting working
|
// todo: would be nice to get this asserting working
|
||||||
//firmwareError(OBD_PCM_Processor_Fault, "channel index %d/%d", channelIndex, waveCount);
|
//firmwareError(OBD_PCM_Processor_Fault, "channel index %d/%d", channelIndex, waveCount);
|
||||||
}
|
}
|
||||||
return ((waveForm[phaseIndex] >> channelIndex) & 1) ? TV_RISE : TV_FALL;
|
return ((waveForm[phaseIndex] >> channelIndex) & 1) ? TriggerValue::RISE : TriggerValue::FALL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void reset() {
|
void reset() {
|
||||||
|
@ -100,7 +100,7 @@ public:
|
||||||
//firmwareError(OBD_PCM_Processor_Fault, "channel index %d/%d", channelIndex, waveCount);
|
//firmwareError(OBD_PCM_Processor_Fault, "channel index %d/%d", channelIndex, waveCount);
|
||||||
}
|
}
|
||||||
uint8_t & ref = waveForm[phaseIndex];
|
uint8_t & ref = waveForm[phaseIndex];
|
||||||
ref = (ref & ~(1U << channelIndex)) | ((state == TV_RISE ? 1 : 0) << channelIndex);
|
ref = (ref & ~(1U << channelIndex)) | ((state == TriggerValue::RISE ? 1 : 0) << channelIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -316,8 +316,8 @@ void startSimplePwm(SimplePwm *state, const char *msg, ExecutorInterface *execut
|
||||||
|
|
||||||
state->seq.setSwitchTime(0, dutyCycle);
|
state->seq.setSwitchTime(0, dutyCycle);
|
||||||
state->seq.setSwitchTime(1, 1);
|
state->seq.setSwitchTime(1, 1);
|
||||||
state->seq.setChannelState(0, 0, TV_FALL);
|
state->seq.setChannelState(0, 0, TriggerValue::FALL);
|
||||||
state->seq.setChannelState(0, 1, TV_RISE);
|
state->seq.setChannelState(0, 1, TriggerValue::RISE);
|
||||||
|
|
||||||
state->outputPins[0] = output;
|
state->outputPins[0] = output;
|
||||||
|
|
||||||
|
@ -376,7 +376,7 @@ void applyPinState(int stateIndex, PwmConfig *state) /* pwm_gen_callback */ {
|
||||||
efiAssertVoid(CUSTOM_ERR_6664, state->multiChannelStateSequence->waveCount <= PWM_PHASE_MAX_WAVE_PER_PWM, "invalid waveCount");
|
efiAssertVoid(CUSTOM_ERR_6664, state->multiChannelStateSequence->waveCount <= PWM_PHASE_MAX_WAVE_PER_PWM, "invalid waveCount");
|
||||||
for (int channelIndex = 0; channelIndex < state->multiChannelStateSequence->waveCount; channelIndex++) {
|
for (int channelIndex = 0; channelIndex < state->multiChannelStateSequence->waveCount; channelIndex++) {
|
||||||
OutputPin *output = state->outputPins[channelIndex];
|
OutputPin *output = state->outputPins[channelIndex];
|
||||||
int value = state->multiChannelStateSequence->getChannelState(channelIndex, stateIndex);
|
TriggerValue value = state->multiChannelStateSequence->getChannelState(channelIndex, stateIndex);
|
||||||
output->setValue(value);
|
output->setValue(value == TriggerValue::RISE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,11 +19,11 @@ void initDodgeRam(TriggerWaveform *s) {
|
||||||
|
|
||||||
addSkippedToothTriggerEvents(T_SECONDARY, s, 8, 0, 0.06, -25, 360, 0, 720);
|
addSkippedToothTriggerEvents(T_SECONDARY, s, 8, 0, 0.06, -25, 360, 0, 720);
|
||||||
|
|
||||||
s->addEvent720(360, T_PRIMARY, TV_RISE);
|
s->addEvent720(360, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
addSkippedToothTriggerEvents(T_SECONDARY, s, 8, 0, 0.06, 360 - 25, 360, 0, 720);
|
addSkippedToothTriggerEvents(T_SECONDARY, s, 8, 0, 0.06, 360 - 25, 360, 0, 720);
|
||||||
|
|
||||||
s->addEvent720(720, T_PRIMARY, TV_FALL);
|
s->addEvent720(720, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void configureNeon2003TriggerWaveformCrank(TriggerWaveform *s) {
|
void configureNeon2003TriggerWaveformCrank(TriggerWaveform *s) {
|
||||||
|
@ -32,71 +32,71 @@ void configureNeon2003TriggerWaveformCrank(TriggerWaveform *s) {
|
||||||
|
|
||||||
s->setTriggerSynchronizationGap(3);
|
s->setTriggerSynchronizationGap(3);
|
||||||
|
|
||||||
s->addEvent360(25, T_PRIMARY, TV_FALL);
|
s->addEvent360(25, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(30, T_PRIMARY, TV_RISE);
|
s->addEvent360(30, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(35, T_PRIMARY, TV_FALL);
|
s->addEvent360(35, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(40, T_PRIMARY, TV_RISE);
|
s->addEvent360(40, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(45, T_PRIMARY, TV_FALL);
|
s->addEvent360(45, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(50, T_PRIMARY, TV_RISE);
|
s->addEvent360(50, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(55, T_PRIMARY, TV_FALL);
|
s->addEvent360(55, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(60, T_PRIMARY, TV_RISE);
|
s->addEvent360(60, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(65, T_PRIMARY, TV_FALL);
|
s->addEvent360(65, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(70, T_PRIMARY, TV_RISE);
|
s->addEvent360(70, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(75, T_PRIMARY, TV_FALL);
|
s->addEvent360(75, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(80, T_PRIMARY, TV_RISE);
|
s->addEvent360(80, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(85, T_PRIMARY, TV_FALL);
|
s->addEvent360(85, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(90, T_PRIMARY, TV_RISE);
|
s->addEvent360(90, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(95, T_PRIMARY, TV_FALL);
|
s->addEvent360(95, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(100, T_PRIMARY, TV_RISE);
|
s->addEvent360(100, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(105, T_PRIMARY, TV_FALL);
|
s->addEvent360(105, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(110, T_PRIMARY, TV_RISE);
|
s->addEvent360(110, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(115, T_PRIMARY, TV_FALL);
|
s->addEvent360(115, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(120, T_PRIMARY, TV_RISE);
|
s->addEvent360(120, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(125, T_PRIMARY, TV_FALL);
|
s->addEvent360(125, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(130, T_PRIMARY, TV_RISE);
|
s->addEvent360(130, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(135, T_PRIMARY, TV_FALL);
|
s->addEvent360(135, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(140, T_PRIMARY, TV_RISE);
|
s->addEvent360(140, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(145,T_PRIMARY, TV_FALL);
|
s->addEvent360(145,T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(150, T_PRIMARY, TV_RISE);
|
s->addEvent360(150, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(155, T_PRIMARY, TV_FALL);
|
s->addEvent360(155, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(160, T_PRIMARY, TV_RISE);
|
s->addEvent360(160, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(165, T_PRIMARY, TV_FALL);
|
s->addEvent360(165, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(170, T_PRIMARY, TV_RISE);
|
s->addEvent360(170, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(175, T_PRIMARY, TV_FALL);
|
s->addEvent360(175, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(180, T_PRIMARY, TV_RISE);
|
s->addEvent360(180, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(185, T_PRIMARY, TV_FALL);
|
s->addEvent360(185, T_PRIMARY, TriggerValue::FALL);
|
||||||
// gap 25
|
// gap 25
|
||||||
s->addEvent360(210, T_PRIMARY, TV_RISE);
|
s->addEvent360(210, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(215, T_PRIMARY, TV_FALL);
|
s->addEvent360(215, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(220, T_PRIMARY, TV_RISE);
|
s->addEvent360(220, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(225, T_PRIMARY, TV_FALL);
|
s->addEvent360(225, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(230, T_PRIMARY, TV_RISE);
|
s->addEvent360(230, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(235, T_PRIMARY, TV_FALL);
|
s->addEvent360(235, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(240, T_PRIMARY, TV_RISE);
|
s->addEvent360(240, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(245, T_PRIMARY, TV_FALL);
|
s->addEvent360(245, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(250, T_PRIMARY, TV_RISE);
|
s->addEvent360(250, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(255, T_PRIMARY, TV_FALL);
|
s->addEvent360(255, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(260, T_PRIMARY, TV_RISE);
|
s->addEvent360(260, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(265, T_PRIMARY, TV_FALL);
|
s->addEvent360(265, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(270, T_PRIMARY, TV_RISE);
|
s->addEvent360(270, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(275, T_PRIMARY, TV_FALL);
|
s->addEvent360(275, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(280, T_PRIMARY, TV_RISE);
|
s->addEvent360(280, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(285, T_PRIMARY, TV_FALL);
|
s->addEvent360(285, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(290, T_PRIMARY, TV_RISE);
|
s->addEvent360(290, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(295, T_PRIMARY, TV_FALL);
|
s->addEvent360(295, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(300, T_PRIMARY, TV_RISE);
|
s->addEvent360(300, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(305, T_PRIMARY, TV_FALL);
|
s->addEvent360(305, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(310, T_PRIMARY, TV_RISE);
|
s->addEvent360(310, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(315, T_PRIMARY, TV_FALL);
|
s->addEvent360(315, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(320, T_PRIMARY, TV_RISE);
|
s->addEvent360(320, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(325, T_PRIMARY, TV_FALL);
|
s->addEvent360(325, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(330, T_PRIMARY, TV_RISE);
|
s->addEvent360(330, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(335, T_PRIMARY, TV_FALL);
|
s->addEvent360(335, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(340, T_PRIMARY, TV_RISE);
|
s->addEvent360(340, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(345, T_PRIMARY, TV_FALL);
|
s->addEvent360(345, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(350, T_PRIMARY, TV_RISE);
|
s->addEvent360(350, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(355, T_PRIMARY, TV_FALL);
|
s->addEvent360(355, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent360(360, T_PRIMARY, TV_RISE);
|
s->addEvent360(360, T_PRIMARY, TriggerValue::RISE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void configureNeon2003TriggerWaveformCam(TriggerWaveform *s) {
|
void configureNeon2003TriggerWaveformCam(TriggerWaveform *s) {
|
||||||
|
@ -129,23 +129,23 @@ gap=1.43/0.71
|
||||||
s->useOnlyPrimaryForSync = true;
|
s->useOnlyPrimaryForSync = true;
|
||||||
|
|
||||||
if (useOnlyPrimary) {
|
if (useOnlyPrimary) {
|
||||||
s->addEvent720(144, T_PRIMARY, TV_RISE);
|
s->addEvent720(144, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(180, T_PRIMARY, TV_FALL);
|
s->addEvent720(180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(216, T_PRIMARY, TV_RISE);
|
s->addEvent720(216, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(252, T_PRIMARY, TV_FALL);
|
s->addEvent720(252, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(288, T_PRIMARY, TV_RISE);
|
s->addEvent720(288, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(324, T_PRIMARY, TV_FALL);
|
s->addEvent720(324, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(360, T_PRIMARY, TV_RISE); // width = 144
|
s->addEvent720(360, T_PRIMARY, TriggerValue::RISE); // width = 144
|
||||||
s->addEvent720(504, T_PRIMARY, TV_FALL); // width = 36
|
s->addEvent720(504, T_PRIMARY, TriggerValue::FALL); // width = 36
|
||||||
s->addEvent720(540, T_PRIMARY, TV_RISE);
|
s->addEvent720(540, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(576, T_PRIMARY, TV_FALL);
|
s->addEvent720(576, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(612, T_PRIMARY, TV_RISE);
|
s->addEvent720(612, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(648, T_PRIMARY, TV_FALL);
|
s->addEvent720(648, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(684, T_PRIMARY, TV_RISE);
|
s->addEvent720(684, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(720, T_PRIMARY, TV_FALL);
|
s->addEvent720(720, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
/**
|
/**
|
||||||
|
@ -154,171 +154,171 @@ gap=1.43/0.71
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
s->addEvent720(25, T_SECONDARY, TV_FALL);
|
s->addEvent720(25, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(30, T_SECONDARY, TV_RISE);
|
s->addEvent720(30, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(35, T_SECONDARY, TV_FALL);
|
s->addEvent720(35, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(40, T_SECONDARY, TV_RISE);
|
s->addEvent720(40, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(45, T_SECONDARY, TV_FALL);
|
s->addEvent720(45, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(50, T_SECONDARY, TV_RISE);
|
s->addEvent720(50, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(55, T_SECONDARY, TV_FALL);
|
s->addEvent720(55, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(60, T_SECONDARY, TV_RISE);
|
s->addEvent720(60, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(65, T_SECONDARY, TV_FALL);
|
s->addEvent720(65, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(70, T_SECONDARY, TV_RISE);
|
s->addEvent720(70, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(75, T_SECONDARY, TV_FALL);
|
s->addEvent720(75, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(80, T_SECONDARY, TV_RISE);
|
s->addEvent720(80, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(85, T_SECONDARY, TV_FALL);
|
s->addEvent720(85, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(90, T_SECONDARY, TV_RISE);
|
s->addEvent720(90, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(95, T_SECONDARY, TV_FALL);
|
s->addEvent720(95, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(100, T_SECONDARY, TV_RISE);
|
s->addEvent720(100, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(105, T_SECONDARY, TV_FALL);
|
s->addEvent720(105, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(110, T_SECONDARY, TV_RISE);
|
s->addEvent720(110, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(115, T_SECONDARY, TV_FALL);
|
s->addEvent720(115, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(120, T_SECONDARY, TV_RISE);
|
s->addEvent720(120, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(125, T_SECONDARY, TV_FALL);
|
s->addEvent720(125, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(130, T_SECONDARY, TV_RISE);
|
s->addEvent720(130, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(135, T_SECONDARY, TV_FALL);
|
s->addEvent720(135, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(140, T_SECONDARY, TV_RISE);
|
s->addEvent720(140, T_SECONDARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(144, T_PRIMARY, TV_RISE);
|
s->addEvent720(144, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(145,T_SECONDARY, TV_FALL);
|
s->addEvent720(145,T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(150, T_SECONDARY, TV_RISE);
|
s->addEvent720(150, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(155, T_SECONDARY, TV_FALL);
|
s->addEvent720(155, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(160, T_SECONDARY, TV_RISE);
|
s->addEvent720(160, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(165, T_SECONDARY, TV_FALL);
|
s->addEvent720(165, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(170, T_SECONDARY, TV_RISE);
|
s->addEvent720(170, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(175, T_SECONDARY, TV_FALL);
|
s->addEvent720(175, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(180 - EPS_ANGLE, T_SECONDARY, TV_RISE);
|
s->addEvent720(180 - EPS_ANGLE, T_SECONDARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(180, T_PRIMARY, TV_FALL);
|
s->addEvent720(180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(185, T_SECONDARY, TV_FALL);
|
s->addEvent720(185, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(210, T_SECONDARY, TV_RISE);
|
s->addEvent720(210, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(215, T_SECONDARY, TV_FALL);
|
s->addEvent720(215, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(216, T_PRIMARY, TV_RISE);
|
s->addEvent720(216, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(220, T_SECONDARY, TV_RISE);
|
s->addEvent720(220, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(225, T_SECONDARY, TV_FALL);
|
s->addEvent720(225, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(230, T_SECONDARY, TV_RISE);
|
s->addEvent720(230, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(235, T_SECONDARY, TV_FALL);
|
s->addEvent720(235, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(240, T_SECONDARY, TV_RISE);
|
s->addEvent720(240, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(245, T_SECONDARY, TV_FALL);
|
s->addEvent720(245, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(250, T_SECONDARY, TV_RISE);
|
s->addEvent720(250, T_SECONDARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(252, T_PRIMARY, TV_FALL);
|
s->addEvent720(252, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(255, T_SECONDARY, TV_FALL);
|
s->addEvent720(255, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(260, T_SECONDARY, TV_RISE);
|
s->addEvent720(260, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(265, T_SECONDARY, TV_FALL);
|
s->addEvent720(265, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(270, T_SECONDARY, TV_RISE);
|
s->addEvent720(270, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(275, T_SECONDARY, TV_FALL);
|
s->addEvent720(275, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(280, T_SECONDARY, TV_RISE);
|
s->addEvent720(280, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(285, T_SECONDARY, TV_FALL);
|
s->addEvent720(285, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(288, T_PRIMARY, TV_RISE);
|
s->addEvent720(288, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(290, T_SECONDARY, TV_RISE);
|
s->addEvent720(290, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(295, T_SECONDARY, TV_FALL);
|
s->addEvent720(295, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(300, T_SECONDARY, TV_RISE);
|
s->addEvent720(300, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(305, T_SECONDARY, TV_FALL);
|
s->addEvent720(305, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(310, T_SECONDARY, TV_RISE);
|
s->addEvent720(310, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(315, T_SECONDARY, TV_FALL);
|
s->addEvent720(315, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(320, T_SECONDARY, TV_RISE);
|
s->addEvent720(320, T_SECONDARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(324, T_PRIMARY, TV_FALL);
|
s->addEvent720(324, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(325, T_SECONDARY, TV_FALL);
|
s->addEvent720(325, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(330, T_SECONDARY, TV_RISE);
|
s->addEvent720(330, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(335, T_SECONDARY, TV_FALL);
|
s->addEvent720(335, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(340, T_SECONDARY, TV_RISE);
|
s->addEvent720(340, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(345, T_SECONDARY, TV_FALL);
|
s->addEvent720(345, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(350, T_SECONDARY, TV_RISE);
|
s->addEvent720(350, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(355, T_SECONDARY, TV_FALL);
|
s->addEvent720(355, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(360 - EPS_ANGLE, T_SECONDARY, TV_RISE);
|
s->addEvent720(360 - EPS_ANGLE, T_SECONDARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(360, T_PRIMARY, TV_RISE);
|
s->addEvent720(360, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(385, T_SECONDARY, TV_FALL);
|
s->addEvent720(385, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(390, T_SECONDARY, TV_RISE);
|
s->addEvent720(390, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(395, T_SECONDARY, TV_FALL);
|
s->addEvent720(395, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(400, T_SECONDARY, TV_RISE);
|
s->addEvent720(400, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(405, T_SECONDARY, TV_FALL);
|
s->addEvent720(405, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(410, T_SECONDARY, TV_RISE);
|
s->addEvent720(410, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(415, T_SECONDARY, TV_FALL);
|
s->addEvent720(415, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(420, T_SECONDARY, TV_RISE);
|
s->addEvent720(420, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(425, T_SECONDARY, TV_FALL);
|
s->addEvent720(425, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(430, T_SECONDARY, TV_RISE);
|
s->addEvent720(430, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(435, T_SECONDARY, TV_FALL);
|
s->addEvent720(435, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(440, T_SECONDARY, TV_RISE);
|
s->addEvent720(440, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(445, T_SECONDARY, TV_FALL);
|
s->addEvent720(445, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(450, T_SECONDARY, TV_RISE);
|
s->addEvent720(450, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(455, T_SECONDARY, TV_FALL);
|
s->addEvent720(455, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(460, T_SECONDARY, TV_RISE);
|
s->addEvent720(460, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(465, T_SECONDARY, TV_FALL);
|
s->addEvent720(465, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(470, T_SECONDARY, TV_RISE);
|
s->addEvent720(470, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(475, T_SECONDARY, TV_FALL);
|
s->addEvent720(475, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(480, T_SECONDARY, TV_RISE);
|
s->addEvent720(480, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(485, T_SECONDARY, TV_FALL);
|
s->addEvent720(485, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(490, T_SECONDARY, TV_RISE);
|
s->addEvent720(490, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(495, T_SECONDARY, TV_FALL);
|
s->addEvent720(495, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(500, T_SECONDARY, TV_RISE);
|
s->addEvent720(500, T_SECONDARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(504, T_PRIMARY, TV_FALL);
|
s->addEvent720(504, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(505, T_SECONDARY, TV_FALL);
|
s->addEvent720(505, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(510, T_SECONDARY, TV_RISE);
|
s->addEvent720(510, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(515, T_SECONDARY, TV_FALL);
|
s->addEvent720(515, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(520, T_SECONDARY, TV_RISE);
|
s->addEvent720(520, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(525, T_SECONDARY, TV_FALL);
|
s->addEvent720(525, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(530, T_SECONDARY, TV_RISE);
|
s->addEvent720(530, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(535, T_SECONDARY, TV_FALL);
|
s->addEvent720(535, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(540 - EPS_ANGLE, T_SECONDARY, TV_RISE);
|
s->addEvent720(540 - EPS_ANGLE, T_SECONDARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(540, T_PRIMARY, TV_RISE);
|
s->addEvent720(540, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(545, T_SECONDARY, TV_FALL);
|
s->addEvent720(545, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(570, T_SECONDARY, TV_RISE);
|
s->addEvent720(570, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(575, T_SECONDARY, TV_FALL);
|
s->addEvent720(575, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(576, T_PRIMARY, TV_FALL);
|
s->addEvent720(576, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(580, T_SECONDARY, TV_RISE);
|
s->addEvent720(580, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(585, T_SECONDARY, TV_FALL);
|
s->addEvent720(585, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(590, T_SECONDARY, TV_RISE);
|
s->addEvent720(590, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(595, T_SECONDARY, TV_FALL);
|
s->addEvent720(595, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(600, T_SECONDARY, TV_RISE);
|
s->addEvent720(600, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(605, T_SECONDARY, TV_FALL);
|
s->addEvent720(605, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(610, T_SECONDARY, TV_RISE);
|
s->addEvent720(610, T_SECONDARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(612, T_PRIMARY, TV_RISE);
|
s->addEvent720(612, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(615, T_SECONDARY, TV_FALL);
|
s->addEvent720(615, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(620, T_SECONDARY, TV_RISE);
|
s->addEvent720(620, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(625, T_SECONDARY, TV_FALL);
|
s->addEvent720(625, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(630, T_SECONDARY, TV_RISE);
|
s->addEvent720(630, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(635, T_SECONDARY, TV_FALL);
|
s->addEvent720(635, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(640, T_SECONDARY, TV_RISE);
|
s->addEvent720(640, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(645, T_SECONDARY, TV_FALL);
|
s->addEvent720(645, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(648, T_PRIMARY, TV_FALL);
|
s->addEvent720(648, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(650, T_SECONDARY, TV_RISE);
|
s->addEvent720(650, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(655, T_SECONDARY, TV_FALL);
|
s->addEvent720(655, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(660, T_SECONDARY, TV_RISE);
|
s->addEvent720(660, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(665, T_SECONDARY, TV_FALL);
|
s->addEvent720(665, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(670, T_SECONDARY, TV_RISE);
|
s->addEvent720(670, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(675, T_SECONDARY, TV_FALL);
|
s->addEvent720(675, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(680, T_SECONDARY, TV_RISE);
|
s->addEvent720(680, T_SECONDARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(684, T_PRIMARY, TV_RISE);
|
s->addEvent720(684, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(685, T_SECONDARY, TV_FALL);
|
s->addEvent720(685, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(690, T_SECONDARY, TV_RISE);
|
s->addEvent720(690, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(695, T_SECONDARY, TV_FALL);
|
s->addEvent720(695, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(700, T_SECONDARY, TV_RISE);
|
s->addEvent720(700, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(705, T_SECONDARY, TV_FALL);
|
s->addEvent720(705, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(710, T_SECONDARY, TV_RISE);
|
s->addEvent720(710, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(715, T_SECONDARY, TV_FALL);
|
s->addEvent720(715, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(720 - EPS_ANGLE, T_SECONDARY, TV_RISE);
|
s->addEvent720(720 - EPS_ANGLE, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(720, T_PRIMARY, TV_FALL);
|
s->addEvent720(720, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -334,56 +334,56 @@ void configureDodgeStratusTriggerWaveform(TriggerWaveform *s) {
|
||||||
float base = 0;
|
float base = 0;
|
||||||
// 2 teeth
|
// 2 teeth
|
||||||
float angle = base + 120.0 - w;
|
float angle = base + 120.0 - w;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
angle += g;
|
angle += g;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
base += 120;
|
base += 120;
|
||||||
// 3 teeth
|
// 3 teeth
|
||||||
angle = base + 120.0 - w;
|
angle = base + 120.0 - w;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
angle += g;
|
angle += g;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
angle += g;
|
angle += g;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
base += 120;
|
base += 120;
|
||||||
// 2 teeth
|
// 2 teeth
|
||||||
angle = base + 120.0 - w;
|
angle = base + 120.0 - w;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
angle += g;
|
angle += g;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
base += 120;
|
base += 120;
|
||||||
// just one
|
// just one
|
||||||
angle = base + 120.0 - w;
|
angle = base + 120.0 - w;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
base += 120;
|
base += 120;
|
||||||
// 3 teeth
|
// 3 teeth
|
||||||
angle = base + 120.0 - w;
|
angle = base + 120.0 - w;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
angle += g;
|
angle += g;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
angle += g;
|
angle += g;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
base += 120;
|
base += 120;
|
||||||
// just one again
|
// just one again
|
||||||
angle = base + 120.0 - w;
|
angle = base + 120.0 - w;
|
||||||
s->addEvent720(angle, T_PRIMARY, TV_RISE);
|
s->addEvent720(angle, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + w, T_PRIMARY, TV_FALL);
|
s->addEvent720(angle + w, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void configureNeon1995TriggerWaveformCommon(bool withCam, TriggerWaveform *s) {
|
static void configureNeon1995TriggerWaveformCommon(bool withCam, TriggerWaveform *s) {
|
||||||
|
@ -394,54 +394,54 @@ static void configureNeon1995TriggerWaveformCommon(bool withCam, TriggerWaveform
|
||||||
|
|
||||||
float m = withCam ? 1 : 2;
|
float m = withCam ? 1 : 2;
|
||||||
|
|
||||||
s->addEvent720(m * (base - 120), crank, TV_RISE);
|
s->addEvent720(m * (base - 120), crank, TriggerValue::RISE);
|
||||||
s->addEvent720(m * (base - 116), crank, TV_FALL);
|
s->addEvent720(m * (base - 116), crank, TriggerValue::FALL);
|
||||||
s->addEvent720(m * (base - 720 + 616), crank, TV_RISE);
|
s->addEvent720(m * (base - 720 + 616), crank, TriggerValue::RISE);
|
||||||
s->addEvent720(m * (base - 100), crank, TV_FALL);
|
s->addEvent720(m * (base - 100), crank, TriggerValue::FALL);
|
||||||
s->addEvent720(m * (base - 720 + 643), crank, TV_RISE);
|
s->addEvent720(m * (base - 720 + 643), crank, TriggerValue::RISE);
|
||||||
s->addEvent720(m * (base - 720 + 648), crank, TV_FALL);
|
s->addEvent720(m * (base - 720 + 648), crank, TriggerValue::FALL);
|
||||||
s->addEvent720(m * (base - 720 + 671), crank, TV_RISE);
|
s->addEvent720(m * (base - 720 + 671), crank, TriggerValue::RISE);
|
||||||
s->addEvent720(m * (base - 44), crank, TV_FALL);
|
s->addEvent720(m * (base - 44), crank, TriggerValue::FALL);
|
||||||
|
|
||||||
if (withCam) {
|
if (withCam) {
|
||||||
s->addEvent720(base + 0, T_PRIMARY, TV_FALL);
|
s->addEvent720(base + 0, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
s->addEvent720(m * (base + 20), crank, TV_RISE);
|
s->addEvent720(m * (base + 20), crank, TriggerValue::RISE);
|
||||||
s->addEvent720(m * (base + 60), crank, TV_FALL);
|
s->addEvent720(m * (base + 60), crank, TriggerValue::FALL);
|
||||||
s->addEvent720(m * (base + 75), crank, TV_RISE);
|
s->addEvent720(m * (base + 75), crank, TriggerValue::RISE);
|
||||||
s->addEvent720(m * (base + 79), crank, TV_FALL);
|
s->addEvent720(m * (base + 79), crank, TriggerValue::FALL);
|
||||||
s->addEvent720(m * (base + 101), crank, TV_RISE);
|
s->addEvent720(m * (base + 101), crank, TriggerValue::RISE);
|
||||||
s->addEvent720(m * (base + 106), crank, TV_FALL);
|
s->addEvent720(m * (base + 106), crank, TriggerValue::FALL);
|
||||||
s->addEvent720(m * (base + 130), crank, TV_RISE);
|
s->addEvent720(m * (base + 130), crank, TriggerValue::RISE);
|
||||||
s->addEvent720(m * (base + 135), crank, TV_FALL);
|
s->addEvent720(m * (base + 135), crank, TriggerValue::FALL);
|
||||||
|
|
||||||
if (withCam) {
|
if (withCam) {
|
||||||
s->addEvent720(base + 200, T_PRIMARY, TV_RISE); // width = 150
|
s->addEvent720(base + 200, T_PRIMARY, TriggerValue::RISE); // width = 150
|
||||||
|
|
||||||
s->addEvent720(base + 236, crank, TV_RISE);
|
s->addEvent720(base + 236, crank, TriggerValue::RISE);
|
||||||
s->addEvent720(base + 239, crank, TV_FALL);
|
s->addEvent720(base + 239, crank, TriggerValue::FALL);
|
||||||
s->addEvent720(base + 250, crank, TV_RISE);
|
s->addEvent720(base + 250, crank, TriggerValue::RISE);
|
||||||
s->addEvent720(base + 255, crank, TV_FALL);
|
s->addEvent720(base + 255, crank, TriggerValue::FALL);
|
||||||
s->addEvent720(base + 277, crank, TV_RISE);
|
s->addEvent720(base + 277, crank, TriggerValue::RISE);
|
||||||
s->addEvent720(base + 282, crank, TV_FALL);
|
s->addEvent720(base + 282, crank, TriggerValue::FALL);
|
||||||
s->addEvent720(base + 305, crank, TV_RISE);
|
s->addEvent720(base + 305, crank, TriggerValue::RISE);
|
||||||
s->addEvent720(base + 310, crank, TV_FALL);
|
s->addEvent720(base + 310, crank, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(base + 374, crank, TV_RISE);
|
s->addEvent720(base + 374, crank, TriggerValue::RISE);
|
||||||
|
|
||||||
// if (withCam)
|
// if (withCam)
|
||||||
s->addEvent720(base + 395, T_PRIMARY, TV_FALL); // width =
|
s->addEvent720(base + 395, T_PRIMARY, TriggerValue::FALL); // width =
|
||||||
|
|
||||||
s->addEvent720(base + 418, crank, TV_FALL);
|
s->addEvent720(base + 418, crank, TriggerValue::FALL);
|
||||||
s->addEvent720(base + 436, crank, TV_RISE);
|
s->addEvent720(base + 436, crank, TriggerValue::RISE);
|
||||||
s->addEvent720(base + 441, crank, TV_FALL);
|
s->addEvent720(base + 441, crank, TriggerValue::FALL);
|
||||||
s->addEvent720(base + 463, crank, TV_RISE);
|
s->addEvent720(base + 463, crank, TriggerValue::RISE);
|
||||||
s->addEvent720(base + 468, crank, TV_FALL);
|
s->addEvent720(base + 468, crank, TriggerValue::FALL);
|
||||||
s->addEvent720(base + 492, crank, TV_RISE);
|
s->addEvent720(base + 492, crank, TriggerValue::RISE);
|
||||||
s->addEvent720(base + 497, crank, TV_FALL);
|
s->addEvent720(base + 497, crank, TriggerValue::FALL);
|
||||||
|
|
||||||
// if (withCam)
|
// if (withCam)
|
||||||
s->addEvent720(base + 560, T_PRIMARY, TV_RISE); // width =
|
s->addEvent720(base + 560, T_PRIMARY, TriggerValue::RISE); // width =
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -464,7 +464,7 @@ void configureNeon1995TriggerWaveform(TriggerWaveform *s) {
|
||||||
s->useRiseEdge = false;
|
s->useRiseEdge = false;
|
||||||
|
|
||||||
|
|
||||||
s->initialState[T_PRIMARY] = TV_RISE;
|
s->initialState[T_PRIMARY] = TriggerValue::RISE;
|
||||||
|
|
||||||
configureNeon1995TriggerWaveformCommon(true, s);
|
configureNeon1995TriggerWaveformCommon(true, s);
|
||||||
|
|
||||||
|
@ -478,79 +478,79 @@ void initJeep18_2_2_2(TriggerWaveform *s) {
|
||||||
|
|
||||||
float off = 212;
|
float off = 212;
|
||||||
|
|
||||||
s->addEvent720(534 - 720 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(534 - 720 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(536 - 720 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(536 - 720 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(554 - 720 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(554 - 720 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(556 - 720 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(556 - 720 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(574 - 720 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(574 - 720 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(576 - 720 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(576 - 720 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(594 - 720 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(594 - 720 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(596 - 720 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(596 - 720 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(654 - 720 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(654 - 720 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(656 - 720 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(656 - 720 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(674 - 720 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(674 - 720 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(676 - 720 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(676 - 720 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(694 - 720 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(694 - 720 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(696 - 720 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(696 - 720 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(714 - 720 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(714 - 720 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(716 - 720 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(716 - 720 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
|
|
||||||
s->addEvent720(54 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(54 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(56 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(56 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(74 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(74 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(76 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(76 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(94 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(94 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(96 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(96 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(114 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(114 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(116 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(116 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(148 + off, T_PRIMARY, TV_RISE); // 360
|
s->addEvent720(148 + off, T_PRIMARY, TriggerValue::RISE); // 360
|
||||||
|
|
||||||
s->addEvent720(174 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(174 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(176 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(176 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(194 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(194 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(196 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(196 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(214 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(214 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(216 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(216 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(234 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(234 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(236 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(236 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(294 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(294 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(296 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(296 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(314 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(314 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(316 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(316 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(334 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(334 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(336 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(336 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(354 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(354 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(356 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(356 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(414 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(414 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(416 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(416 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(434 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(434 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(436 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(436 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(454 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(454 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(456 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(456 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(474 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(474 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(476 + off, T_SECONDARY, TV_FALL);
|
s->addEvent720(476 + off, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(508 + off, T_PRIMARY, TV_FALL); // 720
|
s->addEvent720(508 + off, T_PRIMARY, TriggerValue::FALL); // 720
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void add4cylblock(int off, TriggerWaveform *s) {
|
static void add4cylblock(int off, TriggerWaveform *s) {
|
||||||
s->addEvent720(114 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(114 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(114 + off + 2, T_SECONDARY, TV_FALL);
|
s->addEvent720(114 + off + 2, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(134 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(134 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(134 + off + 2, T_SECONDARY, TV_FALL);
|
s->addEvent720(134 + off + 2, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(154 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(154 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(154 + off + 2, T_SECONDARY, TV_FALL);
|
s->addEvent720(154 + off + 2, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(174 + off, T_SECONDARY, TV_RISE);
|
s->addEvent720(174 + off, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(174 + off + 2, T_SECONDARY, TV_FALL);
|
s->addEvent720(174 + off + 2, T_SECONDARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TT_JEEP_4_CYL
|
// TT_JEEP_4_CYL
|
||||||
|
@ -564,12 +564,12 @@ void initJeep_XJ_4cyl_2500(TriggerWaveform *s) {
|
||||||
add4cylblock(offset - 180, s);
|
add4cylblock(offset - 180, s);
|
||||||
add4cylblock(offset, s);
|
add4cylblock(offset, s);
|
||||||
|
|
||||||
s->addEvent720(236 + offset, T_PRIMARY, TV_RISE); // 360
|
s->addEvent720(236 + offset, T_PRIMARY, TriggerValue::RISE); // 360
|
||||||
|
|
||||||
add4cylblock(offset + 180, s);
|
add4cylblock(offset + 180, s);
|
||||||
add4cylblock(offset + 360, s);
|
add4cylblock(offset + 360, s);
|
||||||
|
|
||||||
s->addEvent720(596 + offset, T_PRIMARY, TV_FALL); // 720
|
s->addEvent720(596 + offset, T_PRIMARY, TriggerValue::FALL); // 720
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -588,24 +588,24 @@ void configureChryslerNGC_36_2_2(TriggerWaveform *s) {
|
||||||
float base = 0;
|
float base = 0;
|
||||||
|
|
||||||
for (int i = 0; i < 14; i++) {
|
for (int i = 0; i < 14; i++) {
|
||||||
s->addEventAngle(base + narrow / 2, T_PRIMARY, TV_RISE);
|
s->addEventAngle(base + narrow / 2, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(base + narrow, T_PRIMARY, TV_FALL);
|
s->addEventAngle(base + narrow, T_PRIMARY, TriggerValue::FALL);
|
||||||
base += narrow;
|
base += narrow;
|
||||||
}
|
}
|
||||||
|
|
||||||
s->addEventAngle(base + narrow / 2, T_PRIMARY, TV_RISE);
|
s->addEventAngle(base + narrow / 2, T_PRIMARY, TriggerValue::RISE);
|
||||||
base += narrow / 2;
|
base += narrow / 2;
|
||||||
s->addEventAngle(base + wide, T_PRIMARY, TV_FALL);
|
s->addEventAngle(base + wide, T_PRIMARY, TriggerValue::FALL);
|
||||||
base += wide;
|
base += wide;
|
||||||
|
|
||||||
for (int i = 0; i < 16; i++) {
|
for (int i = 0; i < 16; i++) {
|
||||||
s->addEventAngle(base + narrow / 2, T_PRIMARY, TV_RISE);
|
s->addEventAngle(base + narrow / 2, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(base + narrow, T_PRIMARY, TV_FALL);
|
s->addEventAngle(base + narrow, T_PRIMARY, TriggerValue::FALL);
|
||||||
base += narrow;
|
base += narrow;
|
||||||
}
|
}
|
||||||
|
|
||||||
// one small tooth at the end of the engine cycle
|
// one small tooth at the end of the engine cycle
|
||||||
s->addEventAngle(s->getCycleDuration() - narrow / 2, T_PRIMARY, TV_RISE);
|
s->addEventAngle(s->getCycleDuration() - narrow / 2, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(s->getCycleDuration(), T_PRIMARY, TV_FALL);
|
s->addEventAngle(s->getCycleDuration(), T_PRIMARY, TriggerValue::FALL);
|
||||||
s->useOnlyPrimaryForSync = true;
|
s->useOnlyPrimaryForSync = true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,9 +10,9 @@
|
||||||
#include "trigger_gm.h"
|
#include "trigger_gm.h"
|
||||||
|
|
||||||
static float addTooth(float offset, TriggerWaveform *s) {
|
static float addTooth(float offset, TriggerWaveform *s) {
|
||||||
s->addEventAngle(offset, T_SECONDARY, TV_RISE);
|
s->addEventAngle(offset, T_SECONDARY, TriggerValue::RISE);
|
||||||
offset += CRANK_MODE_MULTIPLIER * 3;
|
offset += CRANK_MODE_MULTIPLIER * 3;
|
||||||
s->addEventAngle(offset, T_SECONDARY, TV_FALL);
|
s->addEventAngle(offset, T_SECONDARY, TriggerValue::FALL);
|
||||||
offset += CRANK_MODE_MULTIPLIER * 3;
|
offset += CRANK_MODE_MULTIPLIER * 3;
|
||||||
return offset;
|
return offset;
|
||||||
}
|
}
|
||||||
|
@ -52,11 +52,11 @@ void configureGm60_2_2_2(TriggerWaveform *s) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
s->addEventAngle(m * (360 - 6), T_PRIMARY, TV_RISE);
|
s->addEventAngle(m * (360 - 6), T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
offset = addTooth(offset, s);
|
offset = addTooth(offset, s);
|
||||||
|
|
||||||
s->addEventAngle(m * (360), T_PRIMARY, TV_FALL);
|
s->addEventAngle(m * (360), T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -65,26 +65,26 @@ void configureGmTriggerWaveform(TriggerWaveform *s) {
|
||||||
|
|
||||||
float w = 5;
|
float w = 5;
|
||||||
|
|
||||||
s->addEvent360(60 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(60 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(60, T_PRIMARY, TV_FALL);
|
s->addEvent360(60, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(120 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(120 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(120.0, T_PRIMARY, TV_FALL);
|
s->addEvent360(120.0, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(180 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(180 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(180, T_PRIMARY, TV_FALL);
|
s->addEvent360(180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(240 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(240 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(240.0, T_PRIMARY, TV_FALL);
|
s->addEvent360(240.0, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(300 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(300 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(300.0, T_PRIMARY, TV_FALL);
|
s->addEvent360(300.0, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(350 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(350 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(350.0, T_PRIMARY, TV_FALL);
|
s->addEvent360(350.0, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(360 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(360 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(360.0, T_PRIMARY, TV_FALL);
|
s->addEvent360(360.0, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->setTriggerSynchronizationGap(6);
|
s->setTriggerSynchronizationGap(6);
|
||||||
}
|
}
|
||||||
|
@ -94,8 +94,8 @@ static int gm_tooth_pair(float startAngle, bool isShortLong, TriggerWaveform* s,
|
||||||
int window = (isShortLong ? shortToothWidth : (15 - shortToothWidth)) * mult;
|
int window = (isShortLong ? shortToothWidth : (15 - shortToothWidth)) * mult;
|
||||||
int end = startAngle + mult * 15;
|
int end = startAngle + mult * 15;
|
||||||
|
|
||||||
s->addEvent720(startAngle + window, T_PRIMARY, TV_RISE);
|
s->addEvent720(startAngle + window, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(end, T_PRIMARY, TV_FALL);
|
s->addEvent720(end, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
return end;
|
return end;
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,20 +22,20 @@ void configureHondaCbr600(TriggerWaveform *s) {
|
||||||
addSkippedToothTriggerEvents(T_SECONDARY, s, totalTeethCount, skippedCount, 0.5, 0, 720,
|
addSkippedToothTriggerEvents(T_SECONDARY, s, totalTeethCount, skippedCount, 0.5, 0, 720,
|
||||||
0, 349);
|
0, 349);
|
||||||
|
|
||||||
s->addEvent720(350.0f, T_PRIMARY, TV_FALL);
|
s->addEvent720(350.0f, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(360.0f, T_PRIMARY, TV_RISE);
|
s->addEvent720(360.0f, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(360 + 0.2, T_SECONDARY, TV_FALL);
|
s->addEvent720(360 + 0.2, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
addSkippedToothTriggerEvents(T_SECONDARY, s, totalTeethCount, skippedCount, 0.5, 0, 720,
|
addSkippedToothTriggerEvents(T_SECONDARY, s, totalTeethCount, skippedCount, 0.5, 0, 720,
|
||||||
361, 649);
|
361, 649);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
s->addEvent720(650.0f, T_PRIMARY, TV_FALL);
|
s->addEvent720(650.0f, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(660.0f, T_PRIMARY, TV_RISE);
|
s->addEvent720(660.0f, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(660 + 0.2, T_SECONDARY, TV_FALL);
|
s->addEvent720(660 + 0.2, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
|
|
||||||
addSkippedToothTriggerEvents(T_SECONDARY, s, totalTeethCount, skippedCount, 0.5, 0, 720,
|
addSkippedToothTriggerEvents(T_SECONDARY, s, totalTeethCount, skippedCount, 0.5, 0, 720,
|
||||||
|
@ -44,11 +44,11 @@ void configureHondaCbr600(TriggerWaveform *s) {
|
||||||
|
|
||||||
// exit(-1);
|
// exit(-1);
|
||||||
|
|
||||||
s->addEvent720(710.0f, T_PRIMARY, TV_FALL);
|
s->addEvent720(710.0f, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(720.0f - 1, T_SECONDARY, TV_FALL);
|
s->addEvent720(720.0f - 1, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(720.0f, T_PRIMARY, TV_RISE);
|
s->addEvent720(720.0f, T_PRIMARY, TriggerValue::RISE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void configureOnePlus16(TriggerWaveform *s) {
|
void configureOnePlus16(TriggerWaveform *s) {
|
||||||
|
@ -58,12 +58,12 @@ void configureOnePlus16(TriggerWaveform *s) {
|
||||||
float tooth = s->getCycleDuration() / count;
|
float tooth = s->getCycleDuration() / count;
|
||||||
float width = tooth / 2; // for VR we only handle rises so width does not matter much
|
float width = tooth / 2; // for VR we only handle rises so width does not matter much
|
||||||
|
|
||||||
s->addEventAngle(1, T_PRIMARY, TV_RISE);
|
s->addEventAngle(1, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(5, T_PRIMARY, TV_FALL);
|
s->addEventAngle(5, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
for (int i = 1; i <= count; i++) {
|
for (int i = 1; i <= count; i++) {
|
||||||
s->addEventAngle(tooth * i - width, T_SECONDARY, TV_RISE);
|
s->addEventAngle(tooth * i - width, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(tooth * i, T_SECONDARY, TV_FALL);
|
s->addEventAngle(tooth * i, T_SECONDARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
s->isSynchronizationNeeded = false;
|
s->isSynchronizationNeeded = false;
|
||||||
|
@ -71,8 +71,8 @@ void configureOnePlus16(TriggerWaveform *s) {
|
||||||
|
|
||||||
static void kseriesTooth(TriggerWaveform* s, float end) {
|
static void kseriesTooth(TriggerWaveform* s, float end) {
|
||||||
// for VR we only handle rises so width does not matter much
|
// for VR we only handle rises so width does not matter much
|
||||||
s->addEvent360(end - 4, T_PRIMARY, TV_RISE);
|
s->addEvent360(end - 4, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(end , T_PRIMARY, TV_FALL);
|
s->addEvent360(end , T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TT_HONDA_K_12_1
|
// TT_HONDA_K_12_1
|
||||||
|
@ -107,18 +107,18 @@ void configureHondaK_4_1(TriggerWaveform *s) {
|
||||||
|
|
||||||
angle_t start = 55.5;
|
angle_t start = 55.5;
|
||||||
angle_t end = 70.5;
|
angle_t end = 70.5;
|
||||||
s->addEvent360(start + 90 * 0, T_PRIMARY, TV_RISE);
|
s->addEvent360(start + 90 * 0, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(end + 90 * 0, T_PRIMARY, TV_FALL);
|
s->addEvent360(end + 90 * 0, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(start + 90 * 1, T_PRIMARY, TV_RISE);
|
s->addEvent360(start + 90 * 1, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(end + 90 * 1, T_PRIMARY, TV_FALL);
|
s->addEvent360(end + 90 * 1, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(start + 90 * 2, T_PRIMARY, TV_RISE);
|
s->addEvent360(start + 90 * 2, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(end + 90 * 2, T_PRIMARY, TV_FALL);
|
s->addEvent360(end + 90 * 2, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(start + 90 * 3, T_PRIMARY, TV_RISE);
|
s->addEvent360(start + 90 * 3, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(end + 90 * 3, T_PRIMARY, TV_FALL);
|
s->addEvent360(end + 90 * 3, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(353, T_PRIMARY, TV_RISE);
|
s->addEvent360(353, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(360, T_PRIMARY, TV_FALL);
|
s->addEvent360(360, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,21 +43,21 @@ void initializeMazdaMiataNaShape(TriggerWaveform *s) {
|
||||||
/**
|
/**
|
||||||
* http://rusefi.com/forum/viewtopic.php?f=3&t=729&p=12983#p12983
|
* http://rusefi.com/forum/viewtopic.php?f=3&t=729&p=12983#p12983
|
||||||
*/
|
*/
|
||||||
s->addEvent720(52.960405, T_SECONDARY, TV_RISE);
|
s->addEvent720(52.960405, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(122.635956, T_SECONDARY, TV_FALL);
|
s->addEvent720(122.635956, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(216.897031, T_PRIMARY, TV_RISE);
|
s->addEvent720(216.897031, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(232.640068, T_SECONDARY, TV_RISE);
|
s->addEvent720(232.640068, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(288.819688, T_PRIMARY, TV_FALL); // <-- This edge is the sync point
|
s->addEvent720(288.819688, T_PRIMARY, TriggerValue::FALL); // <-- This edge is the sync point
|
||||||
s->addEvent720(302.646323, T_SECONDARY, TV_FALL);
|
s->addEvent720(302.646323, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(412.448056, T_SECONDARY, TV_RISE);
|
s->addEvent720(412.448056, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(482.816719, T_SECONDARY, TV_FALL);
|
s->addEvent720(482.816719, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(577.035495, T_PRIMARY, TV_RISE);
|
s->addEvent720(577.035495, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(592.878113, T_SECONDARY, TV_RISE);
|
s->addEvent720(592.878113, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(662.899708, T_SECONDARY, TV_FALL);
|
s->addEvent720(662.899708, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(720.0f, T_PRIMARY, TV_FALL);
|
s->addEvent720(720.0f, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->useOnlyPrimaryForSync = true;
|
s->useOnlyPrimaryForSync = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -77,15 +77,15 @@ void initializeMazdaMiataNb2Crank(TriggerWaveform *s) {
|
||||||
s->setSecondTriggerSynchronizationGap2(0.8f, 1.8f);
|
s->setSecondTriggerSynchronizationGap2(0.8f, 1.8f);
|
||||||
|
|
||||||
// todo: NB2 fronts are inverted comparing to NB1, life is not perfect :(
|
// todo: NB2 fronts are inverted comparing to NB1, life is not perfect :(
|
||||||
s->addEventAngle(180.0f - NB_CRANK_MAGIC - 4, T_PRIMARY, TV_FALL);
|
s->addEventAngle(180.0f - NB_CRANK_MAGIC - 4, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEventAngle(180.0f - NB_CRANK_MAGIC, T_PRIMARY, TV_RISE);
|
s->addEventAngle(180.0f - NB_CRANK_MAGIC, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(180.0f - 4, T_PRIMARY, TV_FALL);
|
s->addEventAngle(180.0f - 4, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEventAngle(180.0f, T_PRIMARY, TV_RISE);
|
s->addEventAngle(180.0f, T_PRIMARY, TriggerValue::RISE);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void addNBCrankTooth(TriggerWaveform *s, angle_t angle, trigger_wheel_e const channelIndex) {
|
static void addNBCrankTooth(TriggerWaveform *s, angle_t angle, trigger_wheel_e const channelIndex) {
|
||||||
s->addEvent720(angle, channelIndex, TV_RISE);
|
s->addEvent720(angle, channelIndex, TriggerValue::RISE);
|
||||||
s->addEvent720(angle + 4, channelIndex, TV_FALL);
|
s->addEvent720(angle + 4, channelIndex, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void initializeMazdaMiataNb1ShapeWithOffset(TriggerWaveform *s, float offset) {
|
static void initializeMazdaMiataNb1ShapeWithOffset(TriggerWaveform *s, float offset) {
|
||||||
|
@ -100,25 +100,25 @@ static void initializeMazdaMiataNb1ShapeWithOffset(TriggerWaveform *s, float off
|
||||||
/**
|
/**
|
||||||
* cam sensor is primary, crank sensor is secondary
|
* cam sensor is primary, crank sensor is secondary
|
||||||
*/
|
*/
|
||||||
s->addEvent720(20.0f, T_PRIMARY, TV_FALL);
|
s->addEvent720(20.0f, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
addNBCrankTooth(s, offset + 66.0f, T_SECONDARY);
|
addNBCrankTooth(s, offset + 66.0f, T_SECONDARY);
|
||||||
addNBCrankTooth(s, offset + 66.0f + NB_CRANK_MAGIC, T_SECONDARY);
|
addNBCrankTooth(s, offset + 66.0f + NB_CRANK_MAGIC, T_SECONDARY);
|
||||||
addNBCrankTooth(s, offset + 66.0f + 180, T_SECONDARY);
|
addNBCrankTooth(s, offset + 66.0f + 180, T_SECONDARY);
|
||||||
addNBCrankTooth(s, offset + 66.0f + 180 + NB_CRANK_MAGIC, T_SECONDARY);
|
addNBCrankTooth(s, offset + 66.0f + 180 + NB_CRANK_MAGIC, T_SECONDARY);
|
||||||
|
|
||||||
s->addEvent720(340.0f, T_PRIMARY, TV_RISE);
|
s->addEvent720(340.0f, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(360.0f, T_PRIMARY, TV_FALL);
|
s->addEvent720(360.0f, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(380.0f, T_PRIMARY, TV_RISE);
|
s->addEvent720(380.0f, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(400.0f, T_PRIMARY, TV_FALL);
|
s->addEvent720(400.0f, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
addNBCrankTooth(s, offset + 66.0f + 360, T_SECONDARY);
|
addNBCrankTooth(s, offset + 66.0f + 360, T_SECONDARY);
|
||||||
addNBCrankTooth(s, offset + 66.0f + 360 + NB_CRANK_MAGIC, T_SECONDARY);
|
addNBCrankTooth(s, offset + 66.0f + 360 + NB_CRANK_MAGIC, T_SECONDARY);
|
||||||
addNBCrankTooth(s, offset + 66.0f + 540, T_SECONDARY);
|
addNBCrankTooth(s, offset + 66.0f + 540, T_SECONDARY);
|
||||||
addNBCrankTooth(s, offset + 66.0f + 540 + NB_CRANK_MAGIC, T_SECONDARY);
|
addNBCrankTooth(s, offset + 66.0f + 540 + NB_CRANK_MAGIC, T_SECONDARY);
|
||||||
|
|
||||||
s->addEvent720(720.0f, T_PRIMARY, TV_RISE);
|
s->addEvent720(720.0f, T_PRIMARY, TriggerValue::RISE);
|
||||||
}
|
}
|
||||||
|
|
||||||
void initializeMazdaMiataVVtTestShape(TriggerWaveform *s) {
|
void initializeMazdaMiataVVtTestShape(TriggerWaveform *s) {
|
||||||
|
@ -136,18 +136,18 @@ void configureMazdaProtegeSOHC(TriggerWaveform *s) {
|
||||||
|
|
||||||
float z = 0.093;
|
float z = 0.093;
|
||||||
a = 180;
|
a = 180;
|
||||||
s->addEvent720(a - z * 720, T_PRIMARY, TV_RISE);
|
s->addEvent720(a - z * 720, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(a, T_PRIMARY, TV_FALL);
|
s->addEvent720(a, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
a += 180;
|
a += 180;
|
||||||
s->addEvent720(a - z * 720, T_PRIMARY, TV_RISE);
|
s->addEvent720(a - z * 720, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(a, T_PRIMARY, TV_FALL);
|
s->addEvent720(a, T_PRIMARY, TriggerValue::FALL);
|
||||||
a += 180;
|
a += 180;
|
||||||
s->addEvent720(a - z * 720, T_PRIMARY, TV_RISE);
|
s->addEvent720(a - z * 720, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(a, T_PRIMARY, TV_FALL);
|
s->addEvent720(a, T_PRIMARY, TriggerValue::FALL);
|
||||||
a += 180;
|
a += 180;
|
||||||
s->addEvent720(a - z * 720, T_PRIMARY, TV_RISE);
|
s->addEvent720(a - z * 720, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(a, T_PRIMARY, TV_FALL);
|
s->addEvent720(a, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->isSynchronizationNeeded = false;
|
s->isSynchronizationNeeded = false;
|
||||||
s->shapeWithoutTdc = true;
|
s->shapeWithoutTdc = true;
|
||||||
|
@ -159,21 +159,21 @@ void configureMazdaProtegeLx(TriggerWaveform *s) {
|
||||||
/**
|
/**
|
||||||
* based on https://svn.code.sf.net/p/rusefi/code/trunk/misc/logs/1993_escort_gt/MAIN_rfi_report_2015-02-01%2017_39.csv
|
* based on https://svn.code.sf.net/p/rusefi/code/trunk/misc/logs/1993_escort_gt/MAIN_rfi_report_2015-02-01%2017_39.csv
|
||||||
*/
|
*/
|
||||||
s->addEvent720(95.329254, T_PRIMARY, TV_RISE);
|
s->addEvent720(95.329254, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(95.329254 + 14.876692, T_SECONDARY, TV_RISE);
|
s->addEvent720(95.329254 + 14.876692, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(95.329254 + 82.693557, T_SECONDARY, TV_FALL);
|
s->addEvent720(95.329254 + 82.693557, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(95.329254 + 137.119154, T_PRIMARY, TV_FALL);
|
s->addEvent720(95.329254 + 137.119154, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(95.329254 + 192.378308, T_SECONDARY, TV_RISE);
|
s->addEvent720(95.329254 + 192.378308, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(95.329254 + 261.556418, T_SECONDARY, TV_FALL);
|
s->addEvent720(95.329254 + 261.556418, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(95.329254 + 373.060597, T_SECONDARY, TV_RISE);
|
s->addEvent720(95.329254 + 373.060597, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(95.329254 + 443.503184, T_SECONDARY, TV_FALL);
|
s->addEvent720(95.329254 + 443.503184, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(95.329254 + 555.349776, T_SECONDARY, TV_RISE);
|
s->addEvent720(95.329254 + 555.349776, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(720, T_SECONDARY, TV_FALL);
|
s->addEvent720(720, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->tdcPosition = 137.119154;
|
s->tdcPosition = 137.119154;
|
||||||
s->isSynchronizationNeeded = false;
|
s->isSynchronizationNeeded = false;
|
||||||
|
@ -187,14 +187,14 @@ void initializeMazdaMiataVVtCamShape(TriggerWaveform *s) {
|
||||||
// Nominal gap is 0.128
|
// Nominal gap is 0.128
|
||||||
s->setSecondTriggerSynchronizationGap2(0.04f, 0.2f);
|
s->setSecondTriggerSynchronizationGap2(0.04f, 0.2f);
|
||||||
|
|
||||||
s->addEvent720(325, T_PRIMARY, TV_FALL);
|
s->addEvent720(325, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(360, T_PRIMARY, TV_RISE);
|
s->addEvent720(360, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(641, T_PRIMARY, TV_FALL);
|
s->addEvent720(641, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(679, T_PRIMARY, TV_RISE);
|
s->addEvent720(679, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(700, T_PRIMARY, TV_FALL);
|
s->addEvent720(700, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(720, T_PRIMARY, TV_RISE);
|
s->addEvent720(720, T_PRIMARY, TriggerValue::RISE);
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://rusefi.com/forum/viewtopic.php?f=17&t=2417
|
// https://rusefi.com/forum/viewtopic.php?f=17&t=2417
|
||||||
|
@ -203,26 +203,26 @@ void initializeMazdaSkyactivCam(TriggerWaveform *s) {
|
||||||
s->initialize(FOUR_STROKE_CAM_SENSOR);
|
s->initialize(FOUR_STROKE_CAM_SENSOR);
|
||||||
|
|
||||||
// wide
|
// wide
|
||||||
s->addEvent360(50, T_PRIMARY, TV_RISE);
|
s->addEvent360(50, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(70, T_PRIMARY, TV_FALL);
|
s->addEvent360(70, T_PRIMARY, TriggerValue::FALL);
|
||||||
// narrow
|
// narrow
|
||||||
s->addEvent360(80, T_PRIMARY, TV_RISE);
|
s->addEvent360(80, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(90, T_PRIMARY, TV_FALL);
|
s->addEvent360(90, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
// wide
|
// wide
|
||||||
s->addEvent360(140, T_PRIMARY, TV_RISE);
|
s->addEvent360(140, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(160, T_PRIMARY, TV_FALL);
|
s->addEvent360(160, T_PRIMARY, TriggerValue::FALL);
|
||||||
// narrow
|
// narrow
|
||||||
s->addEvent360(170, T_PRIMARY, TV_RISE);
|
s->addEvent360(170, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(180, T_PRIMARY, TV_FALL);
|
s->addEvent360(180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
// wide
|
// wide
|
||||||
s->addEvent360(250, T_PRIMARY, TV_RISE);
|
s->addEvent360(250, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(270, T_PRIMARY, TV_FALL);
|
s->addEvent360(270, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
// wide
|
// wide
|
||||||
s->addEvent360(340, T_PRIMARY, TV_RISE);
|
s->addEvent360(340, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(360, T_PRIMARY, TV_FALL);
|
s->addEvent360(360, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->setTriggerSynchronizationGap(0.43);
|
s->setTriggerSynchronizationGap(0.43);
|
||||||
s->setSecondTriggerSynchronizationGap(0.78);
|
s->setSecondTriggerSynchronizationGap(0.78);
|
||||||
|
|
|
@ -6,14 +6,14 @@
|
||||||
void setMercedesTwoSegment(TriggerWaveform* s) {
|
void setMercedesTwoSegment(TriggerWaveform* s) {
|
||||||
s->initialize(FOUR_STROKE_CRANK_SENSOR);
|
s->initialize(FOUR_STROKE_CRANK_SENSOR);
|
||||||
|
|
||||||
s->addEvent360(180 - 10, T_PRIMARY, TV_RISE);
|
s->addEvent360(180 - 10, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(180, T_PRIMARY, TV_FALL);
|
s->addEvent360(180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(227 - 10, T_PRIMARY, TV_RISE);
|
s->addEvent360(227 - 10, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(227, T_PRIMARY, TV_FALL);
|
s->addEvent360(227, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(360 - 10, T_PRIMARY, TV_RISE);
|
s->addEvent360(360 - 10, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(360, T_PRIMARY, TV_FALL);
|
s->addEvent360(360, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->setTriggerSynchronizationGap(1.35);
|
s->setTriggerSynchronizationGap(1.35);
|
||||||
s->setSecondTriggerSynchronizationGap(2.84);
|
s->setSecondTriggerSynchronizationGap(2.84);
|
||||||
|
|
|
@ -17,11 +17,11 @@ void configureFiatIAQ_P8(TriggerWaveform * s) {
|
||||||
int width = 60;
|
int width = 60;
|
||||||
s->tdcPosition = width;
|
s->tdcPosition = width;
|
||||||
|
|
||||||
s->addEvent720(width, T_PRIMARY, TV_RISE);
|
s->addEvent720(width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(180, T_PRIMARY, TV_FALL);
|
s->addEvent720(180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(180 + width, T_PRIMARY, TV_RISE);
|
s->addEvent720(180 + width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(720, T_PRIMARY, TV_FALL);
|
s->addEvent720(720, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->setTriggerSynchronizationGap(3);
|
s->setTriggerSynchronizationGap(3);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,10 +40,10 @@ void configureTriTach(TriggerWaveform * s) {
|
||||||
|
|
||||||
float angleDown = engineCycle / totalTeethCount * (0 + (1 - toothWidth));
|
float angleDown = engineCycle / totalTeethCount * (0 + (1 - toothWidth));
|
||||||
float angleUp = engineCycle / totalTeethCount * (0 + 1);
|
float angleUp = engineCycle / totalTeethCount * (0 + 1);
|
||||||
s->addEventClamped(offset + angleDown, T_PRIMARY, TV_RISE, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
s->addEventClamped(offset + angleDown, T_PRIMARY, TriggerValue::RISE, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
||||||
s->addEventClamped(offset + angleDown + 0.1, T_SECONDARY, TV_RISE, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
s->addEventClamped(offset + angleDown + 0.1, T_SECONDARY, TriggerValue::RISE, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
||||||
s->addEventClamped(offset + angleUp, T_PRIMARY, TV_FALL, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
s->addEventClamped(offset + angleUp, T_PRIMARY, TriggerValue::FALL, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
||||||
s->addEventClamped(offset + angleUp + 0.1, T_SECONDARY, TV_FALL, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
s->addEventClamped(offset + angleUp + 0.1, T_SECONDARY, TriggerValue::FALL, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
||||||
|
|
||||||
|
|
||||||
addSkippedToothTriggerEvents(T_SECONDARY, s, totalTeethCount, /* skipped */ 0, toothWidth, offset, engineCycle,
|
addSkippedToothTriggerEvents(T_SECONDARY, s, totalTeethCount, /* skipped */ 0, toothWidth, offset, engineCycle,
|
||||||
|
@ -67,13 +67,13 @@ void configureFordPip(TriggerWaveform * s) {
|
||||||
*/
|
*/
|
||||||
int oneCylinder = s->getCycleDuration() / 8;
|
int oneCylinder = s->getCycleDuration() / 8;
|
||||||
|
|
||||||
s->addEventAngle(oneCylinder * 0.75, T_PRIMARY, TV_RISE);
|
s->addEventAngle(oneCylinder * 0.75, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(oneCylinder, T_PRIMARY, TV_FALL);
|
s->addEventAngle(oneCylinder, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
|
|
||||||
for (int i = 2;i<=8;i++) {
|
for (int i = 2;i<=8;i++) {
|
||||||
s->addEventAngle(oneCylinder * (i - 0.5), T_PRIMARY, TV_RISE);
|
s->addEventAngle(oneCylinder * (i - 0.5), T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(oneCylinder * i, T_PRIMARY, TV_FALL);
|
s->addEventAngle(oneCylinder * i, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -84,20 +84,20 @@ void configureFordST170(TriggerWaveform * s) {
|
||||||
|
|
||||||
int total = s->getCycleDuration() / 8;
|
int total = s->getCycleDuration() / 8;
|
||||||
|
|
||||||
s->addEventAngle(1 * total - width, T_PRIMARY, TV_RISE);
|
s->addEventAngle(1 * total - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(1 * total, T_PRIMARY, TV_FALL);
|
s->addEventAngle(1 * total, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEventAngle(2 * total - width, T_PRIMARY, TV_RISE);
|
s->addEventAngle(2 * total - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(2 * total, T_PRIMARY, TV_FALL);
|
s->addEventAngle(2 * total, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEventAngle(4 * total - width, T_PRIMARY, TV_RISE);
|
s->addEventAngle(4 * total - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(4 * total, T_PRIMARY, TV_FALL);
|
s->addEventAngle(4 * total, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEventAngle(6 * total - width, T_PRIMARY, TV_RISE);
|
s->addEventAngle(6 * total - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(6 * total, T_PRIMARY, TV_FALL);
|
s->addEventAngle(6 * total, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEventAngle(8 * total - width, T_PRIMARY, TV_RISE);
|
s->addEventAngle(8 * total - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(8 * total, T_PRIMARY, TV_FALL);
|
s->addEventAngle(8 * total, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void configureDaihatsu4(TriggerWaveform * s) {
|
void configureDaihatsu4(TriggerWaveform * s) {
|
||||||
|
@ -107,18 +107,18 @@ void configureDaihatsu4(TriggerWaveform * s) {
|
||||||
|
|
||||||
s->setTriggerSynchronizationGap(0.125);
|
s->setTriggerSynchronizationGap(0.125);
|
||||||
|
|
||||||
s->addEventAngle(30 - width, T_PRIMARY, TV_RISE);
|
s->addEventAngle(30 - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(30, T_PRIMARY, TV_FALL);
|
s->addEventAngle(30, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
|
|
||||||
s->addEventAngle(s->getCycleDuration() / 3 - width, T_PRIMARY, TV_RISE);
|
s->addEventAngle(s->getCycleDuration() / 3 - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(s->getCycleDuration() / 3, T_PRIMARY, TV_FALL);
|
s->addEventAngle(s->getCycleDuration() / 3, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEventAngle(s->getCycleDuration() / 3 * 2 - width, T_PRIMARY, TV_RISE);
|
s->addEventAngle(s->getCycleDuration() / 3 * 2 - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(s->getCycleDuration() / 3 * 2, T_PRIMARY, TV_FALL);
|
s->addEventAngle(s->getCycleDuration() / 3 * 2, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEventAngle(s->getCycleDuration() - width, T_PRIMARY, TV_RISE);
|
s->addEventAngle(s->getCycleDuration() - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(s->getCycleDuration(), T_PRIMARY, TV_FALL);
|
s->addEventAngle(s->getCycleDuration(), T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -136,23 +136,23 @@ void configureBarra3plus1cam(TriggerWaveform *s) {
|
||||||
{
|
{
|
||||||
int offset = 120;
|
int offset = 120;
|
||||||
|
|
||||||
s->addEventAngle(offset + 2 * 0 - 10, T_PRIMARY, TV_RISE);
|
s->addEventAngle(offset + 2 * 0 - 10, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(offset + 2 * 0 + 0, T_PRIMARY, TV_FALL);
|
s->addEventAngle(offset + 2 * 0 + 0, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
// short gap 60 deg
|
// short gap 60 deg
|
||||||
|
|
||||||
s->addEventAngle(offset + 2 * 60 - 10, T_PRIMARY, TV_RISE);
|
s->addEventAngle(offset + 2 * 60 - 10, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(offset + 2 * 60 + 0, T_PRIMARY, TV_FALL);
|
s->addEventAngle(offset + 2 * 60 + 0, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
// long gap 120 deg
|
// long gap 120 deg
|
||||||
|
|
||||||
s->addEventAngle(offset + 2 * 180 - 10, T_PRIMARY, TV_RISE);
|
s->addEventAngle(offset + 2 * 180 - 10, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(offset + 2 * 180 + 0, T_PRIMARY, TV_FALL);
|
s->addEventAngle(offset + 2 * 180 + 0, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
// long gap 120 deg
|
// long gap 120 deg
|
||||||
|
|
||||||
s->addEventAngle(offset + 2 * 300 - 10, T_PRIMARY, TV_RISE);
|
s->addEventAngle(offset + 2 * 300 - 10, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(offset + 2 * 300 + 0, T_PRIMARY, TV_FALL);
|
s->addEventAngle(offset + 2 * 300 + 0, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
// short gap, 60 deg back to zero/720
|
// short gap, 60 deg back to zero/720
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,17 +18,17 @@ void configureFordAspireTriggerWaveform(TriggerWaveform * s) {
|
||||||
float x = 121.90;
|
float x = 121.90;
|
||||||
float y = 110.86;
|
float y = 110.86;
|
||||||
|
|
||||||
s->addEvent720(x + y - 180, T_SECONDARY, TV_RISE);
|
s->addEvent720(x + y - 180, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(x, T_SECONDARY, TV_FALL);
|
s->addEvent720(x, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(x + y, T_SECONDARY, TV_RISE);
|
s->addEvent720(x + y, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(x + 180, T_SECONDARY, TV_FALL);
|
s->addEvent720(x + 180, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(360, T_PRIMARY, TV_RISE);
|
s->addEvent720(360, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(x + 180 + y, T_SECONDARY, TV_RISE);
|
s->addEvent720(x + 180 + y, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(x + 360, T_SECONDARY, TV_FALL);
|
s->addEvent720(x + 360, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(x + 360 + y, T_SECONDARY, TV_RISE);
|
s->addEvent720(x + 360 + y, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(x + 540, T_SECONDARY, TV_FALL);
|
s->addEvent720(x + 540, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(720, T_PRIMARY, TV_FALL);
|
s->addEvent720(720, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -40,18 +40,18 @@ void initializeMitsubishi4g18(TriggerWaveform *s) {
|
||||||
|
|
||||||
s->setTriggerSynchronizationGap(1.6666);
|
s->setTriggerSynchronizationGap(1.6666);
|
||||||
|
|
||||||
s->addEvent720(106.77999999999997, T_PRIMARY, TV_FALL);
|
s->addEvent720(106.77999999999997, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(120.09999999999998, T_SECONDARY, TV_RISE);
|
s->addEvent720(120.09999999999998, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(188.0775, T_SECONDARY, TV_FALL);
|
s->addEvent720(188.0775, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(286.33, T_PRIMARY, TV_RISE);
|
s->addEvent720(286.33, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(298.875, T_SECONDARY, TV_RISE);
|
s->addEvent720(298.875, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(354.91999999999996, T_PRIMARY, TV_FALL);
|
s->addEvent720(354.91999999999996, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(366.6825, T_SECONDARY, TV_FALL);
|
s->addEvent720(366.6825, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(476.45, T_SECONDARY, TV_RISE);
|
s->addEvent720(476.45, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(543.9749999999999, T_SECONDARY, TV_FALL);
|
s->addEvent720(543.9749999999999, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(639.52, T_PRIMARY, TV_RISE);
|
s->addEvent720(639.52, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(653.15, T_SECONDARY, TV_RISE);
|
s->addEvent720(653.15, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(720.0, T_SECONDARY, TV_FALL);
|
s->addEvent720(720.0, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->useOnlyPrimaryForSync = true;
|
s->useOnlyPrimaryForSync = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -114,17 +114,17 @@ void initializeVvt3A92(TriggerWaveform *s) {
|
||||||
s->initialize(FOUR_STROKE_CRANK_SENSOR);
|
s->initialize(FOUR_STROKE_CRANK_SENSOR);
|
||||||
|
|
||||||
int w = 5;
|
int w = 5;
|
||||||
s->addEvent360(120 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(120 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(120, T_PRIMARY, TV_FALL);
|
s->addEvent360(120, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(12 + 120 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(12 + 120 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(12 + 120, T_PRIMARY, TV_FALL);
|
s->addEvent360(12 + 120, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(240 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(240 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(240, T_PRIMARY, TV_FALL);
|
s->addEvent360(240, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(360 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(360 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(360, T_PRIMARY, TV_FALL);
|
s->addEvent360(360, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->setTriggerSynchronizationGap(9);
|
s->setTriggerSynchronizationGap(9);
|
||||||
s->setSecondTriggerSynchronizationGap(0.11); // redundancy
|
s->setSecondTriggerSynchronizationGap(0.11); // redundancy
|
||||||
|
|
|
@ -26,24 +26,24 @@ void initializeNissanSR20VE_4(TriggerWaveform *s) {
|
||||||
|
|
||||||
float width = 4;
|
float width = 4;
|
||||||
|
|
||||||
s->addEvent720(1 * 180 - 4 * width, T_PRIMARY, TV_RISE);
|
s->addEvent720(1 * 180 - 4 * width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(1 * 180, T_PRIMARY, TV_FALL);
|
s->addEvent720(1 * 180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(2 * 180 - width, T_PRIMARY, TV_RISE);
|
s->addEvent720(2 * 180 - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(2 * 180, T_PRIMARY, TV_FALL);
|
s->addEvent720(2 * 180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(3 * 180 - width, T_PRIMARY, TV_RISE);
|
s->addEvent720(3 * 180 - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(3 * 180, T_PRIMARY, TV_FALL);
|
s->addEvent720(3 * 180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(4 * 180 - width, T_PRIMARY, TV_RISE);
|
s->addEvent720(4 * 180 - width, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(4 * 180, T_PRIMARY, TV_FALL);
|
s->addEvent720(4 * 180, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void addPrimaryToothEndingAt(TriggerWaveform *s, float fallAngle) {
|
static void addPrimaryToothEndingAt(TriggerWaveform *s, float fallAngle) {
|
||||||
int vvtWidth = 20;
|
int vvtWidth = 20;
|
||||||
|
|
||||||
s->addEventAngle(fallAngle - vvtWidth, T_PRIMARY, TV_RISE);
|
s->addEventAngle(fallAngle - vvtWidth, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(fallAngle, T_PRIMARY, TV_FALL);
|
s->addEventAngle(fallAngle, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -73,8 +73,8 @@ void makeNissanPattern(TriggerWaveform* s, size_t halfCylinderCount, size_t tota
|
||||||
float currentAngle = missing * toothAngle;
|
float currentAngle = missing * toothAngle;
|
||||||
for (size_t i = 0; i < toothCount; i++) {
|
for (size_t i = 0; i < toothCount; i++) {
|
||||||
currentAngle += toothAngle;
|
currentAngle += toothAngle;
|
||||||
s->addEventAngle(currentAngle - 5, T_PRIMARY, TV_RISE);
|
s->addEventAngle(currentAngle - 5, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(currentAngle, T_PRIMARY, TV_FALL);
|
s->addEventAngle(currentAngle, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -111,14 +111,14 @@ void initializeNissanQR25crank(TriggerWaveform *s) {
|
||||||
float currentAngle = 20;
|
float currentAngle = 20;
|
||||||
for (int i = 0;i < 16;i++) {
|
for (int i = 0;i < 16;i++) {
|
||||||
currentAngle += 10;
|
currentAngle += 10;
|
||||||
s->addEventAngle(currentAngle - 5, T_PRIMARY, TV_RISE);
|
s->addEventAngle(currentAngle - 5, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(currentAngle, T_PRIMARY, TV_FALL);
|
s->addEventAngle(currentAngle, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void addvq30tooth(TriggerWaveform *s, float angle) {
|
static void addvq30tooth(TriggerWaveform *s, float angle) {
|
||||||
s->addEvent360(angle - 4, T_PRIMARY, TV_RISE);
|
s->addEvent360(angle - 4, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(angle, T_PRIMARY, TV_FALL);
|
s->addEvent360(angle, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
// yes, this is CAM shaft shape NOT crank shaft shape!
|
// yes, this is CAM shaft shape NOT crank shaft shape!
|
||||||
|
|
|
@ -19,15 +19,15 @@ static void commonRenix(TriggerWaveform *s) {
|
||||||
|
|
||||||
float currentAngle = 0;
|
float currentAngle = 0;
|
||||||
for (int i = 0;i < 20;i++) {
|
for (int i = 0;i < 20;i++) {
|
||||||
s->addEventAngle(currentAngle + tooth / 2, T_PRIMARY, TV_RISE);
|
s->addEventAngle(currentAngle + tooth / 2, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEventAngle(currentAngle + tooth, T_PRIMARY, TV_FALL);
|
s->addEventAngle(currentAngle + tooth, T_PRIMARY, TriggerValue::FALL);
|
||||||
currentAngle += tooth;
|
currentAngle += tooth;
|
||||||
}
|
}
|
||||||
|
|
||||||
s->addEventAngle(currentAngle + tooth, T_PRIMARY, TV_RISE);
|
s->addEventAngle(currentAngle + tooth, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
// float math error accumulates at this point so we have to spell out 180
|
// float math error accumulates at this point so we have to spell out 180
|
||||||
s->addEventAngle(s->getCycleDuration(), T_PRIMARY, TV_FALL);
|
s->addEventAngle(s->getCycleDuration(), T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TT_RENIX_44_2_2
|
// TT_RENIX_44_2_2
|
||||||
|
|
|
@ -26,32 +26,32 @@ void initializeRoverK(TriggerWaveform *s) {
|
||||||
float base = 0;
|
float base = 0;
|
||||||
|
|
||||||
for (int i = 0; i < 2; i++) {
|
for (int i = 0; i < 2; i++) {
|
||||||
s->addEvent720(base + tooth / 2, T_PRIMARY, TV_RISE);
|
s->addEvent720(base + tooth / 2, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(base + tooth, T_PRIMARY, TV_FALL);
|
s->addEvent720(base + tooth, T_PRIMARY, TriggerValue::FALL);
|
||||||
base += tooth;
|
base += tooth;
|
||||||
}
|
}
|
||||||
base += tooth;
|
base += tooth;
|
||||||
for (int i = 0; i < 2; i++) {
|
for (int i = 0; i < 2; i++) {
|
||||||
s->addEvent720(base + tooth / 2, T_PRIMARY, TV_RISE);
|
s->addEvent720(base + tooth / 2, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(base + tooth, T_PRIMARY, TV_FALL);
|
s->addEvent720(base + tooth, T_PRIMARY, TriggerValue::FALL);
|
||||||
base += tooth;
|
base += tooth;
|
||||||
}
|
}
|
||||||
base += tooth;
|
base += tooth;
|
||||||
for (int i = 0; i < 14; i++) {
|
for (int i = 0; i < 14; i++) {
|
||||||
s->addEvent720(base + tooth / 2, T_PRIMARY, TV_RISE);
|
s->addEvent720(base + tooth / 2, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(base + tooth, T_PRIMARY, TV_FALL);
|
s->addEvent720(base + tooth, T_PRIMARY, TriggerValue::FALL);
|
||||||
base += tooth;
|
base += tooth;
|
||||||
}
|
}
|
||||||
base += tooth;
|
base += tooth;
|
||||||
for (int i = 0; i < 3; i++) {
|
for (int i = 0; i < 3; i++) {
|
||||||
s->addEvent720(base + tooth / 2, T_PRIMARY, TV_RISE);
|
s->addEvent720(base + tooth / 2, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(base + tooth, T_PRIMARY, TV_FALL);
|
s->addEvent720(base + tooth, T_PRIMARY, TriggerValue::FALL);
|
||||||
base += tooth;
|
base += tooth;
|
||||||
}
|
}
|
||||||
base += tooth;
|
base += tooth;
|
||||||
for (int i = 0; i < 11; i++) {
|
for (int i = 0; i < 11; i++) {
|
||||||
s->addEvent720(base + tooth / 2, T_PRIMARY, TV_RISE);
|
s->addEvent720(base + tooth / 2, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(base + tooth, T_PRIMARY, TV_FALL);
|
s->addEvent720(base + tooth, T_PRIMARY, TriggerValue::FALL);
|
||||||
base += tooth;
|
base += tooth;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -168,7 +168,7 @@ angle_t TriggerWaveform::getAngle(int index) const {
|
||||||
return cycleStartAngle + positionWithinCycle;
|
return cycleStartAngle + positionWithinCycle;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TriggerWaveform::addEventClamped(angle_t angle, trigger_wheel_e const channelIndex, trigger_value_e const stateParam, float filterLeft, float filterRight) {
|
void TriggerWaveform::addEventClamped(angle_t angle, trigger_wheel_e const channelIndex, TriggerValue const stateParam, float filterLeft, float filterRight) {
|
||||||
if (angle > filterLeft && angle < filterRight) {
|
if (angle > filterLeft && angle < filterRight) {
|
||||||
#if EFI_UNIT_TEST
|
#if EFI_UNIT_TEST
|
||||||
// printf("addEventClamped %f %s\r\n", angle, getTrigger_value_e(stateParam));
|
// printf("addEventClamped %f %s\r\n", angle, getTrigger_value_e(stateParam));
|
||||||
|
@ -212,7 +212,7 @@ void TriggerWaveform::calculateExpectedEventCounts(bool useOnlyRisingEdgeForTrig
|
||||||
}
|
}
|
||||||
|
|
||||||
// todo: move the following logic from below here
|
// todo: move the following logic from below here
|
||||||
// if (!useOnlyRisingEdgeForTrigger || stateParam == TV_RISE) {
|
// if (!useOnlyRisingEdgeForTrigger || stateParam == TriggerValue::RISE) {
|
||||||
// expectedEventCount[channelIndex]++;
|
// expectedEventCount[channelIndex]++;
|
||||||
// }
|
// }
|
||||||
|
|
||||||
|
@ -221,20 +221,20 @@ void TriggerWaveform::calculateExpectedEventCounts(bool useOnlyRisingEdgeForTrig
|
||||||
/**
|
/**
|
||||||
* Deprecated! many usages should be replaced by addEvent360
|
* Deprecated! many usages should be replaced by addEvent360
|
||||||
*/
|
*/
|
||||||
void TriggerWaveform::addEvent720(angle_t angle, trigger_wheel_e const channelIndex, trigger_value_e const state) {
|
void TriggerWaveform::addEvent720(angle_t angle, trigger_wheel_e const channelIndex, TriggerValue const state) {
|
||||||
addEvent(angle / FOUR_STROKE_CYCLE_DURATION, channelIndex, state);
|
addEvent(angle / FOUR_STROKE_CYCLE_DURATION, channelIndex, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TriggerWaveform::addEvent360(angle_t angle, trigger_wheel_e const channelIndex, trigger_value_e const state) {
|
void TriggerWaveform::addEvent360(angle_t angle, trigger_wheel_e const channelIndex, TriggerValue const state) {
|
||||||
efiAssertVoid(CUSTOM_OMODE_UNDEF, operationMode == FOUR_STROKE_CAM_SENSOR || operationMode == FOUR_STROKE_CRANK_SENSOR, "Not a mode for 360");
|
efiAssertVoid(CUSTOM_OMODE_UNDEF, operationMode == FOUR_STROKE_CAM_SENSOR || operationMode == FOUR_STROKE_CRANK_SENSOR, "Not a mode for 360");
|
||||||
addEvent(CRANK_MODE_MULTIPLIER * angle / FOUR_STROKE_CYCLE_DURATION, channelIndex, state);
|
addEvent(CRANK_MODE_MULTIPLIER * angle / FOUR_STROKE_CYCLE_DURATION, channelIndex, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TriggerWaveform::addEventAngle(angle_t angle, trigger_wheel_e const channelIndex, trigger_value_e const state) {
|
void TriggerWaveform::addEventAngle(angle_t angle, trigger_wheel_e const channelIndex, TriggerValue const state) {
|
||||||
addEvent(angle / getCycleDuration(), channelIndex, state);
|
addEvent(angle / getCycleDuration(), channelIndex, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TriggerWaveform::addEvent(angle_t angle, trigger_wheel_e const channelIndex, trigger_value_e const state) {
|
void TriggerWaveform::addEvent(angle_t angle, trigger_wheel_e const channelIndex, TriggerValue const state) {
|
||||||
efiAssertVoid(CUSTOM_OMODE_UNDEF, operationMode != OM_NONE, "operationMode not set");
|
efiAssertVoid(CUSTOM_OMODE_UNDEF, operationMode != OM_NONE, "operationMode not set");
|
||||||
|
|
||||||
if (channelIndex == T_SECONDARY) {
|
if (channelIndex == T_SECONDARY) {
|
||||||
|
@ -257,7 +257,7 @@ void TriggerWaveform::addEvent(angle_t angle, trigger_wheel_e const channelIndex
|
||||||
// todo: the whole 'useOnlyRisingEdgeForTrigger' parameter and logic should not be here
|
// todo: the whole 'useOnlyRisingEdgeForTrigger' parameter and logic should not be here
|
||||||
// todo: see calculateExpectedEventCounts
|
// todo: see calculateExpectedEventCounts
|
||||||
// related calculation should be done once trigger is initialized outside of trigger shape scope
|
// related calculation should be done once trigger is initialized outside of trigger shape scope
|
||||||
if (!useOnlyRisingEdgeForTriggerTemp || state == TV_RISE) {
|
if (!useOnlyRisingEdgeForTriggerTemp || state == TriggerValue::RISE) {
|
||||||
expectedEventCount[channelIndex]++;
|
expectedEventCount[channelIndex]++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -284,7 +284,7 @@ void TriggerWaveform::addEvent(angle_t angle, trigger_wheel_e const channelIndex
|
||||||
wave.setChannelState(i, /* switchIndex */ 0, /* value */ initialState[i]);
|
wave.setChannelState(i, /* switchIndex */ 0, /* value */ initialState[i]);
|
||||||
}
|
}
|
||||||
|
|
||||||
isRiseEvent[0] = TV_RISE == state;
|
isRiseEvent[0] = TriggerValue::RISE == state;
|
||||||
wave.setSwitchTime(0, angle);
|
wave.setSwitchTime(0, angle);
|
||||||
wave.setChannelState(channelIndex, /* channelIndex */ 0, /* value */ state);
|
wave.setChannelState(channelIndex, /* channelIndex */ 0, /* value */ state);
|
||||||
return;
|
return;
|
||||||
|
@ -311,7 +311,7 @@ void TriggerWaveform::addEvent(angle_t angle, trigger_wheel_e const channelIndex
|
||||||
wave.setSwitchTime(i + 1, wave.getSwitchTime(i));
|
wave.setSwitchTime(i + 1, wave.getSwitchTime(i));
|
||||||
}
|
}
|
||||||
*/
|
*/
|
||||||
isRiseEvent[index] = TV_RISE == state;
|
isRiseEvent[index] = TriggerValue::RISE == state;
|
||||||
|
|
||||||
if ((unsigned)index != wave.phaseCount) {
|
if ((unsigned)index != wave.phaseCount) {
|
||||||
firmwareError(ERROR_TRIGGER_DRAMA, "are we ever here?");
|
firmwareError(ERROR_TRIGGER_DRAMA, "are we ever here?");
|
||||||
|
|
|
@ -176,7 +176,7 @@ public:
|
||||||
* These signals are used for trigger export only
|
* These signals are used for trigger export only
|
||||||
*/
|
*/
|
||||||
int triggerSignalIndeces[PWM_PHASE_MAX_COUNT];
|
int triggerSignalIndeces[PWM_PHASE_MAX_COUNT];
|
||||||
int triggerSignalStates[PWM_PHASE_MAX_COUNT];
|
TriggerValue triggerSignalStates[PWM_PHASE_MAX_COUNT];
|
||||||
// see also 'doesTriggerImplyOperationMode'
|
// see also 'doesTriggerImplyOperationMode'
|
||||||
bool knownOperationMode = true;
|
bool knownOperationMode = true;
|
||||||
#endif
|
#endif
|
||||||
|
@ -199,16 +199,16 @@ public:
|
||||||
bool useOnlyRisingEdgeForTriggerTemp;
|
bool useOnlyRisingEdgeForTriggerTemp;
|
||||||
|
|
||||||
/* (0..1] angle range */
|
/* (0..1] angle range */
|
||||||
void addEvent(angle_t angle, trigger_wheel_e const channelIndex, trigger_value_e const state);
|
void addEvent(angle_t angle, trigger_wheel_e const channelIndex, TriggerValue const state);
|
||||||
/* (0..720] angle range
|
/* (0..720] angle range
|
||||||
* Deprecated! many usages should be replaced by addEvent360
|
* Deprecated! many usages should be replaced by addEvent360
|
||||||
*/
|
*/
|
||||||
void addEvent720(angle_t angle, trigger_wheel_e const channelIndex, trigger_value_e const state);
|
void addEvent720(angle_t angle, trigger_wheel_e const channelIndex, TriggerValue const state);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* this method helps us use real world 360 degrees shape for FOUR_STROKE_CAM_SENSOR and FOUR_STROKE_CRANK_SENSOR
|
* this method helps us use real world 360 degrees shape for FOUR_STROKE_CAM_SENSOR and FOUR_STROKE_CRANK_SENSOR
|
||||||
*/
|
*/
|
||||||
void addEvent360(angle_t angle, trigger_wheel_e const channelIndex, trigger_value_e const state);
|
void addEvent360(angle_t angle, trigger_wheel_e const channelIndex, TriggerValue const state);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This version of 'addEvent...' family considers the angle duration of operationMode in this trigger
|
* This version of 'addEvent...' family considers the angle duration of operationMode in this trigger
|
||||||
|
@ -217,12 +217,12 @@ public:
|
||||||
* TODO: one day kill all usages with FOUR_STROKE_CAM_SENSOR 720 cycle and add runtime prohibition
|
* TODO: one day kill all usages with FOUR_STROKE_CAM_SENSOR 720 cycle and add runtime prohibition
|
||||||
* TODO: for FOUR_STROKE_CAM_SENSOR addEvent360 is the way to go
|
* TODO: for FOUR_STROKE_CAM_SENSOR addEvent360 is the way to go
|
||||||
*/
|
*/
|
||||||
void addEventAngle(angle_t angle, trigger_wheel_e const channelIndex, trigger_value_e const state);
|
void addEventAngle(angle_t angle, trigger_wheel_e const channelIndex, TriggerValue const state);
|
||||||
|
|
||||||
/* (0..720] angle range
|
/* (0..720] angle range
|
||||||
* Deprecated?
|
* Deprecated?
|
||||||
*/
|
*/
|
||||||
void addEventClamped(angle_t angle, trigger_wheel_e const channelIndex, trigger_value_e const stateParam, float filterLeft, float filterRight);
|
void addEventClamped(angle_t angle, trigger_wheel_e const channelIndex, TriggerValue const stateParam, float filterLeft, float filterRight);
|
||||||
operation_mode_e getWheelOperationMode() const;
|
operation_mode_e getWheelOperationMode() const;
|
||||||
|
|
||||||
void initialize(operation_mode_e operationMode);
|
void initialize(operation_mode_e operationMode);
|
||||||
|
|
|
@ -23,26 +23,26 @@ static void initialize_one_of_36_2_2_2(TriggerWaveform *s, int firstCount, int s
|
||||||
float base = 0;
|
float base = 0;
|
||||||
|
|
||||||
for (int i = 0; i < firstCount; i++) {
|
for (int i = 0; i < firstCount; i++) {
|
||||||
s->addEvent720(base + narrow / 2, T_PRIMARY, TV_FALL);
|
s->addEvent720(base + narrow / 2, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(base + narrow, T_PRIMARY, TV_RISE);
|
s->addEvent720(base + narrow, T_PRIMARY, TriggerValue::RISE);
|
||||||
base += narrow;
|
base += narrow;
|
||||||
}
|
}
|
||||||
|
|
||||||
s->addEvent720(base + wide / 2, T_PRIMARY, TV_FALL);
|
s->addEvent720(base + wide / 2, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(base + wide, T_PRIMARY, TV_RISE);
|
s->addEvent720(base + wide, T_PRIMARY, TriggerValue::RISE);
|
||||||
base += wide;
|
base += wide;
|
||||||
|
|
||||||
for (int i = 0; i < secondCount; i++) {
|
for (int i = 0; i < secondCount; i++) {
|
||||||
s->addEvent720(base + narrow / 2, T_PRIMARY, TV_FALL);
|
s->addEvent720(base + narrow / 2, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(base + narrow, T_PRIMARY, TV_RISE);
|
s->addEvent720(base + narrow, T_PRIMARY, TriggerValue::RISE);
|
||||||
base += narrow;
|
base += narrow;
|
||||||
}
|
}
|
||||||
|
|
||||||
s->addEvent720(720 - wide - wide / 2, T_PRIMARY, TV_FALL);
|
s->addEvent720(720 - wide - wide / 2, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(720 - wide, T_PRIMARY, TV_RISE);
|
s->addEvent720(720 - wide, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(720 - wide / 2, T_PRIMARY, TV_FALL);
|
s->addEvent720(720 - wide / 2, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEvent720(720, T_PRIMARY, TV_RISE);
|
s->addEvent720(720, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->useOnlyPrimaryForSync = true;
|
s->useOnlyPrimaryForSync = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -86,22 +86,22 @@ static void initializeSubaru7_6(TriggerWaveform *s, bool withCrankWheel) {
|
||||||
/* 97 degrees BTDC, but we have 20 degrees shift:
|
/* 97 degrees BTDC, but we have 20 degrees shift:
|
||||||
* 180 - 97 - 20 = 63 */
|
* 180 - 97 - 20 = 63 */
|
||||||
#define SUBARU76_CRANK_PULSE0(cycle) \
|
#define SUBARU76_CRANK_PULSE0(cycle) \
|
||||||
s->addEvent720((180 * (cycle)) + 63 - width, T_SECONDARY, TV_RISE); \
|
s->addEvent720((180 * (cycle)) + 63 - width, T_SECONDARY, TriggerValue::RISE); \
|
||||||
s->addEvent720((180 * (cycle)) + 63, T_SECONDARY, TV_FALL)
|
s->addEvent720((180 * (cycle)) + 63, T_SECONDARY, TriggerValue::FALL)
|
||||||
/* 65 degrees BTDC, but we have 20 degrees shift:
|
/* 65 degrees BTDC, but we have 20 degrees shift:
|
||||||
* 180 - 65 - 20 = 95 */
|
* 180 - 65 - 20 = 95 */
|
||||||
#define SUBARU76_CRANK_PULSE1(cycle) \
|
#define SUBARU76_CRANK_PULSE1(cycle) \
|
||||||
s->addEvent720((180 * (cycle)) + 95 - width, T_SECONDARY, TV_RISE); \
|
s->addEvent720((180 * (cycle)) + 95 - width, T_SECONDARY, TriggerValue::RISE); \
|
||||||
s->addEvent720((180 * (cycle)) + 95, T_SECONDARY, TV_FALL)
|
s->addEvent720((180 * (cycle)) + 95, T_SECONDARY, TriggerValue::FALL)
|
||||||
/* 10 degrees BTDC, but we have 20 degrees shift:
|
/* 10 degrees BTDC, but we have 20 degrees shift:
|
||||||
* 180 - 10 - 20 = 150 */
|
* 180 - 10 - 20 = 150 */
|
||||||
#define SUBARU76_CRANK_PULSE2(cycle) \
|
#define SUBARU76_CRANK_PULSE2(cycle) \
|
||||||
s->addEvent720((180 * (cycle)) + 150 - width, T_SECONDARY, TV_RISE); \
|
s->addEvent720((180 * (cycle)) + 150 - width, T_SECONDARY, TriggerValue::RISE); \
|
||||||
s->addEvent720((180 * (cycle)) + 150, T_SECONDARY, TV_FALL)
|
s->addEvent720((180 * (cycle)) + 150, T_SECONDARY, TriggerValue::FALL)
|
||||||
|
|
||||||
#define SUBARU76_CAM_PULSE(cycle, offset) \
|
#define SUBARU76_CAM_PULSE(cycle, offset) \
|
||||||
s->addEvent720((180 * (cycle)) + (offset) - width, T_PRIMARY, TV_RISE); \
|
s->addEvent720((180 * (cycle)) + (offset) - width, T_PRIMARY, TriggerValue::RISE); \
|
||||||
s->addEvent720((180 * (cycle)) + (offset), T_PRIMARY, TV_FALL)
|
s->addEvent720((180 * (cycle)) + (offset), T_PRIMARY, TriggerValue::FALL)
|
||||||
|
|
||||||
/* (TDC#2 + 20) + 15 */
|
/* (TDC#2 + 20) + 15 */
|
||||||
SUBARU76_CAM_PULSE(0, +15);
|
SUBARU76_CAM_PULSE(0, +15);
|
||||||
|
@ -202,14 +202,14 @@ void initializeSubaru_SVX(TriggerWaveform *s) {
|
||||||
#define CRANK_1_RISE(n) (CRANK_1_FALL(n) - width)
|
#define CRANK_1_RISE(n) (CRANK_1_FALL(n) - width)
|
||||||
|
|
||||||
#define SUBARU_SVX_CRANK1_PULSE(n) \
|
#define SUBARU_SVX_CRANK1_PULSE(n) \
|
||||||
s->addEventAngle(20 + (30 * (n)) + offset - width, SVX_CRANK_1, TV_RISE); \
|
s->addEventAngle(20 + (30 * (n)) + offset - width, SVX_CRANK_1, TriggerValue::RISE); \
|
||||||
s->addEventAngle(20 + (30 * (n)) + offset, SVX_CRANK_1, TV_FALL)
|
s->addEventAngle(20 + (30 * (n)) + offset, SVX_CRANK_1, TriggerValue::FALL)
|
||||||
|
|
||||||
/* cam falling edge offset from preceding Cr #1 falling edge */
|
/* cam falling edge offset from preceding Cr #1 falling edge */
|
||||||
float cam_offset = (10.0 + 30.0 + 30.0 + 30.0) - 90.0;
|
float cam_offset = (10.0 + 30.0 + 30.0 + 30.0) - 90.0;
|
||||||
#define SUBARU_SVX_CAM_PULSE(n) \
|
#define SUBARU_SVX_CAM_PULSE(n) \
|
||||||
s->addEvent720(CRANK_1_RISE(n) + cam_offset, SVX_CAM, TV_RISE); \
|
s->addEvent720(CRANK_1_RISE(n) + cam_offset, SVX_CAM, TriggerValue::RISE); \
|
||||||
s->addEvent720(CRANK_1_FALL(n) + cam_offset, SVX_CAM, TV_FALL)
|
s->addEvent720(CRANK_1_FALL(n) + cam_offset, SVX_CAM, TriggerValue::FALL)
|
||||||
|
|
||||||
#ifdef SVX_CRANK_2
|
#ifdef SVX_CRANK_2
|
||||||
/* Cr #2 signle tooth falling edge is (55 + 1) BTDC
|
/* Cr #2 signle tooth falling edge is (55 + 1) BTDC
|
||||||
|
@ -217,8 +217,8 @@ void initializeSubaru_SVX(TriggerWaveform *s) {
|
||||||
float crank_2_offset = (10.0 + 30.0 + 30.0) - (55.0 + 1.0);
|
float crank_2_offset = (10.0 + 30.0 + 30.0) - (55.0 + 1.0);
|
||||||
|
|
||||||
#define SUBARU_SVX_CRANK2_PULSE(n) \
|
#define SUBARU_SVX_CRANK2_PULSE(n) \
|
||||||
s->addEvent720(CRANK_1_RISE(n) + crank_2_offset, SVX_CRANK_2, TV_RISE); \
|
s->addEvent720(CRANK_1_RISE(n) + crank_2_offset, SVX_CRANK_2, TriggerValue::RISE); \
|
||||||
s->addEvent720(CRANK_1_FALL(n) + crank_2_offset, SVX_CRANK_2, TV_FALL)
|
s->addEvent720(CRANK_1_FALL(n) + crank_2_offset, SVX_CRANK_2, TriggerValue::FALL)
|
||||||
#else
|
#else
|
||||||
#define SUBARU_SVX_CRANK2_PULSE(n) (void)(n)
|
#define SUBARU_SVX_CRANK2_PULSE(n) (void)(n)
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -15,20 +15,20 @@ void initializeSuzukiG13B(TriggerWaveform *s) {
|
||||||
float w = 5;
|
float w = 5;
|
||||||
float specialTooth = 20;
|
float specialTooth = 20;
|
||||||
|
|
||||||
s->addEvent720(180 - w, T_PRIMARY, TV_RISE);
|
s->addEvent720(180 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(180, T_PRIMARY, TV_FALL);
|
s->addEvent720(180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(2 * specialTooth + 180 - w, T_PRIMARY, TV_RISE);
|
s->addEvent720(2 * specialTooth + 180 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(2 * specialTooth + 180, T_PRIMARY, TV_FALL);
|
s->addEvent720(2 * specialTooth + 180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(360 - w, T_PRIMARY, TV_RISE);
|
s->addEvent720(360 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(360, T_PRIMARY, TV_FALL);
|
s->addEvent720(360, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(540 - w, T_PRIMARY, TV_RISE);
|
s->addEvent720(540 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(540, T_PRIMARY, TV_FALL);
|
s->addEvent720(540, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent720(720 - w, T_PRIMARY, TV_RISE);
|
s->addEvent720(720 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(720, T_PRIMARY, TV_FALL);
|
s->addEvent720(720, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->setTriggerSynchronizationGap(0.22);
|
s->setTriggerSynchronizationGap(0.22);
|
||||||
s->setSecondTriggerSynchronizationGap(1);
|
s->setSecondTriggerSynchronizationGap(1);
|
||||||
|
|
|
@ -23,30 +23,30 @@ void initialize2jzGE1_12(TriggerWaveform *s) {
|
||||||
float crankD = 360 / 12 / 2; // 15
|
float crankD = 360 / 12 / 2; // 15
|
||||||
|
|
||||||
float crankAngle = 10;
|
float crankAngle = 10;
|
||||||
s->addEventClamped(crankAngle, T_SECONDARY, TV_FALL, -1, 721); // 120
|
s->addEventClamped(crankAngle, T_SECONDARY, TriggerValue::FALL, -1, 721); // 120
|
||||||
|
|
||||||
for (int i = 0; i < 2; i++) {
|
for (int i = 0; i < 2; i++) {
|
||||||
s->addEventClamped(crankAngle + crankD, T_SECONDARY, TV_RISE, -1, 721);
|
s->addEventClamped(crankAngle + crankD, T_SECONDARY, TriggerValue::RISE, -1, 721);
|
||||||
crankAngle += crankD;
|
crankAngle += crankD;
|
||||||
s->addEventClamped(crankAngle + crankD, T_SECONDARY, TV_FALL, -1, 721); // 120
|
s->addEventClamped(crankAngle + crankD, T_SECONDARY, TriggerValue::FALL, -1, 721); // 120
|
||||||
crankAngle += crankD;
|
crankAngle += crankD;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
s->addEventClamped(75, T_PRIMARY, TV_FALL, -1, 721);
|
s->addEventClamped(75, T_PRIMARY, TriggerValue::FALL, -1, 721);
|
||||||
|
|
||||||
for (int i = 0; i < 21; i++) {
|
for (int i = 0; i < 21; i++) {
|
||||||
s->addEventClamped(crankAngle + crankD, T_SECONDARY, TV_RISE, -1, 721);
|
s->addEventClamped(crankAngle + crankD, T_SECONDARY, TriggerValue::RISE, -1, 721);
|
||||||
crankAngle += crankD;
|
crankAngle += crankD;
|
||||||
s->addEventClamped(crankAngle + crankD, T_SECONDARY, TV_FALL, -1, 721); // 120
|
s->addEventClamped(crankAngle + crankD, T_SECONDARY, TriggerValue::FALL, -1, 721); // 120
|
||||||
crankAngle += crankD;
|
crankAngle += crankD;
|
||||||
}
|
}
|
||||||
|
|
||||||
s->addEventClamped(crankAngle + crankD, T_SECONDARY, TV_RISE, -1, 721);
|
s->addEventClamped(crankAngle + crankD, T_SECONDARY, TriggerValue::RISE, -1, 721);
|
||||||
crankAngle += crankD;
|
crankAngle += crankD;
|
||||||
|
|
||||||
|
|
||||||
s->addEventClamped(720, T_PRIMARY, TV_RISE, -1, 721);
|
s->addEventClamped(720, T_PRIMARY, TriggerValue::RISE, -1, 721);
|
||||||
|
|
||||||
s->isSynchronizationNeeded = false;
|
s->isSynchronizationNeeded = false;
|
||||||
}
|
}
|
||||||
|
@ -65,18 +65,18 @@ void initialize2jzGE3_34_simulation_shape(TriggerWaveform *s) {
|
||||||
float crankAngle = 2 * crankDelta; // skipping two teeth
|
float crankAngle = 2 * crankDelta; // skipping two teeth
|
||||||
|
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
s->addEvent720(crankAngle + 5, T_SECONDARY, TV_RISE);
|
s->addEvent720(crankAngle + 5, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TV_FALL); // 120
|
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TriggerValue::FALL); // 120
|
||||||
crankAngle += 10;
|
crankAngle += 10;
|
||||||
} // 2 + 10
|
} // 2 + 10
|
||||||
|
|
||||||
camAngle += camD;
|
camAngle += camD;
|
||||||
s->addEvent720(camAngle, T_PRIMARY, TV_RISE); // 120
|
s->addEvent720(camAngle, T_PRIMARY, TriggerValue::RISE); // 120
|
||||||
s->addEvent720(camAngle + 3, T_PRIMARY, TV_FALL);
|
s->addEvent720(camAngle + 3, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
for (int i = 0; i < 12; i++) {
|
for (int i = 0; i < 12; i++) {
|
||||||
s->addEvent720(crankAngle + 5, T_SECONDARY, TV_RISE);
|
s->addEvent720(crankAngle + 5, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TV_FALL); // 120
|
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TriggerValue::FALL); // 120
|
||||||
crankAngle += 10;
|
crankAngle += 10;
|
||||||
} // 2 + 22
|
} // 2 + 22
|
||||||
|
|
||||||
|
@ -84,38 +84,38 @@ void initialize2jzGE3_34_simulation_shape(TriggerWaveform *s) {
|
||||||
camAngle += camD;
|
camAngle += camD;
|
||||||
|
|
||||||
for (int i = 0; i < 12; i++) {
|
for (int i = 0; i < 12; i++) {
|
||||||
s->addEvent720(crankAngle + 5, T_SECONDARY, TV_RISE);
|
s->addEvent720(crankAngle + 5, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TV_FALL); // 120
|
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TriggerValue::FALL); // 120
|
||||||
crankAngle += crankDelta;
|
crankAngle += crankDelta;
|
||||||
} // 2 + 34
|
} // 2 + 34
|
||||||
|
|
||||||
camAngle += camD;
|
camAngle += camD;
|
||||||
s->addEvent720(camAngle, T_PRIMARY, TV_RISE); // 360
|
s->addEvent720(camAngle, T_PRIMARY, TriggerValue::RISE); // 360
|
||||||
s->addEvent720(camAngle + 3, T_PRIMARY, TV_FALL);
|
s->addEvent720(camAngle + 3, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
crankAngle += 20; // skipping two teeth one more time
|
crankAngle += 20; // skipping two teeth one more time
|
||||||
for (int i = 0; i < 10; i++) {
|
for (int i = 0; i < 10; i++) {
|
||||||
s->addEvent720(crankAngle + 5, T_SECONDARY, TV_RISE);
|
s->addEvent720(crankAngle + 5, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TV_FALL); // 120
|
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TriggerValue::FALL); // 120
|
||||||
crankAngle += crankDelta;
|
crankAngle += crankDelta;
|
||||||
} // 2 + 10
|
} // 2 + 10
|
||||||
|
|
||||||
camAngle += camD;
|
camAngle += camD;
|
||||||
|
|
||||||
for (int i = 0; i < 12; i++) {
|
for (int i = 0; i < 12; i++) {
|
||||||
s->addEvent720(crankAngle + 5, T_SECONDARY, TV_RISE);
|
s->addEvent720(crankAngle + 5, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TV_FALL); // 120
|
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TriggerValue::FALL); // 120
|
||||||
crankAngle += crankDelta;
|
crankAngle += crankDelta;
|
||||||
} // 2 + 22
|
} // 2 + 22
|
||||||
|
|
||||||
camAngle += camD;
|
camAngle += camD;
|
||||||
s->addEvent720(camAngle, T_PRIMARY, TV_RISE); // 600
|
s->addEvent720(camAngle, T_PRIMARY, TriggerValue::RISE); // 600
|
||||||
s->addEvent720(camAngle + 3, T_PRIMARY, TV_FALL);
|
s->addEvent720(camAngle + 3, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
|
|
||||||
for (int i = 0; i < 12; i++) {
|
for (int i = 0; i < 12; i++) {
|
||||||
s->addEvent720(crankAngle + 5, T_SECONDARY, TV_RISE);
|
s->addEvent720(crankAngle + 5, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TV_FALL); // 120
|
s->addEvent720(crankAngle + crankDelta, T_SECONDARY, TriggerValue::FALL); // 120
|
||||||
crankAngle += 10;
|
crankAngle += 10;
|
||||||
} // 2 + 32
|
} // 2 + 32
|
||||||
camAngle += camD;
|
camAngle += camD;
|
||||||
|
@ -130,12 +130,12 @@ void initializeToyota4_1(TriggerWaveform *s) {
|
||||||
|
|
||||||
int w = 10;
|
int w = 10;
|
||||||
|
|
||||||
s->addEvent360(180 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(180 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(180, T_PRIMARY, TV_FALL);
|
s->addEvent360(180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(270 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(270 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(270, T_PRIMARY, TV_FALL);
|
s->addEvent360(270, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(360 - w, T_PRIMARY, TV_RISE);
|
s->addEvent360(360 - w, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(360, T_PRIMARY, TV_FALL);
|
s->addEvent360(360, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,14 +24,14 @@ void addSkippedToothTriggerEvents(trigger_wheel_e wheel, TriggerWaveform *s, int
|
||||||
for (int i = 0; i < totalTeethCount - skippedCount - 1; i++) {
|
for (int i = 0; i < totalTeethCount - skippedCount - 1; i++) {
|
||||||
float angleDown = engineCycle / totalTeethCount * (i + (1 - toothWidth));
|
float angleDown = engineCycle / totalTeethCount * (i + (1 - toothWidth));
|
||||||
float angleUp = engineCycle / totalTeethCount * (i + 1);
|
float angleUp = engineCycle / totalTeethCount * (i + 1);
|
||||||
s->addEventClamped(offset + angleDown, wheel, TV_RISE, filterLeft, filterRight);
|
s->addEventClamped(offset + angleDown, wheel, TriggerValue::RISE, filterLeft, filterRight);
|
||||||
s->addEventClamped(offset + angleUp, wheel, TV_FALL, filterLeft, filterRight);
|
s->addEventClamped(offset + angleUp, wheel, TriggerValue::FALL, filterLeft, filterRight);
|
||||||
}
|
}
|
||||||
|
|
||||||
float angleDown = engineCycle / totalTeethCount * (totalTeethCount - skippedCount - 1 + (1 - toothWidth));
|
float angleDown = engineCycle / totalTeethCount * (totalTeethCount - skippedCount - 1 + (1 - toothWidth));
|
||||||
s->addEventClamped(offset + angleDown, wheel, TV_RISE, filterLeft, filterRight);
|
s->addEventClamped(offset + angleDown, wheel, TriggerValue::RISE, filterLeft, filterRight);
|
||||||
// custom handling of last event in order to avoid rounding error
|
// custom handling of last event in order to avoid rounding error
|
||||||
s->addEventClamped(offset + engineCycle, wheel, TV_FALL, filterLeft, filterRight);
|
s->addEventClamped(offset + engineCycle, wheel, TriggerValue::FALL, filterLeft, filterRight);
|
||||||
}
|
}
|
||||||
|
|
||||||
void initializeSkippedToothTriggerWaveformExt(TriggerWaveform *s, int totalTeethCount, int skippedCount,
|
void initializeSkippedToothTriggerWaveformExt(TriggerWaveform *s, int totalTeethCount, int skippedCount,
|
||||||
|
@ -63,11 +63,11 @@ void initializeSkippedToothTriggerWaveformExt(TriggerWaveform *s, int totalTeeth
|
||||||
void configureOnePlusOne(TriggerWaveform *s) {
|
void configureOnePlusOne(TriggerWaveform *s) {
|
||||||
s->initialize(FOUR_STROKE_CAM_SENSOR);
|
s->initialize(FOUR_STROKE_CAM_SENSOR);
|
||||||
|
|
||||||
s->addEvent360( 90, T_PRIMARY, TV_RISE);
|
s->addEvent360( 90, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(180, T_PRIMARY, TV_FALL);
|
s->addEvent360(180, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(270, T_SECONDARY, TV_RISE);
|
s->addEvent360(270, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent360(360, T_SECONDARY, TV_FALL);
|
s->addEvent360(360, T_SECONDARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->isSynchronizationNeeded = false;
|
s->isSynchronizationNeeded = false;
|
||||||
s->useOnlyPrimaryForSync = true;
|
s->useOnlyPrimaryForSync = true;
|
||||||
|
@ -82,29 +82,29 @@ void configure3_1_cam(TriggerWaveform *s) {
|
||||||
|
|
||||||
trigger_wheel_e crank = T_SECONDARY;
|
trigger_wheel_e crank = T_SECONDARY;
|
||||||
|
|
||||||
s->addEvent720(10, T_PRIMARY, TV_RISE);
|
s->addEvent720(10, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent720(50, T_PRIMARY, TV_FALL);
|
s->addEvent720(50, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
|
|
||||||
float a = 2 * crankW;
|
float a = 2 * crankW;
|
||||||
|
|
||||||
// #1/3
|
// #1/3
|
||||||
s->addEvent720(a += crankW, crank, TV_RISE);
|
s->addEvent720(a += crankW, crank, TriggerValue::RISE);
|
||||||
s->addEvent720(a += crankW, crank, TV_FALL);
|
s->addEvent720(a += crankW, crank, TriggerValue::FALL);
|
||||||
// #2/3
|
// #2/3
|
||||||
s->addEvent720(a += crankW, crank, TV_RISE);
|
s->addEvent720(a += crankW, crank, TriggerValue::RISE);
|
||||||
s->addEvent720(a += crankW, crank, TV_FALL);
|
s->addEvent720(a += crankW, crank, TriggerValue::FALL);
|
||||||
// #3/3
|
// #3/3
|
||||||
a += crankW;
|
a += crankW;
|
||||||
a += crankW;
|
a += crankW;
|
||||||
|
|
||||||
// 2nd #1/3
|
// 2nd #1/3
|
||||||
s->addEvent720(a += crankW, crank, TV_RISE);
|
s->addEvent720(a += crankW, crank, TriggerValue::RISE);
|
||||||
s->addEvent720(a += crankW, crank, TV_FALL);
|
s->addEvent720(a += crankW, crank, TriggerValue::FALL);
|
||||||
|
|
||||||
// 2nd #2/3
|
// 2nd #2/3
|
||||||
s->addEvent720(a += crankW, crank, TV_RISE);
|
s->addEvent720(a += crankW, crank, TriggerValue::RISE);
|
||||||
s->addEvent720(a += crankW, crank, TV_FALL);
|
s->addEvent720(a += crankW, crank, TriggerValue::FALL);
|
||||||
|
|
||||||
s->isSynchronizationNeeded = false;
|
s->isSynchronizationNeeded = false;
|
||||||
}
|
}
|
||||||
|
@ -123,8 +123,8 @@ void configureKawaKX450F(TriggerWaveform *s) {
|
||||||
addSkippedToothTriggerEvents(T_PRIMARY, s, 18, 0, toothWidth, 0, engineCycle,
|
addSkippedToothTriggerEvents(T_PRIMARY, s, 18, 0, toothWidth, 0, engineCycle,
|
||||||
NO_LEFT_FILTER, 720 - 39);
|
NO_LEFT_FILTER, 720 - 39);
|
||||||
|
|
||||||
s->addEvent(0.97, T_PRIMARY, TV_RISE);
|
s->addEvent(0.97, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent(1, T_PRIMARY, TV_FALL);
|
s->addEvent(1, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void configureQuickStartSenderWheel(TriggerWaveform *s) {
|
void configureQuickStartSenderWheel(TriggerWaveform *s) {
|
||||||
|
@ -138,17 +138,17 @@ void configureQuickStartSenderWheel(TriggerWaveform *s) {
|
||||||
s->setTriggerSynchronizationGap(0.645);
|
s->setTriggerSynchronizationGap(0.645);
|
||||||
s->setSecondTriggerSynchronizationGap(1.556);
|
s->setSecondTriggerSynchronizationGap(1.556);
|
||||||
|
|
||||||
s->addEvent360(offset + 0, T_PRIMARY, TV_RISE);
|
s->addEvent360(offset + 0, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(offset + 70, T_PRIMARY, TV_FALL);
|
s->addEvent360(offset + 70, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(offset + 90, T_PRIMARY, TV_RISE);
|
s->addEvent360(offset + 90, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(offset + 110, T_PRIMARY, TV_FALL);
|
s->addEvent360(offset + 110, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(offset + 180, T_PRIMARY, TV_RISE);
|
s->addEvent360(offset + 180, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(offset + 200, T_PRIMARY, TV_FALL);
|
s->addEvent360(offset + 200, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(offset + 270, T_PRIMARY, TV_RISE);
|
s->addEvent360(offset + 270, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(offset + 340, T_PRIMARY, TV_FALL);
|
s->addEvent360(offset + 340, T_PRIMARY, TriggerValue::FALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Useful for:
|
// Useful for:
|
||||||
|
@ -166,6 +166,6 @@ void configure12ToothCrank(TriggerWaveform* s) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Just a single tooth with 50% duty cycle
|
// Just a single tooth with 50% duty cycle
|
||||||
s->addEventAngle(15, T_PRIMARY, TV_FALL);
|
s->addEventAngle(15, T_PRIMARY, TriggerValue::FALL);
|
||||||
s->addEventAngle(30, T_PRIMARY, TV_RISE);
|
s->addEventAngle(30, T_PRIMARY, TriggerValue::RISE);
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,14 +12,14 @@
|
||||||
void setSkodaFavorit(TriggerWaveform *s) {
|
void setSkodaFavorit(TriggerWaveform *s) {
|
||||||
s->initialize(FOUR_STROKE_CRANK_SENSOR);
|
s->initialize(FOUR_STROKE_CRANK_SENSOR);
|
||||||
|
|
||||||
s->addEvent360(46, T_PRIMARY, TV_RISE);
|
s->addEvent360(46, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(177, T_PRIMARY, TV_FALL);
|
s->addEvent360(177, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(180, T_PRIMARY, TV_RISE);
|
s->addEvent360(180, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(183, T_PRIMARY, TV_FALL);
|
s->addEvent360(183, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->addEvent360(226, T_PRIMARY, TV_RISE);
|
s->addEvent360(226, T_PRIMARY, TriggerValue::RISE);
|
||||||
s->addEvent360(360, T_PRIMARY, TV_FALL);
|
s->addEvent360(360, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
s->tdcPosition = 180 - 46;
|
s->tdcPosition = 180 - 46;
|
||||||
s->setTriggerSynchronizationGap(3.91);
|
s->setTriggerSynchronizationGap(3.91);
|
||||||
|
@ -38,8 +38,8 @@ void setVwConfiguration(TriggerWaveform *s) {
|
||||||
NO_LEFT_FILTER, 690);
|
NO_LEFT_FILTER, 690);
|
||||||
|
|
||||||
float angleDown = engineCycle / totalTeethCount * (totalTeethCount - skippedCount - 1 + (1 - toothWidth) );
|
float angleDown = engineCycle / totalTeethCount * (totalTeethCount - skippedCount - 1 + (1 - toothWidth) );
|
||||||
s->addEventClamped(0 + angleDown + 12, T_PRIMARY, TV_RISE, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
s->addEventClamped(0 + angleDown + 12, T_PRIMARY, TriggerValue::RISE, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
||||||
s->addEventClamped(0 + engineCycle, T_PRIMARY, TV_FALL, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
s->addEventClamped(0 + engineCycle, T_PRIMARY, TriggerValue::FALL, NO_LEFT_FILTER, NO_RIGHT_FILTER);
|
||||||
|
|
||||||
s->setTriggerSynchronizationGap2(1.6, 4);
|
s->setTriggerSynchronizationGap2(1.6, 4);
|
||||||
s->setSecondTriggerSynchronizationGap(1); // this gap is not required to synch on perfect signal but is needed to handle to reject cranking transition noise
|
s->setSecondTriggerSynchronizationGap(1); // this gap is not required to synch on perfect signal but is needed to handle to reject cranking transition noise
|
||||||
|
|
|
@ -234,7 +234,7 @@ static void logFront(bool isImportantFront, efitick_t nowNt, int index) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void hwHandleVvtCamSignal(trigger_value_e front, efitick_t nowNt, int index) {
|
void hwHandleVvtCamSignal(TriggerValue front, efitick_t nowNt, int index) {
|
||||||
if (engine->directSelfStimulation || !engine->hwTriggerInputEnabled) {
|
if (engine->directSelfStimulation || !engine->hwTriggerInputEnabled) {
|
||||||
// sensor noise + self-stim = loss of trigger sync
|
// sensor noise + self-stim = loss of trigger sync
|
||||||
return;
|
return;
|
||||||
|
@ -243,7 +243,7 @@ void hwHandleVvtCamSignal(trigger_value_e front, efitick_t nowNt, int index) {
|
||||||
int bankIndex = index / CAMS_PER_BANK;
|
int bankIndex = index / CAMS_PER_BANK;
|
||||||
int camIndex = index % CAMS_PER_BANK;
|
int camIndex = index % CAMS_PER_BANK;
|
||||||
TriggerCentral *tc = &engine->triggerCentral;
|
TriggerCentral *tc = &engine->triggerCentral;
|
||||||
if (front == TV_RISE) {
|
if (front == TriggerValue::RISE) {
|
||||||
tc->vvtEventRiseCounter[index]++;
|
tc->vvtEventRiseCounter[index]++;
|
||||||
} else {
|
} else {
|
||||||
tc->vvtEventFallCounter[index]++;
|
tc->vvtEventFallCounter[index]++;
|
||||||
|
@ -269,18 +269,18 @@ void hwHandleVvtCamSignal(trigger_value_e front, efitick_t nowNt, int index) {
|
||||||
|
|
||||||
if (!engineConfiguration->displayLogicLevelsInEngineSniffer) {
|
if (!engineConfiguration->displayLogicLevelsInEngineSniffer) {
|
||||||
// todo: migrate injector_pressure_type_e to class enum, maybe merge with FrontDirection?
|
// todo: migrate injector_pressure_type_e to class enum, maybe merge with FrontDirection?
|
||||||
addEngineSnifferVvtEvent(index, front == TV_RISE ? FrontDirection::UP : FrontDirection::DOWN);
|
addEngineSnifferVvtEvent(index, front == TriggerValue::RISE ? FrontDirection::UP : FrontDirection::DOWN);
|
||||||
|
|
||||||
#if EFI_TOOTH_LOGGER
|
#if EFI_TOOTH_LOGGER
|
||||||
// todo: we need to start logging different VVT channels differently!!!
|
// todo: we need to start logging different VVT channels differently!!!
|
||||||
trigger_event_e tooth = front == TV_RISE ? SHAFT_SECONDARY_RISING : SHAFT_SECONDARY_FALLING;
|
trigger_event_e tooth = front == TriggerValue::RISE ? SHAFT_SECONDARY_RISING : SHAFT_SECONDARY_FALLING;
|
||||||
|
|
||||||
LogTriggerTooth(tooth, nowNt);
|
LogTriggerTooth(tooth, nowNt);
|
||||||
#endif /* EFI_TOOTH_LOGGER */
|
#endif /* EFI_TOOTH_LOGGER */
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool isImportantFront = (engineConfiguration->vvtCamSensorUseRise ^ (front == TV_FALL));
|
bool isImportantFront = (engineConfiguration->vvtCamSensorUseRise ^ (front == TriggerValue::FALL));
|
||||||
bool isVvtWithRealDecoder = vvtWithRealDecoder(engineConfiguration->vvtMode[camIndex]);
|
bool isVvtWithRealDecoder = vvtWithRealDecoder(engineConfiguration->vvtMode[camIndex]);
|
||||||
if (!isVvtWithRealDecoder && !isImportantFront) {
|
if (!isVvtWithRealDecoder && !isImportantFront) {
|
||||||
// todo: there should be a way to always use real trigger code for this logic?
|
// todo: there should be a way to always use real trigger code for this logic?
|
||||||
|
@ -302,7 +302,7 @@ void hwHandleVvtCamSignal(trigger_value_e front, efitick_t nowNt, int index) {
|
||||||
tc->vvtShape[camIndex],
|
tc->vvtShape[camIndex],
|
||||||
nullptr,
|
nullptr,
|
||||||
engine->vvtTriggerConfiguration[camIndex],
|
engine->vvtTriggerConfiguration[camIndex],
|
||||||
front == TV_RISE ? SHAFT_PRIMARY_RISING : SHAFT_PRIMARY_FALLING, nowNt);
|
front == TriggerValue::RISE ? SHAFT_PRIMARY_RISING : SHAFT_PRIMARY_FALLING, nowNt);
|
||||||
// yes we log data from all VVT channels into same fields for now
|
// yes we log data from all VVT channels into same fields for now
|
||||||
tc->triggerState.vvtSyncGapRatio = vvtDecoder.triggerSyncGapRatio;
|
tc->triggerState.vvtSyncGapRatio = vvtDecoder.triggerSyncGapRatio;
|
||||||
tc->triggerState.vvtStateIndex = vvtDecoder.currentCycle.current_index;
|
tc->triggerState.vvtStateIndex = vvtDecoder.currentCycle.current_index;
|
||||||
|
@ -623,8 +623,8 @@ void TriggerCentral::decodeMapCam(efitick_t timestamp, float currentPhase) {
|
||||||
mapVvt_MAP_AT_CYCLE_COUNT = revolutionCounter - prevChangeAtCycle;
|
mapVvt_MAP_AT_CYCLE_COUNT = revolutionCounter - prevChangeAtCycle;
|
||||||
prevChangeAtCycle = revolutionCounter;
|
prevChangeAtCycle = revolutionCounter;
|
||||||
|
|
||||||
hwHandleVvtCamSignal(TV_RISE, timestamp, /*index*/0);
|
hwHandleVvtCamSignal(TriggerValue::RISE, timestamp, /*index*/0);
|
||||||
hwHandleVvtCamSignal(TV_FALL, timestamp, /*index*/0);
|
hwHandleVvtCamSignal(TriggerValue::FALL, timestamp, /*index*/0);
|
||||||
#if EFI_UNIT_TEST
|
#if EFI_UNIT_TEST
|
||||||
// hack? feature? existing unit test relies on VVT phase available right away
|
// hack? feature? existing unit test relies on VVT phase available right away
|
||||||
// but current implementation which is based on periodicFastCallback would only make result available on NEXT tooth
|
// but current implementation which is based on periodicFastCallback would only make result available on NEXT tooth
|
||||||
|
|
|
@ -149,7 +149,7 @@ private:
|
||||||
void triggerInfo(void);
|
void triggerInfo(void);
|
||||||
void hwHandleShaftSignal(int signalIndex, bool isRising, efitick_t timestamp);
|
void hwHandleShaftSignal(int signalIndex, bool isRising, efitick_t timestamp);
|
||||||
void handleShaftSignal(int signalIndex, bool isRising, efitick_t timestamp);
|
void handleShaftSignal(int signalIndex, bool isRising, efitick_t timestamp);
|
||||||
void hwHandleVvtCamSignal(trigger_value_e front, efitick_t timestamp, int index);
|
void hwHandleVvtCamSignal(TriggerValue front, efitick_t timestamp, int index);
|
||||||
|
|
||||||
void validateTriggerInputs();
|
void validateTriggerInputs();
|
||||||
|
|
||||||
|
|
|
@ -339,7 +339,7 @@ bool TriggerDecoderBase::isValidIndex(const TriggerWaveform& triggerShape) const
|
||||||
}
|
}
|
||||||
|
|
||||||
static trigger_wheel_e eventIndex[4] = { T_PRIMARY, T_PRIMARY, T_SECONDARY, T_SECONDARY };
|
static trigger_wheel_e eventIndex[4] = { T_PRIMARY, T_PRIMARY, T_SECONDARY, T_SECONDARY };
|
||||||
static trigger_value_e eventType[4] = { TV_FALL, TV_RISE, TV_FALL, TV_RISE };
|
static TriggerValue eventType[4] = { TriggerValue::FALL, TriggerValue::RISE, TriggerValue::FALL, TriggerValue::RISE };
|
||||||
|
|
||||||
#if EFI_UNIT_TEST
|
#if EFI_UNIT_TEST
|
||||||
#define PRINT_INC_INDEX if (printTriggerTrace) {\
|
#define PRINT_INC_INDEX if (printTriggerTrace) {\
|
||||||
|
@ -358,8 +358,8 @@ static trigger_value_e eventType[4] = { TV_FALL, TV_RISE, TV_FALL, TV_RISE };
|
||||||
|
|
||||||
#define considerEventForGap() (!triggerShape.useOnlyPrimaryForSync || isPrimary)
|
#define considerEventForGap() (!triggerShape.useOnlyPrimaryForSync || isPrimary)
|
||||||
|
|
||||||
#define needToSkipFall(type) ((!triggerShape.gapBothDirections) && (( triggerShape.useRiseEdge) && (type != TV_RISE)))
|
#define needToSkipFall(type) ((!triggerShape.gapBothDirections) && (( triggerShape.useRiseEdge) && (type != TriggerValue::RISE)))
|
||||||
#define needToSkipRise(type) ((!triggerShape.gapBothDirections) && ((!triggerShape.useRiseEdge) && (type != TV_FALL)))
|
#define needToSkipRise(type) ((!triggerShape.gapBothDirections) && ((!triggerShape.useRiseEdge) && (type != TriggerValue::FALL)))
|
||||||
|
|
||||||
int TriggerDecoderBase::getCurrentIndex() const {
|
int TriggerDecoderBase::getCurrentIndex() const {
|
||||||
return currentCycle.current_index;
|
return currentCycle.current_index;
|
||||||
|
@ -441,12 +441,12 @@ case SHAFT_SECONDARY_RISING:
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
const char *getTrigger_value_e(trigger_value_e value){
|
const char *getTrigger_value_e(TriggerValue value){
|
||||||
switch(value) {
|
switch(value) {
|
||||||
case TV_FALL:
|
case TriggerValue::FALL:
|
||||||
return "TV_FALL";
|
return "TriggerValue::FALL";
|
||||||
case TV_RISE:
|
case TriggerValue::RISE:
|
||||||
return "TV_RISE";
|
return "TriggerValue::RISE";
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -536,7 +536,7 @@ expected<TriggerDecodeResult> TriggerDecoderBase::decodeTriggerEvent(
|
||||||
efiAssert(CUSTOM_TRIGGER_UNEXPECTED, signal <= SHAFT_SECONDARY_RISING, "unexpected signal", unexpected);
|
efiAssert(CUSTOM_TRIGGER_UNEXPECTED, signal <= SHAFT_SECONDARY_RISING, "unexpected signal", unexpected);
|
||||||
|
|
||||||
trigger_wheel_e triggerWheel = eventIndex[signal];
|
trigger_wheel_e triggerWheel = eventIndex[signal];
|
||||||
trigger_value_e type = eventType[signal];
|
TriggerValue type = eventType[signal];
|
||||||
|
|
||||||
// Check that we didn't get the same edge twice in a row - that should be impossible
|
// Check that we didn't get the same edge twice in a row - that should be impossible
|
||||||
if (!useOnlyRisingEdgeForTrigger && prevSignal == signal) {
|
if (!useOnlyRisingEdgeForTrigger && prevSignal == signal) {
|
||||||
|
|
|
@ -15,7 +15,7 @@
|
||||||
#include "timer.h"
|
#include "timer.h"
|
||||||
|
|
||||||
const char *getTrigger_event_e(trigger_event_e value);
|
const char *getTrigger_event_e(trigger_event_e value);
|
||||||
const char *getTrigger_value_e(trigger_value_e value);
|
const char *getTrigger_value_e(TriggerValue value);
|
||||||
|
|
||||||
struct TriggerStateListener {
|
struct TriggerStateListener {
|
||||||
#if EFI_SHAFT_POSITION_INPUT
|
#if EFI_SHAFT_POSITION_INPUT
|
||||||
|
|
|
@ -48,7 +48,7 @@ void TriggerEmulatorHelper::handleEmulatorCallback(const MultiChannelStateSequen
|
||||||
if (needEvent(stateIndex, multiChannelStateSequence, i)) {
|
if (needEvent(stateIndex, multiChannelStateSequence, i)) {
|
||||||
pin_state_t currentValue = multiChannelStateSequence.getChannelState(/*phaseIndex*/i, stateIndex);
|
pin_state_t currentValue = multiChannelStateSequence.getChannelState(/*phaseIndex*/i, stateIndex);
|
||||||
|
|
||||||
handleShaftSignal(i, currentValue, stamp);
|
handleShaftSignal(i, currentValue == TriggerValue::RISE, stamp);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif // EFI_SHAFT_POSITION_INPUT
|
#endif // EFI_SHAFT_POSITION_INPUT
|
||||||
|
|
|
@ -76,7 +76,7 @@ void TriggerStimulatorHelper::feedSimulatedEvent(
|
||||||
for (size_t i = 0; i < PWM_PHASE_MAX_WAVE_PER_PWM; i++) {
|
for (size_t i = 0; i < PWM_PHASE_MAX_WAVE_PER_PWM; i++) {
|
||||||
if (needEvent(stateIndex, multiChannelStateSequence, i)) {
|
if (needEvent(stateIndex, multiChannelStateSequence, i)) {
|
||||||
pin_state_t currentValue = multiChannelStateSequence.getChannelState(/*phaseIndex*/i, stateIndex);
|
pin_state_t currentValue = multiChannelStateSequence.getChannelState(/*phaseIndex*/i, stateIndex);
|
||||||
trigger_event_e event = (currentValue ? riseEvents : fallEvents)[i];
|
trigger_event_e event = (currentValue == TriggerValue::RISE ? riseEvents : fallEvents)[i];
|
||||||
if (isUsefulSignal(event, triggerConfiguration)) {
|
if (isUsefulSignal(event, triggerConfiguration)) {
|
||||||
state.decodeTriggerEvent(
|
state.decodeTriggerEvent(
|
||||||
"sim",
|
"sim",
|
||||||
|
|
|
@ -72,9 +72,9 @@ static void comp_cam_callback(COMPDriver *comp) {
|
||||||
efitick_t stamp = getTimeNowNt();
|
efitick_t stamp = getTimeNowNt();
|
||||||
|
|
||||||
if (isRising) {
|
if (isRising) {
|
||||||
hwHandleVvtCamSignal(TV_RISE, stamp, index);
|
hwHandleVvtCamSignal(TriggerValue::RISE, stamp, index);
|
||||||
} else {
|
} else {
|
||||||
hwHandleVvtCamSignal(TV_FALL, stamp, index);
|
hwHandleVvtCamSignal(TriggerValue::FALL, stamp, index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -43,9 +43,9 @@ static void cam_callback(void *arg, efitick_t stamp) {
|
||||||
bool rise = (palReadLine(pal_line) == PAL_HIGH);
|
bool rise = (palReadLine(pal_line) == PAL_HIGH);
|
||||||
|
|
||||||
if (rise ^ engineConfiguration->invertCamVVTSignal) {
|
if (rise ^ engineConfiguration->invertCamVVTSignal) {
|
||||||
hwHandleVvtCamSignal(TV_RISE, stamp, index);
|
hwHandleVvtCamSignal(TriggerValue::RISE, stamp, index);
|
||||||
} else {
|
} else {
|
||||||
hwHandleVvtCamSignal(TV_FALL, stamp, index);
|
hwHandleVvtCamSignal(TriggerValue::FALL, stamp, index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -316,8 +316,8 @@ void startSimplePwm(SimplePwm *state, const char *msg, ExecutorInterface *execut
|
||||||
|
|
||||||
state->seq.setSwitchTime(0, dutyCycle);
|
state->seq.setSwitchTime(0, dutyCycle);
|
||||||
state->seq.setSwitchTime(1, 1);
|
state->seq.setSwitchTime(1, 1);
|
||||||
state->seq.setChannelState(0, 0, TV_FALL);
|
state->seq.setChannelState(0, 0, TriggerValue::FALL);
|
||||||
state->seq.setChannelState(0, 1, TV_RISE);
|
state->seq.setChannelState(0, 1, TriggerValue::RISE);
|
||||||
|
|
||||||
state->outputPins[0] = output;
|
state->outputPins[0] = output;
|
||||||
|
|
||||||
|
|
|
@ -101,7 +101,7 @@ void CsvReader::processLine(EngineTestHelper *eth) {
|
||||||
}
|
}
|
||||||
|
|
||||||
efitick_t nowNt = getTimeNowNt();
|
efitick_t nowNt = getTimeNowNt();
|
||||||
trigger_value_e event = newVvtState[vvtIndex] ^ engineConfiguration->invertCamVVTSignal ? TV_RISE : TV_FALL;
|
TriggerValue event = newVvtState[vvtIndex] ^ engineConfiguration->invertCamVVTSignal ? TriggerValue::RISE : TriggerValue::FALL;
|
||||||
// todo: configurable selection of vvt mode - dual bank or dual cam single bank
|
// todo: configurable selection of vvt mode - dual bank or dual cam single bank
|
||||||
int bankIndex = vvtIndex;
|
int bankIndex = vvtIndex;
|
||||||
int camIndex = 0;
|
int camIndex = 0;
|
||||||
|
|
|
@ -88,34 +88,34 @@ static void configureFordAspireTriggerWaveform(TriggerWaveform * s) {
|
||||||
s->initialize(FOUR_STROKE_CAM_SENSOR);
|
s->initialize(FOUR_STROKE_CAM_SENSOR);
|
||||||
s->useOnlyRisingEdgeForTriggerTemp = false;
|
s->useOnlyRisingEdgeForTriggerTemp = false;
|
||||||
|
|
||||||
s->addEvent720(53.747, T_SECONDARY, TV_RISE);
|
s->addEvent720(53.747, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(121.90, T_SECONDARY, TV_FALL);
|
s->addEvent720(121.90, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(232.76, T_SECONDARY, TV_RISE);
|
s->addEvent720(232.76, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(300.54, T_SECONDARY, TV_FALL);
|
s->addEvent720(300.54, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(360, T_PRIMARY, TV_RISE);
|
s->addEvent720(360, T_PRIMARY, TriggerValue::RISE);
|
||||||
|
|
||||||
s->addEvent720(409.8412, T_SECONDARY, TV_RISE);
|
s->addEvent720(409.8412, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(478.6505, T_SECONDARY, TV_FALL);
|
s->addEvent720(478.6505, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(588.045, T_SECONDARY, TV_RISE);
|
s->addEvent720(588.045, T_SECONDARY, TriggerValue::RISE);
|
||||||
s->addEvent720(657.03, T_SECONDARY, TV_FALL);
|
s->addEvent720(657.03, T_SECONDARY, TriggerValue::FALL);
|
||||||
s->addEvent720(720, T_PRIMARY, TV_FALL);
|
s->addEvent720(720, T_PRIMARY, TriggerValue::FALL);
|
||||||
|
|
||||||
ASSERT_FLOAT_EQ(53.747 / 720, s->wave.getSwitchTime(0));
|
ASSERT_FLOAT_EQ(53.747 / 720, s->wave.getSwitchTime(0));
|
||||||
ASSERT_EQ( 1, s->wave.getChannelState(1, 0)) << "@0";
|
ASSERT_EQ( TriggerValue::RISE, s->wave.getChannelState(1, 0)) << "@0";
|
||||||
ASSERT_EQ( 1, s->wave.getChannelState(1, 0)) << "@0";
|
ASSERT_EQ( TriggerValue::RISE, s->wave.getChannelState(1, 0)) << "@0";
|
||||||
|
|
||||||
ASSERT_EQ( 0, s->wave.getChannelState(0, 1)) << "@1";
|
ASSERT_EQ( TriggerValue::FALL, s->wave.getChannelState(0, 1)) << "@1";
|
||||||
ASSERT_EQ( 0, s->wave.getChannelState(1, 1)) << "@1";
|
ASSERT_EQ( TriggerValue::FALL, s->wave.getChannelState(1, 1)) << "@1";
|
||||||
|
|
||||||
ASSERT_EQ( 0, s->wave.getChannelState(0, 2)) << "@2";
|
ASSERT_EQ( TriggerValue::FALL, s->wave.getChannelState(0, 2)) << "@2";
|
||||||
ASSERT_EQ( 1, s->wave.getChannelState(1, 2)) << "@2";
|
ASSERT_EQ( TriggerValue::RISE, s->wave.getChannelState(1, 2)) << "@2";
|
||||||
|
|
||||||
ASSERT_EQ( 0, s->wave.getChannelState(0, 3)) << "@3";
|
ASSERT_EQ( TriggerValue::FALL, s->wave.getChannelState(0, 3)) << "@3";
|
||||||
ASSERT_EQ( 0, s->wave.getChannelState(1, 3)) << "@3";
|
ASSERT_EQ( TriggerValue::FALL, s->wave.getChannelState(1, 3)) << "@3";
|
||||||
|
|
||||||
ASSERT_EQ( 1, s->wave.getChannelState(0, 4)) << "@4";
|
ASSERT_EQ( TriggerValue::RISE, s->wave.getChannelState(0, 4)) << "@4";
|
||||||
ASSERT_EQ( 1, s->wave.getChannelState(1, 5)) << "@5";
|
ASSERT_EQ( TriggerValue::RISE, s->wave.getChannelState(1, 5)) << "@5";
|
||||||
ASSERT_EQ( 0, s->wave.getChannelState(1, 8)) << "@8";
|
ASSERT_EQ( TriggerValue::FALL, s->wave.getChannelState(1, 8)) << "@8";
|
||||||
ASSERT_FLOAT_EQ(121.90 / 720, s->wave.getSwitchTime(1));
|
ASSERT_FLOAT_EQ(121.90 / 720, s->wave.getSwitchTime(1));
|
||||||
ASSERT_FLOAT_EQ(657.03 / 720, s->wave.getSwitchTime(8));
|
ASSERT_FLOAT_EQ(657.03 / 720, s->wave.getSwitchTime(8));
|
||||||
|
|
||||||
|
|
|
@ -29,8 +29,8 @@ TEST(sensors, test2jz) {
|
||||||
|
|
||||||
eth.moveTimeForwardUs(MS2US(3)); // shifting VVT phase a few angles
|
eth.moveTimeForwardUs(MS2US(3)); // shifting VVT phase a few angles
|
||||||
|
|
||||||
hwHandleVvtCamSignal(TV_FALL, getTimeNowNt(), 0);
|
hwHandleVvtCamSignal(TriggerValue::FALL, getTimeNowNt(), 0);
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), 0);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), 0);
|
||||||
|
|
||||||
// currentPosition
|
// currentPosition
|
||||||
ASSERT_NEAR(608.2 - 720, engine->triggerCentral.currentVVTEventPosition[0][0], EPS3D);
|
ASSERT_NEAR(608.2 - 720, engine->triggerCentral.currentVVTEventPosition[0][0], EPS3D);
|
||||||
|
|
|
@ -110,7 +110,7 @@ TEST(trigger, testCamInput) {
|
||||||
|
|
||||||
for (int i = 0; i < 600;i++) {
|
for (int i = 0; i < 600;i++) {
|
||||||
eth.moveTimeForwardUs(MS2US(10));
|
eth.moveTimeForwardUs(MS2US(10));
|
||||||
hwHandleVvtCamSignal(TV_FALL, getTimeNowNt(), 0);
|
hwHandleVvtCamSignal(TriggerValue::FALL, getTimeNowNt(), 0);
|
||||||
eth.moveTimeForwardUs(MS2US(40));
|
eth.moveTimeForwardUs(MS2US(40));
|
||||||
eth.firePrimaryTriggerRise();
|
eth.firePrimaryTriggerRise();
|
||||||
}
|
}
|
||||||
|
@ -147,21 +147,21 @@ TEST(trigger, testNB2CamInput) {
|
||||||
|
|
||||||
eth.moveTimeForwardUs(MS2US(3)); // shifting VVT phase a few angles
|
eth.moveTimeForwardUs(MS2US(3)); // shifting VVT phase a few angles
|
||||||
|
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), 0);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), 0);
|
||||||
|
|
||||||
// first gap - long
|
// first gap - long
|
||||||
|
|
||||||
eth.moveTimeForwardUs(MS2US(130));
|
eth.moveTimeForwardUs(MS2US(130));
|
||||||
hwHandleVvtCamSignal(TV_FALL, getTimeNowNt(), 0);
|
hwHandleVvtCamSignal(TriggerValue::FALL, getTimeNowNt(), 0);
|
||||||
eth.moveTimeForwardUs(MS2US( 30));
|
eth.moveTimeForwardUs(MS2US( 30));
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), 0);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), 0);
|
||||||
|
|
||||||
// second gap - short
|
// second gap - short
|
||||||
|
|
||||||
eth.moveTimeForwardUs(MS2US(10));
|
eth.moveTimeForwardUs(MS2US(10));
|
||||||
hwHandleVvtCamSignal(TV_FALL, getTimeNowNt(), 0);
|
hwHandleVvtCamSignal(TriggerValue::FALL, getTimeNowNt(), 0);
|
||||||
eth.moveTimeForwardUs(MS2US(10));
|
eth.moveTimeForwardUs(MS2US(10));
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), 0);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), 0);
|
||||||
|
|
||||||
ASSERT_FLOAT_EQ(0, engine->triggerCentral.getVVTPosition(0, 0));
|
ASSERT_FLOAT_EQ(0, engine->triggerCentral.getVVTPosition(0, 0));
|
||||||
ASSERT_EQ(totalRevolutionCountBeforeVvtSync, engine->triggerCentral.triggerState.getCrankSynchronizationCounter());
|
ASSERT_EQ(totalRevolutionCountBeforeVvtSync, engine->triggerCentral.triggerState.getCrankSynchronizationCounter());
|
||||||
|
@ -169,9 +169,9 @@ TEST(trigger, testNB2CamInput) {
|
||||||
// Third gap - long
|
// Third gap - long
|
||||||
|
|
||||||
eth.moveTimeForwardUs(MS2US(130));
|
eth.moveTimeForwardUs(MS2US(130));
|
||||||
hwHandleVvtCamSignal(TV_FALL, getTimeNowNt(), 0);
|
hwHandleVvtCamSignal(TriggerValue::FALL, getTimeNowNt(), 0);
|
||||||
eth.moveTimeForwardUs(MS2US( 30));
|
eth.moveTimeForwardUs(MS2US( 30));
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), 0);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), 0);
|
||||||
|
|
||||||
EXPECT_NEAR(290.5f, engine->triggerCentral.getVVTPosition(0, 0), EPS2D);
|
EXPECT_NEAR(290.5f, engine->triggerCentral.getVVTPosition(0, 0), EPS2D);
|
||||||
// actually position based on VVT!
|
// actually position based on VVT!
|
||||||
|
|
|
@ -24,13 +24,12 @@ static void func(TriggerCallback *callback) {
|
||||||
Engine *engine = callback->engine;
|
Engine *engine = callback->engine;
|
||||||
|
|
||||||
|
|
||||||
int value = callback->form->wave.getChannelState(0, formIndex);
|
TriggerValue value = callback->form->wave.getChannelState(0, formIndex);
|
||||||
efitick_t nowNt = getTimeNowNt();
|
efitick_t nowNt = getTimeNowNt();
|
||||||
if (callback->isVvt) {
|
if (callback->isVvt) {
|
||||||
trigger_value_e v = value ? TV_RISE : TV_FALL;
|
hwHandleVvtCamSignal(value, nowNt, callback->vvtBankIndex * CAMS_PER_BANK);
|
||||||
hwHandleVvtCamSignal(v, nowNt, callback->vvtBankIndex * CAMS_PER_BANK);
|
|
||||||
} else {
|
} else {
|
||||||
handleShaftSignal(0, value, nowNt);
|
handleShaftSignal(0, value == TriggerValue::RISE, nowNt);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -59,10 +59,10 @@ TEST(trigger, testQuadCam) {
|
||||||
ASSERT_EQ(0, engine->triggerCentral.getVVTPosition(secondBank, firstCam));
|
ASSERT_EQ(0, engine->triggerCentral.getVVTPosition(secondBank, firstCam));
|
||||||
ASSERT_EQ(0, engine->triggerCentral.getVVTPosition(secondBank, secondCam));
|
ASSERT_EQ(0, engine->triggerCentral.getVVTPosition(secondBank, secondCam));
|
||||||
|
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), firstCam);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), firstCam);
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), secondCam);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), secondCam);
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), firstCamSecondBank);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), firstCamSecondBank);
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), secondCamSecondBank);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), secondCamSecondBank);
|
||||||
|
|
||||||
float basePos = -80.2f;
|
float basePos = -80.2f;
|
||||||
|
|
||||||
|
@ -74,13 +74,13 @@ TEST(trigger, testQuadCam) {
|
||||||
|
|
||||||
// Now fire cam events again, but with time gaps between each
|
// Now fire cam events again, but with time gaps between each
|
||||||
eth.moveTimeForwardMs(1);
|
eth.moveTimeForwardMs(1);
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), firstCam);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), firstCam);
|
||||||
eth.moveTimeForwardMs(1);
|
eth.moveTimeForwardMs(1);
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), secondCam);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), secondCam);
|
||||||
eth.moveTimeForwardMs(1);
|
eth.moveTimeForwardMs(1);
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), firstCamSecondBank);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), firstCamSecondBank);
|
||||||
eth.moveTimeForwardMs(1);
|
eth.moveTimeForwardMs(1);
|
||||||
hwHandleVvtCamSignal(TV_RISE, getTimeNowNt(), secondCamSecondBank);
|
hwHandleVvtCamSignal(TriggerValue::RISE, getTimeNowNt(), secondCamSecondBank);
|
||||||
|
|
||||||
// All four cams should have different positions, each retarded by 1ms from the last
|
// All four cams should have different positions, each retarded by 1ms from the last
|
||||||
float oneMsDegrees = 1000 / engine->rpmCalculator.oneDegreeUs;
|
float oneMsDegrees = 1000 / engine->rpmCalculator.oneDegreeUs;
|
||||||
|
|
Loading…
Reference in New Issue