Speeduino
Loading...
Searching...
No Matches
Classes | Macros | Enumerations | Functions | Variables
scheduler.h File Reference
#include <SimplyAtomic.h>
#include "globals.h"
#include "crankMaths.h"
#include "scheduledIO.h"
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Classes

struct  Schedule
 A schedule for a single output channel. More...
 
struct  IgnitionSchedule
 
struct  FuelSchedule
 

Macros

#define USE_IGN_REFRESH
 
#define IGNITION_REFRESH_THRESHOLD   30
 

Enumerations

enum  ScheduleStatus { OFF = 0b00000000U , PENDING = 0b00000001U , RUNNING = 0b00000010U , RUNNING_WITHNEXT = 0b00000100U }
 The current state of a schedule. More...
 

Functions

void initialiseIgnitionSchedulers (void)
 
void startIgnitionSchedulers (void)
 
void stopIgnitionSchedulers (void)
 
void disableIgnSchedule (uint8_t channel)
 
void refreshIgnitionSchedule1 (unsigned long timeToEnd)
 
void disableAllIgnSchedules (void)
 
void initialiseFuelSchedulers (void)
 
void startFuelSchedulers (void)
 
void stopFuelSchedulers (void)
 
void beginInjectorPriming (void)
 
void disableFuelSchedule (uint8_t channel)
 
void disableAllFuelSchedules (void)
 
static bool isRunning (const Schedule &schedule)
 Is the schedule action currently running?
 
void setCallbacks (Schedule &schedule, voidVoidCallback pStartCallback, voidVoidCallback pEndCallback)
 Set the schedule action start & end callbacks.
 
void setSchedule (Schedule &schedule, uint32_t delay, uint16_t duration, bool allowQueuedSchedule)
 Set the schedule action to run for a certain duration in the future.
 
static void setIgnitionSchedule (IgnitionSchedule &schedule, uint32_t delay, uint16_t duration)
 Set the ignition schedule action (charge & fire a coil) to run for a certain duration in the future.
 
static void setFuelSchedule (FuelSchedule &schedule, uint32_t delay, uint16_t duration)
 Set the fuel schedule action (open & close an injector) to run for a certain duration in the future.
 

Variables

FuelSchedule fuelSchedule1
 
FuelSchedule fuelSchedule2
 
FuelSchedule fuelSchedule3
 
FuelSchedule fuelSchedule4
 
IgnitionSchedule ignitionSchedule1
 
IgnitionSchedule ignitionSchedule2
 
IgnitionSchedule ignitionSchedule3
 
IgnitionSchedule ignitionSchedule4
 
IgnitionSchedule ignitionSchedule5
 

Detailed Description

Injector and Ignition (on/off) scheduling (structs).

This scheduler is designed to maintain 2 schedules for use by the fuel and ignition systems. It functions by waiting for the overflow vectors from each of the timers in use to overflow, which triggers an interrupt.

Technical

Currently I am prescaling the 16-bit timers to 256 for injection and 64 for ignition. This means that the counter increments every 16us (injection) / 4uS (ignition) and will overflow every 1048576uS.

Max Period = (Prescale)*(1/Frequency)*(2^17)

For more details see https://playground.arduino.cc/Code/Timer1/ (OLD: http://playground.arduino.cc/code/timer1 ). This means that the precision of the scheduler is:

Features

This differs from most other schedulers in that its calls are non-recurring (ie when you schedule an event at a certain time and once it has occurred, it will not reoccur unless you explicitly ask/re-register for it). Each timer can have only 1 callback associated with it at any given time. If you call the setCallback function a 2nd time, the original schedule will be overwritten and not occur.

Timer identification

Arduino timers usage for injection and ignition schedules:

Timers 3,4 and 5 are 16-bit timers (ie count to 65536). See page 136 of the processors datasheet: http://www.atmel.com/Images/doc2549.pdf .

256 prescale gives tick every 16uS. 256 prescale gives overflow every 1048576uS (This means maximum wait time is 1.0485 seconds).

Macro Definition Documentation

◆ IGNITION_REFRESH_THRESHOLD

#define IGNITION_REFRESH_THRESHOLD   30

◆ USE_IGN_REFRESH

#define USE_IGN_REFRESH

Enumeration Type Documentation

◆ ScheduleStatus

The current state of a schedule.

Enumerator
OFF 

Not running

PENDING 

The delay phase of the schedule is active

RUNNING 

The schedule action is running

RUNNING_WITHNEXT 

The schedule is running, with a next schedule queued up

Function Documentation

◆ beginInjectorPriming()

void beginInjectorPriming ( void  )

Perform the injector priming pulses. Set these to run at an arbitrary time in the future (100us). The prime pulse value is in ms*10, so need to multiple by 100 to get to uS

Here is the call graph for this function:
Here is the caller graph for this function:

◆ disableAllFuelSchedules()

void disableAllFuelSchedules ( void  )
Here is the call graph for this function:
Here is the caller graph for this function:

◆ disableAllIgnSchedules()

void disableAllIgnSchedules ( void  )
Here is the call graph for this function:
Here is the caller graph for this function:

◆ disableFuelSchedule()

void disableFuelSchedule ( uint8_t  channel)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ disableIgnSchedule()

void disableIgnSchedule ( uint8_t  channel)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ initialiseFuelSchedulers()

void initialiseFuelSchedulers ( void  )

< The number of crank degrees until cylinder 1 is at TDC (This is obviously 0 for virtually ALL engines, but there's some weird ones)

< The number of crank degrees until cylinder 2 (and 5/6/7/8) is at TDC

< The number of crank degrees until cylinder 3 (and 5/6/7/8) is at TDC

< The number of crank degrees until cylinder 4 (and 5/6/7/8) is at TDC

Here is the call graph for this function:
Here is the caller graph for this function:

◆ initialiseIgnitionSchedulers()

void initialiseIgnitionSchedulers ( void  )

< The number of crank degrees until cylinder 1 is at TDC (This is obviously 0 for virtually ALL engines, but there's some weird ones)

< The number of crank degrees until cylinder 2 (and 5/6/7/8) is at TDC

< The number of crank degrees until cylinder 2 (and 5/6/7/8) is at TDC

< The number of crank degrees until cylinder 2 (and 5/6/7/8) is at TDC

Here is the call graph for this function:
Here is the caller graph for this function:

◆ isRunning()

static bool isRunning ( const Schedule schedule)
inlinestatic

Is the schedule action currently running?

Here is the call graph for this function:
Here is the caller graph for this function:

◆ refreshIgnitionSchedule1()

void refreshIgnitionSchedule1 ( unsigned long  timeToEnd)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ setCallbacks()

void setCallbacks ( Schedule schedule,
voidVoidCallback  pStartCallback,
voidVoidCallback  pEndCallback 
)

Set the schedule action start & end callbacks.

Parameters
scheduleSchedule to modify
pStartCallbackStart callback
pEndCallbackEnd callback
Here is the call graph for this function:
Here is the caller graph for this function:

◆ setFuelSchedule()

static void setFuelSchedule ( FuelSchedule schedule,
uint32_t  delay,
uint16_t  duration 
)
inlinestatic

Set the fuel schedule action (open & close an injector) to run for a certain duration in the future.

Parameters
scheduleSchedule to modify
delayDelay until the injector opens (µS)
durationInjector open time (µS)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ setIgnitionSchedule()

static void setIgnitionSchedule ( IgnitionSchedule schedule,
uint32_t  delay,
uint16_t  duration 
)
inlinestatic

Set the ignition schedule action (charge & fire a coil) to run for a certain duration in the future.

Parameters
scheduleSchedule to modify
delayDelay until the coil begins charging (µS)
durationDwell time (µS)
Here is the call graph for this function:
Here is the caller graph for this function:

◆ setSchedule()

void setSchedule ( Schedule schedule,
uint32_t  delay,
uint16_t  duration,
bool  allowQueuedSchedule 
)

Set the schedule action to run for a certain duration in the future.

Parameters
scheduleSchedule to modify
delayDelay until the action starts (µS)
durationAction duration (µS)
allowQueuedScheduletrue to allow a schedule to be queued up if one is currently running; false otherwise
Here is the call graph for this function:
Here is the caller graph for this function:

◆ startFuelSchedulers()

void startFuelSchedulers ( void  )
Here is the call graph for this function:
Here is the caller graph for this function:

◆ startIgnitionSchedulers()

void startIgnitionSchedulers ( void  )
Here is the call graph for this function:
Here is the caller graph for this function:

◆ stopFuelSchedulers()

void stopFuelSchedulers ( void  )
Here is the call graph for this function:

◆ stopIgnitionSchedulers()

void stopIgnitionSchedulers ( void  )
Here is the call graph for this function:

Variable Documentation

◆ fuelSchedule1

FuelSchedule fuelSchedule1
extern

◆ fuelSchedule2

FuelSchedule fuelSchedule2
extern

◆ fuelSchedule3

FuelSchedule fuelSchedule3
extern

◆ fuelSchedule4

FuelSchedule fuelSchedule4
extern

◆ ignitionSchedule1

IgnitionSchedule ignitionSchedule1
extern

◆ ignitionSchedule2

IgnitionSchedule ignitionSchedule2
extern

◆ ignitionSchedule3

IgnitionSchedule ignitionSchedule3
extern

◆ ignitionSchedule4

IgnitionSchedule ignitionSchedule4
extern

◆ ignitionSchedule5

IgnitionSchedule ignitionSchedule5
extern