| OLD | NEW |
| (Empty) |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #ifndef CONTENT_BROWSER_TRACE_CONTROLLER_H_ | |
| 6 #define CONTENT_BROWSER_TRACE_CONTROLLER_H_ | |
| 7 | |
| 8 #include <set> | |
| 9 #include <string> | |
| 10 #include <vector> | |
| 11 | |
| 12 #include "base/debug/trace_event.h" | |
| 13 #include "base/memory/ref_counted_memory.h" | |
| 14 #include "base/memory/singleton.h" | |
| 15 #include "content/common/content_export.h" | |
| 16 | |
| 17 class CommandLine; | |
| 18 class TraceMessageFilter; | |
| 19 | |
| 20 // Objects interested in receiving trace data derive from TraceSubscriber. | |
| 21 // See also: trace_message_filter.h | |
| 22 // See also: child_trace_message_filter.h | |
| 23 class CONTENT_EXPORT TraceSubscriber { | |
| 24 public: | |
| 25 // Called once after TraceController::EndTracingAsync. | |
| 26 virtual void OnEndTracingComplete() = 0; | |
| 27 // Called 0 or more times between TraceController::BeginTracing and | |
| 28 // OnEndTracingComplete. Use base::debug::TraceResultBuffer to convert one or | |
| 29 // more trace fragments to JSON. | |
| 30 virtual void OnTraceDataCollected( | |
| 31 const scoped_refptr<base::RefCountedString>& trace_fragment) = 0; | |
| 32 // Called once after TraceController::GetKnownCategoriesAsync. | |
| 33 virtual void OnKnownCategoriesCollected( | |
| 34 const std::set<std::string>& known_categories); | |
| 35 virtual void OnTraceBufferPercentFullReply(float percent_full); | |
| 36 | |
| 37 protected: | |
| 38 virtual ~TraceSubscriber(); | |
| 39 }; | |
| 40 | |
| 41 // TraceController is used on the browser processes to enable/disable | |
| 42 // trace status and collect trace data. Only the browser UI thread is allowed | |
| 43 // to interact with the TraceController object. All calls on the TraceSubscriber | |
| 44 // happen on the UI thread. | |
| 45 class CONTENT_EXPORT TraceController { | |
| 46 public: | |
| 47 static TraceController* GetInstance(); | |
| 48 | |
| 49 // Called on the main thread of the browser process to initialize | |
| 50 // startup tracing. | |
| 51 void InitStartupTracing(const CommandLine& command_line); | |
| 52 | |
| 53 // Get set of known categories. This can change as new code paths are reached. | |
| 54 // If true is returned, subscriber->OnKnownCategoriesCollected will be called | |
| 55 // when once the categories are retrieved from child processes. | |
| 56 bool GetKnownCategoriesAsync(TraceSubscriber* subscriber); | |
| 57 | |
| 58 // Called by browser process to start tracing events on all processes. | |
| 59 // | |
| 60 // Currently only one subscriber is allowed at a time. | |
| 61 // Tracing begins immediately locally, and asynchronously on child processes | |
| 62 // as soon as they receive the BeginTracing request. | |
| 63 // By default, all categories are traced except those matching "test_*". | |
| 64 // | |
| 65 // If BeginTracing was already called previously, | |
| 66 // or if an EndTracingAsync is pending, | |
| 67 // or if another subscriber is tracing, | |
| 68 // BeginTracing will return false meaning it failed. | |
| 69 bool BeginTracing(TraceSubscriber* subscriber); | |
| 70 | |
| 71 // Same as above, but specifies which categories to trace. | |
| 72 // If both included_categories and excluded_categories are empty, | |
| 73 // all categories are traced. | |
| 74 // Else if included_categories is non-empty, only those are traced. | |
| 75 // Else if excluded_categories is non-empty, everything but those are traced. | |
| 76 bool BeginTracing(TraceSubscriber* subscriber, | |
| 77 const std::vector<std::string>& included_categories, | |
| 78 const std::vector<std::string>& excluded_categories); | |
| 79 | |
| 80 // |categories| is a comma-delimited list of category wildcards. | |
| 81 // A category can have an optional '-' prefix to make it an excluded category. | |
| 82 // All the same rules apply above, so for example, having both included and | |
| 83 // excluded categories in the same list would not be supported. | |
| 84 // | |
| 85 // Example: BeginTracing("test_MyTest*"); | |
| 86 // Example: BeginTracing("test_MyTest*,test_OtherStuff"); | |
| 87 // Example: BeginTracing("-excluded_category1,-excluded_category2"); | |
| 88 bool BeginTracing(TraceSubscriber* subscriber, const std::string& categories); | |
| 89 | |
| 90 // Called by browser process to stop tracing events on all processes. | |
| 91 // | |
| 92 // Child processes typically are caching trace data and only rarely flush | |
| 93 // and send trace data back to the browser process. That is because it may be | |
| 94 // an expensive operation to send the trace data over IPC, and we would like | |
| 95 // to avoid much runtime overhead of tracing. So, to end tracing, we must | |
| 96 // asynchronously ask all child processes to flush any pending trace data. | |
| 97 // | |
| 98 // Once all child processes have acked the EndTracing request, | |
| 99 // TraceSubscriber will be called with OnEndTracingComplete. | |
| 100 // | |
| 101 // If a previous call to EndTracingAsync is already pending, | |
| 102 // or if another subscriber is tracing, | |
| 103 // EndTracingAsync will return false meaning it failed. | |
| 104 bool EndTracingAsync(TraceSubscriber* subscriber); | |
| 105 | |
| 106 // Get the maximum across processes of trace buffer percent full state. | |
| 107 // When the TraceBufferPercentFull value is determined, | |
| 108 // subscriber->OnTraceBufferPercentFullReply is called. | |
| 109 // When any child process reaches 100% full, the TraceController will end | |
| 110 // tracing, and call TraceSubscriber::OnEndTracingComplete. | |
| 111 // GetTraceBufferPercentFullAsync fails in the following conditions: | |
| 112 // trace is ending or disabled; | |
| 113 // a previous call to GetTraceBufferPercentFullAsync is pending; or | |
| 114 // the caller is not the current subscriber. | |
| 115 bool GetTraceBufferPercentFullAsync(TraceSubscriber* subscriber); | |
| 116 | |
| 117 // Cancel the subscriber so that it will not be called when EndTracingAsync is | |
| 118 // acked by all child processes. This will also call EndTracingAsync | |
| 119 // internally if necessary. | |
| 120 // Safe to call even if caller is not the current subscriber. | |
| 121 void CancelSubscriber(TraceSubscriber* subscriber); | |
| 122 | |
| 123 private: | |
| 124 typedef std::set<scoped_refptr<TraceMessageFilter> > FilterMap; | |
| 125 | |
| 126 friend struct DefaultSingletonTraits<TraceController>; | |
| 127 friend class TraceMessageFilter; | |
| 128 | |
| 129 TraceController(); | |
| 130 ~TraceController(); | |
| 131 | |
| 132 bool is_tracing_enabled() const { | |
| 133 return can_end_tracing(); | |
| 134 } | |
| 135 | |
| 136 bool can_end_tracing() const { | |
| 137 return is_tracing_ && pending_end_ack_count_ == 0; | |
| 138 } | |
| 139 | |
| 140 // Can get Buffer Percent Full | |
| 141 bool can_get_buffer_percent_full() const { | |
| 142 return is_tracing_ && | |
| 143 pending_end_ack_count_ == 0 && | |
| 144 pending_bpf_ack_count_ == 0; | |
| 145 } | |
| 146 | |
| 147 bool can_begin_tracing(TraceSubscriber* subscriber) const { | |
| 148 return !is_tracing_ && | |
| 149 (subscriber_ == NULL || subscriber == subscriber_); | |
| 150 } | |
| 151 | |
| 152 // Methods for use by TraceMessageFilter. | |
| 153 | |
| 154 void AddFilter(TraceMessageFilter* filter); | |
| 155 void RemoveFilter(TraceMessageFilter* filter); | |
| 156 void OnTracingBegan(TraceSubscriber* subscriber); | |
| 157 void OnEndTracingAck(const std::vector<std::string>& known_categories); | |
| 158 void OnTraceDataCollected( | |
| 159 const scoped_refptr<base::RefCountedString>& events_str_ptr); | |
| 160 void OnTraceBufferFull(); | |
| 161 void OnTraceBufferPercentFullReply(float percent_full); | |
| 162 | |
| 163 FilterMap filters_; | |
| 164 TraceSubscriber* subscriber_; | |
| 165 // Pending acks for EndTracingAsync: | |
| 166 int pending_end_ack_count_; | |
| 167 // Pending acks for GetTraceBufferPercentFullAsync: | |
| 168 int pending_bpf_ack_count_; | |
| 169 float maximum_bpf_; | |
| 170 bool is_tracing_; | |
| 171 bool is_get_categories_; | |
| 172 std::set<std::string> known_categories_; | |
| 173 std::vector<std::string> included_categories_; | |
| 174 std::vector<std::string> excluded_categories_; | |
| 175 | |
| 176 DISALLOW_COPY_AND_ASSIGN(TraceController); | |
| 177 }; | |
| 178 | |
| 179 #endif // CONTENT_BROWSER_TRACE_CONTROLLER_H_ | |
| 180 | |
| OLD | NEW |