bundle up MAP samplers
This commit is contained in:
parent
e7ef178c8d
commit
dd02db4c7b
|
@ -54,15 +54,19 @@ static int averagedMapBufIdx = 0;
|
||||||
/**
|
/**
|
||||||
* here we have averaging start and averaging end points for each cylinder
|
* here we have averaging start and averaging end points for each cylinder
|
||||||
*/
|
*/
|
||||||
static scheduling_s startTimers[MAX_CYLINDER_COUNT][2];
|
struct sampler {
|
||||||
static scheduling_s endTimers[MAX_CYLINDER_COUNT][2];
|
scheduling_s startTimer;
|
||||||
|
scheduling_s endTimer;
|
||||||
|
};
|
||||||
|
|
||||||
|
static sampler samplers[MAX_CYLINDER_COUNT][2];
|
||||||
|
|
||||||
#if EFI_ENGINE_CONTROL && EFI_PROD_CODE
|
#if EFI_ENGINE_CONTROL && EFI_PROD_CODE
|
||||||
static void endAveraging(MapAverager* arg);
|
static void endAveraging(MapAverager* arg);
|
||||||
|
|
||||||
static size_t currentMapAverager = 0;
|
static size_t currentMapAverager = 0;
|
||||||
|
|
||||||
static void startAveraging(scheduling_s *endAveragingScheduling) {
|
static void startAveraging(sampler* s) {
|
||||||
efiAssertVoid(ObdCode::CUSTOM_ERR_6649, hasLotsOfRemainingStack(), "lowstck#9");
|
efiAssertVoid(ObdCode::CUSTOM_ERR_6649, hasLotsOfRemainingStack(), "lowstck#9");
|
||||||
|
|
||||||
// TODO: set currentMapAverager based on cylinder bank
|
// TODO: set currentMapAverager based on cylinder bank
|
||||||
|
@ -71,7 +75,7 @@ static void startAveraging(scheduling_s *endAveragingScheduling) {
|
||||||
|
|
||||||
mapAveragingPin.setHigh();
|
mapAveragingPin.setHigh();
|
||||||
|
|
||||||
scheduleByAngle(endAveragingScheduling, getTimeNowNt(), engine->engineState.mapAveragingDuration,
|
scheduleByAngle(&s->endTimer, getTimeNowNt(), engine->engineState.mapAveragingDuration,
|
||||||
{ endAveraging, &averager });
|
{ endAveraging, &averager });
|
||||||
}
|
}
|
||||||
#endif // EFI_ENGINE_CONTROL && EFI_PROD_CODE
|
#endif // EFI_ENGINE_CONTROL && EFI_PROD_CODE
|
||||||
|
@ -259,14 +263,13 @@ void mapAveragingTriggerCallback(
|
||||||
// only if value is already prepared
|
// only if value is already prepared
|
||||||
int structIndex = getRevolutionCounter() % 2;
|
int structIndex = getRevolutionCounter() % 2;
|
||||||
|
|
||||||
scheduling_s *startTimer = &startTimers[i][structIndex];
|
sampler* s = &samplers[i][structIndex];
|
||||||
scheduling_s *endTimer = &endTimers[i][structIndex];
|
|
||||||
|
|
||||||
// at the moment we schedule based on time prediction based on current RPM and angle
|
// at the moment we schedule based on time prediction based on current RPM and angle
|
||||||
// we are loosing precision in case of changing RPM - the further away is the event the worse is precision
|
// we are loosing precision in case of changing RPM - the further away is the event the worse is precision
|
||||||
// todo: schedule this based on closest trigger event, same as ignition works
|
// todo: schedule this based on closest trigger event, same as ignition works
|
||||||
scheduleByAngle(startTimer, edgeTimestamp, samplingStart,
|
scheduleByAngle(&s->startTimer, edgeTimestamp, samplingStart,
|
||||||
{ startAveraging, endTimer });
|
{ startAveraging, s });
|
||||||
}
|
}
|
||||||
#endif // EFI_ENGINE_CONTROL && EFI_PROD_CODE
|
#endif // EFI_ENGINE_CONTROL && EFI_PROD_CODE
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue