Startup improvements on Nissan 360 CAS
This commit is contained in:
parent
515cf332f1
commit
e7ac717796
|
@ -1341,7 +1341,7 @@ menuDialog = main
|
||||||
field = "Note: This is the number of revolutions that will be skipped during"
|
field = "Note: This is the number of revolutions that will be skipped during"
|
||||||
field = "cranking before the injectors and coils are fired"
|
field = "cranking before the injectors and coils are fired"
|
||||||
field = "Trigger edge", TrigEdge
|
field = "Trigger edge", TrigEdge
|
||||||
field = "Secondary trigger edge", TrigEdgeSec, { TrigPattern == 0 || TrigPattern == 2 || TrigPattern == 9 } ;Missing tooth, dual wheel and Miata 9905
|
field = "Secondary trigger edge", TrigEdgeSec, { TrigPattern == 0 || TrigPattern == 2 || TrigPattern == 9 || TrigPattern == 12 } ;Missing tooth, dual wheel and Miata 9905
|
||||||
field = "Trigger Filter", TrigFilter
|
field = "Trigger Filter", TrigFilter
|
||||||
field = "Re-sync every cycle", useResync, { TrigPattern == 2 || TrigPattern == 4 || TrigPattern == 7 } ;Dual wheel, 4G63 and Audi 135
|
field = "Re-sync every cycle", useResync, { TrigPattern == 2 || TrigPattern == 4 || TrigPattern == 7 } ;Dual wheel, 4G63 and Audi 135
|
||||||
field = ""
|
field = ""
|
||||||
|
|
|
@ -1767,25 +1767,20 @@ void triggerPri_Nissan360()
|
||||||
toothLastMinusOneToothTime = toothLastToothTime;
|
toothLastMinusOneToothTime = toothLastToothTime;
|
||||||
toothLastToothTime = curTime;
|
toothLastToothTime = curTime;
|
||||||
|
|
||||||
//if ( currentStatus.hasSync == false ) { return; }
|
if ( currentStatus.hasSync == true )
|
||||||
|
|
||||||
if ( toothCurrentCount == 181) //1 complete crank revolution
|
|
||||||
{
|
{
|
||||||
toothOneMinusOneTime = toothOneTime;
|
|
||||||
toothOneTime = curTime;
|
if ( toothCurrentCount == 361 ) //2 complete crank revolutions
|
||||||
currentStatus.startRevolutions++;
|
|
||||||
}
|
|
||||||
else if ( toothCurrentCount == 361 ) //2 complete crank revolutions
|
|
||||||
{
|
{
|
||||||
toothCurrentCount = 1;
|
toothCurrentCount = 1;
|
||||||
toothOneMinusOneTime = toothOneTime;
|
toothOneMinusOneTime = toothOneTime;
|
||||||
toothOneTime = curTime;
|
toothOneTime = curTime;
|
||||||
currentStatus.startRevolutions++; //Counter
|
currentStatus.startRevolutions++; //Counter
|
||||||
}
|
}
|
||||||
|
|
||||||
//Recalc the new filter value
|
//Recalc the new filter value
|
||||||
//setFilter(curGap);
|
//setFilter(curGap);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void triggerSec_Nissan360()
|
void triggerSec_Nissan360()
|
||||||
{
|
{
|
||||||
|
@ -1798,7 +1793,11 @@ void triggerSec_Nissan360()
|
||||||
|
|
||||||
|
|
||||||
//Calculate number of primary teeth that this window has been active for
|
//Calculate number of primary teeth that this window has been active for
|
||||||
if( (secondaryToothCount == 0) || (READ_SEC_TRIGGER() == LOW) ) { secondaryToothCount = toothCurrentCount; } //This occurs on the first rotation upon powerup OR the start of a secondary window
|
byte trigEdge;
|
||||||
|
if(configPage2.TrigEdgeSec == 0) { trigEdge = LOW; }
|
||||||
|
else { trigEdge = HIGH; }
|
||||||
|
|
||||||
|
if( (secondaryToothCount == 0) || (READ_SEC_TRIGGER() == trigEdge) ) { secondaryToothCount = toothCurrentCount; } //This occurs on the first rotation upon powerup OR the start of a secondary window
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
//If we reach here, we are at the end of a secondary window
|
//If we reach here, we are at the end of a secondary window
|
||||||
|
@ -1887,7 +1886,29 @@ void triggerSec_Nissan360()
|
||||||
|
|
||||||
uint16_t getRPM_Nissan360()
|
uint16_t getRPM_Nissan360()
|
||||||
{
|
{
|
||||||
return stdGetRPM();
|
//Can't use stdGetRPM as there is no separate cranking RPM calc (stdGetRPM returns 0 if cranking)
|
||||||
|
uint16_t tempRPM;
|
||||||
|
if( (currentStatus.hasSync == true) && (toothLastToothTime != 0) && (toothLastMinusOneToothTime != 0) )
|
||||||
|
{
|
||||||
|
if(currentStatus.startRevolutions < 2)
|
||||||
|
{
|
||||||
|
noInterrupts();
|
||||||
|
revolutionTime = (toothLastToothTime - toothLastMinusOneToothTime) * 180;
|
||||||
|
interrupts();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
noInterrupts();
|
||||||
|
revolutionTime = (toothOneTime - toothOneMinusOneTime) >> 2; //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)
|
||||||
|
interrupts();
|
||||||
|
}
|
||||||
|
tempRPM = (US_IN_MINUTE / revolutionTime); //Calc RPM based on last full revolution time (Faster as /)
|
||||||
|
if(tempRPM >= MAX_RPM) { tempRPM = currentStatus.RPM; } //Sanity check
|
||||||
|
MAX_STALL_TIME = revolutionTime << 1; //Set the stall time to be twice the current RPM. This is a safe figure as there should be no single revolution where this changes more than this
|
||||||
|
}
|
||||||
|
else { tempRPM = 0; }
|
||||||
|
|
||||||
|
return tempRPM;
|
||||||
}
|
}
|
||||||
|
|
||||||
int getCrankAngle_Nissan360(int timePerDegree)
|
int getCrankAngle_Nissan360(int timePerDegree)
|
||||||
|
@ -1902,6 +1923,10 @@ int getCrankAngle_Nissan360(int timePerDegree)
|
||||||
}
|
}
|
||||||
else { crankAngle = (toothCurrentCount * triggerToothAngle); }
|
else { crankAngle = (toothCurrentCount * triggerToothAngle); }
|
||||||
|
|
||||||
|
if (crankAngle >= 720) { crankAngle -= 720; }
|
||||||
|
if (crankAngle > CRANK_ANGLE_MAX) { crankAngle -= CRANK_ANGLE_MAX; }
|
||||||
|
if (crankAngle < 0) { crankAngle += 360; }
|
||||||
|
|
||||||
return crankAngle;
|
return crankAngle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue