69 lines
1.6 KiB
C++
69 lines
1.6 KiB
C++
/*
|
|
* @file knock_logic.c
|
|
*
|
|
* @date Apr 04, 2021
|
|
* @author Andrey Gusakov
|
|
*/
|
|
|
|
#include "pch.h"
|
|
#include "knock_logic.h"
|
|
#include "os_access.h"
|
|
#include "peak_detect.h"
|
|
|
|
int getCylinderKnockBank(uint8_t cylinderIndex) {
|
|
// C/C++ can't index in to bit fields, we have to provide lookup ourselves
|
|
switch (cylinderIndex) {
|
|
#if EFI_PROD_CODE
|
|
case 0:
|
|
return CONFIG(knockBankCyl1);
|
|
case 1:
|
|
return CONFIG(knockBankCyl2);
|
|
case 2:
|
|
return CONFIG(knockBankCyl3);
|
|
case 3:
|
|
return CONFIG(knockBankCyl4);
|
|
case 4:
|
|
return CONFIG(knockBankCyl5);
|
|
case 5:
|
|
return CONFIG(knockBankCyl6);
|
|
case 6:
|
|
return CONFIG(knockBankCyl7);
|
|
case 7:
|
|
return CONFIG(knockBankCyl8);
|
|
case 8:
|
|
return CONFIG(knockBankCyl9);
|
|
case 9:
|
|
return CONFIG(knockBankCyl10);
|
|
case 10:
|
|
return CONFIG(knockBankCyl11);
|
|
case 11:
|
|
return CONFIG(knockBankCyl12);
|
|
#endif
|
|
default:
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
using PD = PeakDetect<float, MS2NT(100)>;
|
|
static PD peakDetectors[12];
|
|
static PD allCylinderPeakDetector;
|
|
|
|
void onKnockSenseCompleted(uint8_t cylinderIndex, float dbv, efitick_t lastKnockTime) {
|
|
#if EFI_TUNER_STUDIO
|
|
// Pass through per-cylinder peak detector
|
|
float cylPeak = peakDetectors[cylinderIndex].detect(dbv, lastKnockTime);
|
|
tsOutputChannels.knockLevels[cylinderIndex] = roundf(cylPeak);
|
|
|
|
// Pass through all-cylinders peak detector
|
|
tsOutputChannels.knockLevel = allCylinderPeakDetector.detect(dbv, lastKnockTime);
|
|
|
|
// If this was a knock, count it!
|
|
bool isKnock = dbv > ENGINE(engineState).knockThreshold;
|
|
if (isKnock) {
|
|
tsOutputChannels.knockCount++;
|
|
}
|
|
#endif // EFI_TUNER_STUDIO
|
|
|
|
// TODO: retard timing, then put it back!
|
|
}
|