2019-07-07 12:22:46 -07:00
|
|
|
/*
|
|
|
|
* @file tooth_logger.h
|
|
|
|
*
|
|
|
|
* @date Jul 7, 2019
|
|
|
|
* @author Matthew Kennedy
|
|
|
|
*/
|
|
|
|
|
2019-07-06 17:48:58 -07:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <cstdint>
|
|
|
|
#include <cstddef>
|
2020-01-19 19:23:41 -08:00
|
|
|
#include "efitime.h"
|
2019-07-06 17:48:58 -07:00
|
|
|
#include "rusefi_enums.h"
|
2020-04-14 12:17:15 -07:00
|
|
|
#include "engine.h"
|
2019-07-06 17:48:58 -07:00
|
|
|
|
2020-07-19 21:36:10 -07:00
|
|
|
#if EFI_UNIT_TEST
|
|
|
|
#include "logicdata.h"
|
|
|
|
int copyCompositeEvents(CompositeEvent *events);
|
|
|
|
#endif // EFI_UNIT_TEST
|
|
|
|
|
2020-05-26 19:30:53 -07:00
|
|
|
int getCompositeRecordCount();
|
|
|
|
|
|
|
|
void EnableToothLoggerIfNotEnabled();
|
|
|
|
|
2019-07-06 17:48:58 -07:00
|
|
|
// Enable the tooth logger - this clears the buffer starts logging
|
|
|
|
void EnableToothLogger();
|
|
|
|
|
|
|
|
// Stop logging - leave buffer intact
|
|
|
|
void DisableToothLogger();
|
|
|
|
|
|
|
|
// A new tooth has arrived! Log to the buffer if enabled.
|
2020-04-14 12:17:15 -07:00
|
|
|
void LogTriggerTooth(trigger_event_e tooth, efitick_t timestamp DECLARE_ENGINE_PARAMETER_SUFFIX);
|
2019-07-06 17:48:58 -07:00
|
|
|
|
2020-04-19 17:46:29 -07:00
|
|
|
void LogTriggerTopDeadCenter(efitick_t timestamp DECLARE_ENGINE_PARAMETER_SUFFIX);
|
|
|
|
|
2020-05-25 21:07:18 -07:00
|
|
|
void LogTriggerCoilState(efitick_t timestamp, bool state DECLARE_ENGINE_PARAMETER_SUFFIX);
|
|
|
|
|
|
|
|
void LogTriggerInjectorState(efitick_t timestamp, bool state DECLARE_ENGINE_PARAMETER_SUFFIX);
|
|
|
|
|
2019-07-06 17:48:58 -07:00
|
|
|
struct ToothLoggerBuffer
|
|
|
|
{
|
|
|
|
const uint8_t* const Buffer;
|
|
|
|
const size_t Length;
|
|
|
|
};
|
|
|
|
|
|
|
|
// Get a reference to the buffer
|
|
|
|
ToothLoggerBuffer GetToothLoggerBuffer();
|