OLD | NEW |
(Empty) | |
| 1 // Copyright 2016 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 #include "components/scheduler/base/task_time_tracker.h" |
| 6 |
| 7 #include "base/metrics/histogram_macros.h" |
| 8 #include "base/trace_event/trace_event.h" |
| 9 |
| 10 namespace scheduler { |
| 11 |
| 12 TaskTimeTracker::TaskTimeTracker() |
| 13 : task_time_observer_(nullptr), |
| 14 queueing_time_estimator_(this, base::TimeDelta::FromSeconds(1)) {} |
| 15 |
| 16 TaskTimeTracker::~TaskTimeTracker() {} |
| 17 |
| 18 void TaskTimeTracker::SetObserver(TaskTimeObserver* task_time_observer) { |
| 19 task_time_observer_ = task_time_observer; |
| 20 } |
| 21 |
| 22 void TaskTimeTracker::OnQueueingTimeForWindowEstimated( |
| 23 base::TimeDelta queueing_time) { |
| 24 UMA_HISTOGRAM_TIMES("RendererScheduler.ExpectedTaskQueueingDuration", |
| 25 queueing_time); |
| 26 TRACE_COUNTER1(TRACE_DISABLED_BY_DEFAULT("renderer.scheduler"), |
| 27 "estimated_queueing_time_for_window", |
| 28 queueing_time.InMillisecondsF()); |
| 29 } |
| 30 |
| 31 void TaskTimeTracker::ReportTaskTime( |
| 32 base::TimeTicks task_start_time, base::TimeTicks task_end_time) { |
| 33 queueing_time_estimator_.OnToplevelTaskCompleted(task_start_time, |
| 34 task_end_time); |
| 35 } |
| 36 |
| 37 } // scheduler |
OLD | NEW |