2018-12-31 13:00:41 -08:00
|
|
|
/*
|
|
|
|
* @file cdm_ion_sense.cpp
|
|
|
|
*
|
2019-05-05 14:21:36 -07:00
|
|
|
* Saab Ion Sensing Module integration
|
|
|
|
*
|
2018-12-31 13:00:41 -08:00
|
|
|
* See https://github.com/rusefi/rusefi_documentation/tree/master/misc/Saab_Trionic_8_Combustion%20Detection%20Module_on_Mazda_Miata_running_rusEfi
|
|
|
|
*
|
|
|
|
* Created on: Dec 31, 2018
|
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2019
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "cdm_ion_sense.h"
|
2019-01-04 20:47:39 -08:00
|
|
|
#include "engine.h"
|
|
|
|
|
|
|
|
CdmState::CdmState() {
|
2019-05-05 15:53:34 -07:00
|
|
|
accumilatingAtRevolution = 0;
|
2019-01-04 20:47:39 -08:00
|
|
|
currentValue = 0;
|
2019-05-05 15:53:34 -07:00
|
|
|
accumulatingCurrentValue = 0;
|
2019-01-04 20:47:39 -08:00
|
|
|
}
|
|
|
|
|
2019-05-05 15:53:34 -07:00
|
|
|
int CdmState::getValue(int currentRevolution) {
|
|
|
|
applyAccumulatedData(currentRevolution);
|
|
|
|
if (currentRevolution == currentValueAtIndex + 1) {
|
|
|
|
// returning total result of previous engine cycle
|
|
|
|
return currentValue;
|
|
|
|
}
|
|
|
|
// we are here if previous engine cycle had no knock events
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CdmState::applyAccumulatedData(int currentRevolution) {
|
|
|
|
if (currentRevolution > accumilatingAtRevolution) {
|
|
|
|
currentValue = accumulatingCurrentValue;
|
|
|
|
currentValueAtIndex = accumilatingAtRevolution;
|
|
|
|
}
|
2019-01-04 20:47:39 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
void CdmState::onNewSignal(int currentRevolution) {
|
2019-05-05 15:53:34 -07:00
|
|
|
if (this->accumilatingAtRevolution == currentRevolution) {
|
|
|
|
accumulatingCurrentValue++;
|
2019-01-04 20:47:39 -08:00
|
|
|
} else {
|
2019-05-05 15:53:34 -07:00
|
|
|
applyAccumulatedData(currentRevolution);
|
|
|
|
// start new accumulation
|
|
|
|
accumilatingAtRevolution = currentRevolution;
|
|
|
|
accumulatingCurrentValue = 1;
|
2019-01-04 20:47:39 -08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-05 14:21:36 -07:00
|
|
|
// above logic compiles unconditionally so that unit tests are happy, but without an instance linker would have nothing to link
|
2019-01-04 20:47:39 -08:00
|
|
|
#if EFI_CDM_INTEGRATION
|
2019-05-05 14:21:36 -07:00
|
|
|
|
2019-01-04 20:47:39 -08:00
|
|
|
#include "digital_input_exti.h"
|
|
|
|
|
|
|
|
EXTERN_ENGINE;
|
2018-12-31 13:00:41 -08:00
|
|
|
|
2019-05-05 14:21:36 -07:00
|
|
|
static CdmState instance;
|
|
|
|
|
2019-05-05 15:53:34 -07:00
|
|
|
int getCurrentCdmValue(int currentRevolution) {
|
|
|
|
return instance.getValue(currentRevolution);
|
|
|
|
}
|
|
|
|
|
2019-01-03 20:51:29 -08:00
|
|
|
#if EFI_TUNER_STUDIO
|
2018-12-31 13:00:41 -08:00
|
|
|
void ionPostState(TunerStudioOutputChannels *tsOutputChannels) {
|
2019-05-05 14:21:36 -07:00
|
|
|
tsOutputChannels->debugIntField1 = instance.totalCdmEvents;
|
2018-12-31 13:00:41 -08:00
|
|
|
}
|
2019-05-05 14:21:36 -07:00
|
|
|
#endif /* EFI_TUNER_STUDIO */
|
2019-01-04 20:47:39 -08:00
|
|
|
|
2019-04-21 06:28:49 -07:00
|
|
|
static void extIonCallback(void *arg) {
|
|
|
|
UNUSED(arg);
|
2019-05-05 14:21:36 -07:00
|
|
|
instance.totalCdmEvents++;
|
2019-01-04 20:47:39 -08:00
|
|
|
|
|
|
|
int currentRevolution = engine->triggerCentral.triggerState.getTotalRevolutionCounter();
|
|
|
|
instance.onNewSignal(currentRevolution);
|
|
|
|
}
|
|
|
|
|
|
|
|
void cdmIonInit(void) {
|
2019-05-05 15:53:34 -07:00
|
|
|
if (CONFIGB(cdmInputPin) == GPIO_UNASSIGNED) {
|
2019-01-04 20:47:39 -08:00
|
|
|
return;
|
|
|
|
}
|
2019-01-09 19:57:33 -08:00
|
|
|
int pin = (int)CONFIGB(cdmInputPin);
|
2019-01-04 20:47:39 -08:00
|
|
|
if (pin <= 0 || pin > (int)GPIO_UNASSIGNED) {
|
|
|
|
// todo: remove this protection once we migrate to new mandatory configuration
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-04-21 06:28:49 -07:00
|
|
|
efiExtiEnablePin("ion", CONFIGB(cdmInputPin), PAL_EVENT_MODE_RISING_EDGE, extIonCallback, NULL);
|
2019-01-04 20:47:39 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* EFI_CDM_INTEGRATION */
|