Injection/Ignition angle inaccuracy on 60-2? EngineSniffer vs Real Hardware #778
first steps of scheduling metric
This commit is contained in:
parent
af7b39154a
commit
8cbac692ad
|
@ -184,13 +184,17 @@ public:
|
|||
angle_t mapAveragingStart[INJECTION_PIN_COUNT];
|
||||
angle_t mapAveragingDuration = 0;
|
||||
|
||||
// spark-related
|
||||
floatms_t sparkDwell = 0;
|
||||
angle_t timingAdvance = 0;
|
||||
|
||||
// spark-related
|
||||
/**
|
||||
* ignition dwell duration in ms
|
||||
* See also dwellAngle
|
||||
*/
|
||||
floatms_t sparkDwell = 0;
|
||||
/**
|
||||
* ignition dwell duration as crankshaft angle
|
||||
* NAN if engine is stopped
|
||||
* See also sparkDwell
|
||||
*/
|
||||
angle_t dwellAngle = NAN;
|
||||
|
||||
|
|
|
@ -41,6 +41,7 @@ public:
|
|||
scheduling_s signalTimerUp;
|
||||
scheduling_s signalTimerDown;
|
||||
angle_t advance;
|
||||
floatms_t sparkDwell;
|
||||
event_trigger_position_s dwellPosition;
|
||||
event_trigger_position_s sparkPosition;
|
||||
IgnitionEvent *next;
|
||||
|
|
|
@ -65,9 +65,12 @@ static void fireSparkBySettingPinLow(IgnitionEvent *event, IgnitionOutputPin *ou
|
|||
} \
|
||||
}
|
||||
|
||||
static void prepareCylinderIgnitionSchedule(angle_t dwellAngle, IgnitionEvent *event DECLARE_ENGINE_PARAMETER_SUFFIX) {
|
||||
static void prepareCylinderIgnitionSchedule(angle_t dwellAngle, floatms_t sparkDwell, IgnitionEvent *event DECLARE_ENGINE_PARAMETER_SUFFIX) {
|
||||
// todo: clean up this implementation? does not look too nice as is.
|
||||
|
||||
// let's save planned duration so that we can later compare it with reality
|
||||
event->sparkDwell = sparkDwell;
|
||||
|
||||
// change of sign here from 'before TDC' to 'after TDC'
|
||||
angle_t ignitionPositionWithinEngineCycle = ENGINE(ignitionPositionWithinEngineCycle[event->cylinderIndex]);
|
||||
assertAngleRange(ignitionPositionWithinEngineCycle, "aPWEC", CUSTOM_ERR_6566);
|
||||
|
@ -121,11 +124,12 @@ void fireSparkAndPrepareNextSchedule(IgnitionEvent *event) {
|
|||
// now that we've just fired a coil let's prepare the new schedule for the next engine revolution
|
||||
|
||||
angle_t dwellAngle = ENGINE(engineState.dwellAngle);
|
||||
if (cisnan(dwellAngle)) {
|
||||
floatms_t sparkDwell = ENGINE(engineState.sparkDwell);
|
||||
if (cisnan(dwellAngle) || cisnan(sparkDwell)) {
|
||||
// we are here if engine has just stopped
|
||||
return;
|
||||
}
|
||||
prepareCylinderIgnitionSchedule(dwellAngle, event PASS_ENGINE_PARAMETER_SUFFIX);
|
||||
prepareCylinderIgnitionSchedule(dwellAngle, sparkDwell, event PASS_ENGINE_PARAMETER_SUFFIX);
|
||||
}
|
||||
|
||||
static void startDwellByTurningSparkPinHigh(IgnitionEvent *event, IgnitionOutputPin *output) {
|
||||
|
@ -283,6 +287,7 @@ static ALWAYS_INLINE void handleSparkEvent(bool limitedSpark, uint32_t trgEventI
|
|||
|
||||
static void initializeIgnitionActions(IgnitionEventList *list DECLARE_ENGINE_PARAMETER_SUFFIX) {
|
||||
angle_t dwellAngle = ENGINE(engineState.dwellAngle);
|
||||
floatms_t sparkDwell = ENGINE(engineState.sparkDwell);
|
||||
if (cisnan(ENGINE(engineState.timingAdvance)) || cisnan(dwellAngle)) {
|
||||
// error should already be reported
|
||||
// need to invalidate previous ignition schedule
|
||||
|
@ -296,7 +301,7 @@ static void initializeIgnitionActions(IgnitionEventList *list DECLARE_ENGINE_PAR
|
|||
#if EFI_UNIT_TEST
|
||||
list->elements[cylinderIndex].engine = engine;
|
||||
#endif /* EFI_UNIT_TEST */
|
||||
prepareCylinderIgnitionSchedule(dwellAngle, &list->elements[cylinderIndex] PASS_ENGINE_PARAMETER_SUFFIX);
|
||||
prepareCylinderIgnitionSchedule(dwellAngle, sparkDwell, &list->elements[cylinderIndex] PASS_ENGINE_PARAMETER_SUFFIX);
|
||||
}
|
||||
list->isReady = true;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue