| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef CONTENT_BROWSER_TRACE_CONTROLLER_H_ | 5 #ifndef CONTENT_BROWSER_TRACE_CONTROLLER_IMPL_H_ |
| 6 #define CONTENT_BROWSER_TRACE_CONTROLLER_H_ | 6 #define CONTENT_BROWSER_TRACE_CONTROLLER_IMPL_H_ |
| 7 | 7 |
| 8 #include <set> | 8 #include <set> |
| 9 #include <string> | 9 #include <string> |
| 10 #include <vector> | 10 #include <vector> |
| 11 | 11 |
| 12 #include "base/debug/trace_event.h" | 12 #include "base/debug/trace_event.h" |
| 13 #include "base/memory/ref_counted_memory.h" | |
| 14 #include "base/memory/singleton.h" | 13 #include "base/memory/singleton.h" |
| 15 #include "content/common/content_export.h" | 14 #include "content/public/browser/trace_controller.h" |
| 16 | 15 |
| 17 class CommandLine; | 16 class CommandLine; |
| 18 class TraceMessageFilter; | 17 class TraceMessageFilter; |
| 19 | 18 |
| 20 // Objects interested in receiving trace data derive from TraceSubscriber. | 19 namespace content { |
| 21 // See also: trace_message_filter.h | 20 |
| 22 // See also: child_trace_message_filter.h | 21 class TraceControllerImpl : public TraceController { |
| 23 class CONTENT_EXPORT TraceSubscriber { | |
| 24 public: | 22 public: |
| 25 // Called once after TraceController::EndTracingAsync. | 23 static TraceControllerImpl* GetInstance(); |
| 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 | 24 |
| 49 // Called on the main thread of the browser process to initialize | 25 // Called on the main thread of the browser process to initialize |
| 50 // startup tracing. | 26 // startup tracing. |
| 51 void InitStartupTracing(const CommandLine& command_line); | 27 void InitStartupTracing(const CommandLine& command_line); |
| 52 | 28 |
| 53 // Get set of known categories. This can change as new code paths are reached. | 29 // Get set of known categories. This can change as new code paths are reached. |
| 54 // If true is returned, subscriber->OnKnownCategoriesCollected will be called | 30 // If true is returned, subscriber->OnKnownCategoriesCollected will be called |
| 55 // when once the categories are retrieved from child processes. | 31 // when once the categories are retrieved from child processes. |
| 56 bool GetKnownCategoriesAsync(TraceSubscriber* subscriber); | 32 bool GetKnownCategoriesAsync(TraceSubscriber* subscriber); |
| 57 | 33 |
| 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. | 34 // Same as above, but specifies which categories to trace. |
| 72 // If both included_categories and excluded_categories are empty, | 35 // If both included_categories and excluded_categories are empty, |
| 73 // all categories are traced. | 36 // all categories are traced. |
| 74 // Else if included_categories is non-empty, only those are traced. | 37 // Else if included_categories is non-empty, only those are traced. |
| 75 // Else if excluded_categories is non-empty, everything but those are traced. | 38 // Else if excluded_categories is non-empty, everything but those are traced. |
| 76 bool BeginTracing(TraceSubscriber* subscriber, | 39 bool BeginTracing(TraceSubscriber* subscriber, |
| 77 const std::vector<std::string>& included_categories, | 40 const std::vector<std::string>& included_categories, |
| 78 const std::vector<std::string>& excluded_categories); | 41 const std::vector<std::string>& excluded_categories); |
| 79 | 42 |
| 80 // |categories| is a comma-delimited list of category wildcards. | 43 // TraceController implementation: |
| 81 // A category can have an optional '-' prefix to make it an excluded category. | 44 virtual bool BeginTracing(TraceSubscriber* subscriber) OVERRIDE; |
| 82 // All the same rules apply above, so for example, having both included and | 45 virtual bool BeginTracing(TraceSubscriber* subscriber, |
| 83 // excluded categories in the same list would not be supported. | 46 const std::string& categories) OVERRIDE; |
| 84 // | 47 virtual bool EndTracingAsync(TraceSubscriber* subscriber) OVERRIDE; |
| 85 // Example: BeginTracing("test_MyTest*"); | 48 virtual bool GetTraceBufferPercentFullAsync( |
| 86 // Example: BeginTracing("test_MyTest*,test_OtherStuff"); | 49 TraceSubscriber* subscriber) OVERRIDE; |
| 87 // Example: BeginTracing("-excluded_category1,-excluded_category2"); | 50 virtual void CancelSubscriber(TraceSubscriber* subscriber) OVERRIDE; |
| 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 | 51 |
| 123 private: | 52 private: |
| 124 typedef std::set<scoped_refptr<TraceMessageFilter> > FilterMap; | 53 typedef std::set<scoped_refptr<TraceMessageFilter> > FilterMap; |
| 125 | 54 |
| 126 friend struct DefaultSingletonTraits<TraceController>; | 55 friend struct DefaultSingletonTraits<TraceControllerImpl>; |
| 127 friend class TraceMessageFilter; | 56 friend class ::TraceMessageFilter; |
| 128 | 57 |
| 129 TraceController(); | 58 TraceControllerImpl(); |
| 130 ~TraceController(); | 59 virtual ~TraceControllerImpl(); |
| 131 | 60 |
| 132 bool is_tracing_enabled() const { | 61 bool is_tracing_enabled() const { |
| 133 return can_end_tracing(); | 62 return can_end_tracing(); |
| 134 } | 63 } |
| 135 | 64 |
| 136 bool can_end_tracing() const { | 65 bool can_end_tracing() const { |
| 137 return is_tracing_ && pending_end_ack_count_ == 0; | 66 return is_tracing_ && pending_end_ack_count_ == 0; |
| 138 } | 67 } |
| 139 | 68 |
| 140 // Can get Buffer Percent Full | 69 // Can get Buffer Percent Full |
| (...skipping 25 matching lines...) Expand all Loading... |
| 166 int pending_end_ack_count_; | 95 int pending_end_ack_count_; |
| 167 // Pending acks for GetTraceBufferPercentFullAsync: | 96 // Pending acks for GetTraceBufferPercentFullAsync: |
| 168 int pending_bpf_ack_count_; | 97 int pending_bpf_ack_count_; |
| 169 float maximum_bpf_; | 98 float maximum_bpf_; |
| 170 bool is_tracing_; | 99 bool is_tracing_; |
| 171 bool is_get_categories_; | 100 bool is_get_categories_; |
| 172 std::set<std::string> known_categories_; | 101 std::set<std::string> known_categories_; |
| 173 std::vector<std::string> included_categories_; | 102 std::vector<std::string> included_categories_; |
| 174 std::vector<std::string> excluded_categories_; | 103 std::vector<std::string> excluded_categories_; |
| 175 | 104 |
| 176 DISALLOW_COPY_AND_ASSIGN(TraceController); | 105 DISALLOW_COPY_AND_ASSIGN(TraceControllerImpl); |
| 177 }; | 106 }; |
| 178 | 107 |
| 179 #endif // CONTENT_BROWSER_TRACE_CONTROLLER_H_ | 108 } // namespace content |
| 180 | 109 |
| 110 #endif // CONTENT_BROWSER_TRACE_CONTROLLER_IMPL_H_ |
| 111 |
| OLD | NEW |