2014-05-06 04:07:49 -07:00
|
|
|
/*
|
|
|
|
Timers are used for having actions performed repeatedly at a fixed interval (Eg every 100ms)
|
|
|
|
They should not be confused with Schedulers, which are for performing an action once at a given point of time in the future
|
2014-01-30 20:02:32 -08:00
|
|
|
|
2014-05-06 04:07:49 -07:00
|
|
|
Timers are typically low resolution (Compared to Schedulers), with maximum frequency currently being approximately every 10ms
|
|
|
|
*/
|
2014-01-30 20:02:32 -08:00
|
|
|
|
2014-02-06 01:48:19 -08:00
|
|
|
void initialiseTimers()
|
|
|
|
{
|
2014-01-30 20:02:32 -08:00
|
|
|
//Configure Timer2 for our low-freq interrupt code.
|
2014-02-06 01:48:19 -08:00
|
|
|
TCCR2B = 0x00; //Disbale Timer2 while we set it up
|
|
|
|
TCNT2 = 99; //Preload timer2 with 100 cycles, leaving 156 till overflow.
|
|
|
|
TIFR2 = 0x00; //Timer2 INT Flag Reg: Clear Timer Overflow Flag
|
|
|
|
TIMSK2 = 0x01; //Timer2 Set Overflow Interrupt enabled.
|
|
|
|
TCCR2A = 0x00; //Timer2 Control Reg A: Wave Gen Mode normal
|
|
|
|
TCCR2B = ((1 << CS10) | (1 << CS11) | (1 << CS12)); //Timer2 Set Prescaler to 5 (101), 1024 mode.
|
2014-01-30 20:02:32 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//Timer2 Overflow Interrupt Vector, called when the timer overflows.
|
2014-05-06 04:07:49 -07:00
|
|
|
//Executes every ~10ms.
|
2014-01-30 20:02:32 -08:00
|
|
|
ISR(TIMER2_OVF_vect)
|
|
|
|
{
|
|
|
|
|
|
|
|
//Increment Loop Counters
|
2014-05-06 04:07:49 -07:00
|
|
|
loop250ms++;
|
2014-01-30 20:02:32 -08:00
|
|
|
loopSec++;
|
|
|
|
|
|
|
|
|
|
|
|
//Loop executed every 250ms loop (10ms x 25 = 250ms)
|
2014-05-06 04:07:49 -07:00
|
|
|
//Anything inside this if statement will run every 250ms.
|
|
|
|
if (loop250ms == 25)
|
2014-01-30 20:02:32 -08:00
|
|
|
{
|
2014-05-06 04:07:49 -07:00
|
|
|
loop250ms = 0; //Reset Counter.
|
2014-01-30 20:02:32 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
//Loop executed every 1 second (10ms x 100 = 1000ms)
|
|
|
|
if (loopSec == 100)
|
|
|
|
{
|
|
|
|
loopSec = 0; //Reset counter.
|
2014-02-06 01:48:19 -08:00
|
|
|
|
2014-02-17 22:08:55 -08:00
|
|
|
//**************************************************************************************************************************************************
|
|
|
|
//This updates the runSecs variable
|
2014-02-06 01:48:19 -08:00
|
|
|
//If the engine is running or cranking, we need ot update the run time counter.
|
2014-12-23 15:25:51 -08:00
|
|
|
if (BIT_CHECK(currentStatus.engine, BIT_ENGINE_RUN))
|
2014-02-06 01:48:19 -08:00
|
|
|
{ //NOTE - There is a potential for a ~1sec gap between engine crank starting and ths runSec number being incremented. This may delay ASE!
|
|
|
|
if (currentStatus.runSecs <= 254) //Ensure we cap out at 255 and don't overflow. (which would reset ASE)
|
|
|
|
{ currentStatus.runSecs++; } //Increment our run counter by 1 second.
|
|
|
|
}
|
2014-02-17 22:08:55 -08:00
|
|
|
//**************************************************************************************************************************************************
|
|
|
|
//This records the number of main loops the system has completed in the last second
|
|
|
|
currentStatus.loopsPerSecond = mainLoopCount;
|
|
|
|
mainLoopCount = 0;
|
|
|
|
//**************************************************************************************************************************************************
|
2014-05-08 03:46:38 -07:00
|
|
|
//increament secl (secl is simply a counter that increments every second and is used to track whether the system has unexpectedly reset
|
|
|
|
currentStatus.secl++;
|
2014-01-30 20:02:32 -08:00
|
|
|
|
2014-02-18 02:05:13 -08:00
|
|
|
|
|
|
|
}
|
|
|
|
//Reset Timer2 to trigger in another ~10ms
|
2014-01-30 20:02:32 -08:00
|
|
|
TCNT2 = 99; //Preload timer2 with 100 cycles, leaving 156 till overflow.
|
|
|
|
TIFR2 = 0x00; //Timer2 INT Flag Reg: Clear Timer Overflow Flag
|
|
|
|
|
|
|
|
}
|