2016-10-25 16:21:46 -07:00
# ifndef DECODERS_H
# define DECODERS_H
2015-11-24 21:55:36 -08:00
# include <limits.h>
2017-02-28 21:17:30 -08:00
# define READ_PRI_TRIGGER() ((*triggerPri_pin_port & triggerPri_pin_mask) ? HIGH : LOW)
# define READ_SEC_TRIGGER() ((*triggerSec_pin_port & triggerSec_pin_mask) ? HIGH : LOW)
2017-02-28 15:30:23 -08:00
static inline void addToothLogEntry ( unsigned long ) ;
2016-10-25 16:21:46 -07:00
static inline int stdGetRPM ( ) ;
2017-02-28 15:30:23 -08:00
static inline void setFilter ( unsigned long ) ;
static inline int crankingGetRPM ( byte ) ;
2016-10-25 16:21:46 -07:00
void triggerSetup_missingTooth ( ) ;
void triggerPri_missingTooth ( ) ;
void triggerSec_missingTooth ( ) ;
int getRPM_missingTooth ( ) ;
int getCrankAngle_missingTooth ( int timePerDegree ) ;
void triggerSetup_DualWheel ( ) ;
void triggerPri_DualWheel ( ) ;
void triggerSec_DualWheel ( ) ;
int getRPM_DualWheel ( ) ;
int getCrankAngle_DualWheel ( int timePerDegree ) ;
2017-02-28 15:30:23 -08:00
unsigned long MAX_STALL_TIME = 500000UL ; //The maximum time (in uS) that the system will continue to function before the engine is considered stalled/stopped. This is unique to each decoder, depending on the number of teeth etc. 500000 (half a second) is used as the default value, most decoders will be much less.
2016-10-25 16:21:46 -07:00
2015-05-16 04:06:54 -07:00
volatile unsigned long curTime ;
2015-12-08 18:33:35 -08:00
volatile unsigned long curGap ;
2015-09-07 23:46:42 -07:00
volatile unsigned long curTime2 ;
2015-12-08 18:33:35 -08:00
volatile unsigned long curGap2 ;
volatile unsigned long lastGap ;
2017-02-28 15:30:23 -08:00
volatile unsigned long targetGap ;
2015-05-16 04:06:54 -07:00
volatile int toothCurrentCount = 0 ; //The current number of teeth (Onec sync has been achieved, this can never actually be 0
2015-12-14 21:06:42 -08:00
volatile byte toothSystemCount = 0 ; //Used for decoders such as Audi 135 where not every tooth is used for calculating crank angle. This variable stores the actual number of teeth, not the number being used to calculate crank angle
2015-12-21 21:55:49 -08:00
volatile unsigned long toothSystemLastToothTime = 0 ; //As below, but used for decoders where not every tooth count is used for calculation
2015-05-16 04:06:54 -07:00
volatile unsigned long toothLastToothTime = 0 ; //The time (micros()) that the last tooth was registered
2015-09-07 23:46:42 -07:00
volatile unsigned long toothLastSecToothTime = 0 ; //The time (micros()) that the last tooth was registered on the secondary input
2015-05-16 04:06:54 -07:00
volatile unsigned long toothLastMinusOneToothTime = 0 ; //The time (micros()) that the tooth before the last tooth was registered
volatile unsigned long toothOneTime = 0 ; //The time (micros()) that tooth 1 last triggered
volatile unsigned long toothOneMinusOneTime = 0 ; //The 2nd to last time (micros()) that tooth 1 last triggered
2016-10-04 02:28:51 -07:00
volatile bool revolutionOne = 0 ; // For sequential operation, this tracks whether the current revolution is 1 or 2 (not 1)
2015-10-30 02:35:45 -07:00
volatile unsigned int toothHistory [ TOOTH_LOG_BUFFER ] ;
2015-09-07 16:49:34 -07:00
volatile unsigned int toothHistoryIndex = 0 ;
2016-10-18 19:12:08 -07:00
volatile bool toothLogRead = false ; //Flag to indicate whether the current tooth log values have been read out yet
2015-05-16 04:06:54 -07:00
2017-02-28 21:17:30 -08:00
volatile unsigned int secondaryToothCount ; //Used for identifying the current secondary (Usually cam) tooth for patterns with multiple secondary teeth
2015-07-12 03:34:59 -07:00
volatile unsigned long secondaryLastToothTime = 0 ; //The time (micros()) that the last tooth was registered (Cam input)
2017-03-20 23:19:07 -07:00
volatile unsigned long secondaryLastToothTime1 = 0 ; //The time (micros()) that the last tooth was registered (Cam input)
2015-07-12 03:34:59 -07:00
2015-05-16 04:06:54 -07:00
volatile int triggerActualTeeth ;
2015-09-13 04:16:30 -07:00
volatile unsigned long triggerFilterTime ; // The shortest time (in uS) that pulses will be accepted (Used for debounce filtering)
2015-09-07 23:46:42 -07:00
unsigned int triggerSecFilterTime ; // The shortest time (in uS) that pulses will be accepted (Used for debounce filtering) for the secondary input
2017-03-20 23:19:07 -07:00
unsigned int triggerSecFilterTime_duration ; // The shortest valid time (in uS) pulse DURATION
2017-01-01 00:56:04 -08:00
volatile int triggerToothAngle ; //The number of crank degrees that elapse per tooth
2015-06-11 20:18:36 -07:00
unsigned long revolutionTime ; //The time in uS that one revolution would take at current speed (The time tooth 1 was last seen, minus the time it was seen prior to that)
2015-11-29 00:53:41 -08:00
bool secondDerivEnabled ; //The use of the 2nd derivative calculation is limited to certain decoders. This is set to either true or false in each decoders setup routine
2016-02-16 17:37:54 -08:00
bool decoderIsSequential ; //Whether or not the decoder supports sequential operation
2016-11-07 22:04:34 -08:00
byte checkSyncToothCount ; //How many teeth must've been seen on this revolution before we try to confirm sync (Useful for missing tooth type decoders)
2015-07-12 03:34:59 -07:00
2015-10-31 13:18:09 -07:00
int toothAngles [ 24 ] ; //An array for storing fixed tooth angles. Currently sized at 24 for the GM 24X decoder, but may grow later if there are other decoders that use this style
2015-07-12 21:22:05 -07:00
2015-07-12 03:34:59 -07:00
//Used for identifying long and short pulses on the 4G63 (And possibly other) trigger patterns
# define LONG 0;
# define SHORT 1;
2015-11-24 21:55:36 -08:00
2016-10-25 16:21:46 -07:00
# endif