/** * @file perf_trace.h * */ #pragma once #include #include // Defines different events we want to trace. These can be an interval (begin -> end), or an // instant. Instants can be global, or specific to one thread. You probably don't want to use // each element in PE more than once, as they should each indicate that a specific thing began, // ended, or occurred. enum class PE : uint8_t { // The tag below is consumed by PerfTraceTool.java // enum_start_tag INVALID, ISR, ContextSwitch, OutputPinSetValue, DecodeTriggerEvent, EnginePeriodicFastCallback, EnginePeriodicSlowCallback, EngineStatePeriodicFastCallback, HandleShaftSignal, EventQueueInsertTask, EventQueueExecuteAll, SingleTimerExecutorDoExecute, SingleTimerExecutorScheduleTimerCallback, PeriodicControllerPeriodicTask, PeriodicTimerControllerPeriodicTask, AdcCallbackFast, AdcCallbackSlow, AdcConversionSlow, AdcConversionFast, AdcSubscriptionUpdateSubscribers, GetRunningFuel, GetInjectionDuration, HandleFuel, MainTriggerCallback, OnTriggerEventSparkLogic, ShaftPositionListeners, GetBaseFuel, GetTpsEnrichment, GetSpeedDensityFuel, WallFuelAdjust, MapAveragingTriggerCallback, AdcCallbackFastComplete, SingleTimerExecutorScheduleByTimestamp, ScheduleByAngle, EventQueueExecuteCallback, PwmGeneratorCallback, TunerStudioHandleCrcCommand, PwmConfigTogglePwmState, PwmConfigStateChangeCallback, // enum_end_tag // The tag above is consumed by PerfTraceTool.java // please note that the tool requires a comma at the end of last value }; void perfEventBegin(PE event, uint8_t data); void perfEventEnd(PE event, uint8_t data); void perfEventInstantGlobal(PE event, uint8_t data); inline void perfEventBegin(PE event) { perfEventBegin(event, 0); } inline void perfEventEnd(PE event) { perfEventEnd(event, 0); } inline void perfEventInstantGlobal(PE event) { perfEventInstantGlobal(event, 0); } // Enable one buffer's worth of perf tracing, and retrieve the buffer size in bytes void perfTraceEnable(); struct TraceBufferResult { const uint8_t* const Buffer; const size_t Size; }; // Retrieve the trace buffer const TraceBufferResult perfTraceGetBuffer(); class ScopePerf { public: ScopePerf(PE event) : ScopePerf(event, 0) {} ScopePerf(PE event, uint8_t data) : m_event(event), m_data(data) { #if ENABLE_PERF_TRACE perfEventBegin(event, data); #endif /* ENABLE_PERF_TRACE */ } ~ScopePerf() { #if ENABLE_PERF_TRACE perfEventEnd(m_event, m_data); #endif /* ENABLE_PERF_TRACE */ } private: const PE m_event; const uint8_t m_data; };