Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 "content/renderer/gpu/render_widget_compositor.h" | 5 #include "content/renderer/gpu/render_widget_compositor.h" |
| 6 | 6 |
| 7 #include <limits> | 7 #include <limits> |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
| (...skipping 936 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 947 } | 947 } |
| 948 | 948 |
| 949 void RenderWidgetCompositor::DidPostSwapBuffers() { | 949 void RenderWidgetCompositor::DidPostSwapBuffers() { |
| 950 widget_->OnSwapBuffersPosted(); | 950 widget_->OnSwapBuffersPosted(); |
| 951 } | 951 } |
| 952 | 952 |
| 953 void RenderWidgetCompositor::DidAbortSwapBuffers() { | 953 void RenderWidgetCompositor::DidAbortSwapBuffers() { |
| 954 widget_->OnSwapBuffersAborted(); | 954 widget_->OnSwapBuffersAborted(); |
| 955 } | 955 } |
| 956 | 956 |
| 957 void RenderWidgetCompositor::RecordFrameTimingEvents( | |
| 958 scoped_ptr<cc::FrameTimingTracker::CompositeTimingSet> composite_events, | |
| 959 scoped_ptr<cc::FrameTimingTracker::MainFrameTimingSet> main_frame_events) { | |
| 960 for (const auto& composite_event : *composite_events ) { | |
| 961 int64_t frameId = composite_event.first; | |
| 962 const std::vector<cc::FrameTimingTracker::CompositeTimingEvent>& events = | |
| 963 composite_event.second; | |
| 964 std::vector<blink::WebFrameTimingEvent> webEvents(events.size()); | |
| 965 for (size_t i = 0; i < events.size(); ++i) { | |
| 966 webEvents[i] = blink::WebFrameTimingEvent( | |
|
vmpstr
2015/06/02 22:05:19
nit: just create a default vector above and .push_
MikeB
2015/06/03 20:19:20
Done.
| |
| 967 events[i].frame_id, | |
| 968 (events[i].timestamp - base::TimeTicks()).InSecondsF()); | |
| 969 } | |
| 970 widget_->webwidget()->recordFrameTimingEvent( | |
| 971 blink::WebWidget::CompositeEvent, frameId, webEvents); | |
| 972 } | |
| 973 for (const auto& main_frame_event : *main_frame_events ) { | |
| 974 int64_t frameId = main_frame_event.first; | |
| 975 const std::vector<cc::FrameTimingTracker::MainFrameTimingEvent>& events = | |
| 976 main_frame_event.second; | |
| 977 std::vector<blink::WebFrameTimingEvent> webEvents(events.size()); | |
| 978 for (size_t i = 0; i < events.size(); ++i) { | |
| 979 webEvents[i] = blink::WebFrameTimingEvent( | |
|
vmpstr
2015/06/02 22:05:19
nit: just create a default vector above and .push_
MikeB
2015/06/03 20:19:20
Done.
| |
| 980 events[i].frame_id, | |
| 981 (events[i].timestamp - base::TimeTicks()).InSecondsF(), | |
| 982 (events[i].end_time - base::TimeTicks()).InSecondsF()); | |
| 983 } | |
| 984 widget_->webwidget()->recordFrameTimingEvent( | |
| 985 blink::WebWidget::RenderEvent, frameId, webEvents); | |
| 986 } | |
| 987 } | |
| 988 | |
| 957 void RenderWidgetCompositor::RateLimitSharedMainThreadContext() { | 989 void RenderWidgetCompositor::RateLimitSharedMainThreadContext() { |
| 958 cc::ContextProvider* provider = | 990 cc::ContextProvider* provider = |
| 959 compositor_deps_->GetSharedMainThreadContextProvider(); | 991 compositor_deps_->GetSharedMainThreadContextProvider(); |
| 960 // provider can be NULL after the GPU process crashed enough times and we | 992 // provider can be NULL after the GPU process crashed enough times and we |
| 961 // don't want to restart it any more (falling back to software). | 993 // don't want to restart it any more (falling back to software). |
| 962 if (!provider) | 994 if (!provider) |
| 963 return; | 995 return; |
| 964 provider->ContextGL()->RateLimitOffscreenContextCHROMIUM(); | 996 provider->ContextGL()->RateLimitOffscreenContextCHROMIUM(); |
| 965 } | 997 } |
| 966 | 998 |
| 967 void RenderWidgetCompositor::SetSurfaceIdNamespace( | 999 void RenderWidgetCompositor::SetSurfaceIdNamespace( |
| 968 uint32_t surface_id_namespace) { | 1000 uint32_t surface_id_namespace) { |
| 969 layer_tree_host_->set_surface_id_namespace(surface_id_namespace); | 1001 layer_tree_host_->set_surface_id_namespace(surface_id_namespace); |
| 970 } | 1002 } |
| 971 | 1003 |
| 972 } // namespace content | 1004 } // namespace content |
| OLD | NEW |