| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 #include "platform/scheduler/child/worker_scheduler_impl.h" | 5 #include "platform/scheduler/child/worker_scheduler_impl.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/metrics/histogram_macros.h" | 8 #include "base/metrics/histogram_macros.h" |
| 9 #include "base/trace_event/trace_event.h" | 9 #include "base/trace_event/trace_event.h" |
| 10 #include "base/trace_event/trace_event_argument.h" | 10 #include "base/trace_event/trace_event_argument.h" |
| 11 #include "platform/Histogram.h" |
| 11 #include "platform/scheduler/base/time_converter.h" | 12 #include "platform/scheduler/base/time_converter.h" |
| 12 #include "platform/scheduler/child/scheduler_tqm_delegate.h" | 13 #include "platform/scheduler/child/scheduler_tqm_delegate.h" |
| 13 #include "public/platform/scheduler/base/task_queue.h" | 14 #include "public/platform/scheduler/base/task_queue.h" |
| 14 | 15 |
| 15 namespace blink { | 16 namespace blink { |
| 16 namespace scheduler { | 17 namespace scheduler { |
| 17 | 18 |
| 18 namespace { | 19 namespace { |
| 19 // Workers could be short-lived, set a shorter interval than | 20 // Workers could be short-lived, set a shorter interval than |
| 20 // the renderer thread. | 21 // the renderer thread. |
| (...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 113 | 114 |
| 114 // The lifetime could be radically different for different workers, | 115 // The lifetime could be radically different for different workers, |
| 115 // some workers could be short-lived (but last at least 1 sec in | 116 // some workers could be short-lived (but last at least 1 sec in |
| 116 // Service Workers case) or could be around as long as the tab is open. | 117 // Service Workers case) or could be around as long as the tab is open. |
| 117 UMA_HISTOGRAM_CUSTOM_TIMES( | 118 UMA_HISTOGRAM_CUSTOM_TIMES( |
| 118 "WorkerThread.Runtime", delta, base::TimeDelta::FromSeconds(1), | 119 "WorkerThread.Runtime", delta, base::TimeDelta::FromSeconds(1), |
| 119 base::TimeDelta::FromDays(1), 50 /* bucket count */); | 120 base::TimeDelta::FromDays(1), 50 /* bucket count */); |
| 120 helper_.Shutdown(); | 121 helper_.Shutdown(); |
| 121 } | 122 } |
| 122 | 123 |
| 124 scoped_refptr<TaskQueue> WorkerSchedulerImpl::NewUnthrottledTaskRunner( |
| 125 TaskQueue::QueueType queue_type) { |
| 126 helper_.CheckOnValidThread(); |
| 127 scoped_refptr<TaskQueue> unthrottled_task_queue( |
| 128 helper_.NewTaskQueue(TaskQueue::Spec(queue_type) |
| 129 .SetShouldMonitorQuiescence(true) |
| 130 .SetTimeDomain(nullptr))); |
| 131 return unthrottled_task_queue; |
| 132 } |
| 133 |
| 123 SchedulerHelper* WorkerSchedulerImpl::GetSchedulerHelperForTesting() { | 134 SchedulerHelper* WorkerSchedulerImpl::GetSchedulerHelperForTesting() { |
| 124 return &helper_; | 135 return &helper_; |
| 125 } | 136 } |
| 126 | 137 |
| 127 bool WorkerSchedulerImpl::CanEnterLongIdlePeriod(base::TimeTicks, | 138 bool WorkerSchedulerImpl::CanEnterLongIdlePeriod(base::TimeTicks, |
| 128 base::TimeDelta*) { | 139 base::TimeDelta*) { |
| 129 return true; | 140 return true; |
| 130 } | 141 } |
| 131 | 142 |
| 132 base::TimeTicks WorkerSchedulerImpl::CurrentIdleTaskDeadlineForTesting() const { | 143 base::TimeTicks WorkerSchedulerImpl::CurrentIdleTaskDeadlineForTesting() const { |
| 133 return idle_helper_.CurrentIdleTaskDeadline(); | 144 return idle_helper_.CurrentIdleTaskDeadline(); |
| 134 } | 145 } |
| 135 | 146 |
| 136 void WorkerSchedulerImpl::WillProcessTask(TaskQueue* task_queue, | 147 void WorkerSchedulerImpl::WillProcessTask(TaskQueue* task_queue, |
| 137 double start_time) {} | 148 double start_time) {} |
| 138 | 149 |
| 139 void WorkerSchedulerImpl::DidProcessTask(TaskQueue* task_queue, | 150 void WorkerSchedulerImpl::DidProcessTask(TaskQueue* task_queue, |
| 140 double start_time, | 151 double start_time, |
| 141 double end_time) { | 152 double end_time) { |
| 153 DEFINE_THREAD_SAFE_STATIC_LOCAL( |
| 154 CustomCountHistogram, task_time_counter, |
| 155 new CustomCountHistogram("WorkerThread.Task.Time", 0, 10000000, 50)); |
| 156 task_time_counter.Count((end_time - start_time) * |
| 157 base::Time::kMicrosecondsPerSecond); |
| 158 |
| 142 base::TimeTicks start_time_ticks = | 159 base::TimeTicks start_time_ticks = |
| 143 MonotonicTimeInSecondsToTimeTicks(start_time); | 160 MonotonicTimeInSecondsToTimeTicks(start_time); |
| 144 base::TimeTicks end_time_ticks = MonotonicTimeInSecondsToTimeTicks(end_time); | 161 base::TimeTicks end_time_ticks = MonotonicTimeInSecondsToTimeTicks(end_time); |
| 145 | 162 |
| 146 load_tracker_.RecordTaskTime(start_time_ticks, end_time_ticks); | 163 load_tracker_.RecordTaskTime(start_time_ticks, end_time_ticks); |
| 147 } | 164 } |
| 148 | 165 |
| 149 void WorkerSchedulerImpl::OnBeginNestedMessageLoop() {} | 166 void WorkerSchedulerImpl::OnBeginNestedMessageLoop() {} |
| 150 | 167 |
| 151 } // namespace scheduler | 168 } // namespace scheduler |
| 152 } // namespace blink | 169 } // namespace blink |
| OLD | NEW |