diff --git a/firmware/controllers/algo/signal_executor.c b/firmware/controllers/algo/signal_executor.c index f33cc7a520..1b3af42582 100644 --- a/firmware/controllers/algo/signal_executor.c +++ b/firmware/controllers/algo/signal_executor.c @@ -26,16 +26,14 @@ #include "signal_executor.h" #if EFI_WAVE_CHART +/** + * Signal executors feed digital events right into WaveChart used by Sniffer tab of Dev Console + */ #include "rpm_calculator.h" #endif #if EFI_WAVE_ANALYZER -/** - * Signal executors feed digital events right into WaveChart used by Sniffer tab of Dev Console - */ -#include "wave_analyzer.h" - #endif /* EFI_WAVE_ANALYZER */ #if EFI_PROD_CODE || EFI_SIMULATOR diff --git a/firmware/emulation/wave_analyzer.cpp b/firmware/emulation/wave_analyzer.cpp index 4b46e83bd0..5074b2f913 100644 --- a/firmware/emulation/wave_analyzer.cpp +++ b/firmware/emulation/wave_analyzer.cpp @@ -22,6 +22,7 @@ #include "rfiutil.h" #include "engine_math.h" #include "engine.h" +#include "rpm_calculator.h" extern Engine engine; @@ -61,16 +62,28 @@ static void waAnaWidthCallback(WaveReader *reader) { reader->widthEventTimeUs = nowUs; } -static void waIcuPeriodCallback(WaveReader *reader) { +void WaveReader::onFallEvent() { uint64_t nowUs = getTimeNowUs(); - reader->eventCounter++; - reader->lastActivityTimeUs = nowUs; - addWaveChartEvent(reader->name, WC_DOWN, ""); + eventCounter++; + lastActivityTimeUs = nowUs; + addWaveChartEvent(name, WC_DOWN, ""); - uint64_t width = nowUs - reader->widthEventTimeUs; - reader->last_wave_high_widthUs = width; + uint64_t width = nowUs - widthEventTimeUs; + last_wave_high_widthUs = width; - reader->periodEventTimeUs = nowUs; + int revolutionCounter = getRevolutionCounter(); + + totalOnTimeAccumulatorUs += width; + if (currentRevolutionCounter != revolutionCounter) { + /** + * We are here in case of a new engine cycle + */ + currentRevolutionCounter = revolutionCounter; + prevTotalOnTimeUs = totalOnTimeAccumulatorUs; + totalOnTimeAccumulatorUs = 0; + } + + periodEventTimeUs = nowUs; //scheduleSimpleMsg(&irqLogging, "co", reader->chart.counter); @@ -86,10 +99,15 @@ static void waIcuPeriodCallback(WaveReader *reader) { */ offset -= period; } - reader->waveOffsetUs = offset; + waveOffsetUs = offset; // we want only the low phase length, so we subsctract high width from period // processSignal(1, &dataPinReader, last_period - last_adc_response_width); + +} + +static void waIcuPeriodCallback(WaveReader *reader) { + reader->onFallEvent(); } static void setWaveModeSilent(int index, int mode) { @@ -98,18 +116,7 @@ static void setWaveModeSilent(int index, int mode) { setWaveReaderMode(&reader->hw, mode); } -//void setWaveMode(int index, int mode) { -// setWaveModeSilent(index, mode); -// print("wavemode%d:%d\r\n", index, mode); -//} - -int getWaveMode(int index) { - WaveReader *reader = &readers[index]; - ensureInitialized(reader); - return reader->hw.activeMode; -} - -int getEventCounter(int index) { +static int getEventCounter(int index) { WaveReader *reader = &readers[index]; ensureInitialized(reader); return reader->eventCounter; @@ -142,14 +149,6 @@ static void initWave(const char *name, int index) { } #endif -//int getCrankStart() { -// return previousCrankSignalStart; -//} - -//static int getCrankPeriod(void) { -// return ckpPeriod; -//} - static void onWaveShaftSignal(trigger_event_e ckpSignalType, int index, void *arg) { if (index != 0) { return; @@ -177,13 +176,13 @@ static msg_t waThread(void *arg) { #endif } -uint32_t getWaveLowWidth(int index) { +static uint32_t getWaveLowWidth(int index) { WaveReader *reader = &readers[index]; ensureInitialized(reader); return reader->last_wave_low_widthUs; } -static float getWaveHighWidthMs(int index) { +static float getSignalOnTime(int index) { WaveReader *reader = &readers[index]; ensureInitialized(reader); if (getTimeNowUs() - reader->lastActivityTimeUs > 4 * US_PER_SECOND) { @@ -192,19 +191,19 @@ static float getWaveHighWidthMs(int index) { return reader->last_wave_high_widthUs / 1000.0f; } -uint64_t getWaveOffset(int index) { +static uint64_t getWaveOffset(int index) { WaveReader *reader = &readers[index]; ensureInitialized(reader); return reader->waveOffsetUs; } -float getSignalPeriodMs(int index) { +static float getSignalPeriodMs(int index) { WaveReader *reader = &readers[index]; ensureInitialized(reader); return reader->signalPeriodUs / 1000.0f; } -uint64_t getWidthEventTime(int index) { +static uint64_t getWidthEventTime(int index) { WaveReader *reader = &readers[index]; ensureInitialized(reader); return reader->widthEventTimeUs; @@ -214,17 +213,25 @@ static void reportWave(Logging *logging, int index) { // int counter = getEventCounter(index); // debugInt2(logging, "ev", index, counter); - float dwellMs = getWaveHighWidthMs(index); + float dwellMs = getSignalOnTime(index); float periodMs = getSignalPeriodMs(index); appendPrintf(logging, "duty%d%s", index, DELIMETER); appendFloat(logging, 100.0f * dwellMs / periodMs, 2); appendPrintf(logging, "%s", DELIMETER); + /** + * that's the ON time of the LAST signal + */ appendPrintf(logging, "dwell%d%s", index, DELIMETER); appendFloat(logging, dwellMs, 2); appendPrintf(logging, "%s", DELIMETER); + appendPrintf(logging, "total_dwell%d%s", index, DELIMETER); + appendFloat(logging, readers[index].prevTotalOnTimeUs / 1000.0f, 2); + appendPrintf(logging, "%s", DELIMETER); + + appendPrintf(logging, "period%d%s", index, DELIMETER); appendFloat(logging, periodMs, 2); appendPrintf(logging, "%s", DELIMETER); diff --git a/firmware/emulation/wave_analyzer.h b/firmware/emulation/wave_analyzer.h index 620cd20213..a8a56af2b6 100644 --- a/firmware/emulation/wave_analyzer.h +++ b/firmware/emulation/wave_analyzer.h @@ -20,11 +20,23 @@ #define WA_CHANNEL_3 "input3" #define WA_CHANNEL_4 "input4" -typedef struct { +class WaveReader { +public: + void onFallEvent(); + WaveReaderHw hw; const char *name; volatile int eventCounter; + int currentRevolutionCounter; + + /** + * Total ON time during last engine cycle + */ + uint64_t prevTotalOnTimeUs; + + uint64_t totalOnTimeAccumulatorUs; + volatile uint64_t lastActivityTimeUs; // timestamp in microseconds ticks /** * time of signal fall event, in microseconds @@ -37,34 +49,10 @@ typedef struct { volatile uint64_t waveOffsetUs; // offset from CKP signal in systimer ticks volatile uint32_t last_wave_low_widthUs; // time period in systimer ticks volatile uint64_t last_wave_high_widthUs; // time period in systimer ticks -} WaveReader; - -#ifdef __cplusplus -extern "C" -{ -#endif /* __cplusplus */ +}; void initWaveAnalyzer(void); -void pokeWaveInfo(void); -void reportWaveInfo(void); -uint32_t getWaveLowWidth(int index); -uint64_t getWaveOffset(int index); - -int getWaveMode(int index); - -int getEventCounter(int index); - -float getSignalPeriodMs(int index); -uint64_t getWidthEventTime(int index); -uint64_t getPeriodEventTime(int index); - -//int getCrankStart(); -//int getCrankPeriod(); - void printWave(Logging *logging); -#ifdef __cplusplus -} -#endif /* __cplusplus */ - #endif /* WAVE_ANALYZER_H_ */ +