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 |