2015-07-10 06:01:56 -07:00
|
|
|
/**
|
2015-09-13 12:02:21 -07:00
|
|
|
* @file sensor_chart.cpp
|
2015-07-10 06:01:56 -07:00
|
|
|
*
|
|
|
|
* @date Dec 20, 2013
|
2020-01-13 18:57:43 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2020
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
|
|
|
|
2018-09-16 19:26:57 -07:00
|
|
|
#include "global.h"
|
2019-07-03 18:48:04 -07:00
|
|
|
#include "os_access.h"
|
2019-07-05 17:03:32 -07:00
|
|
|
#include "sensor_chart.h"
|
2015-07-10 06:01:56 -07:00
|
|
|
#include "engine.h"
|
|
|
|
#include "rpm_calculator.h"
|
|
|
|
|
2019-04-12 19:10:57 -07:00
|
|
|
#if EFI_SENSOR_CHART
|
2016-05-28 16:02:28 -07:00
|
|
|
#include "status_loop.h"
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2019-04-12 19:10:57 -07:00
|
|
|
#if EFI_TEXT_LOGGING
|
2020-08-26 20:08:48 -07:00
|
|
|
static char LOGGING_BUFFER[SC_BUFFER_SIZE] CCM_OPTIONAL;
|
2018-09-16 21:00:19 -07:00
|
|
|
static Logging scLogging("analog chart", LOGGING_BUFFER, sizeof(LOGGING_BUFFER));
|
|
|
|
#endif /* EFI_TEXT_LOGGING */
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2016-05-28 16:02:28 -07:00
|
|
|
static int initialized = false;
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2019-01-13 21:09:40 -08:00
|
|
|
EXTERN_ENGINE;
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2021-04-12 11:05:52 -07:00
|
|
|
enum class ScState {
|
|
|
|
PreArm,
|
|
|
|
Armed,
|
|
|
|
Logging,
|
|
|
|
Full
|
|
|
|
};
|
|
|
|
|
|
|
|
static ScState state = ScState::PreArm;
|
|
|
|
static uint32_t lastRevCount = 0;
|
|
|
|
|
2015-07-10 06:01:56 -07:00
|
|
|
void scAddData(float angle, float value) {
|
2019-04-12 19:10:57 -07:00
|
|
|
#if EFI_TEXT_LOGGING
|
2015-07-10 06:01:56 -07:00
|
|
|
if (!initialized) {
|
|
|
|
return; // this is possible because of initialization sequence
|
|
|
|
}
|
|
|
|
|
2021-04-12 11:05:52 -07:00
|
|
|
// Don't log if we need a flush
|
|
|
|
if (state == ScState::Full) {
|
2015-07-10 06:01:56 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2021-04-12 11:05:52 -07:00
|
|
|
auto currentRev = getRevolutionCounter();
|
|
|
|
|
|
|
|
if (state == ScState::PreArm) {
|
|
|
|
// nothing to do - we just need to grab the rev counter once so we can detect a change
|
|
|
|
state = ScState::Armed;
|
|
|
|
} else if (state == ScState::Armed) {
|
|
|
|
// If armed, wait for a NEW revolution to start
|
|
|
|
if (lastRevCount != currentRev) {
|
|
|
|
state = ScState::Logging;
|
|
|
|
|
|
|
|
// Reset logging and append header
|
|
|
|
scLogging.reset();
|
|
|
|
scLogging.appendPrintf( "%s%s", PROTOCOL_ANALOG_CHART, DELIMETER);
|
|
|
|
}
|
|
|
|
} else if (state == ScState::Logging) {
|
|
|
|
// If running and the revolution idx changes, terminate logging and wait for flush
|
|
|
|
if (lastRevCount != currentRev) {
|
|
|
|
state = ScState::Full;
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2021-04-12 11:05:52 -07:00
|
|
|
lastRevCount = currentRev;
|
|
|
|
|
|
|
|
if (state == ScState::Logging) {
|
|
|
|
if (scLogging.remainingSize() > 100) {
|
|
|
|
scLogging.appendPrintf( "%.2f|%.2f|", angle, value);
|
|
|
|
} else {
|
|
|
|
state = ScState::Full;
|
|
|
|
}
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
2018-09-16 21:00:19 -07:00
|
|
|
#endif /* EFI_TEXT_LOGGING */
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
void initSensorChart(void) {
|
2018-01-30 11:53:13 -08:00
|
|
|
#if EFI_SIMULATOR
|
|
|
|
printf("initSensorChart\n");
|
|
|
|
#endif
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
initialized = true;
|
|
|
|
}
|
|
|
|
|
2021-04-12 11:05:52 -07:00
|
|
|
void publishSensorChartIfFull() {
|
|
|
|
if (state != ScState::Full) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
scLogging.appendPrintf(DELIMETER);
|
|
|
|
scheduleLogging(&scLogging);
|
|
|
|
|
|
|
|
state = ScState::Armed;
|
|
|
|
}
|
|
|
|
|
2015-09-13 09:01:42 -07:00
|
|
|
#endif /* EFI_SENSOR_CHART */
|