From f085bbefc452ee1215ac3b09a2eb9d4728f46b20 Mon Sep 17 00:00:00 2001 From: Josh Stewart Date: Tue, 24 Sep 2013 23:31:36 +1000 Subject: [PATCH] Testing only code - Will be removed shortly --- kartduino.ino | 7 ++++--- scheduler.ino | 2 +- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/kartduino.ino b/kartduino.ino index 77de85c6..3f4b41ca 100644 --- a/kartduino.ino +++ b/kartduino.ino @@ -58,7 +58,6 @@ int loopCount; void setup() { - pinMode(pinCoil, OUTPUT); digitalWrite(pinCoil, LOW); @@ -198,6 +197,7 @@ void loop() currentStatus.PW = PW(req_fuel_uS, currentStatus.VE, currentStatus.MAP, 100, engineInjectorDeadTime); //The 100 here is just a placeholder for any enrichment factors (Cold start, acceleration etc). To add 10% extra fuel, this would be 110 //Perform a lookup to get the desired ignition advance byte ignitionAdvance = getTableValue(ignitionTable, currentStatus.MAP, currentStatus.RPM); + ignitionAdvance = 10; //Determine the current crank angle //This is the current angle ATDC the engine is at @@ -208,13 +208,14 @@ void loop() //unsigned long timePerDegree = (toothLastToothTime - toothLastMinusOneToothTime) / triggerToothAngle; //The time (uS) it is currently taking to move 1 degree unsigned long timePerDegree = fastDivide32( (toothLastToothTime - toothLastMinusOneToothTime), triggerToothAngle); //The time (uS) it is currently taking to move 1 degree (fastDivide version) //crankAngle += (micros() - toothLastToothTime) / timePerDegree; //Estimate the number of degrees travelled since the last tooth - crankAngle += fastDivide32( (micros() - toothLastToothTime), timePerDegree); //Estimate the number of degrees travelled since the last tooth (fastDivide version) + //crankAngle += fastDivide32( (micros() - toothLastToothTime), timePerDegree); //Estimate the number of degrees travelled since the last tooth (fastDivide version) //Determine next firing angles //int injectorStartAngle = 355 - (currentStatus.PW / timePerDegree); //This is a bit rough, but is based on the idea that all fuel needs to be delivered before the inlet valve opens. I am using 355 as the point at which the injector MUST be closed by. See http://www.extraefi.co.uk/sequential_fuel.html for more detail //int ignitionStartAngle = 360 - ignitionAdvance - (configPage2.dwellRun / timePerDegree); // 360 - desired advance angle - number of degrees the dwell will take int injectorStartAngle = 355 - ( fastDivide32(currentStatus.PW, timePerDegree) ); //As above, but using fastDivide function int ignitionStartAngle = 360 - ignitionAdvance - (fastDivide32(configPage2.dwellRun, timePerDegree) ); //As above, but using fastDivide function + ignitionStartAngle = 340; //Finally calculate the time (uS) until we reach the firing angles and set the schedules //We only need to set the shcedule if we're BEFORE the open angle @@ -232,7 +233,7 @@ void loop() { setIgnitionSchedule1(beginCoil1Charge, (ignitionStartAngle - crankAngle) * timePerDegree, - configPage2.dwellRun, + (configPage2.dwellRun * 1000), endCoil1Charge ); } diff --git a/scheduler.ino b/scheduler.ino index 224c0860..bb04169c 100644 --- a/scheduler.ino +++ b/scheduler.ino @@ -67,11 +67,11 @@ void setFuelSchedule2(void (*startCallback)(), unsigned long timeout, unsigned l void setIgnitionSchedule1(void (*startCallback)(), unsigned long timeout, unsigned long duration, void(*endCallback)()) { if(ignitionSchedule1.Status == RUNNING) { return; } //Check that we're not already part way through a schedule + if(ignitionSchedule1.Status == PENDING) { return; } //Check that we're not already part way through a schedule //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)) //unsigned int absoluteTimeout = TCNT5 + (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 = TCNT5 + (timeout >> 4); //Divide by 16 (See line above) unsigned int absoluteTimeout = TCNT5 + (timeout >> 4); //As above, but with bit shift instead of / 16 OCR5A = absoluteTimeout; ignitionSchedule1.duration = duration;