| 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" |
| (...skipping 432 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 443 return; | 443 return; |
| 444 | 444 |
| 445 MainThreadOnly().begin_frame_not_expected_soon = true; | 445 MainThreadOnly().begin_frame_not_expected_soon = true; |
| 446 idle_helper_.EnableLongIdlePeriod(); | 446 idle_helper_.EnableLongIdlePeriod(); |
| 447 { | 447 { |
| 448 base::AutoLock lock(any_thread_lock_); | 448 base::AutoLock lock(any_thread_lock_); |
| 449 AnyThread().begin_main_frame_on_critical_path = false; | 449 AnyThread().begin_main_frame_on_critical_path = false; |
| 450 } | 450 } |
| 451 } | 451 } |
| 452 | 452 |
| 453 void RendererSchedulerImpl::BeginMainFrameNotExpectedUntil( |
| 454 const base::TimeTicks& frame_time) { |
| 455 TRACE_EVENT0(TRACE_DISABLED_BY_DEFAULT("renderer.scheduler"), |
| 456 "RendererSchedulerImpl::BeginMainFrameNotExpectedUntil"); |
| 457 helper_.CheckOnValidThread(); |
| 458 if (helper_.IsShutdown()) |
| 459 return; |
| 460 |
| 461 base::TimeTicks now(helper_.scheduler_tqm_delegate()->NowTicks()); |
| 462 |
| 463 if (now < frame_time) { |
| 464 // End any previous idle period. |
| 465 EndIdlePeriod(); |
| 466 |
| 467 // TODO(rmcilroy): Consider reducing the idle period based on the runtime of |
| 468 // the next pending delayed tasks (as currently done in for long idle times) |
| 469 idle_helper_.StartIdlePeriod( |
| 470 IdleHelper::IdlePeriodState::IN_SHORT_IDLE_PERIOD, now, frame_time); |
| 471 } |
| 472 } |
| 473 |
| 453 void RendererSchedulerImpl::SetAllRenderWidgetsHidden(bool hidden) { | 474 void RendererSchedulerImpl::SetAllRenderWidgetsHidden(bool hidden) { |
| 454 TRACE_EVENT1(TRACE_DISABLED_BY_DEFAULT("renderer.scheduler"), | 475 TRACE_EVENT1(TRACE_DISABLED_BY_DEFAULT("renderer.scheduler"), |
| 455 "RendererSchedulerImpl::SetAllRenderWidgetsHidden", "hidden", | 476 "RendererSchedulerImpl::SetAllRenderWidgetsHidden", "hidden", |
| 456 hidden); | 477 hidden); |
| 457 | 478 |
| 458 helper_.CheckOnValidThread(); | 479 helper_.CheckOnValidThread(); |
| 459 | 480 |
| 460 if (helper_.IsShutdown() || MainThreadOnly().renderer_hidden == hidden) | 481 if (helper_.IsShutdown() || MainThreadOnly().renderer_hidden == hidden) |
| 461 return; | 482 return; |
| 462 | 483 |
| (...skipping 1450 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1913 case TimeDomainType::VIRTUAL: | 1934 case TimeDomainType::VIRTUAL: |
| 1914 return "virtual"; | 1935 return "virtual"; |
| 1915 default: | 1936 default: |
| 1916 NOTREACHED(); | 1937 NOTREACHED(); |
| 1917 return nullptr; | 1938 return nullptr; |
| 1918 } | 1939 } |
| 1919 } | 1940 } |
| 1920 | 1941 |
| 1921 } // namespace scheduler | 1942 } // namespace scheduler |
| 1922 } // namespace blink | 1943 } // namespace blink |
| OLD | NEW |