1*d9f75844SAndroid Build Coastguard Worker /* 2*d9f75844SAndroid Build Coastguard Worker * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 3*d9f75844SAndroid Build Coastguard Worker * 4*d9f75844SAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license 5*d9f75844SAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source 6*d9f75844SAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found 7*d9f75844SAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may 8*d9f75844SAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree. 9*d9f75844SAndroid Build Coastguard Worker */ 10*d9f75844SAndroid Build Coastguard Worker 11*d9f75844SAndroid Build Coastguard Worker // This file defines the interface for event tracing in WebRTC. 12*d9f75844SAndroid Build Coastguard Worker // 13*d9f75844SAndroid Build Coastguard Worker // Event log handlers are set through SetupEventTracer(). User of this API will 14*d9f75844SAndroid Build Coastguard Worker // provide two function pointers to handle event tracing calls. 15*d9f75844SAndroid Build Coastguard Worker // 16*d9f75844SAndroid Build Coastguard Worker // * GetCategoryEnabledPtr 17*d9f75844SAndroid Build Coastguard Worker // Event tracing system calls this function to determine if a particular 18*d9f75844SAndroid Build Coastguard Worker // event category is enabled. 19*d9f75844SAndroid Build Coastguard Worker // 20*d9f75844SAndroid Build Coastguard Worker // * AddTraceEventPtr 21*d9f75844SAndroid Build Coastguard Worker // Adds a tracing event. It is the user's responsibility to log the data 22*d9f75844SAndroid Build Coastguard Worker // provided. 23*d9f75844SAndroid Build Coastguard Worker // 24*d9f75844SAndroid Build Coastguard Worker // Parameters for the above two functions are described in trace_event.h. 25*d9f75844SAndroid Build Coastguard Worker 26*d9f75844SAndroid Build Coastguard Worker #ifndef RTC_BASE_EVENT_TRACER_H_ 27*d9f75844SAndroid Build Coastguard Worker #define RTC_BASE_EVENT_TRACER_H_ 28*d9f75844SAndroid Build Coastguard Worker 29*d9f75844SAndroid Build Coastguard Worker #include <stdio.h> 30*d9f75844SAndroid Build Coastguard Worker 31*d9f75844SAndroid Build Coastguard Worker #include "absl/strings/string_view.h" 32*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/system/rtc_export.h" 33*d9f75844SAndroid Build Coastguard Worker 34*d9f75844SAndroid Build Coastguard Worker namespace webrtc { 35*d9f75844SAndroid Build Coastguard Worker 36*d9f75844SAndroid Build Coastguard Worker typedef const unsigned char* (*GetCategoryEnabledPtr)(const char* name); 37*d9f75844SAndroid Build Coastguard Worker typedef void (*AddTraceEventPtr)(char phase, 38*d9f75844SAndroid Build Coastguard Worker const unsigned char* category_enabled, 39*d9f75844SAndroid Build Coastguard Worker const char* name, 40*d9f75844SAndroid Build Coastguard Worker unsigned long long id, 41*d9f75844SAndroid Build Coastguard Worker int num_args, 42*d9f75844SAndroid Build Coastguard Worker const char** arg_names, 43*d9f75844SAndroid Build Coastguard Worker const unsigned char* arg_types, 44*d9f75844SAndroid Build Coastguard Worker const unsigned long long* arg_values, 45*d9f75844SAndroid Build Coastguard Worker unsigned char flags); 46*d9f75844SAndroid Build Coastguard Worker 47*d9f75844SAndroid Build Coastguard Worker // User of WebRTC can call this method to setup event tracing. 48*d9f75844SAndroid Build Coastguard Worker // 49*d9f75844SAndroid Build Coastguard Worker // This method must be called before any WebRTC methods. Functions 50*d9f75844SAndroid Build Coastguard Worker // provided should be thread-safe. 51*d9f75844SAndroid Build Coastguard Worker void SetupEventTracer(GetCategoryEnabledPtr get_category_enabled_ptr, 52*d9f75844SAndroid Build Coastguard Worker AddTraceEventPtr add_trace_event_ptr); 53*d9f75844SAndroid Build Coastguard Worker 54*d9f75844SAndroid Build Coastguard Worker // This class defines interface for the event tracing system to call 55*d9f75844SAndroid Build Coastguard Worker // internally. Do not call these methods directly. 56*d9f75844SAndroid Build Coastguard Worker class EventTracer { 57*d9f75844SAndroid Build Coastguard Worker public: 58*d9f75844SAndroid Build Coastguard Worker static const unsigned char* GetCategoryEnabled(const char* name); 59*d9f75844SAndroid Build Coastguard Worker 60*d9f75844SAndroid Build Coastguard Worker static void AddTraceEvent(char phase, 61*d9f75844SAndroid Build Coastguard Worker const unsigned char* category_enabled, 62*d9f75844SAndroid Build Coastguard Worker const char* name, 63*d9f75844SAndroid Build Coastguard Worker unsigned long long id, 64*d9f75844SAndroid Build Coastguard Worker int num_args, 65*d9f75844SAndroid Build Coastguard Worker const char** arg_names, 66*d9f75844SAndroid Build Coastguard Worker const unsigned char* arg_types, 67*d9f75844SAndroid Build Coastguard Worker const unsigned long long* arg_values, 68*d9f75844SAndroid Build Coastguard Worker unsigned char flags); 69*d9f75844SAndroid Build Coastguard Worker }; 70*d9f75844SAndroid Build Coastguard Worker 71*d9f75844SAndroid Build Coastguard Worker } // namespace webrtc 72*d9f75844SAndroid Build Coastguard Worker 73*d9f75844SAndroid Build Coastguard Worker namespace rtc { 74*d9f75844SAndroid Build Coastguard Worker namespace tracing { 75*d9f75844SAndroid Build Coastguard Worker // Set up internal event tracer. 76*d9f75844SAndroid Build Coastguard Worker RTC_EXPORT void SetupInternalTracer(bool enable_all_categories = true); 77*d9f75844SAndroid Build Coastguard Worker RTC_EXPORT bool StartInternalCapture(absl::string_view filename); 78*d9f75844SAndroid Build Coastguard Worker RTC_EXPORT void StartInternalCaptureToFile(FILE* file); 79*d9f75844SAndroid Build Coastguard Worker RTC_EXPORT void StopInternalCapture(); 80*d9f75844SAndroid Build Coastguard Worker // Make sure we run this, this will tear down the internal tracing. 81*d9f75844SAndroid Build Coastguard Worker RTC_EXPORT void ShutdownInternalTracer(); 82*d9f75844SAndroid Build Coastguard Worker } // namespace tracing 83*d9f75844SAndroid Build Coastguard Worker } // namespace rtc 84*d9f75844SAndroid Build Coastguard Worker 85*d9f75844SAndroid Build Coastguard Worker #endif // RTC_BASE_EVENT_TRACER_H_ 86