xref: /aosp_15_r20/external/webrtc/rtc_base/event_tracer.h (revision d9f758449e529ab9291ac668be2861e7a55c2422)
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