Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(100)

Side by Side Diff: third_party/WebKit/Source/platform/scheduler/renderer/renderer_scheduler_impl.h

Issue 2890173002: EQT: Record the max queueing time from navigation start to navigation away (Closed)
Patch Set: fix mock_renderer_scheduler Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 #ifndef THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_RENDERER_SCHEDULER _IMPL_H_ 5 #ifndef THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_RENDERER_SCHEDULER _IMPL_H_
6 #define THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_RENDERER_SCHEDULER _IMPL_H_ 6 #define THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_RENDERER_SCHEDULER _IMPL_H_
7 7
8 #include "base/atomicops.h" 8 #include "base/atomicops.h"
9 #include "base/gtest_prod_util.h" 9 #include "base/gtest_prod_util.h"
10 #include "base/macros.h" 10 #include "base/macros.h"
11 #include "base/message_loop/message_loop.h" 11 #include "base/message_loop/message_loop.h"
12 #include "base/metrics/single_sample_metrics.h"
12 #include "base/single_thread_task_runner.h" 13 #include "base/single_thread_task_runner.h"
13 #include "base/synchronization/lock.h" 14 #include "base/synchronization/lock.h"
14 #include "base/trace_event/trace_log.h" 15 #include "base/trace_event/trace_log.h"
15 #include "device/base/synchronization/shared_memory_seqlock_buffer.h" 16 #include "device/base/synchronization/shared_memory_seqlock_buffer.h"
16 #include "platform/scheduler/base/pollable_thread_safe_flag.h" 17 #include "platform/scheduler/base/pollable_thread_safe_flag.h"
17 #include "platform/scheduler/base/queueing_time_estimator.h" 18 #include "platform/scheduler/base/queueing_time_estimator.h"
18 #include "platform/scheduler/base/task_time_observer.h" 19 #include "platform/scheduler/base/task_time_observer.h"
19 #include "platform/scheduler/base/thread_load_tracker.h" 20 #include "platform/scheduler/base/thread_load_tracker.h"
20 #include "platform/scheduler/child/idle_canceled_delayed_task_sweeper.h" 21 #include "platform/scheduler/child/idle_canceled_delayed_task_sweeper.h"
21 #include "platform/scheduler/child/idle_helper.h" 22 #include "platform/scheduler/child/idle_helper.h"
(...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after
101 void DidHandleInputEventOnMainThread(const WebInputEvent& web_input_event, 102 void DidHandleInputEventOnMainThread(const WebInputEvent& web_input_event,
102 WebInputEventResult result) override; 103 WebInputEventResult result) override;
103 void DidAnimateForInputOnCompositorThread() override; 104 void DidAnimateForInputOnCompositorThread() override;
104 void OnRendererBackgrounded() override; 105 void OnRendererBackgrounded() override;
105 void OnRendererForegrounded() override; 106 void OnRendererForegrounded() override;
106 void SuspendRenderer() override; 107 void SuspendRenderer() override;
107 void ResumeRenderer() override; 108 void ResumeRenderer() override;
108 void AddPendingNavigation(NavigatingFrameType type) override; 109 void AddPendingNavigation(NavigatingFrameType type) override;
109 void RemovePendingNavigation(NavigatingFrameType type) override; 110 void RemovePendingNavigation(NavigatingFrameType type) override;
110 void OnNavigationStarted() override; 111 void OnNavigationStarted() override;
112 void OnCommitProvisionalLoad() override;
111 bool IsHighPriorityWorkAnticipated() override; 113 bool IsHighPriorityWorkAnticipated() override;
112 bool ShouldYieldForHighPriorityWork() override; 114 bool ShouldYieldForHighPriorityWork() override;
113 bool CanExceedIdleDeadlineIfRequired() const override; 115 bool CanExceedIdleDeadlineIfRequired() const override;
114 void AddTaskObserver(base::MessageLoop::TaskObserver* task_observer) override; 116 void AddTaskObserver(base::MessageLoop::TaskObserver* task_observer) override;
115 void RemoveTaskObserver( 117 void RemoveTaskObserver(
116 base::MessageLoop::TaskObserver* task_observer) override; 118 base::MessageLoop::TaskObserver* task_observer) override;
117 void Shutdown() override; 119 void Shutdown() override;
118 void SuspendTimerQueue() override; 120 void SuspendTimerQueue() override;
119 void ResumeTimerQueue() override; 121 void ResumeTimerQueue() override;
120 void VirtualTimePaused() override; 122 void VirtualTimePaused() override;
(...skipping 250 matching lines...) Expand 10 before | Expand all | Expand 10 after
371 373
372 // Helper for computing the use case. |expected_usecase_duration| will be 374 // Helper for computing the use case. |expected_usecase_duration| will be
373 // filled with the amount of time after which the use case should be updated 375 // filled with the amount of time after which the use case should be updated
374 // again. If the duration is zero, a new use case update should not be 376 // again. If the duration is zero, a new use case update should not be
375 // scheduled. Must be called with |any_thread_lock_| held. Can be called from 377 // scheduled. Must be called with |any_thread_lock_| held. Can be called from
376 // any thread. 378 // any thread.
377 UseCase ComputeCurrentUseCase( 379 UseCase ComputeCurrentUseCase(
378 base::TimeTicks now, 380 base::TimeTicks now,
379 base::TimeDelta* expected_use_case_duration) const; 381 base::TimeDelta* expected_use_case_duration) const;
380 382
383 std::unique_ptr<base::SingleSampleMetric> CreateMaxQueueingTimeMetric();
384
381 // An input event of some sort happened, the policy may need updating. 385 // An input event of some sort happened, the policy may need updating.
382 void UpdateForInputEventOnCompositorThread(WebInputEvent::Type type, 386 void UpdateForInputEventOnCompositorThread(WebInputEvent::Type type,
383 InputEventState input_event_state); 387 InputEventState input_event_state);
384 388
385 // Helpers for safely suspending/resuming the timer queue after a 389 // Helpers for safely suspending/resuming the timer queue after a
386 // background/foreground signal. 390 // background/foreground signal.
387 void SuspendTimerQueueWhenBackgrounded(); 391 void SuspendTimerQueueWhenBackgrounded();
388 void ResumeTimerQueueWhenForegroundedOrResumed(); 392 void ResumeTimerQueueWhenForegroundedOrResumed();
389 393
390 // The task cost estimators and the UserModel need to be reset upon page 394 // The task cost estimators and the UserModel need to be reset upon page
(...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after
488 bool touchstart_expected_soon; 492 bool touchstart_expected_soon;
489 bool have_seen_a_begin_main_frame; 493 bool have_seen_a_begin_main_frame;
490 bool have_reported_blocking_intervention_in_current_policy; 494 bool have_reported_blocking_intervention_in_current_policy;
491 bool have_reported_blocking_intervention_since_navigation; 495 bool have_reported_blocking_intervention_since_navigation;
492 bool has_visible_render_widget_with_touch_handler; 496 bool has_visible_render_widget_with_touch_handler;
493 bool begin_frame_not_expected_soon; 497 bool begin_frame_not_expected_soon;
494 bool in_idle_period_for_testing; 498 bool in_idle_period_for_testing;
495 bool use_virtual_time; 499 bool use_virtual_time;
496 bool is_audio_playing; 500 bool is_audio_playing;
497 bool virtual_time_paused; 501 bool virtual_time_paused;
502 bool has_navigated;
503 std::unique_ptr<base::SingleSampleMetric> max_queueing_time_metric;
504 base::TimeDelta max_queueing_time;
498 std::set<WebViewSchedulerImpl*> web_view_schedulers; // Not owned. 505 std::set<WebViewSchedulerImpl*> web_view_schedulers; // Not owned.
499 RAILModeObserver* rail_mode_observer; // Not owned. 506 RAILModeObserver* rail_mode_observer; // Not owned.
500 WakeUpBudgetPool* wake_up_budget_pool; // Not owned. 507 WakeUpBudgetPool* wake_up_budget_pool; // Not owned.
501 TaskDurationMetricReporter task_duration_reporter; 508 TaskDurationMetricReporter task_duration_reporter;
502 TaskDurationMetricReporter foreground_task_duration_reporter; 509 TaskDurationMetricReporter foreground_task_duration_reporter;
503 TaskDurationMetricReporter background_task_duration_reporter; 510 TaskDurationMetricReporter background_task_duration_reporter;
504 }; 511 };
505 512
506 struct AnyThread { 513 struct AnyThread {
507 AnyThread(); 514 AnyThread();
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after
573 580
574 base::WeakPtrFactory<RendererSchedulerImpl> weak_factory_; 581 base::WeakPtrFactory<RendererSchedulerImpl> weak_factory_;
575 582
576 DISALLOW_COPY_AND_ASSIGN(RendererSchedulerImpl); 583 DISALLOW_COPY_AND_ASSIGN(RendererSchedulerImpl);
577 }; 584 };
578 585
579 } // namespace scheduler 586 } // namespace scheduler
580 } // namespace blink 587 } // namespace blink
581 588
582 #endif // THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_RENDERER_SCHEDU LER_IMPL_H_ 589 #endif // THIRD_PARTY_WEBKIT_SOURCE_PLATFORM_SCHEDULER_RENDERER_RENDERER_SCHEDU LER_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698