OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/render_thread_impl.h" | 5 #include "content/renderer/render_thread_impl.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <limits> | 8 #include <limits> |
9 #include <map> | 9 #include <map> |
10 #include <vector> | 10 #include <vector> |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
58 #include "content/renderer/gpu/compositor_output_surface.h" | 58 #include "content/renderer/gpu/compositor_output_surface.h" |
59 #include "content/renderer/gpu/gpu_benchmarking_extension.h" | 59 #include "content/renderer/gpu/gpu_benchmarking_extension.h" |
60 #include "content/renderer/gpu/input_event_filter.h" | 60 #include "content/renderer/gpu/input_event_filter.h" |
61 #include "content/renderer/gpu/input_handler_manager.h" | 61 #include "content/renderer/gpu/input_handler_manager.h" |
62 #include "content/renderer/media/audio_input_message_filter.h" | 62 #include "content/renderer/media/audio_input_message_filter.h" |
63 #include "content/renderer/media/audio_message_filter.h" | 63 #include "content/renderer/media/audio_message_filter.h" |
64 #include "content/renderer/media/audio_renderer_mixer_manager.h" | 64 #include "content/renderer/media/audio_renderer_mixer_manager.h" |
65 #include "content/renderer/media/media_stream_center.h" | 65 #include "content/renderer/media/media_stream_center.h" |
66 #include "content/renderer/media/media_stream_dependency_factory.h" | 66 #include "content/renderer/media/media_stream_dependency_factory.h" |
67 #include "content/renderer/media/peer_connection_tracker.h" | 67 #include "content/renderer/media/peer_connection_tracker.h" |
| 68 #include "content/renderer/media/renderer_gpu_video_decoder_factories.h" |
68 #include "content/renderer/media/video_capture_impl_manager.h" | 69 #include "content/renderer/media/video_capture_impl_manager.h" |
69 #include "content/renderer/media/video_capture_message_filter.h" | 70 #include "content/renderer/media/video_capture_message_filter.h" |
70 #include "content/renderer/memory_benchmarking_extension.h" | 71 #include "content/renderer/memory_benchmarking_extension.h" |
71 #include "content/renderer/p2p/socket_dispatcher.h" | 72 #include "content/renderer/p2p/socket_dispatcher.h" |
72 #include "content/renderer/plugin_channel_host.h" | 73 #include "content/renderer/plugin_channel_host.h" |
73 #include "content/renderer/render_process_impl.h" | 74 #include "content/renderer/render_process_impl.h" |
74 #include "content/renderer/render_view_impl.h" | 75 #include "content/renderer/render_view_impl.h" |
75 #include "content/renderer/renderer_webkitplatformsupport_impl.h" | 76 #include "content/renderer/renderer_webkitplatformsupport_impl.h" |
76 #include "content/renderer/skia_benchmarking_extension.h" | 77 #include "content/renderer/skia_benchmarking_extension.h" |
77 #include "grit/content_resources.h" | 78 #include "grit/content_resources.h" |
(...skipping 789 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
867 bool RenderThreadImpl::ResolveProxy(const GURL& url, std::string* proxy_list) { | 868 bool RenderThreadImpl::ResolveProxy(const GURL& url, std::string* proxy_list) { |
868 bool result = false; | 869 bool result = false; |
869 Send(new ViewHostMsg_ResolveProxy(url, &result, proxy_list)); | 870 Send(new ViewHostMsg_ResolveProxy(url, &result, proxy_list)); |
870 return result; | 871 return result; |
871 } | 872 } |
872 | 873 |
873 void RenderThreadImpl::PostponeIdleNotification() { | 874 void RenderThreadImpl::PostponeIdleNotification() { |
874 idle_notifications_to_skip_ = 2; | 875 idle_notifications_to_skip_ = 2; |
875 } | 876 } |
876 | 877 |
| 878 scoped_refptr<media::GpuVideoDecoder::Factories> |
| 879 RenderThreadImpl::GetGpuFactories() { |
| 880 const CommandLine* cmd_line = CommandLine::ForCurrentProcess(); |
| 881 scoped_refptr<media::GpuVideoDecoder::Factories> gpu_factories; |
| 882 WebGraphicsContext3DCommandBufferImpl* context3d = NULL; |
| 883 if (!cmd_line->HasSwitch(switches::kDisableAcceleratedVideoDecode)) |
| 884 context3d = RenderThreadImpl::current()->GetGpuVDAContext3D(); |
| 885 if (context3d) { |
| 886 scoped_refptr<base::MessageLoopProxy> factories_loop = |
| 887 RenderThreadImpl::current()->compositor_message_loop_proxy(); |
| 888 if (!factories_loop.get()) |
| 889 factories_loop = base::MessageLoopProxy::current(); |
| 890 GpuChannelHost* gpu_channel_host = |
| 891 RenderThreadImpl::current()->EstablishGpuChannelSync( |
| 892 CAUSE_FOR_GPU_LAUNCH_VIDEODECODEACCELERATOR_INITIALIZE); |
| 893 gpu_factories = new RendererGpuVideoDecoderFactories( |
| 894 gpu_channel_host, factories_loop, context3d); |
| 895 } |
| 896 return gpu_factories; |
| 897 } |
| 898 |
877 /* static */ | 899 /* static */ |
878 void RenderThreadImpl::OnGpuVDAContextLoss() { | 900 void RenderThreadImpl::OnGpuVDAContextLoss() { |
879 RenderThreadImpl* self = RenderThreadImpl::current(); | 901 RenderThreadImpl* self = RenderThreadImpl::current(); |
880 DCHECK(self); | 902 DCHECK(self); |
881 if (!self->gpu_vda_context3d_) | 903 if (!self->gpu_vda_context3d_) |
882 return; | 904 return; |
883 if (self->compositor_message_loop_proxy().get()) { | 905 if (self->compositor_message_loop_proxy().get()) { |
884 self->compositor_message_loop_proxy() | 906 self->compositor_message_loop_proxy() |
885 ->DeleteSoon(FROM_HERE, self->gpu_vda_context3d_.release()); | 907 ->DeleteSoon(FROM_HERE, self->gpu_vda_context3d_.release()); |
886 } else { | 908 } else { |
(...skipping 371 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1258 | 1280 |
1259 void RenderThreadImpl::SetFlingCurveParameters( | 1281 void RenderThreadImpl::SetFlingCurveParameters( |
1260 const std::vector<float>& new_touchpad, | 1282 const std::vector<float>& new_touchpad, |
1261 const std::vector<float>& new_touchscreen) { | 1283 const std::vector<float>& new_touchscreen) { |
1262 webkit_platform_support_->SetFlingCurveParameters(new_touchpad, | 1284 webkit_platform_support_->SetFlingCurveParameters(new_touchpad, |
1263 new_touchscreen); | 1285 new_touchscreen); |
1264 | 1286 |
1265 } | 1287 } |
1266 | 1288 |
1267 } // namespace content | 1289 } // namespace content |
OLD | NEW |