Chromium Code Reviews| 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/renderer/renderer_scheduler_impl.h" | 5 #include "platform/scheduler/renderer/renderer_scheduler_impl.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/debug/stack_trace.h" | 8 #include "base/debug/stack_trace.h" |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/memory/ptr_util.h" | 10 #include "base/memory/ptr_util.h" |
| 11 #include "base/metrics/histogram.h" | 11 #include "base/metrics/histogram.h" |
| 12 #include "base/metrics/histogram_macros.h" | 12 #include "base/metrics/histogram_macros.h" |
| 13 #include "base/threading/thread_task_runner_handle.h" | 13 #include "base/threading/thread_task_runner_handle.h" |
| 14 #include "base/trace_event/trace_event.h" | 14 #include "base/trace_event/trace_event.h" |
| 15 #include "base/trace_event/trace_event_argument.h" | 15 #include "base/trace_event/trace_event_argument.h" |
| 16 #include "cc/output/begin_frame_args.h" | 16 #include "cc/output/begin_frame_args.h" |
| 17 #include "components/metrics/single_sample_metrics_factory_impl.h" | |
| 17 #include "platform/RuntimeEnabledFeatures.h" | 18 #include "platform/RuntimeEnabledFeatures.h" |
| 18 #include "platform/scheduler/base/real_time_domain.h" | 19 #include "platform/scheduler/base/real_time_domain.h" |
| 19 #include "platform/scheduler/base/task_queue_impl.h" | 20 #include "platform/scheduler/base/task_queue_impl.h" |
| 20 #include "platform/scheduler/base/task_queue_selector.h" | 21 #include "platform/scheduler/base/task_queue_selector.h" |
| 21 #include "platform/scheduler/base/time_converter.h" | 22 #include "platform/scheduler/base/time_converter.h" |
| 22 #include "platform/scheduler/base/trace_helper.h" | 23 #include "platform/scheduler/base/trace_helper.h" |
| 23 #include "platform/scheduler/base/virtual_time_domain.h" | 24 #include "platform/scheduler/base/virtual_time_domain.h" |
| 24 #include "platform/scheduler/child/scheduler_tqm_delegate.h" | 25 #include "platform/scheduler/child/scheduler_tqm_delegate.h" |
| 25 #include "platform/scheduler/renderer/auto_advancing_virtual_time_domain.h" | 26 #include "platform/scheduler/renderer/auto_advancing_virtual_time_domain.h" |
| 26 #include "platform/scheduler/renderer/task_queue_throttler.h" | 27 #include "platform/scheduler/renderer/task_queue_throttler.h" |
| (...skipping 185 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 212 timer_tasks_seem_expensive(false), | 213 timer_tasks_seem_expensive(false), |
| 213 touchstart_expected_soon(false), | 214 touchstart_expected_soon(false), |
| 214 have_seen_a_begin_main_frame(false), | 215 have_seen_a_begin_main_frame(false), |
| 215 have_reported_blocking_intervention_in_current_policy(false), | 216 have_reported_blocking_intervention_in_current_policy(false), |
| 216 have_reported_blocking_intervention_since_navigation(false), | 217 have_reported_blocking_intervention_since_navigation(false), |
| 217 has_visible_render_widget_with_touch_handler(false), | 218 has_visible_render_widget_with_touch_handler(false), |
| 218 begin_frame_not_expected_soon(false), | 219 begin_frame_not_expected_soon(false), |
| 219 in_idle_period_for_testing(false), | 220 in_idle_period_for_testing(false), |
| 220 use_virtual_time(false), | 221 use_virtual_time(false), |
| 221 is_audio_playing(false), | 222 is_audio_playing(false), |
| 223 has_navigated(false), | |
| 222 rail_mode_observer(nullptr), | 224 rail_mode_observer(nullptr), |
| 223 wake_up_budget_pool(nullptr), | 225 wake_up_budget_pool(nullptr), |
| 224 task_duration_per_queue_type_histogram(base::Histogram::FactoryGet( | 226 task_duration_per_queue_type_histogram(base::Histogram::FactoryGet( |
| 225 "RendererScheduler.TaskDurationPerQueueType2", | 227 "RendererScheduler.TaskDurationPerQueueType2", |
| 226 1, | 228 1, |
| 227 static_cast<int>(TaskQueue::QueueType::COUNT), | 229 static_cast<int>(TaskQueue::QueueType::COUNT), |
| 228 static_cast<int>(TaskQueue::QueueType::COUNT) + 1, | 230 static_cast<int>(TaskQueue::QueueType::COUNT) + 1, |
| 229 base::HistogramBase::kUmaTargetedHistogramFlag)) { | 231 base::HistogramBase::kUmaTargetedHistogramFlag)) { |
| 230 foreground_main_thread_load_tracker.Resume(now); | 232 foreground_main_thread_load_tracker.Resume(now); |
| 231 } | 233 } |
| (...skipping 1392 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1624 void RendererSchedulerImpl::RemovePendingNavigation(NavigatingFrameType type) { | 1626 void RendererSchedulerImpl::RemovePendingNavigation(NavigatingFrameType type) { |
| 1625 helper_.CheckOnValidThread(); | 1627 helper_.CheckOnValidThread(); |
| 1626 DCHECK_GT(GetMainThreadOnly().navigation_task_expected_count, 0); | 1628 DCHECK_GT(GetMainThreadOnly().navigation_task_expected_count, 0); |
| 1627 if (type == NavigatingFrameType::kMainFrame && | 1629 if (type == NavigatingFrameType::kMainFrame && |
| 1628 GetMainThreadOnly().navigation_task_expected_count > 0) { | 1630 GetMainThreadOnly().navigation_task_expected_count > 0) { |
| 1629 GetMainThreadOnly().navigation_task_expected_count--; | 1631 GetMainThreadOnly().navigation_task_expected_count--; |
| 1630 UpdatePolicy(); | 1632 UpdatePolicy(); |
| 1631 } | 1633 } |
| 1632 } | 1634 } |
| 1633 | 1635 |
| 1636 void RendererSchedulerImpl::OnCommitProvisionalLoad() { | |
| 1637 // Initialize |max_queueing_time_metric| lazily so that | |
| 1638 // |SingleSampleMetricsFactory::SetFactory()| is called before | |
| 1639 // |SingleSampleMetricsFactory::Get()| | |
| 1640 if (!GetMainThreadOnly().max_queueing_time_metric) { | |
| 1641 GetMainThreadOnly().max_queueing_time_metric = | |
| 1642 GetOrCreateMaxQueueingTimeMetric(); | |
| 1643 } | |
| 1644 GetMainThreadOnly().max_queueing_time_metric.reset(); | |
| 1645 GetMainThreadOnly().max_queueing_time = base::TimeDelta(); | |
| 1646 GetMainThreadOnly().has_navigated = true; | |
| 1647 } | |
| 1648 | |
| 1649 std::unique_ptr<base::SingleSampleMetric> | |
| 1650 RendererSchedulerImpl::GetOrCreateMaxQueueingTimeMetric() { | |
| 1651 return base::SingleSampleMetricsFactory::Get()->CreateCustomCountsMetric( | |
|
Sami
2017/05/31 10:30:34
Based on the method name I would expect this to ca
Liquan (Max) Gu
2017/06/01 14:39:39
There is a difference between caching it in max_qu
Sami
2017/06/01 18:29:40
I see. This function seems to create a new metric
Liquan (Max) Gu
2017/06/01 18:36:05
Whoops, you are right.
| |
| 1652 "RendererScheduler.MaxQueueingTime", 1, 10000, 50); | |
| 1653 } | |
| 1654 | |
| 1634 void RendererSchedulerImpl::OnNavigationStarted() { | 1655 void RendererSchedulerImpl::OnNavigationStarted() { |
| 1635 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("renderer.scheduler"), | 1656 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("renderer.scheduler"), |
| 1636 "RendererSchedulerImpl::OnNavigationStarted"); | 1657 "RendererSchedulerImpl::OnNavigationStarted"); |
| 1637 base::AutoLock lock(any_thread_lock_); | 1658 base::AutoLock lock(any_thread_lock_); |
| 1638 ResetForNavigationLocked(); | 1659 ResetForNavigationLocked(); |
| 1639 } | 1660 } |
| 1640 | 1661 |
| 1641 void RendererSchedulerImpl::OnFirstMeaningfulPaint() { | 1662 void RendererSchedulerImpl::OnFirstMeaningfulPaint() { |
| 1642 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("renderer.scheduler"), | 1663 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("renderer.scheduler"), |
| 1643 "RendererSchedulerImpl::OnFirstMeaningfulPaint"); | 1664 "RendererSchedulerImpl::OnFirstMeaningfulPaint"); |
| (...skipping 256 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1900 } | 1921 } |
| 1901 | 1922 |
| 1902 void RendererSchedulerImpl::RemoveTaskTimeObserver( | 1923 void RendererSchedulerImpl::RemoveTaskTimeObserver( |
| 1903 TaskTimeObserver* task_time_observer) { | 1924 TaskTimeObserver* task_time_observer) { |
| 1904 helper_.RemoveTaskTimeObserver(task_time_observer); | 1925 helper_.RemoveTaskTimeObserver(task_time_observer); |
| 1905 } | 1926 } |
| 1906 | 1927 |
| 1907 void RendererSchedulerImpl::OnQueueingTimeForWindowEstimated( | 1928 void RendererSchedulerImpl::OnQueueingTimeForWindowEstimated( |
| 1908 base::TimeDelta queueing_time, | 1929 base::TimeDelta queueing_time, |
| 1909 base::TimeTicks window_start_time) { | 1930 base::TimeTicks window_start_time) { |
| 1931 if (GetMainThreadOnly().has_navigated) { | |
| 1932 if (GetMainThreadOnly().max_queueing_time < queueing_time) { | |
| 1933 if (!GetMainThreadOnly().max_queueing_time_metric) { | |
| 1934 GetMainThreadOnly().max_queueing_time_metric = | |
| 1935 GetOrCreateMaxQueueingTimeMetric(); | |
| 1936 } | |
| 1937 GetMainThreadOnly().max_queueing_time_metric->SetSample( | |
| 1938 queueing_time.InMilliseconds()); | |
| 1939 GetMainThreadOnly().max_queueing_time = queueing_time; | |
| 1940 } | |
| 1941 } | |
| 1942 | |
| 1910 // RendererScheduler reports the queueing time once per window's duration. | 1943 // RendererScheduler reports the queueing time once per window's duration. |
| 1911 // |stepEQT|stepEQT|stepEQT|stepEQT|stepEQT|stepEQT| | 1944 // |stepEQT|stepEQT|stepEQT|stepEQT|stepEQT|stepEQT| |
| 1912 // Report: |-------window EQT------| | 1945 // Report: |-------window EQT------| |
| 1913 // Discard: |-------window EQT------| | 1946 // Discard: |-------window EQT------| |
| 1914 // Discard: |-------window EQT------| | 1947 // Discard: |-------window EQT------| |
| 1915 // Report: |-------window EQT------| | 1948 // Report: |-------window EQT------| |
| 1916 if (window_start_time - | 1949 if (window_start_time - |
| 1917 GetMainThreadOnly().uma_last_queueing_time_report_window_start_time < | 1950 GetMainThreadOnly().uma_last_queueing_time_report_window_start_time < |
| 1918 kQueueingTimeWindowDuration) { | 1951 kQueueingTimeWindowDuration) { |
| 1919 return; | 1952 return; |
| (...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 2057 case TimeDomainType::VIRTUAL: | 2090 case TimeDomainType::VIRTUAL: |
| 2058 return "virtual"; | 2091 return "virtual"; |
| 2059 default: | 2092 default: |
| 2060 NOTREACHED(); | 2093 NOTREACHED(); |
| 2061 return nullptr; | 2094 return nullptr; |
| 2062 } | 2095 } |
| 2063 } | 2096 } |
| 2064 | 2097 |
| 2065 } // namespace scheduler | 2098 } // namespace scheduler |
| 2066 } // namespace blink | 2099 } // namespace blink |
| OLD | NEW |