2015-02-14 05:11:43 -08:00
# ifndef GLOBALS_H
# define GLOBALS_H
2013-07-08 17:43:41 -07:00
# include <Arduino.h>
2013-07-18 03:36:36 -07:00
const byte ms_version = 20 ;
2014-02-06 01:48:19 -08:00
const byte signature = 20 ;
const byte data_structure_version = 2 ; //This identifies the data structure when reading / writing.
const byte page_size = 128 ;
2013-07-09 17:26:16 -07:00
2013-09-19 03:49:28 -07:00
//Handy bitsetting macros
# define BIT_SET(a,b) ((a) |= (1<<(b)))
# define BIT_CLEAR(a,b) ((a) &= ~(1<<(b)))
2014-05-06 04:07:49 -07:00
# define BIT_CHECK(var,pos) ((var) & (1<<(pos)))
2013-09-19 03:49:28 -07:00
2014-05-06 04:07:49 -07:00
//Define bit positions within engine virable
# define BIT_ENGINE_RUN 0 // Engine running
# define BIT_ENGINE_CRANK 1 // Engine cranking
# define BIT_ENGINE_ASE 2 // after start enrichment (ASE)
# define BIT_ENGINE_WARMUP 3 // Engine in warmup
2015-01-27 15:01:12 -08:00
# define BIT_ENGINE_ACC 4 // in TPS acceleration mode
# define BIT_ENGINE_DCC 5 // in deceleration mode
2014-05-06 04:07:49 -07:00
# define BIT_ENGINE_MAP 6 // in MAP acceleration mode
# define BIT_ENGINE_IDLE 7 // idle on
2014-01-29 21:28:21 -08:00
2014-01-30 16:49:50 -08:00
//Define masks for Squirt
2014-05-06 04:07:49 -07:00
# define BIT_SQUIRT_INJ1 0 //inj1 Squirt
# define BIT_SQUIRT_INJ2 1 //inj2 Squirt
# define BIT_SQUIRT_SCHSQRT 2 //Scheduled to squirt
# define BIT_SQUIRT_SQRTING 3 //Squirting
# define BIT_SQUIRT_INJ2SCHED 4
# define BIT_SQUIRT_INJ2SQRT 5 //Injector2 (Schedule2)
# define BIT_SQUIRT_BOOSTCTRLOFF 6 //Squirting Injector 2
2014-01-29 21:28:21 -08:00
2014-05-12 04:28:24 -07:00
# define SIZE_BYTE 8
# define SIZE_INT 16
2014-12-10 15:21:59 -08:00
//Table sizes
# define CALIBRATION_TABLE_SIZE 512
2014-12-15 05:34:02 -08:00
# define CALIBRATION_TEMPERATURE_OFFSET 40 // All temperature measurements are stored offset by 40 degrees. This is so we can use an unsigned byte (0-255) to represent temperature ranges from -40 to 215
2014-12-10 15:21:59 -08:00
2015-01-26 00:40:48 -08:00
# define SERIAL_BUFFER_THRESHOLD 32 // When the serial buffer is filled to greater than this threshold value, the serial processing operations will be performed more urgently in order to avoid it overflowing. Serial buffer is 64 bytes long, so the threshold is set at half this as a reasonable figure
2013-07-09 17:26:16 -07:00
//The status struct contains the current values for all 'live' variables
2013-07-16 05:29:17 -07:00
//In current version this is 64 bytes
2013-07-09 17:26:16 -07:00
struct statuses {
volatile boolean hasSync ;
unsigned int RPM ;
byte MAP ;
2014-02-13 14:27:33 -08:00
byte TPS ; //The current TPS reading (0% - 100%)
byte TPSlast ; //The previous TPS reading
2015-02-16 21:31:26 -08:00
unsigned long TPS_time ; //The time the TPS sample was taken
unsigned long TPSlast_time ; //The time the previous TPS sample was taken
2014-02-13 14:27:33 -08:00
byte tpsADC ; //0-255 byte representation of the TPS
2014-05-07 05:55:15 -07:00
byte tpsDOT ;
2013-07-09 17:26:16 -07:00
byte VE ;
2013-09-23 05:23:34 -07:00
byte O2 ;
2014-12-15 05:34:02 -08:00
int coolant ;
2014-12-10 15:21:59 -08:00
int cltADC ;
2014-12-15 05:34:02 -08:00
int IAT ;
2014-12-10 15:21:59 -08:00
int iatADC ;
int batADC ;
2015-01-12 02:23:25 -08:00
int O2ADC ;
2015-02-06 23:16:08 -08:00
int dwell ;
2014-10-14 17:49:11 -07:00
byte battery10 ; //The current BRV in volts (multiplied by 10. Eg 12.5V = 125)
2013-09-24 21:56:38 -07:00
byte advance ;
2014-09-20 15:17:14 -07:00
byte corrections ;
2015-01-27 15:01:12 -08:00
byte TAEamount ; //The amount of accleration enrichment currently being applied
2015-02-04 19:09:01 -08:00
byte egoCorrection ; //The amount of closed loop AFR enrichment currently being applied
byte wueCorrection ; //The amount of closed loop AFR enrichment currently being applied
2015-02-05 18:11:16 -08:00
byte afrTarget ;
2015-01-27 15:01:12 -08:00
unsigned long TAEEndTime ; //The target end time used whenever TAE is turned on
2013-09-17 23:45:53 -07:00
volatile byte squirt ;
2015-02-09 05:01:46 -08:00
volatile byte spark ;
2013-08-25 21:11:47 -07:00
byte engine ;
2014-09-21 12:52:32 -07:00
unsigned int PW ; //In uS
2014-05-08 03:46:38 -07:00
volatile byte runSecs ; //Counter of seconds since cranking commenced (overflows at 255 obviously)
volatile byte secl ; //Continous
2014-02-23 21:15:13 -08:00
volatile int loopsPerSecond ;
2015-03-01 16:12:39 -08:00
int freeRAM ;
2013-07-09 17:26:16 -07:00
2013-08-25 21:11:47 -07:00
//Helpful bitwise operations:
//Useful reference: http://playground.arduino.cc/Code/BitMath
// y = (x >> n) & 1; // n=0..15. stores nth bit of x in y. y becomes 0 or 1.
// x &= ~(1 << n); // forces nth bit of x to be 0. all other bits left alone.
// x |= (1 << n); // forces nth bit of x to be 1. all other bits left alone.
2013-07-09 17:26:16 -07:00
} ;
2013-07-16 05:29:17 -07:00
//Page 1 of the config - See the ini file for further reference
//This mostly covers off variables that are required for fuel
struct config1 {
2013-07-18 03:36:36 -07:00
byte crankCold ; //Cold cranking pulsewidth modifier. This is added to the fuel pulsewidth when cranking under a certain temp threshold (ms)
byte crankHot ; //Warm cranking pulsewidth modifier. This is added to the fuel pulsewidth when cranking (ms)
byte asePct ; //Afterstart enrichment (%)
2013-07-16 20:09:18 -07:00
byte aseCount ; //Afterstart enrichment cycles. This is the number of ignition cycles that the afterstart enrichment % lasts for
2014-02-26 20:17:14 -08:00
byte wueValues [ 10 ] ; //Warm up enrichment array (10 bytes)
2015-02-06 13:29:51 -08:00
byte crankingPct ; //Cranking enrichment
2015-03-15 04:54:47 -07:00
byte pinMapping ; // The board / ping mapping to be used
2015-02-06 13:29:51 -08:00
byte unused96 ;
byte unused97 ;
2013-07-16 05:29:17 -07:00
byte taeColdA ;
byte tpsThresh ;
byte taeTime ;
byte tdePct ;
2015-02-28 13:27:16 -08:00
//Display config bits
byte displayType : 3 ;
byte display1 : 3 ;
byte display2 : 2 ;
byte display3 : 3 ;
byte display4 : 2 ;
byte display5 : 3 ;
byte displayB1 : 4 ;
byte displayB2 : 4 ;
2015-02-03 02:33:22 -08:00
byte unused105 ;
2013-07-16 05:29:17 -07:00
byte reqFuel ;
byte divider ;
byte alternate ;
byte injOpen ;
byte injOCfuel ;
byte injPwmP ;
byte injPwmT ;
byte battFac ; //Whether to compensate pulsewidth for battery voltage (ms/v)
2014-02-06 01:48:19 -08:00
int rpmk ; //2 bytes
//36
2013-09-16 00:39:24 -07:00
//config1 in ini
2013-09-15 17:18:33 -07:00
byte mapType : 2 ;
byte strokes : 1 ;
byte injType : 1 ;
byte nCylinders : 4 ; //Number of cylinders
2013-09-16 00:39:24 -07:00
//config2 in ini
2013-09-15 17:18:33 -07:00
byte cltType : 2 ;
byte matType : 2 ;
byte nInjectors : 4 ; //Number of injectors
2013-09-16 00:39:24 -07:00
2013-09-15 17:18:33 -07:00
2013-09-16 00:39:24 -07:00
//config3 in ini
2013-09-15 17:18:33 -07:00
byte engineType : 1 ;
byte egoType : 1 ;
byte algorithm : 1 ; //"Speed Density", "Alpha-N"
byte baroCorr : 1 ;
2013-07-16 05:29:17 -07:00
byte primePulse ;
byte egoRPM ;
byte fastIdleT ; //Fast idle temperature
byte egoSwitch ;
byte taeColdM ;
2014-02-06 01:48:19 -08:00
byte tpsMin ;
byte tpsMax ;
2013-09-15 05:39:55 -07:00
byte unused1 ;
2014-02-06 01:48:19 -08:00
//48
2013-07-16 05:29:17 -07:00
} ;
//Page 2 of the config - See the ini file for further reference
//This mostly covers off variables that are required for ignition
struct config2 {
2013-07-16 05:31:01 -07:00
byte triggerAngle ;
2013-07-16 05:29:17 -07:00
byte FixAng ;
byte Trim ;
byte CrankAng ;
byte IgHold ;
2013-09-26 04:23:22 -07:00
byte Trig_plus : 2 ;
byte TrigCrank : 1 ;
byte IgInv : 1 ;
byte oddfire : 4 ;
2013-07-16 05:29:17 -07:00
byte IdleAdv ;
byte IdleAdvTPS ;
byte IdleAdvRPM ;
2014-08-25 05:03:57 -07:00
byte IdleAdvCLT ; //The temperature below which the idle is advanced
2013-07-16 05:29:17 -07:00
byte IdleDelayTime ;
2014-08-25 05:03:57 -07:00
byte StgCycles ; //The number of initial cycles before the ignition should fire when first cranking
2013-07-16 05:31:01 -07:00
byte dwellCont ; //Fixed duty dwell control
2014-08-25 05:03:57 -07:00
byte dwellCrank ; //Dwell time whilst cranking
byte dwellRun ; //Dwell time whilst running
2013-07-16 05:29:17 -07:00
byte triggerTeeth ; //The full count of teeth on the trigger wheel if there were no gaps
byte triggerMissingTeeth ; //The size of the tooth gap (ie number of missing teeth)
2013-09-19 03:49:28 -07:00
byte crankRPM ; //RPM below which the engine is considered to be cranking
byte floodClear ; //TPS value that triggers flood clear mode (No fuel whilst cranking)
2014-01-09 22:17:10 -08:00
byte SoftRevLim ; //Soft rev limit (RPM/100)
byte SoftLimRetard ; //Amount soft limit retards (degrees)
byte SoftLimMax ; //Time the soft limit can run
byte HardRevLim ; //Hard rev limit (RPM/100)
2014-02-17 02:54:28 -08:00
byte taeBins [ 4 ] ; //TPS based acceleration enrichment bins (%/s)
2014-02-26 20:17:14 -08:00
byte taeValues [ 4 ] ; //TPS based acceleration enrichment rates (% to add)
byte wueBins [ 10 ] ; //Warmup Enrichment bins (Values are in configTable1)
2015-02-09 05:19:58 -08:00
byte dwellLimit ;
2015-03-19 21:13:16 -07:00
byte dwellCorrectionValues [ 6 ] ; //Correction table for dwell vs battery voltage
//Full - All 128bytes of this table are used
2014-02-17 02:54:28 -08:00
2013-07-16 05:29:17 -07:00
2015-02-03 02:33:22 -08:00
} ;
//Page 3 of the config - See the ini file for further reference
//This mostly covers off variables that are required for AFR targets and closed loop
struct config3 {
byte egoAlgorithm : 2 ;
byte egoType : 2 ;
byte unused : 4 ;
byte egoKP ;
byte egoKI ;
byte egoKD ;
byte egoTemp ; //The temperature above which closed loop functions
byte egoCount ; //The number of ignition cylces per step
byte egoDelta ; //The step size (In %) when using simple algorithm
byte egoLimit ; //Maximum amount the closed loop will vary the fueling
byte ego_min ; //AFR must be above this for closed loop to function
byte ego_max ; //AFR must be below this for closed loop to function
byte ego_sdelay ; //Time in seconds after engine starts that closed loop becomes available
byte egoRPM ; //RPM must be above this for closed loop to function
byte egoTPSMax ; //TPS must be below this for closed loop to function
byte floodClear ; //TPS value that triggers flood clear mode (No fuel whilst cranking)
byte egoLoadMax ; //Load (TPS or MAP) must be below this for closed loop to function
byte egoLoadMin ; //Load (TPS or MAP) must be above this for closed loop to function
2015-03-19 21:13:16 -07:00
byte dwellCorrectionBins [ 6 ] ; //Correction table for dwell vs battery voltage
2015-02-03 02:33:22 -08:00
byte unused116 ;
byte unused117 ;
byte unused118 ;
byte unused119 ;
byte unused120 ;
byte unused121 ;
byte unused122 ;
byte unused123 ;
byte unused124 ;
byte unused125 ;
byte unused126 ;
byte unused127 ;
2013-07-16 05:29:17 -07:00
} ;
2014-09-03 15:19:17 -07:00
2015-03-15 04:54:47 -07:00
byte pinInjector1 ; //Output pin injector 1
byte pinInjector2 ; //Output pin injector 2
byte pinInjector3 ; //Output pin injector 3 is on
byte pinInjector4 ; //Output pin injector 4 is on
2015-03-19 06:35:41 -07:00
byte pinInjector5 ; //Placeholder only - NOT USED
byte pinInjector6 ; //Placeholder only - NOT USED
byte pinInjector7 ; //Placeholder only - NOT USED
byte pinInjector8 ; //Placeholder only - NOT USED
2015-03-15 04:54:47 -07:00
byte pinCoil1 ; //Pin for coil 1
byte pinCoil2 ; //Pin for coil 2
byte pinCoil3 ; //Pin for coil 3
byte pinCoil4 ; //Pin for coil 4
byte pinTrigger ; //The CAS pin
byte pinTrigger2 ; //The Cam Sensor pin
byte pinTPS ; //TPS input pin
byte pinMAP ; //MAP sensor pin
2015-03-19 06:35:41 -07:00
byte pinMAP2 ; //2nd MAP sensor (Currently unused)
2015-03-15 04:54:47 -07:00
byte pinIAT ; //IAT sensor pin
byte pinCLT ; //CLS sensor pin
byte pinO2 ; //O2 Sensor pin
byte pinBat ; //O2 Sensor pin
byte pinDisplayReset ; // OLED reset pin
2015-03-19 06:35:41 -07:00
byte pinSpareTemp1 ; // Future use only
byte pinSpareTemp2 ; // Future use only
2015-02-14 05:11:43 -08:00
2015-02-14 09:04:00 -08:00
// global variables // from speeduino.ino
extern struct statuses currentStatus ; // from speeduino.ino
extern struct table3D fuelTable ; //8x8 fuel map
extern struct table3D ignitionTable ; //8x8 ignition map
extern struct table3D afrTable ; //8x8 afr target map
extern struct table2D taeTable ; //4 bin TPS Acceleration Enrichment map
extern struct table2D WUETable ; //10 bin Warm Up Enrichment map (2D)
extern struct config1 configPage1 ;
extern struct config2 configPage2 ;
extern struct config3 configPage3 ;
extern unsigned long currentLoopTime ; //The time the current loop started (uS)
extern unsigned long previousLoopTime ; //The time the previous loop started (uS)
extern byte ignitionCount ;
extern byte cltCalibrationTable [ CALIBRATION_TABLE_SIZE ] ;
extern byte iatCalibrationTable [ CALIBRATION_TABLE_SIZE ] ;
extern byte o2CalibrationTable [ CALIBRATION_TABLE_SIZE ] ;
extern volatile int toothHistory [ 512 ] ;
extern volatile int toothHistoryIndex ;
2015-02-14 05:11:43 -08:00
# endif // GLOBALS_H