2015-07-10 06:01:56 -07:00
/**
* @ file trigger_structure . cpp
*
* @ date Jan 20 , 2014
2020-01-14 00:54:46 -08:00
* @ author Andrey Belomutskiy , ( c ) 2012 - 2020
2015-07-10 06:01:56 -07:00
*
* This file is part of rusEfi - see http : //rusefi.com
*
* rusEfi is free software ; you can redistribute it and / or modify it under the terms of
* the GNU General Public License as published by the Free Software Foundation ; either
* version 3 of the License , or ( at your option ) any later version .
*
* rusEfi is distributed in the hope that it will be useful , but WITHOUT ANY WARRANTY ; without
* even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License along with this program .
* If not , see < http : //www.gnu.org/licenses/>.
*/
2021-07-25 22:05:17 -07:00
# include "pch.h"
2018-12-25 19:47:29 -08:00
# include "trigger_chrysler.h"
2023-05-13 11:26:31 -07:00
# include "trigger_ford.h"
2018-12-25 19:47:29 -08:00
# include "trigger_gm.h"
# include "trigger_nissan.h"
# include "trigger_mazda.h"
# include "trigger_misc.h"
# include "trigger_mitsubishi.h"
2023-08-15 09:50:54 -07:00
# include "trigger_renault.h"
2018-12-25 19:47:29 -08:00
# include "trigger_subaru.h"
2021-10-04 16:28:45 -07:00
# include "trigger_suzuki.h"
2015-07-10 06:01:56 -07:00
# include "trigger_structure.h"
2018-12-25 19:47:29 -08:00
# include "trigger_toyota.h"
2020-04-18 19:20:17 -07:00
# include "trigger_renix.h"
2018-12-25 19:47:29 -08:00
# include "trigger_rover.h"
# include "trigger_honda.h"
# include "trigger_vw.h"
2017-01-03 13:02:43 -08:00
# include "trigger_universal.h"
2021-11-13 18:50:04 -08:00
# include "trigger_mercedes.h"
2018-12-25 19:47:29 -08:00
2019-04-12 19:07:03 -07:00
# if EFI_SENSOR_CHART
2017-05-18 13:39:04 -07:00
# include "sensor_chart.h"
2017-05-19 10:04:16 -07:00
# endif /* EFI_SENSOR_CHART */
2015-07-10 06:01:56 -07:00
2021-11-21 01:56:07 -08:00
TriggerWaveform : : TriggerWaveform ( ) {
2022-09-23 17:39:41 -07:00
initialize ( OM_NONE , SyncEdge : : Rise ) ;
2020-08-24 21:59:07 -07:00
}
2016-08-18 21:02:50 -07:00
2022-09-23 17:39:41 -07:00
void TriggerWaveform : : initialize ( operation_mode_e operationMode , SyncEdge syncEdge ) {
2016-08-17 21:02:22 -07:00
isSynchronizationNeeded = true ; // that's default value
2022-04-01 18:10:08 -07:00
isSecondWheelCam = false ;
2020-01-12 07:43:02 -08:00
needSecondTriggerInput = false ;
2020-01-14 00:54:46 -08:00
shapeWithoutTdc = false ;
2016-08-18 19:01:57 -07:00
2022-11-08 18:48:39 -08:00
// If RiseOnly, ignore falling edges completely.
useOnlyRisingEdges = syncEdge = = SyncEdge : : RiseOnly ;
2018-10-21 10:58:54 -07:00
setTriggerSynchronizationGap ( 2 ) ;
2018-12-25 07:20:13 -08:00
for ( int gapIndex = 1 ; gapIndex < GAP_TRACKING_LENGTH ; gapIndex + + ) {
2018-10-21 10:58:54 -07:00
// NaN means do not use this gap ratio
2018-12-25 07:20:13 -08:00
setTriggerSynchronizationGap3 ( gapIndex , NAN , 100000 ) ;
2018-10-21 10:58:54 -07:00
}
2020-10-04 10:05:49 -07:00
gapTrackingLength = 1 ;
2016-08-18 19:01:57 -07:00
2015-07-10 06:01:56 -07:00
tdcPosition = 0 ;
2023-06-01 11:04:56 -07:00
shapeDefinitionError = false ;
useOnlyPrimaryForSync = false ;
2015-07-10 06:01:56 -07:00
this - > operationMode = operationMode ;
2022-09-23 17:39:41 -07:00
this - > syncEdge = syncEdge ;
2015-07-10 06:01:56 -07:00
triggerShapeSynchPointIndex = 0 ;
memset ( expectedEventCount , 0 , sizeof ( expectedEventCount ) ) ;
2021-11-21 01:56:07 -08:00
wave . reset ( ) ;
2022-06-01 18:24:20 -07:00
wave . waveCount = TRIGGER_INPUT_PIN_COUNT ;
2021-11-21 01:56:07 -08:00
wave . phaseCount = 0 ;
2015-07-10 06:01:56 -07:00
previousAngle = 0 ;
2019-02-02 22:49:41 -08:00
memset ( isRiseEvent , 0 , sizeof ( isRiseEvent ) ) ;
2019-04-12 19:07:03 -07:00
# if EFI_UNIT_TEST
2020-12-02 19:17:38 -08:00
memset ( & triggerSignalIndeces , 0 , sizeof ( triggerSignalIndeces ) ) ;
memset ( & triggerSignalStates , 0 , sizeof ( triggerSignalStates ) ) ;
2022-04-03 09:22:47 -07:00
knownOperationMode = true ;
# endif // EFI_UNIT_TEST
2015-07-10 06:01:56 -07:00
}
2020-03-03 05:37:02 -08:00
size_t TriggerWaveform : : getSize ( ) const {
2021-11-21 01:56:07 -08:00
return wave . phaseCount ;
2016-08-20 06:02:06 -07:00
}
2019-12-07 22:09:39 -08:00
int TriggerWaveform : : getTriggerWaveformSynchPointIndex ( ) const {
2016-08-20 06:02:06 -07:00
return triggerShapeSynchPointIndex ;
}
2015-07-10 06:01:56 -07:00
/**
2016-11-14 12:04:44 -08:00
* physical primary trigger duration
2020-08-08 14:00:14 -07:00
* @ see getEngineCycle
2021-07-01 19:10:37 -07:00
* @ see getCrankDivider
2015-07-10 06:01:56 -07:00
*/
2019-12-07 22:09:39 -08:00
angle_t TriggerWaveform : : getCycleDuration ( ) const {
2016-11-13 21:02:13 -08:00
switch ( operationMode ) {
2020-04-19 06:59:55 -07:00
case FOUR_STROKE_THREE_TIMES_CRANK_SENSOR :
2021-11-06 21:03:16 -07:00
return FOUR_STROKE_CYCLE_DURATION / SYMMETRICAL_THREE_TIMES_CRANK_SENSOR_DIVIDER ;
2016-11-13 21:02:13 -08:00
case FOUR_STROKE_SYMMETRICAL_CRANK_SENSOR :
2021-11-06 21:03:16 -07:00
return FOUR_STROKE_CYCLE_DURATION / SYMMETRICAL_CRANK_SENSOR_DIVIDER ;
2022-05-17 18:38:24 -07:00
case FOUR_STROKE_TWELVE_TIMES_CRANK_SENSOR :
return FOUR_STROKE_CYCLE_DURATION / SYMMETRICAL_TWELVE_TIMES_CRANK_SENSOR_DIVIDER ;
2016-11-13 21:02:13 -08:00
case FOUR_STROKE_CRANK_SENSOR :
2016-11-14 12:04:44 -08:00
case TWO_STROKE :
2021-11-06 21:03:16 -07:00
return TWO_STROKE_CYCLE_DURATION ;
2016-11-13 21:02:13 -08:00
default :
2021-11-06 21:03:16 -07:00
return FOUR_STROKE_CYCLE_DURATION ;
2016-11-13 21:02:13 -08:00
}
2015-07-10 06:01:56 -07:00
}
2022-06-09 14:21:22 -07:00
bool TriggerWaveform : : needsDisambiguation ( ) const {
2022-09-04 22:16:24 -07:00
switch ( getWheelOperationMode ( ) ) {
2022-06-09 14:21:22 -07:00
case FOUR_STROKE_CRANK_SENSOR :
case FOUR_STROKE_SYMMETRICAL_CRANK_SENSOR :
case FOUR_STROKE_THREE_TIMES_CRANK_SENSOR :
case FOUR_STROKE_TWELVE_TIMES_CRANK_SENSOR :
return true ;
case FOUR_STROKE_CAM_SENSOR :
case TWO_STROKE :
return false ;
default :
2023-08-20 19:23:44 -07:00
criticalError ( " bad operationMode() in needsDisambiguation " ) ;
2022-06-09 14:21:22 -07:00
return true ;
}
}
2016-11-14 12:04:44 -08:00
/**
* Trigger event count equals engine cycle event count if we have a cam sensor .
* Two trigger cycles make one engine cycle in case of a four stroke engine If we only have a cranksensor .
2020-08-26 20:35:11 -07:00
*
* ' engine - > engineCycleEventCount ' hold a pre - calculated copy of this value as a performance optimization
2016-11-14 12:04:44 -08:00
*/
2020-03-03 05:37:02 -08:00
size_t TriggerWaveform : : getLength ( ) const {
2016-11-14 12:04:44 -08:00
/**
2022-05-17 18:38:24 -07:00
* 24 for FOUR_STROKE_TWELVE_TIMES_CRANK_SENSOR
2021-07-05 20:07:36 -07:00
* 6 for FOUR_STROKE_THREE_TIMES_CRANK_SENSOR
2016-11-14 12:04:44 -08:00
* 4 for FOUR_STROKE_SYMMETRICAL_CRANK_SENSOR
* 2 for FOUR_STROKE_CRANK_SENSOR
* 1 otherwise
*/
int multiplier = getEngineCycle ( operationMode ) / getCycleDuration ( ) ;
return multiplier * getSize ( ) ;
}
2019-12-07 22:09:39 -08:00
angle_t TriggerWaveform : : getAngle ( int index ) const {
2015-07-10 06:01:56 -07:00
/**
* FOUR_STROKE_CRANK_SENSOR magic :
* We have two crank shaft revolutions for each engine cycle
* See also trigger_central . cpp
* See also getEngineCycleEventCount ( )
*/
2023-04-28 21:13:13 -07:00
efiAssert ( ObdCode : : CUSTOM_ERR_ASSERT , wave . phaseCount ! = 0 , " shapeSize=0 " , NAN ) ;
2021-11-21 01:56:07 -08:00
int crankCycle = index / wave . phaseCount ;
int remainder = index % wave . phaseCount ;
2016-11-13 21:02:13 -08:00
2021-07-17 20:27:20 -07:00
auto cycleStartAngle = getCycleDuration ( ) * crankCycle ;
auto positionWithinCycle = getSwitchAngle ( remainder ) ;
return cycleStartAngle + positionWithinCycle ;
2015-07-10 06:01:56 -07:00
}
2022-11-16 11:28:43 -08:00
void TriggerWaveform : : addEventClamped ( angle_t angle , TriggerValue const stateParam , TriggerWheel const channelIndex , float filterLeft , float filterRight ) {
2019-07-23 16:22:40 -07:00
if ( angle > filterLeft & & angle < filterRight ) {
# if EFI_UNIT_TEST
// printf("addEventClamped %f %s\r\n", angle, getTrigger_value_e(stateParam));
# endif /* EFI_UNIT_TEST */
2022-11-16 11:28:43 -08:00
addEvent ( angle / getEngineCycle ( operationMode ) , stateParam , channelIndex ) ;
2019-07-23 16:22:40 -07:00
}
2015-07-10 06:01:56 -07:00
}
2022-09-04 22:16:24 -07:00
/**
* See also Engine # getOperationMode which accounts for additional settings which are
* needed to resolve precise mode for vague wheels
*/
operation_mode_e TriggerWaveform : : getWheelOperationMode ( ) const {
2015-07-10 06:01:56 -07:00
return operationMode ;
}
2019-04-12 19:07:03 -07:00
# if EFI_UNIT_TEST
2015-09-10 20:01:32 -07:00
extern bool printTriggerDebug ;
# endif
2022-09-11 00:46:50 -07:00
size_t TriggerWaveform : : getExpectedEventCount ( TriggerWheel channelIndex ) const {
return expectedEventCount [ ( int ) channelIndex ] ;
2021-06-26 19:07:26 -07:00
}
2022-09-25 15:49:54 -07:00
void TriggerWaveform : : calculateExpectedEventCounts ( ) {
if ( ! useOnlyRisingEdges ) {
2021-03-20 05:40:36 -07:00
for ( size_t i = 0 ; i < efi : : size ( expectedEventCount ) ; i + + ) {
2022-09-11 00:46:50 -07:00
if ( getExpectedEventCount ( ( TriggerWheel ) i ) % 2 ! = 0 ) {
2023-04-28 21:13:13 -07:00
firmwareError ( ObdCode : : ERROR_TRIGGER_DRAMA , " Trigger: should be even number of events index=%d count=%d " , i , getExpectedEventCount ( ( TriggerWheel ) i ) ) ;
2021-01-04 20:34:19 -08:00
}
}
}
2022-09-25 15:49:54 -07:00
bool isSingleToothOnPrimaryChannel = useOnlyRisingEdges ? getExpectedEventCount ( TriggerWheel : : T_PRIMARY ) = = 1 : getExpectedEventCount ( TriggerWheel : : T_PRIMARY ) = = 2 ;
2020-01-14 00:54:46 -08:00
// todo: next step would be to set 'isSynchronizationNeeded' automatically based on the logic we have here
if ( ! shapeWithoutTdc & & isSingleToothOnPrimaryChannel ! = ! isSynchronizationNeeded ) {
2023-04-28 21:13:13 -07:00
firmwareError ( ObdCode : : ERROR_TRIGGER_DRAMA , " shapeWithoutTdc isSynchronizationNeeded isSingleToothOnPrimaryChannel constraint violation " ) ;
2020-01-14 00:54:46 -08:00
}
2021-03-07 21:00:48 -08:00
if ( isSingleToothOnPrimaryChannel ) {
useOnlyPrimaryForSync = true ;
2022-09-23 17:39:41 -07:00
} else {
if ( getExpectedEventCount ( TriggerWheel : : T_SECONDARY ) = = 0 & & useOnlyPrimaryForSync ) {
2023-04-28 21:13:13 -07:00
firmwareError ( ObdCode : : ERROR_TRIGGER_DRAMA , " why would you set useOnlyPrimaryForSync with only one trigger wheel? " ) ;
2022-09-23 17:39:41 -07:00
}
2021-03-07 21:00:48 -08:00
}
2020-01-14 00:54:46 -08:00
2018-12-24 20:16:33 -08:00
// todo: move the following logic from below here
2022-09-10 23:57:35 -07:00
// if (!useOnlyRisingEdgeForTrigger || stateParam == TriggerValue::RISE) {
2018-12-25 07:13:00 -08:00
// expectedEventCount[channelIndex]++;
2018-12-24 20:16:33 -08:00
// }
}
2021-11-14 12:35:11 -08:00
/**
2022-11-16 12:23:42 -08:00
* See header for documentation
2021-11-14 12:35:11 -08:00
*/
2022-11-16 11:28:43 -08:00
void TriggerWaveform : : addEvent720 ( angle_t angle , TriggerValue const state , TriggerWheel const channelIndex ) {
addEvent ( angle / FOUR_STROKE_CYCLE_DURATION , state , channelIndex ) ;
2020-04-18 17:28:03 -07:00
}
2022-11-16 11:28:43 -08:00
void TriggerWaveform : : addEvent360 ( angle_t angle , TriggerValue const state , TriggerWheel const channelIndex ) {
2023-04-28 21:13:13 -07:00
efiAssertVoid ( ObdCode : : CUSTOM_OMODE_UNDEF , operationMode = = FOUR_STROKE_CAM_SENSOR | | operationMode = = FOUR_STROKE_CRANK_SENSOR , " Not a mode for 360 " ) ;
2023-05-13 11:59:17 -07:00
# define CRANK_MODE_MULTIPLIER 2.0f
2022-11-16 11:28:43 -08:00
addEvent ( CRANK_MODE_MULTIPLIER * angle / FOUR_STROKE_CYCLE_DURATION , state , channelIndex ) ;
2021-07-16 21:45:47 -07:00
}
2023-05-13 11:26:31 -07:00
void TriggerWaveform : : addToothRiseFall ( angle_t angle , angle_t width , TriggerWheel const channelIndex ) {
addEvent360 ( angle - width , TriggerValue : : RISE , channelIndex ) ;
addEvent360 ( angle , TriggerValue : : FALL , channelIndex ) ;
}
2022-11-16 11:28:43 -08:00
void TriggerWaveform : : addEventAngle ( angle_t angle , TriggerValue const state , TriggerWheel const channelIndex ) {
addEvent ( angle / getCycleDuration ( ) , state , channelIndex ) ;
2018-12-25 07:20:13 -08:00
}
2022-11-16 11:28:43 -08:00
void TriggerWaveform : : addEvent ( angle_t angle , TriggerValue const state , TriggerWheel const channelIndex ) {
2023-04-28 21:13:13 -07:00
efiAssertVoid ( ObdCode : : CUSTOM_OMODE_UNDEF , operationMode ! = OM_NONE , " operationMode not set " ) ;
2015-07-10 06:01:56 -07:00
2022-09-11 00:46:50 -07:00
if ( channelIndex = = TriggerWheel : : T_SECONDARY ) {
2020-01-12 07:43:02 -08:00
needSecondTriggerInput = true ;
}
2015-07-10 06:01:56 -07:00
2019-04-12 19:07:03 -07:00
# if EFI_UNIT_TEST
2015-09-10 20:01:32 -07:00
if ( printTriggerDebug ) {
2021-11-06 23:57:32 -07:00
printf ( " addEvent2 %.2f i=%d r/f=%d \r \n " , angle , channelIndex , state ) ;
2015-09-10 20:01:32 -07:00
}
# endif
2019-04-12 19:07:03 -07:00
# if EFI_UNIT_TEST
2021-11-21 01:56:07 -08:00
assertIsInBounds ( wave . phaseCount , triggerSignalIndeces , " trigger shape overflow " ) ;
triggerSignalIndeces [ wave . phaseCount ] = channelIndex ;
triggerSignalStates [ wave . phaseCount ] = state ;
2021-01-04 18:05:16 -08:00
# endif // EFI_UNIT_TEST
2015-07-10 06:01:56 -07:00
2019-02-02 22:34:20 -08:00
// todo: the whole 'useOnlyRisingEdgeForTrigger' parameter and logic should not be here
// todo: see calculateExpectedEventCounts
// related calculation should be done once trigger is initialized outside of trigger shape scope
2022-09-25 15:49:54 -07:00
if ( ! useOnlyRisingEdges | | state = = TriggerValue : : RISE ) {
2022-09-11 00:46:50 -07:00
expectedEventCount [ ( int ) channelIndex ] + + ;
2015-07-10 06:01:56 -07:00
}
2022-03-19 14:51:47 -07:00
if ( angle < = 0 | | angle > 1 ) {
2023-04-28 21:13:13 -07:00
firmwareError ( ObdCode : : CUSTOM_ERR_6599 , " angle should be positive not above 1: index=%d angle %f " , channelIndex , angle ) ;
2022-03-19 14:51:47 -07:00
return ;
}
2021-11-21 01:56:07 -08:00
if ( wave . phaseCount > 0 ) {
2015-07-10 06:01:56 -07:00
if ( angle < = previousAngle ) {
2023-04-28 21:13:13 -07:00
warning ( ObdCode : : CUSTOM_ERR_TRG_ANGLE_ORDER , " invalid angle order %s %s: new=%.2f/%f and prev=%.2f/%f, size=%d " ,
2022-09-11 09:40:24 -07:00
getTriggerWheel ( channelIndex ) ,
2022-09-10 23:16:47 -07:00
getTrigger_value_e ( state ) ,
2020-05-08 22:49:17 -07:00
angle , angle * getCycleDuration ( ) ,
previousAngle , previousAngle * getCycleDuration ( ) ,
2021-11-21 01:56:07 -08:00
wave . phaseCount ) ;
2019-08-07 19:02:08 -07:00
setShapeDefinitionError ( true ) ;
2015-07-10 06:01:56 -07:00
return ;
}
}
previousAngle = angle ;
2021-11-21 01:56:07 -08:00
if ( wave . phaseCount = = 0 ) {
wave . phaseCount = 1 ;
2015-07-10 06:01:56 -07:00
for ( int i = 0 ; i < PWM_PHASE_MAX_WAVE_PER_PWM ; i + + ) {
2023-05-31 13:20:54 -07:00
wave . setChannelState ( i , /* switchIndex */ 0 , TriggerValue : : FALL ) ;
2015-07-10 06:01:56 -07:00
}
2022-09-10 23:57:35 -07:00
isRiseEvent [ 0 ] = TriggerValue : : RISE = = state ;
2021-11-21 01:56:07 -08:00
wave . setSwitchTime ( 0 , angle ) ;
2022-09-11 00:46:50 -07:00
wave . setChannelState ( ( int ) channelIndex , /* channelIndex */ 0 , /* value */ state ) ;
2015-07-10 06:01:56 -07:00
return ;
}
2022-08-28 06:43:21 -07:00
if ( wave . findAngleMatch ( angle ) ) {
2023-04-28 21:13:13 -07:00
warning ( ObdCode : : CUSTOM_ERR_SAME_ANGLE , " same angle: not supported " ) ;
2019-08-07 19:02:08 -07:00
setShapeDefinitionError ( true ) ;
2015-07-10 06:01:56 -07:00
return ;
}
2021-11-21 01:56:07 -08:00
int index = wave . findInsertionAngle ( angle ) ;
2015-07-10 06:01:56 -07:00
2018-04-29 23:22:54 -07:00
/**
* todo : it would be nice to be able to provide trigger angles without sorting them externally
* The idea here is to shift existing data - including handling high vs low state of the signals
*/
2018-02-05 14:16:34 -08:00
// todo: does this logic actually work? I think it does not! due to broken state handling
2018-04-29 23:22:54 -07:00
/*
2015-07-10 06:01:56 -07:00
for ( int i = size - 1 ; i > = index ; i - - ) {
for ( int j = 0 ; j < PWM_PHASE_MAX_WAVE_PER_PWM ; j + + ) {
2021-11-21 01:56:07 -08:00
wave . waves [ j ] . pinStates [ i + 1 ] = wave . getChannelState ( j , index ) ;
2015-07-10 06:01:56 -07:00
}
2021-11-21 01:56:07 -08:00
wave . setSwitchTime ( i + 1 , wave . getSwitchTime ( i ) ) ;
2015-07-10 06:01:56 -07:00
}
2018-04-29 23:22:54 -07:00
*/
2022-09-10 23:57:35 -07:00
isRiseEvent [ index ] = TriggerValue : : RISE = = state ;
2015-07-10 06:01:56 -07:00
2021-11-21 01:56:07 -08:00
if ( ( unsigned ) index ! = wave . phaseCount ) {
2023-04-28 21:13:13 -07:00
firmwareError ( ObdCode : : ERROR_TRIGGER_DRAMA , " are we ever here? " ) ;
2015-07-10 06:01:56 -07:00
}
2021-11-21 01:56:07 -08:00
wave . phaseCount + + ;
2015-07-10 06:01:56 -07:00
for ( int i = 0 ; i < PWM_PHASE_MAX_WAVE_PER_PWM ; i + + ) {
2021-11-21 01:56:07 -08:00
pin_state_t value = wave . getChannelState ( /* channelIndex */ i , index - 1 ) ;
wave . setChannelState ( i , index , value ) ;
2015-07-10 06:01:56 -07:00
}
2021-11-21 01:56:07 -08:00
wave . setSwitchTime ( index , angle ) ;
2022-09-11 00:46:50 -07:00
wave . setChannelState ( ( int ) channelIndex , index , state ) ;
2015-07-10 06:01:56 -07:00
}
2019-12-07 22:09:39 -08:00
angle_t TriggerWaveform : : getSwitchAngle ( int index ) const {
2021-11-21 01:56:07 -08:00
return getCycleDuration ( ) * wave . getSwitchTime ( index ) ;
2015-07-10 06:01:56 -07:00
}
2019-12-07 22:09:39 -08:00
void TriggerWaveform : : setTriggerSynchronizationGap2 ( float syncRatioFrom , float syncRatioTo ) {
2018-12-25 07:20:13 -08:00
setTriggerSynchronizationGap3 ( /*gapIndex*/ 0 , syncRatioFrom , syncRatioTo ) ;
2018-10-21 10:41:01 -07:00
}
2019-12-07 22:09:39 -08:00
void TriggerWaveform : : setTriggerSynchronizationGap3 ( int gapIndex , float syncRatioFrom , float syncRatioTo ) {
2015-07-10 06:01:56 -07:00
isSynchronizationNeeded = true ;
2023-09-05 18:28:39 -07:00
criticalAssertVoid ( gapIndex > = 0 & & gapIndex < GAP_TRACKING_LENGTH , " gapIndex out of range " ) ;
2023-09-09 16:53:18 -07:00
synchronizationRatioFrom [ gapIndex ] = syncRatioFrom ;
synchronizationRatioTo [ gapIndex ] = syncRatioTo ;
2018-12-25 07:20:13 -08:00
if ( gapIndex = = 0 ) {
2018-10-21 10:41:01 -07:00
// we have a special case here - only sync with one gap has this feature
this - > syncRatioAvg = ( int ) efiRound ( ( syncRatioFrom + syncRatioTo ) * 0.5f , 1.0f ) ;
}
2020-10-04 10:05:49 -07:00
gapTrackingLength = maxI ( 1 + gapIndex , gapTrackingLength ) ;
2018-10-21 10:41:01 -07:00
2019-04-12 19:07:03 -07:00
# if EFI_UNIT_TEST
2017-03-04 16:47:15 -08:00
if ( printTriggerDebug ) {
2018-12-25 07:20:13 -08:00
printf ( " setTriggerSynchronizationGap3 %d %.2f %.2f \r \n " , gapIndex , syncRatioFrom , syncRatioTo ) ;
2017-03-04 16:47:15 -08:00
}
# endif /* EFI_UNIT_TEST */
2018-10-21 10:41:01 -07:00
2015-07-10 06:01:56 -07:00
}
2021-07-17 14:47:13 -07:00
uint16_t TriggerWaveform : : findAngleIndex ( TriggerFormDetails * details , angle_t targetAngle ) const {
2021-01-16 18:22:30 -08:00
size_t engineCycleEventCount = getLength ( ) ;
2018-12-25 09:27:34 -08:00
2023-04-28 21:13:13 -07:00
efiAssert ( ObdCode : : CUSTOM_ERR_ASSERT , engineCycleEventCount ! = 0 & & engineCycleEventCount < = 0xFFFF ,
2021-11-09 04:03:27 -08:00
" engineCycleEventCount " , 0 ) ;
2018-12-25 09:27:34 -08:00
uint32_t left = 0 ;
uint32_t right = engineCycleEventCount - 1 ;
/**
* Let ' s find the last trigger angle which is less or equal to the desired angle
* todo : extract binary search as template method ?
*/
2021-11-09 04:03:27 -08:00
do {
uint32_t middle = ( left + right ) / 2 ;
if ( details - > eventAngles [ middle ] < = targetAngle ) {
left = middle + 1 ;
} else {
right = middle - 1 ;
}
} while ( left < = right ) ;
left - = 1 ;
2022-09-25 15:49:54 -07:00
if ( useOnlyRisingEdges ) {
2021-11-09 04:03:27 -08:00
left & = ~ 1U ;
}
return left ;
2018-12-25 09:27:34 -08:00
}
2019-12-07 22:09:39 -08:00
void TriggerWaveform : : setShapeDefinitionError ( bool value ) {
2019-08-07 19:02:08 -07:00
shapeDefinitionError = value ;
}
2019-12-07 22:09:39 -08:00
void TriggerWaveform : : setTriggerSynchronizationGap ( float syncRatio ) {
2020-12-04 13:24:19 -08:00
setTriggerSynchronizationGap3 ( /*gapIndex*/ 0 , syncRatio * TRIGGER_GAP_DEVIATION_LOW , syncRatio * TRIGGER_GAP_DEVIATION_HIGH ) ;
2015-09-12 12:02:40 -07:00
}
2021-10-24 14:12:19 -07:00
void TriggerWaveform : : setSecondTriggerSynchronizationGap ( float syncRatio ) {
setTriggerSynchronizationGap3 ( /*gapIndex*/ 1 , syncRatio * TRIGGER_GAP_DEVIATION_LOW , syncRatio * TRIGGER_GAP_DEVIATION_HIGH ) ;
}
2019-12-07 22:09:39 -08:00
void TriggerWaveform : : setSecondTriggerSynchronizationGap2 ( float syncRatioFrom , float syncRatioTo ) {
2018-12-25 07:20:13 -08:00
setTriggerSynchronizationGap3 ( /*gapIndex*/ 1 , syncRatioFrom , syncRatioTo ) ;
2015-09-12 12:02:40 -07:00
}
2019-12-07 22:09:39 -08:00
void TriggerWaveform : : setThirdTriggerSynchronizationGap ( float syncRatio ) {
2020-12-04 13:24:19 -08:00
setTriggerSynchronizationGap3 ( /*gapIndex*/ 2 , syncRatio * TRIGGER_GAP_DEVIATION_LOW , syncRatio * TRIGGER_GAP_DEVIATION_HIGH ) ;
2015-12-27 13:02:44 -08:00
}
2018-12-25 19:47:29 -08:00
/**
* External logger is needed because at this point our logger is not yet initialized
*/
2023-03-02 21:21:40 -08:00
void TriggerWaveform : : initializeTriggerWaveform ( operation_mode_e triggerOperationMode , const trigger_config_s & triggerType ) {
2018-12-25 19:47:29 -08:00
2019-04-12 19:07:03 -07:00
# if EFI_PROD_CODE
2023-06-24 23:08:53 -07:00
efiAssertVoid ( ObdCode : : CUSTOM_ERR_6641 , hasLotsOfRemainingStack ( ) , " init t " ) ;
2023-03-02 21:02:26 -08:00
efiPrintf ( " initializeTriggerWaveform(%s/%d) " , getTrigger_type_e ( triggerType . type ) , ( int ) triggerType . type ) ;
2018-12-25 19:47:29 -08:00
# endif
shapeDefinitionError = false ;
2023-03-02 21:02:26 -08:00
switch ( triggerType . type ) {
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_TOOTHED_WHEEL :
2023-03-02 21:02:26 -08:00
initializeSkippedToothTrigger ( this , triggerType . customTotalToothCount ,
triggerType . customSkippedToothCount , triggerOperationMode , SyncEdge : : RiseOnly ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_MAZDA_MIATA_NA :
2019-02-02 21:40:25 -08:00
initializeMazdaMiataNaShape ( this ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_MAZDA_MIATA_VVT_TEST :
2018-12-25 19:47:29 -08:00
initializeMazdaMiataVVtTestShape ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_SUZUKI_G13B :
2021-10-04 16:28:45 -07:00
initializeSuzukiG13B ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_FORD_TFI_PIP :
2021-09-12 08:56:12 -07:00
configureFordPip ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_FORD_ST170 :
2020-12-03 20:54:08 -08:00
configureFordST170 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_VVT_MIATA_NB :
2020-02-04 22:49:33 -08:00
initializeMazdaMiataVVtCamShape ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_RENIX_66_2_2_2 :
2020-04-19 11:54:02 -07:00
initializeRenix66_2_2 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_RENIX_44_2_2 :
2020-04-19 06:59:55 -07:00
initializeRenix44_2_2 ( this ) ;
2020-04-18 19:20:17 -07:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_MIATA_VVT :
2018-12-25 19:47:29 -08:00
initializeMazdaMiataNb2Crank ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_DODGE_NEON_1995 :
case trigger_type_e : : TT_DODGE_NEON_1995_ONLY_CRANK :
2019-12-07 22:09:39 -08:00
configureNeon1995TriggerWaveformOnlyCrank ( this ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_DODGE_STRATUS :
2019-12-07 22:09:39 -08:00
configureDodgeStratusTriggerWaveform ( this ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_DODGE_NEON_2003_CAM :
2019-12-07 22:09:39 -08:00
configureNeon2003TriggerWaveformCam ( this ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_DODGE_NEON_2003_CRANK :
2019-12-07 22:09:39 -08:00
configureNeon2003TriggerWaveformCam ( this ) ;
// configureNeon2003TriggerWaveformCrank(triggerShape);
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_FORD_ASPIRE :
2019-12-07 22:09:39 -08:00
configureFordAspireTriggerWaveform ( this ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_VVT_NISSAN_VQ35 :
2021-07-01 18:48:14 -07:00
initializeNissanVQvvt ( this ) ;
break ;
2023-09-29 20:21:48 -07:00
case trigger_type_e : : TT_MITSU_6G72_CAM :
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_VVT_MITSUBISHI_3A92 :
2022-03-19 19:06:19 -07:00
initializeVvt3A92 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_VVT_TOYOTA_4_1 :
2022-12-02 04:37:18 -08:00
initializeSkippedToothTrigger ( this , 4 , 1 , triggerOperationMode , SyncEdge : : RiseOnly ) ;
2023-01-20 02:17:44 -08:00
setTriggerSynchronizationGap3 ( /*gapIndex*/ 0 , /*from*/ 1.60 , 2.40 ) ;
setTriggerSynchronizationGap3 ( /*gapIndex*/ 1 , /*from*/ 0.75 , 1.25 ) ;
2022-03-23 16:25:13 -07:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_VVT_MITSUBISHI_6G75 :
case trigger_type_e : : TT_NISSAN_QR25 :
2021-08-08 01:56:56 -07:00
initializeNissanQR25crank ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_NISSAN_VQ30 :
2021-07-16 22:10:13 -07:00
initializeNissanVQ30cam ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_NISSAN_VQ35 :
2021-07-16 21:45:47 -07:00
initializeNissanVQ35crank ( this ) ;
2021-07-01 19:10:37 -07:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_NISSAN_MR18_CRANK :
2021-11-05 04:15:03 -07:00
initializeNissanMR18crank ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_NISSAN_MR18_CAM_VVT :
2021-11-05 12:33:22 -07:00
initializeNissanMRvvt ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_KAWA_KX450F :
2021-04-08 20:23:01 -07:00
configureKawaKX450F ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_SKODA_FAVORIT :
2021-02-06 17:53:30 -08:00
setSkodaFavorit ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_GM_60_2_2_2 :
2021-02-02 06:50:20 -08:00
configureGm60_2_2_2 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_GM_7X :
2019-12-07 22:09:39 -08:00
configureGmTriggerWaveform ( this ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_MAZDA_DOHC_1_4 :
2018-12-25 19:47:29 -08:00
configureMazdaProtegeLx ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_ONE_PLUS_ONE :
2020-04-25 19:23:53 -07:00
configureOnePlusOne ( this ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_3_1_CAM :
2020-04-25 19:23:53 -07:00
configure3_1_cam ( this ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_MERCEDES_2_SEGMENT :
2021-11-13 18:50:04 -08:00
setMercedesTwoSegment ( this ) ;
break ;
2023-08-05 15:06:38 -07:00
case trigger_type_e : : TT_HALF_MOON :
/** @note TT_HALF_MOON setup events as 180 and 360 degrees. It uses SyncEdge::Rise
* for additional phase align on falling edge and will not work with non -
* symmetrical blind type where open and closed sections are not equal */
2022-10-17 13:05:27 -07:00
initializeSkippedToothTrigger ( this , 1 , 0 , triggerOperationMode , SyncEdge : : Rise ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-08-05 15:06:38 -07:00
case trigger_type_e : : TT_NARROW_SINGLE_TOOTH :
/** different from TT_HALF_MOON */
initializeSkippedToothTrigger ( this , 1 , 0 , triggerOperationMode , SyncEdge : : RiseOnly ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_MAZDA_SOHC_4 :
2018-12-25 19:47:29 -08:00
configureMazdaProtegeSOHC ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_DAIHATSU :
2020-12-03 20:12:30 -08:00
configureDaihatsu4 ( this ) ;
break ;
2023-09-14 13:53:16 -07:00
case trigger_type_e : : TT_VVT_TOYOTA_3_TOOTH :
2022-10-17 13:05:27 -07:00
initializeSkippedToothTrigger ( this , 3 , 0 , triggerOperationMode , SyncEdge : : RiseOnly ) ;
2020-08-25 13:19:23 -07:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_36_2_1_1 :
2022-03-19 14:51:47 -07:00
initialize36_2_1_1 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_36_2_1 :
2022-03-20 08:24:00 -07:00
initialize36_2_1 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_TOOTHED_WHEEL_32_2 :
2022-10-17 13:05:27 -07:00
initializeSkippedToothTrigger ( this , 32 , 2 , triggerOperationMode , SyncEdge : : RiseOnly ) ;
2022-07-23 07:00:55 -07:00
// todo: why is this 32/2 asking for third gap while 60/2 is happy with just two gaps?
// method above sets second gap, here we add third
// this third gap is not required to sync on perfect signal but is needed to handle to reject cranking transition noise
2021-11-25 17:45:58 -08:00
setThirdTriggerSynchronizationGap ( 1 ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_TOOTHED_WHEEL_60_2 :
2022-10-17 13:05:27 -07:00
initializeSkippedToothTrigger ( this , 60 , 2 , triggerOperationMode , SyncEdge : : RiseOnly ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_TOOTHED_WHEEL_36_2 :
2022-10-17 13:05:27 -07:00
initializeSkippedToothTrigger ( this , 36 , 2 , triggerOperationMode , SyncEdge : : RiseOnly ) ;
2022-05-04 21:41:26 -07:00
setTriggerSynchronizationGap3 ( /*gapIndex*/ 0 , /*from*/ 1.6 , 3.5 ) ;
setTriggerSynchronizationGap3 ( /*gapIndex*/ 1 , /*from*/ 0.7 , 1.3 ) ; // second gap is not required to synch on perfect signal but is needed to handle to reject cranking transition noise
2020-05-09 20:47:51 -07:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_60_2_VW :
2018-12-25 19:47:29 -08:00
setVwConfiguration ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_TOOTHED_WHEEL_36_1 :
2022-10-17 13:05:27 -07:00
initializeSkippedToothTrigger ( this , 36 , 1 , triggerOperationMode , SyncEdge : : RiseOnly ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_VVT_BOSCH_QUICK_START :
2020-04-25 19:23:53 -07:00
configureQuickStartSenderWheel ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_VVT_BARRA_3_PLUS_1 :
2021-03-22 04:48:29 -07:00
configureBarra3plus1cam ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_HONDA_K_CAM_4_1 :
2021-10-24 14:12:19 -07:00
configureHondaK_4_1 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_HONDA_K_CRANK_12_1 :
2020-04-19 11:23:01 -07:00
configureHondaK_12_1 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_SUBARU_EZ30 :
2022-06-20 08:41:33 -07:00
initializeSubaruEZ30 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_VVT_MAZDA_SKYACTIV :
2022-08-31 19:12:45 -07:00
initializeMazdaSkyactivCam ( this ) ;
2022-08-28 19:42:53 -07:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_BENELLI_TRE :
2022-11-16 12:23:42 -08:00
configureBenelli ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_MITSU_4G63_CRANK :
2023-03-30 20:11:15 -07:00
initializeMitsubishi4gSymmetricalCrank ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_VVT_FORD_COYOTE :
2023-05-13 13:08:23 -07:00
configureFordCoyote ( this ) ;
break ;
2023-06-22 19:10:29 -07:00
case trigger_type_e : : TT_60DEG_TOOTH :
/** @note
* Have a something like TT_ONE_PHASED trigger with
* externally setuped blind width will be a good
* approach to utilize : : Rise ( and : : Both in future )
* with both edges phase - sync , but to stay simple I suggest
* just to use another enum for each trigger type . */
configure60degSingleTooth ( this ) ;
break ;
2023-08-15 05:49:07 -07:00
case trigger_type_e : : TT_60_2_2_F3R :
2023-08-15 09:50:54 -07:00
initialize60_2_2_Renault_F ( this ) ;
break ;
2023-08-24 19:50:16 -07:00
case trigger_type_e : : TT_VVT_MITSUBISHI_4G69 :
2023-08-24 22:10:03 -07:00
initializeMitsubishi4G69Cam ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_MITSU_4G63_CAM :
2023-02-16 20:22:34 -08:00
initializeMitsubishi4g63Cam ( this ) ;
2023-01-07 13:28:57 -08:00
break ;
2023-02-21 12:04:29 -08:00
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_MITSU_4G9x_CAM :
2023-02-16 20:22:34 -08:00
initializeMitsubishi4g9xCam ( this ) ;
2023-01-07 13:28:57 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_1_16 :
2020-09-28 18:18:47 -07:00
configureOnePlus16 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_HONDA_CBR_600 :
2018-12-25 19:47:29 -08:00
configureHondaCbr600 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_CHRYSLER_NGC_36_2_2 :
2020-12-03 21:30:22 -08:00
configureChryslerNGC_36_2_2 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_DODGE_RAM :
2018-12-25 19:47:29 -08:00
initDodgeRam ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_JEEP_4_CYL :
2018-12-25 19:47:29 -08:00
initJeep_XJ_4cyl_2500 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_JEEP_18_2_2_2 :
2018-12-25 19:47:29 -08:00
initJeep18_2_2_2 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_SUBARU_7_6 :
2018-12-25 19:47:29 -08:00
initializeSubaru7_6 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_36_2_2_2 :
2018-12-25 19:47:29 -08:00
initialize36_2_2_2 ( this ) ;
break ;
2023-09-29 18:18:19 -07:00
case trigger_type_e : : TT_2JZ_3_34_SIMULATION_ONLY :
2020-05-08 22:15:55 -07:00
initialize2jzGE3_34_simulation_shape ( this ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_12_TOOTH_CRANK :
2022-05-17 18:38:24 -07:00
configure12ToothCrank ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_NISSAN_SR20VE :
2018-12-25 19:47:29 -08:00
initializeNissanSR20VE_4 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_ROVER_K :
2018-12-25 19:47:29 -08:00
initializeRoverK ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_FIAT_IAW_P8 :
2018-12-25 19:47:29 -08:00
configureFiatIAQ_P8 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_TRI_TACH :
2021-01-03 21:26:05 -08:00
configureTriTach ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_GM_24x :
2022-05-06 05:25:44 -07:00
initGmLS24_5deg ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_GM_24x_2 :
2022-05-06 05:25:44 -07:00
initGmLS24_3deg ( this ) ;
2018-12-25 19:47:29 -08:00
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_SUBARU_7_WITHOUT_6 :
2020-12-13 13:22:02 -08:00
initializeSubaruOnly7 ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_SUBARU_SVX :
2020-05-14 17:40:47 -07:00
initializeSubaru_SVX ( this ) ;
break ;
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_SUBARU_SVX_CRANK_1 :
2021-08-31 03:05:57 -07:00
initializeSubaru_SVX ( this ) ;
break ;
2021-08-31 02:54:04 -07:00
2023-05-31 22:56:40 -07:00
case trigger_type_e : : TT_SUBARU_SVX_CAM_VVT :
2021-08-31 03:05:57 -07:00
initializeSubaru_SVX ( this ) ;
break ;
2021-08-31 02:54:04 -07:00
2018-12-25 19:47:29 -08:00
default :
2019-08-07 19:02:08 -07:00
setShapeDefinitionError ( true ) ;
2023-04-28 21:13:13 -07:00
warning ( ObdCode : : CUSTOM_ERR_NO_SHAPE , " initializeTriggerWaveform() not implemented: %d " , triggerType . type ) ;
2018-12-25 19:47:29 -08:00
}
2022-09-25 15:49:54 -07:00
2019-02-02 21:40:25 -08:00
/**
* Feb 2019 suggestion : it would be an improvement to remove ' expectedEventCount ' logic from ' addEvent '
* and move it here , after all events were added .
*/
2022-09-25 15:49:54 -07:00
calculateExpectedEventCounts ( ) ;
2018-12-25 19:47:29 -08:00
version + + ;
if ( ! shapeDefinitionError ) {
2021-11-21 01:56:07 -08:00
wave . checkSwitchTimes ( getCycleDuration ( ) ) ;
2018-12-25 19:47:29 -08:00
}
2022-09-11 02:41:01 -07:00
}