714 lines
27 KiB
C
714 lines
27 KiB
C
#ifndef GLOBALS_H
|
|
#define GLOBALS_H
|
|
#include <Arduino.h>
|
|
#include "table.h"
|
|
|
|
#if defined(__AVR_ATmega1280__) || defined(__AVR_ATmega2560__) || defined(__AVR_ATmega2561__)
|
|
#define BOARD_NR_GPIO_PINS 54
|
|
#define LED_BUILTIN 13
|
|
#define CORE_AVR
|
|
#elif defined(CORE_TEENSY)
|
|
#define BOARD_NR_GPIO_PINS 34
|
|
#elif defined(STM32_MCU_SERIES) || defined(_VARIANT_ARDUINO_STM32_)
|
|
#define CORE_STM32
|
|
#define LED_BUILTIN 33
|
|
|
|
extern "C" char* sbrk(int incr); //Used to freeRam
|
|
inline unsigned char digitalPinToInterrupt(unsigned char Interrupt_pin) { return Interrupt_pin; } //This isn't included in the stm32duino libs (yet)
|
|
#define portOutputRegister(port) (volatile byte *)( &(port->regs->ODR) ) //These are defined in STM32F1/variants/generic_stm32f103c/variant.h but return a non byte* value
|
|
#define portInputRegister(port) (volatile byte *)( &(port->regs->IDR) ) //These are defined in STM32F1/variants/generic_stm32f103c/variant.h but return a non byte* value
|
|
#else
|
|
#error Incorrect board selected. Please select the correct board (Usually Mega 2560) and upload again
|
|
#endif
|
|
|
|
//Handy bitsetting macros
|
|
#define BIT_SET(a,b) ((a) |= (1<<(b)))
|
|
#define BIT_CLEAR(a,b) ((a) &= ~(1<<(b)))
|
|
#define BIT_CHECK(var,pos) !!((var) & (1<<(pos)))
|
|
|
|
#define MS_IN_MINUTE 60000
|
|
#define US_IN_MINUTE 60000000
|
|
|
|
//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
|
|
#define BIT_ENGINE_ACC 4 // in acceleration mode (TPS accel)
|
|
#define BIT_ENGINE_DCC 5 // in deceleration mode
|
|
#define BIT_ENGINE_MAPACC 6 // MAP acceleration mode
|
|
#define BIT_ENGINE_MAPDCC 7 // MAP decelleration mode
|
|
|
|
//Define masks for Squirt
|
|
#define BIT_SQUIRT_INJ1 0 //inj1 Squirt
|
|
#define BIT_SQUIRT_INJ2 1 //inj2 Squirt
|
|
#define BIT_SQUIRT_INJ3 2 //inj3 Squirt
|
|
#define BIT_SQUIRT_INJ4 3 //inj4 Squirt
|
|
#define BIT_SQUIRT_DFCO 4 //Decelleration fuel cutoff
|
|
#define BIT_SQUIRT_BOOSTCUT 5 //Fuel component of MAP based boost cut out
|
|
#define BIT_SQUIRT_TOOTHLOG1READY 6 //Used to flag if tooth log 1 is ready
|
|
#define BIT_SQUIRT_TOOTHLOG2READY 7 //Used to flag if tooth log 2 is ready (Log is not currently used)
|
|
|
|
//Define masks for spark variable
|
|
#define BIT_SPARK_HLAUNCH 0 //Hard Launch indicator
|
|
#define BIT_SPARK_SLAUNCH 1 //Soft Launch indicator
|
|
#define BIT_SPARK_HRDLIM 2 //Hard limiter indicator
|
|
#define BIT_SPARK_SFTLIM 3 //Soft limiter indicator
|
|
#define BIT_SPARK_BOOSTCUT 4 //Spark component of MAP based boost cut out
|
|
#define BIT_SPARK_ERROR 5 // Error is detected
|
|
#define BIT_SPARK_IDLE 6 // idle on
|
|
#define BIT_SPARK_SYNC 7 // Whether engine has sync or not
|
|
|
|
#define BIT_SPARK2_FLATSH 0 //Flat shift hard cut
|
|
#define BIT_SPARK2_FLATSS 1 //Flat shift soft cut
|
|
#define BIT_SPARK2_UNUSED3 2
|
|
#define BIT_SPARK2_UNUSED4 3
|
|
#define BIT_SPARK2_UNUSED5 4
|
|
#define BIT_SPARK2_UNUSED6 5
|
|
#define BIT_SPARK2_UNUSED7 6
|
|
#define BIT_SPARK2_UNUSED8 7
|
|
|
|
#define VALID_MAP_MAX 1022 //The largest ADC value that is valid for the MAP sensor
|
|
#define VALID_MAP_MIN 2 //The smallest ADC value that is valid for the MAP sensor
|
|
|
|
#define TOOTH_LOG_SIZE 128
|
|
#define TOOTH_LOG_BUFFER 256
|
|
|
|
#define INJ_PAIRED 0
|
|
#define INJ_SEMISEQUENTIAL 1
|
|
#define INJ_BANKED 2
|
|
#define INJ_SEQUENTIAL 3
|
|
|
|
#define IGN_MODE_WASTED 0
|
|
#define IGN_MODE_SINGLE 1
|
|
#define IGN_MODE_WASTEDCOP 2
|
|
#define IGN_MODE_SEQUENTIAL 3
|
|
|
|
#define SIZE_BYTE 8
|
|
#define SIZE_INT 16
|
|
|
|
#define EVEN_FIRE 0
|
|
#define ODD_FIRE 1
|
|
|
|
#define MAX_RPM 18000 //This is the maximum rpm that the ECU will attempt to run at. It is NOT related to the rev limiter, but is instead dictates how fast certain operations will be allowed to run. Lower number gives better performance
|
|
|
|
//Table sizes
|
|
#define CALIBRATION_TABLE_SIZE 512
|
|
#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
|
|
#define OFFSET_FUELTRIM 127 //The fuel trim tables are offset by 128 to allow for -128 to +128 values
|
|
#define OFFSET_IGNITION 40 //Ignition values from the main spark table are offset 40 degrees downards to allow for negative spark timing
|
|
|
|
#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
|
|
|
|
#define FUEL_PUMP_ON() *pump_pin_port |= (pump_pin_mask)
|
|
#define FUEL_PUMP_OFF() *pump_pin_port &= ~(pump_pin_mask)
|
|
|
|
const byte signature = 20;
|
|
|
|
//const char signature[] = "speeduino";
|
|
const char displaySignature[] = "speeduino 201609-dev";
|
|
const char TSfirmwareVersion[] = "Speeduino 2016.09";
|
|
|
|
const byte data_structure_version = 2; //This identifies the data structure when reading / writing.
|
|
const byte page_size = 64;
|
|
const int npage_size[12] = {0,288,64,288,64,288,64,64,160,192,128,192};
|
|
//const byte page11_size = 128;
|
|
#define MAP_PAGE_SIZE 288
|
|
|
|
struct table3D fuelTable; //16x16 fuel map
|
|
struct table3D ignitionTable; //16x16 ignition map
|
|
struct table3D afrTable; //16x16 afr target map
|
|
struct table3D boostTable; //8x8 boost map
|
|
struct table3D vvtTable; //8x8 vvt map
|
|
struct table3D trim1Table; //6x6 Fuel trim 1 map
|
|
struct table3D trim2Table; //6x6 Fuel trim 2 map
|
|
struct table3D trim3Table; //6x6 Fuel trim 3 map
|
|
struct table3D trim4Table; //6x6 Fuel trim 4 map
|
|
struct table2D taeTable; //4 bin TPS Acceleration Enrichment map (2D)
|
|
struct table2D WUETable; //10 bin Warm Up Enrichment map (2D)
|
|
struct table2D crankingEnrichTable; //4 bin cranking Enrichment map (2D)
|
|
struct table2D dwellVCorrectionTable; //6 bin dwell voltage correction (2D)
|
|
struct table2D injectorVCorrectionTable; //6 bin injector voltage correction (2D)
|
|
struct table2D IATDensityCorrectionTable; //9 bin inlet air temperature density correction (2D)
|
|
struct table2D IATRetardTable; //6 bin ignition adjustment based on inlet air temperature (2D)
|
|
|
|
//These are for the direct port manipulation of the injectors and coils
|
|
volatile byte *inj1_pin_port;
|
|
volatile byte inj1_pin_mask;
|
|
volatile byte *inj2_pin_port;
|
|
volatile byte inj2_pin_mask;
|
|
volatile byte *inj3_pin_port;
|
|
volatile byte inj3_pin_mask;
|
|
volatile byte *inj4_pin_port;
|
|
volatile byte inj4_pin_mask;
|
|
volatile byte *inj5_pin_port;
|
|
volatile byte inj5_pin_mask;
|
|
|
|
volatile byte *ign1_pin_port;
|
|
volatile byte ign1_pin_mask;
|
|
volatile byte *ign2_pin_port;
|
|
volatile byte ign2_pin_mask;
|
|
volatile byte *ign3_pin_port;
|
|
volatile byte ign3_pin_mask;
|
|
volatile byte *ign4_pin_port;
|
|
volatile byte ign4_pin_mask;
|
|
volatile byte *ign5_pin_port;
|
|
volatile byte ign5_pin_mask;
|
|
|
|
volatile byte *tach_pin_port;
|
|
volatile byte tach_pin_mask;
|
|
volatile byte *pump_pin_port;
|
|
volatile byte pump_pin_mask;
|
|
|
|
volatile byte *triggerPri_pin_port;
|
|
volatile byte triggerPri_pin_mask;
|
|
volatile byte *triggerSec_pin_port;
|
|
volatile byte triggerSec_pin_mask;
|
|
|
|
//These need to be here as they are used in both speeduino.ino and scheduler.ino
|
|
bool channel1InjEnabled = true;
|
|
bool channel2InjEnabled = false;
|
|
bool channel3InjEnabled = false;
|
|
bool channel4InjEnabled = false;
|
|
bool channel5InjEnabled = false;
|
|
|
|
int ignition1EndAngle = 0;
|
|
int ignition2EndAngle = 0;
|
|
int ignition3EndAngle = 0;
|
|
int ignition4EndAngle = 0;
|
|
|
|
//This is used across multiple files
|
|
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)
|
|
|
|
//The status struct contains the current values for all 'live' variables
|
|
//In current version this is 64 bytes
|
|
struct statuses {
|
|
volatile bool hasSync;
|
|
uint16_t RPM;
|
|
long longRPM;
|
|
int mapADC;
|
|
int baroADC;
|
|
long MAP; //Has to be a long for PID calcs (Boost control)
|
|
byte baro; //Barometric pressure is simply the inital MAP reading, taken before the engine is running. Alternatively, can be taken from an external sensor
|
|
byte TPS; //The current TPS reading (0% - 100%)
|
|
byte TPSlast; //The previous TPS reading
|
|
unsigned long TPS_time; //The time the TPS sample was taken
|
|
unsigned long TPSlast_time; //The time the previous TPS sample was taken
|
|
byte tpsADC; //0-255 byte representation of the TPS
|
|
byte tpsDOT;
|
|
volatile int rpmDOT;
|
|
byte VE;
|
|
byte O2;
|
|
byte O2_2;
|
|
int coolant;
|
|
int cltADC;
|
|
int IAT;
|
|
int iatADC;
|
|
int batADC;
|
|
int O2ADC;
|
|
int O2_2ADC;
|
|
int dwell;
|
|
byte dwellCorrection; //The amount of correction being applied to the dwell time.
|
|
byte battery10; //The current BRV in volts (multiplied by 10. Eg 12.5V = 125)
|
|
int8_t advance; //Signed 8 bit as advance can now go negative (ATDC)
|
|
byte corrections;
|
|
byte TAEamount; //The amount of accleration enrichment currently being applied
|
|
byte egoCorrection; //The amount of closed loop AFR enrichment currently being applied
|
|
byte wueCorrection; //The amount of warmup enrichment currently being applied
|
|
byte batCorrection; //The amount of battery voltage enrichment currently being applied
|
|
byte iatCorrection; //The amount of inlet air temperature adjustment currently being applied
|
|
byte launchCorrection; //The amount of correction being applied if launch control is active
|
|
byte flexCorrection; //Amount of correction being applied to compensate for ethanol content
|
|
byte flexIgnCorrection; //Amount of additional advance being applied based on flex
|
|
byte afrTarget;
|
|
byte idleDuty;
|
|
bool fanOn; //Whether or not the fan is turned on
|
|
volatile byte ethanolPct; //Ethanol reading (if enabled). 0 = No ethanol, 100 = pure ethanol. Eg E85 = 85.
|
|
unsigned long TAEEndTime; //The target end time used whenever TAE is turned on
|
|
volatile byte squirt;
|
|
volatile byte spark;
|
|
volatile byte spark2;
|
|
byte engine;
|
|
unsigned int PW1; //In uS
|
|
unsigned int PW2; //In uS
|
|
unsigned int PW3; //In uS
|
|
unsigned int PW4; //In uS
|
|
volatile byte runSecs; //Counter of seconds since cranking commenced (overflows at 255 obviously)
|
|
volatile byte secl; //Continous
|
|
volatile unsigned int loopsPerSecond;
|
|
boolean launchingSoft; //True when in launch control soft limit mode
|
|
boolean launchingHard; //True when in launch control hard limit mode
|
|
uint16_t freeRAM;
|
|
unsigned int clutchEngagedRPM;
|
|
bool flatShiftingHard;
|
|
volatile uint16_t startRevolutions; //A counter for how many revolutions have been completed since sync was achieved.
|
|
byte boostTarget;
|
|
byte testOutputs;
|
|
bool testActive;
|
|
byte boostDuty;
|
|
byte idleLoad; //Either the current steps or current duty cycle for the idle control.
|
|
uint16_t canin[16]; //16bit raw value of selected canin data for channel 0-15
|
|
uint8_t current_caninchannel = 0; //start off at channel 0
|
|
uint16_t crankRPM = 400; //The actual cranking RPM limit. Saves us multiplying it everytime from the config page
|
|
|
|
//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.
|
|
|
|
};
|
|
struct statuses currentStatus; //The global status object
|
|
|
|
//Page 1 of the config - See the ini file for further reference
|
|
//This mostly covers off variables that are required for fuel
|
|
struct config1 {
|
|
|
|
int8_t flexBoostLow; //Must be signed to allow for negatives
|
|
byte flexBoostHigh;
|
|
byte asePct; //Afterstart enrichment (%)
|
|
byte aseCount; //Afterstart enrichment cycles. This is the number of ignition cycles that the afterstart enrichment % lasts for
|
|
byte wueValues[10]; //Warm up enrichment array (10 bytes)
|
|
byte crankingPct; //Cranking enrichment
|
|
byte pinMapping; // The board / ping mapping to be used
|
|
byte tachoPin : 6; //Custom pin setting for tacho output
|
|
byte tachoDiv : 2; //Whether to change the tacho speed
|
|
byte tdePct; // TPS decelleration (%)
|
|
byte taeColdA;
|
|
byte tpsThresh;
|
|
byte taeTime;
|
|
|
|
//Display config bits
|
|
byte displayType : 3; //21
|
|
byte display1 : 3;
|
|
byte display2 : 2;
|
|
|
|
byte display3 : 3; //22
|
|
byte display4 : 2;
|
|
byte display5 : 3;
|
|
|
|
byte displayB1 : 4; //23
|
|
byte displayB2 : 4;
|
|
|
|
byte reqFuel; //24
|
|
byte divider;
|
|
byte injTiming : 1;
|
|
byte multiplyMAP : 1;
|
|
byte includeAFR : 1;
|
|
byte unused26 : 4;
|
|
byte indInjAng : 1;
|
|
byte injOpen; //Injector opening time (ms * 10)
|
|
uint16_t inj1Ang;
|
|
uint16_t inj2Ang;
|
|
uint16_t inj3Ang;
|
|
uint16_t inj4Ang;
|
|
|
|
//config1 in ini
|
|
byte mapSample : 2;
|
|
byte strokes : 1;
|
|
byte injType : 1;
|
|
byte nCylinders : 4; //Number of cylinders
|
|
|
|
//config2 in ini
|
|
byte cltType1 : 2;
|
|
byte matType1 : 2;
|
|
byte nInjectors : 4; //Number of injectors
|
|
|
|
|
|
//config3 in ini
|
|
byte engineType : 1;
|
|
byte flexEnabled : 1;
|
|
byte algorithm : 1; //"Speed Density", "Alpha-N"
|
|
byte baroCorr : 1;
|
|
byte injLayout : 2;
|
|
byte perToothIgn : 1;
|
|
byte unused2_38h : 1;
|
|
|
|
byte primePulse;
|
|
byte dutyLim;
|
|
byte flexFreqLow; //Lowest valid frequency reading from the flex sensor
|
|
byte flexFreqHigh; //Highest valid frequency reading from the flex sensor
|
|
|
|
byte boostMaxDuty;
|
|
byte tpsMin;
|
|
byte tpsMax;
|
|
int8_t mapMin; //Must be signed
|
|
uint16_t mapMax;
|
|
byte fpPrime; //Time (In seconds) that the fuel pump should be primed for on power up
|
|
byte stoich;
|
|
uint16_t oddfire2; //The ATDC angle of channel 2 for oddfire
|
|
uint16_t oddfire3; //The ATDC angle of channel 3 for oddfire
|
|
uint16_t oddfire4; //The ATDC angle of channel 4 for oddfire
|
|
byte flexFuelLow; //Fuel % to be used for the lowest ethanol reading (Typically 100%)
|
|
byte flexFuelHigh; //Fuel % to be used for the highest ethanol reading (Typically 163%)
|
|
byte flexAdvLow; //Additional advance (in degrees) at lowest ethanol reading (Typically 0)
|
|
byte flexAdvHigh; //Additional advance (in degrees) at highest ethanol reading (Varies, usually 10-20)
|
|
|
|
byte iacCLminDuty;
|
|
byte iacCLmaxDuty;
|
|
byte boostMinDuty;
|
|
|
|
#if defined(CORE_AVR)
|
|
};
|
|
#else
|
|
} __attribute__((__packed__)); //The 32 bi systems require all structs to be fully packed
|
|
#endif
|
|
|
|
//Page 2 of the config - See the ini file for further reference
|
|
//This mostly covers off variables that are required for ignition
|
|
struct config2 {
|
|
|
|
int16_t triggerAngle;
|
|
byte FixAng;
|
|
byte CrankAng;
|
|
byte TrigAngMul; //Multiplier for non evenly divisible tooth counts.
|
|
|
|
byte TrigEdge : 1;
|
|
byte TrigSpeed : 1;
|
|
byte IgInv : 1;
|
|
byte oddfire : 1;
|
|
byte TrigPattern : 4;
|
|
|
|
byte TrigEdgeSec : 1;
|
|
byte fuelPumpPin : 6;
|
|
byte useResync : 1;
|
|
|
|
byte sparkDur; //Spark duration in ms * 10
|
|
byte IdleAdvRPM;
|
|
byte IdleAdvCLT; //The temperature below which the idle is advanced
|
|
byte IdleDelayTime;
|
|
byte StgCycles; //The number of initial cycles before the ignition should fire when first cranking
|
|
|
|
byte dwellCont : 1; //Fixed duty dwell control
|
|
byte useDwellLim : 1; //Whether the dwell limiter is off or on
|
|
byte sparkMode : 2; //Spark output mode (Eg Wasted spark, single channel or Wasted COP)
|
|
byte dfcoEnabled : 1; //Whether or not DFCO is turned on
|
|
byte triggerFilter : 2; //The mode of trigger filter being used (0=Off, 1=Light (Not currently used), 2=Normal, 3=Aggressive)
|
|
byte ignCranklock : 1; //Whether or not the ignition timing during cranking is locked to a CAS pulse. Only currently valid for Basic distributor and 4G63.
|
|
|
|
byte dwellCrank; //Dwell time whilst cranking
|
|
byte dwellRun; //Dwell time whilst running
|
|
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)
|
|
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)
|
|
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)
|
|
byte taeBins[4]; //TPS based acceleration enrichment bins (%/s)
|
|
byte taeValues[4]; //TPS based acceleration enrichment rates (% to add)
|
|
byte wueBins[10]; //Warmup Enrichment bins (Values are in configTable1)
|
|
byte dwellLimit;
|
|
byte dwellCorrectionValues[6]; //Correction table for dwell vs battery voltage
|
|
byte iatRetBins[6]; // Inlet Air Temp timing retard curve bins
|
|
byte iatRetValues[6]; // Inlet Air Temp timing retard curve values
|
|
byte dfcoRPM; //RPM at which DFCO turns off/on at
|
|
byte dfcoHyster; //Hysteris RPM for DFCO
|
|
byte dfcoTPSThresh; //TPS must be below this figure for DFCO to engage
|
|
|
|
byte ignBypassEnabled : 1; //Whether or not the ignition bypass is enabled
|
|
byte ignBypassPin : 6; //Pin the ignition bypass is activated on
|
|
byte ignBypassHiLo : 1; //Whether this should be active high or low.
|
|
|
|
#if defined(CORE_AVR)
|
|
};
|
|
#else
|
|
} __attribute__((__packed__)); //The 32 bi systems require all structs to be fully packed
|
|
#endif
|
|
|
|
//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 boostEnabled : 1;
|
|
byte vvtEnabled : 1;
|
|
byte boostCutType : 2;
|
|
|
|
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 vvtPin : 6;
|
|
byte useExtBaro : 1;
|
|
byte unused6_13f : 1;
|
|
byte boostPin : 6;
|
|
byte unused6_14 : 2;
|
|
byte voltageCorrectionBins[6]; //X axis bins for voltage correction tables
|
|
byte injVoltageCorrectionValues[6]; //Correction table for injector PW vs battery voltage
|
|
byte airDenBins[9];
|
|
byte airDenRates[9];
|
|
byte boostFreq; //Frequency of the boost PWM valve
|
|
byte vvtFreq; //Frequency of the vvt PWM valve
|
|
byte idleFreq;
|
|
|
|
byte launchPin : 6;
|
|
byte launchEnabled : 1;
|
|
byte launchHiLo : 1;
|
|
|
|
byte lnchSoftLim;
|
|
int8_t lnchRetard; //Allow for negative advance value (ATDC)
|
|
byte lnchHardLim;
|
|
byte lnchFuelAdd;
|
|
|
|
//PID values for idle needed to go here as out of room in the idle page
|
|
byte idleKP;
|
|
byte idleKI;
|
|
byte idleKD;
|
|
|
|
byte boostLimit; //Is divided by 2, allowing kPa values up to 511
|
|
byte boostKP;
|
|
byte boostKI;
|
|
byte boostKD;
|
|
|
|
byte lnchPullRes : 2;
|
|
byte fuelTrimEnabled : 1;
|
|
byte flatSEnable : 1;
|
|
byte baroPin : 4;
|
|
byte flatSSoftWin;
|
|
byte flatSRetard;
|
|
byte flatSArm;
|
|
|
|
#if defined(CORE_AVR)
|
|
};
|
|
#else
|
|
} __attribute__((__packed__)); //The 32 bit systems require all structs to be fully packed
|
|
#endif
|
|
|
|
|
|
//Page 4 of the config mostly deals with idle control
|
|
//See ini file for further info (Config Page 7 in the ini)
|
|
struct config4 {
|
|
byte iacCLValues[10]; //Closed loop target RPM value
|
|
byte iacOLStepVal[10]; //Open loop step values for stepper motors
|
|
byte iacOLPWMVal[10]; //Open loop duty values for PMWM valves
|
|
byte iacBins[10]; //Temperature Bins for the above 3 curves
|
|
byte iacCrankSteps[4]; //Steps to use when cranking (Stepper motor)
|
|
byte iacCrankDuty[4]; //Duty cycle to use on PWM valves when cranking
|
|
byte iacCrankBins[4]; //Temperature Bins for the above 2 curves
|
|
|
|
byte iacAlgorithm : 3; //Valid values are: "None", "On/Off", "PWM", "PWM Closed Loop", "Stepper", "Stepper Closed Loop"
|
|
byte iacStepTime : 3; //How long to pulse the stepper for to ensure the step completes (ms)
|
|
byte iacChannels : 1; //How many outputs to use in PWM mode (0 = 1 channel, 1 = 2 channels)
|
|
byte iacPWMdir : 1; //Directino of the PWM valve. 0 = Normal = Higher RPM with more duty. 1 = Reverse = Lower RPM with more duty
|
|
|
|
byte iacFastTemp; //Fast idle temp when using a simple on/off valve
|
|
|
|
byte iacStepHome; //When using a stepper motor, the number of steps to be taken on startup to home the motor
|
|
byte iacStepHyster; //Hysteresis temperature (*10). Eg 2.2C = 22
|
|
|
|
byte fanInv : 1; // Fan output inversion bit
|
|
byte fanEnable : 1; // Fan enable bit. 0=Off, 1=On/Off
|
|
byte fanPin : 5;
|
|
byte fanSP; // Cooling fan start temperature
|
|
byte fanHyster; // Fan hysteresis
|
|
byte fanFreq; // Fan PWM frequency
|
|
byte fanPWMBins[4]; //Temperature Bins for the PWM fan control
|
|
#if defined(CORE_AVR)
|
|
};
|
|
#else
|
|
} __attribute__((__packed__)); //The 32 bit systems require all structs to be fully packed
|
|
#endif
|
|
|
|
//Page 10 of the config mostly deals with CANBUS control
|
|
//See ini file for further info (Config Page 10 in the ini)
|
|
struct config10 {
|
|
byte enable_canbus:2;
|
|
byte enable_candata_in:1;
|
|
uint16_t caninput_sel; //bit status on/off if input is enabled
|
|
uint16_t caninput_param_group[16]; //u16 [15] array holding can address of input
|
|
uint8_t caninput_param_start_byte[16]; //u08 [15] array holds the start byte number(value of 0-7)
|
|
uint16_t caninput_param_num_bytes; //u16 bit status of the number of bytes length 1 or 2
|
|
byte unused10_53;
|
|
byte unused10_54;
|
|
byte enable_candata_out : 1;
|
|
byte canoutput_sel[8];
|
|
uint16_t canoutput_param_group[8];
|
|
uint8_t canoutput_param_start_byte[8];
|
|
byte canoutput_param_num_bytes[8];
|
|
|
|
byte unused10_97;
|
|
byte unused10_98;
|
|
byte unused10_99;
|
|
byte speeduino_tsCanId:4; //speeduino TS canid (0-14)
|
|
uint16_t true_address; //speeduino 11bit can address
|
|
uint16_t realtime_base_address; //speeduino 11 bit realtime base address
|
|
uint16_t obd_address; //speeduino OBD diagnostic address
|
|
byte unused10_107;
|
|
byte unused10_108;
|
|
byte unused10_109;
|
|
byte unused10_110;
|
|
byte unused10_111;
|
|
byte unused10_112;
|
|
byte unused10_113;
|
|
byte unused10_114;
|
|
byte unused10_115;
|
|
byte unused10_116;
|
|
byte unused10_117;
|
|
byte unused10_118;
|
|
byte unused10_119;
|
|
byte unused10_120;
|
|
byte unused10_121;
|
|
byte unused10_122;
|
|
byte unused10_123;
|
|
byte unused10_124;
|
|
byte unused10_125;
|
|
byte unused10_126;
|
|
byte unused10_127;
|
|
#if defined(CORE_AVR)
|
|
};
|
|
#else
|
|
} __attribute__((__packed__)); //The 32 bit systems require all structs to be fully packed
|
|
#endif
|
|
|
|
/*
|
|
Page 11 - No specific purpose. Created initially for the cranking enrich curve
|
|
192 bytes long
|
|
See ini file for further info (Config Page 11 in the ini)
|
|
*/
|
|
struct config11 {
|
|
byte crankingEnrichBins[4];
|
|
byte crankingEnrichValues[4];
|
|
byte unused11_8;
|
|
byte unused11_9;
|
|
byte unused11_10;
|
|
byte unused11_11;
|
|
byte unused11_12;
|
|
byte unused11_13;
|
|
byte unused11_14;
|
|
byte unused11_15;
|
|
byte unused11_16;
|
|
byte unused11_17;
|
|
byte unused11_18;
|
|
byte unused11_19;
|
|
byte unused11_20;
|
|
byte unused10_21;
|
|
byte unused11_22;
|
|
byte unused11_23;
|
|
byte unused11_24;
|
|
byte unused11_25;
|
|
byte unused11_26;
|
|
byte unused11_27;
|
|
byte unused11_28;
|
|
byte unused11_29;
|
|
byte unused11_107;
|
|
byte unused11_108;
|
|
byte unused11_109;
|
|
byte unused11_110;
|
|
byte unused11_111;
|
|
byte unused11_112;
|
|
byte unused11_113;
|
|
byte unused11_114;
|
|
byte unused11_115;
|
|
byte unused11_116;
|
|
byte unused11_117;
|
|
byte unused11_118;
|
|
byte unused11_119;
|
|
byte unused11_120;
|
|
byte unused11_121;
|
|
byte unused11_122;
|
|
byte unused11_123;
|
|
byte unused11_124;
|
|
byte unused11_125;
|
|
byte unused11_126;
|
|
byte unused11_127;
|
|
byte unused11_128_192[64];
|
|
#if defined(CORE_AVR)
|
|
};
|
|
#else
|
|
} __attribute__((__packed__)); //The 32 bit systems require all structs to be fully packed
|
|
#endif
|
|
|
|
|
|
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
|
|
byte pinInjector5; //Output pin injector 5 NOT USED YET
|
|
byte pinInjector6; //Placeholder only - NOT USED
|
|
byte pinInjector7; //Placeholder only - NOT USED
|
|
byte pinInjector8; //Placeholder only - NOT USED
|
|
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 pinCoil5; //Pin for coil 5
|
|
byte pinCoil6; //Pin for coil 6
|
|
byte pinCoil7; //Pin for coil 7
|
|
byte pinCoil8; //Pin for coil 8
|
|
byte pinTrigger; //The CAS pin
|
|
byte pinTrigger2; //The Cam Sensor pin
|
|
byte pinTrigger3; //the 2nd cam sensor pin
|
|
byte pinTPS;//TPS input pin
|
|
byte pinMAP; //MAP sensor pin
|
|
byte pinMAP2; //2nd MAP sensor (Currently unused)
|
|
byte pinIAT; //IAT sensor pin
|
|
byte pinCLT; //CLS sensor pin
|
|
byte pinO2; //O2 Sensor pin
|
|
byte pinO2_2; //second O2 pin
|
|
byte pinBat; //Battery voltage pin
|
|
byte pinDisplayReset; // OLED reset pin
|
|
byte pinTachOut; //Tacho output
|
|
byte pinFuelPump; //Fuel pump on/off
|
|
byte pinIdle1; //Single wire idle control
|
|
byte pinIdle2; //2 wire idle control (Not currently used)
|
|
byte pinSpareTemp1; // Future use only
|
|
byte pinSpareTemp2; // Future use only
|
|
byte pinSpareOut1; //Generic output
|
|
byte pinSpareOut2; //Generic output
|
|
byte pinSpareOut3; //Generic output
|
|
byte pinSpareOut4; //Generic output
|
|
byte pinSpareOut5; //Generic output
|
|
byte pinSpareOut6; //Generic output
|
|
byte pinSpareHOut1; //spare high current output
|
|
byte pinSpareHOut2; // spare high current output
|
|
byte pinSpareLOut1; // spare low current output
|
|
byte pinSpareLOut2; // spare low current output
|
|
byte pinSpareLOut3;
|
|
byte pinSpareLOut4;
|
|
byte pinSpareLOut5;
|
|
byte pinBoost;
|
|
byte pinVVT_1; // vvt output 1
|
|
byte pinVVt_2; // vvt output 2
|
|
byte pinFan; // Cooling fan output
|
|
byte pinStepperDir; //Direction pin for the stepper motor driver
|
|
byte pinStepperStep; //Step pin for the stepper motor driver
|
|
byte pinStepperEnable; //Turning the DRV8825 driver on/off
|
|
byte pinLaunch;
|
|
byte pinIgnBypass; //The pin used for an ignition bypass (Optional)
|
|
byte pinFlex; //Pin with the flex sensor attached
|
|
byte pinBaro; //Pin that an external barometric pressure sensor is attached to (If used)
|
|
|
|
// global variables // from speeduino.ino
|
|
extern struct statuses currentStatus; // from speeduino.ino
|
|
extern struct table3D fuelTable; //16x16 fuel map
|
|
extern struct table3D ignitionTable; //16x16 ignition map
|
|
extern struct table3D afrTable; //16x16 afr target map
|
|
extern struct table2D taeTable; //4 bin TPS Acceleration Enrichment map (2D)
|
|
extern struct table2D WUETable; //10 bin Warm Up Enrichment map (2D)
|
|
extern struct table2D crankingEnrichTable; //4 bin cranking Enrichment map (2D)
|
|
extern struct config1 configPage1;
|
|
extern struct config2 configPage2;
|
|
extern struct config3 configPage3;
|
|
extern struct config10 configPage10;
|
|
extern struct config11 configPage11;
|
|
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];
|
|
|
|
|
|
#endif // GLOBALS_H
|