40 lines
2.8 KiB
C
40 lines
2.8 KiB
C
#include <limits.h>
|
|
|
|
volatile unsigned long curTime;
|
|
volatile unsigned long curGap;
|
|
volatile unsigned long curTime2;
|
|
volatile unsigned long curGap2;
|
|
volatile unsigned long lastGap;
|
|
volatile unsigned long targetGap;
|
|
|
|
volatile int toothCurrentCount = 0; //The current number of teeth (Onec sync has been achieved, this can never actually be 0
|
|
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
|
|
volatile unsigned long toothSystemLastToothTime = 0; //As below, but used for decoders where not every tooth count is used for calculation
|
|
volatile unsigned long toothLastToothTime = 0; //The time (micros()) that the last tooth was registered
|
|
volatile unsigned long toothLastSecToothTime = 0; //The time (micros()) that the last tooth was registered on the secondary input
|
|
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
|
|
volatile bool revolutionOne = 0; // For sequential operation, this tracks whether the current revolution is 1 or 2 (not 1)
|
|
volatile unsigned int toothHistory[TOOTH_LOG_BUFFER];
|
|
volatile unsigned int toothHistoryIndex = 0;
|
|
|
|
volatile byte secondaryToothCount; //Used for identifying the current secondary (Usually cam) tooth for patterns with multiple secondary teeth
|
|
volatile unsigned long secondaryLastToothTime = 0; //The time (micros()) that the last tooth was registered (Cam input)
|
|
|
|
volatile int triggerActualTeeth;
|
|
volatile unsigned long triggerFilterTime; // The shortest time (in uS) that pulses will be accepted (Used for debounce filtering)
|
|
unsigned int triggerSecFilterTime; // The shortest time (in uS) that pulses will be accepted (Used for debounce filtering) for the secondary input
|
|
int triggerToothAngle; //The number of crank degrees that elapse per tooth
|
|
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)
|
|
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
|
|
bool decoderIsSequential; //Whether or not the decoder supports sequential operation
|
|
|
|
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
|
|
|
|
//Used for identifying long and short pulses on the 4G63 (And possibly other) trigger patterns
|
|
#define LONG 0;
|
|
#define SHORT 1;
|
|
|
|
|