Revert ignition schedules to high precision
This commit is contained in:
parent
7c74df590a
commit
b22be1aa86
|
@ -27,8 +27,8 @@ void initialiseSchedulers()
|
||||||
TCNT5 = 0; //Reset Timer Count
|
TCNT5 = 0; //Reset Timer Count
|
||||||
TIFR5 = 0x00; //Timer5 INT Flag Reg: Clear Timer Overflow Flag
|
TIFR5 = 0x00; //Timer5 INT Flag Reg: Clear Timer Overflow Flag
|
||||||
TCCR5A = 0x00; //Timer5 Control Reg A: Wave Gen Mode normal
|
TCCR5A = 0x00; //Timer5 Control Reg A: Wave Gen Mode normal
|
||||||
TCCR5B = (1 << CS12); //Timer5 Control Reg B: Timer Prescaler set to 256. Refer to http://www.instructables.com/files/orig/F3T/TIKL/H3WSA4V7/F3TTIKLH3WSA4V7.jpg
|
//TCCR5B = (1 << CS12); //Timer5 Control Reg B: Timer Prescaler set to 256. Refer to http://www.instructables.com/files/orig/F3T/TIKL/H3WSA4V7/F3TTIKLH3WSA4V7.jpg
|
||||||
//TCCR5B = 0x03; //Reverting this for now due to issue with low RPM overflow
|
TCCR5B = 0x03; //Reverting this for now due to issue with low RPM overflow
|
||||||
ignitionSchedule1.Status = OFF;
|
ignitionSchedule1.Status = OFF;
|
||||||
ignitionSchedule2.Status = OFF;
|
ignitionSchedule2.Status = OFF;
|
||||||
ignitionSchedule3.Status = OFF;
|
ignitionSchedule3.Status = OFF;
|
||||||
|
@ -105,7 +105,8 @@ void setFuelSchedule4(void (*startCallback)(), unsigned long timeout, unsigned l
|
||||||
//We need to calculate the value to reset the timer to (preload) in order to achieve the desired overflow time
|
//We need to calculate the value to reset the timer to (preload) in order to achieve the desired overflow time
|
||||||
//As the timer is ticking every 16uS (Time per Tick = (Prescale)*(1/Frequency))
|
//As the timer is ticking every 16uS (Time per Tick = (Prescale)*(1/Frequency))
|
||||||
//unsigned int absoluteTimeout = TCNT3 + (timeout / 16); //Each tick occurs every 16uS with the 256 prescaler, so divide the timeout by 16 to get ther required number of ticks. Add this to the current tick count to get the target time. This will automatically overflow as required
|
//unsigned int absoluteTimeout = TCNT3 + (timeout / 16); //Each tick occurs every 16uS with the 256 prescaler, so divide the timeout by 16 to get ther required number of ticks. Add this to the current tick count to get the target time. This will automatically overflow as required
|
||||||
unsigned int absoluteTimeout = TCNT4 + (timeout >> 4); //As above, but with bit shift instead of / 16
|
//unsigned int absoluteTimeout = TCNT4 + (timeout >> 4); //As above, but with bit shift instead of / 16
|
||||||
|
unsigned int absoluteTimeout = TCNT4 + (timeout >> 2); //As above, but with bit shift instead of / 16
|
||||||
OCR4B = absoluteTimeout; //Use the B compare unit of timer 4
|
OCR4B = absoluteTimeout; //Use the B compare unit of timer 4
|
||||||
fuelSchedule4.duration = duration;
|
fuelSchedule4.duration = duration;
|
||||||
fuelSchedule4.StartCallback = startCallback; //Name the start callback function
|
fuelSchedule4.StartCallback = startCallback; //Name the start callback function
|
||||||
|
@ -124,8 +125,8 @@ void setIgnitionSchedule1(void (*startCallback)(), unsigned long timeout, unsign
|
||||||
//unsigned char sreg;
|
//unsigned char sreg;
|
||||||
//sreg = SREG;
|
//sreg = SREG;
|
||||||
//noInterrupts();
|
//noInterrupts();
|
||||||
unsigned int absoluteTimeout = TCNT5 + (timeout >> 4); //As above, but with bit shift instead of / 16
|
//unsigned int absoluteTimeout = TCNT5 + (timeout >> 4); //As above, but with bit shift instead of / 16
|
||||||
//unsigned int absoluteTimeout = TCNT5 + (timeout >> 2); //As above, but with bit shift instead of / 16
|
unsigned int absoluteTimeout = TCNT5 + (timeout >> 2); //As above, but with bit shift instead of / 16
|
||||||
OCR5A = absoluteTimeout;
|
OCR5A = absoluteTimeout;
|
||||||
//SREG = sreg;
|
//SREG = sreg;
|
||||||
ignitionSchedule1.duration = duration;
|
ignitionSchedule1.duration = duration;
|
||||||
|
@ -263,9 +264,9 @@ ISR(TIMER5_COMPA_vect, ISR_NOBLOCK) //ignitionSchedule1
|
||||||
ignitionSchedule1.Status = RUNNING; //Set the status to be in progress (ie The start callback has been called, but not the end callback)
|
ignitionSchedule1.Status = RUNNING; //Set the status to be in progress (ie The start callback has been called, but not the end callback)
|
||||||
ignitionSchedule1.startTime = currentLoopTime;
|
ignitionSchedule1.startTime = currentLoopTime;
|
||||||
ignitionSchedule1.StartCallback();
|
ignitionSchedule1.StartCallback();
|
||||||
unsigned int absoluteTimeout = TCNT5 + (ignitionSchedule1.duration >> 4);
|
//unsigned int absoluteTimeout = TCNT5 + (ignitionSchedule1.duration >> 4);
|
||||||
ign1LastRev = startRevolutions;
|
ign1LastRev = startRevolutions;
|
||||||
//unsigned int absoluteTimeout = TCNT5 + (ignitionSchedule1.duration >> 2); //Divide by 4
|
unsigned int absoluteTimeout = TCNT5 + (ignitionSchedule1.duration >> 2); //Divide by 4
|
||||||
OCR5A = absoluteTimeout;
|
OCR5A = absoluteTimeout;
|
||||||
}
|
}
|
||||||
else if (ignitionSchedule1.Status == RUNNING)
|
else if (ignitionSchedule1.Status == RUNNING)
|
||||||
|
|
Loading…
Reference in New Issue