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 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
62 #include "content/renderer/gpu/gpu_benchmarking_extension.h" | 62 #include "content/renderer/gpu/gpu_benchmarking_extension.h" |
63 #include "content/renderer/gpu/input_event_filter.h" | 63 #include "content/renderer/gpu/input_event_filter.h" |
64 #include "content/renderer/gpu/input_handler_manager.h" | 64 #include "content/renderer/gpu/input_handler_manager.h" |
65 #include "content/renderer/media/audio_input_message_filter.h" | 65 #include "content/renderer/media/audio_input_message_filter.h" |
66 #include "content/renderer/media/audio_message_filter.h" | 66 #include "content/renderer/media/audio_message_filter.h" |
67 #include "content/renderer/media/audio_renderer_mixer_manager.h" | 67 #include "content/renderer/media/audio_renderer_mixer_manager.h" |
68 #include "content/renderer/media/media_stream_center.h" | 68 #include "content/renderer/media/media_stream_center.h" |
69 #include "content/renderer/media/media_stream_dependency_factory.h" | 69 #include "content/renderer/media/media_stream_dependency_factory.h" |
70 #include "content/renderer/media/midi_message_filter.h" | 70 #include "content/renderer/media/midi_message_filter.h" |
71 #include "content/renderer/media/peer_connection_tracker.h" | 71 #include "content/renderer/media/peer_connection_tracker.h" |
| 72 #include "content/renderer/media/renderer_gpu_video_decoder_factories.h" |
72 #include "content/renderer/media/video_capture_impl_manager.h" | 73 #include "content/renderer/media/video_capture_impl_manager.h" |
73 #include "content/renderer/media/video_capture_message_filter.h" | 74 #include "content/renderer/media/video_capture_message_filter.h" |
74 #include "content/renderer/memory_benchmarking_extension.h" | 75 #include "content/renderer/memory_benchmarking_extension.h" |
75 #include "content/renderer/p2p/socket_dispatcher.h" | 76 #include "content/renderer/p2p/socket_dispatcher.h" |
76 #include "content/renderer/plugin_channel_host.h" | 77 #include "content/renderer/plugin_channel_host.h" |
77 #include "content/renderer/render_process_impl.h" | 78 #include "content/renderer/render_process_impl.h" |
78 #include "content/renderer/render_process_visibility_manager.h" | 79 #include "content/renderer/render_process_visibility_manager.h" |
79 #include "content/renderer/render_view_impl.h" | 80 #include "content/renderer/render_view_impl.h" |
80 #include "content/renderer/renderer_webkitplatformsupport_impl.h" | 81 #include "content/renderer/renderer_webkitplatformsupport_impl.h" |
81 #include "content/renderer/skia_benchmarking_extension.h" | 82 #include "content/renderer/skia_benchmarking_extension.h" |
(...skipping 796 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
878 bool RenderThreadImpl::ResolveProxy(const GURL& url, std::string* proxy_list) { | 879 bool RenderThreadImpl::ResolveProxy(const GURL& url, std::string* proxy_list) { |
879 bool result = false; | 880 bool result = false; |
880 Send(new ViewHostMsg_ResolveProxy(url, &result, proxy_list)); | 881 Send(new ViewHostMsg_ResolveProxy(url, &result, proxy_list)); |
881 return result; | 882 return result; |
882 } | 883 } |
883 | 884 |
884 void RenderThreadImpl::PostponeIdleNotification() { | 885 void RenderThreadImpl::PostponeIdleNotification() { |
885 idle_notifications_to_skip_ = 2; | 886 idle_notifications_to_skip_ = 2; |
886 } | 887 } |
887 | 888 |
| 889 scoped_refptr<media::GpuVideoDecoder::Factories> |
| 890 RenderThreadImpl::GetGpuFactories() { |
| 891 DCHECK(IsMainThread()); |
| 892 |
| 893 const CommandLine* cmd_line = CommandLine::ForCurrentProcess(); |
| 894 scoped_refptr<media::GpuVideoDecoder::Factories> gpu_factories; |
| 895 WebGraphicsContext3DCommandBufferImpl* context3d = NULL; |
| 896 if (!cmd_line->HasSwitch(switches::kDisableAcceleratedVideoDecode)) |
| 897 context3d = GetGpuVDAContext3D(); |
| 898 if (context3d) { |
| 899 scoped_refptr<base::MessageLoopProxy> factories_loop = |
| 900 compositor_message_loop_proxy(); |
| 901 if (!factories_loop.get()) |
| 902 factories_loop = base::MessageLoopProxy::current(); |
| 903 GpuChannelHost* gpu_channel_host = GetGpuChannel(); |
| 904 if (gpu_channel_host) { |
| 905 gpu_factories = new RendererGpuVideoDecoderFactories( |
| 906 gpu_channel_host, factories_loop, context3d); |
| 907 } |
| 908 } |
| 909 return gpu_factories; |
| 910 } |
| 911 |
888 /* static */ | 912 /* static */ |
889 void RenderThreadImpl::OnGpuVDAContextLoss() { | 913 void RenderThreadImpl::OnGpuVDAContextLoss() { |
890 RenderThreadImpl* self = RenderThreadImpl::current(); | 914 RenderThreadImpl* self = RenderThreadImpl::current(); |
891 DCHECK(self); | 915 DCHECK(self); |
892 if (!self->gpu_vda_context3d_) | 916 if (!self->gpu_vda_context3d_) |
893 return; | 917 return; |
894 if (self->compositor_message_loop_proxy().get()) { | 918 if (self->compositor_message_loop_proxy().get()) { |
895 self->compositor_message_loop_proxy() | 919 self->compositor_message_loop_proxy() |
896 ->DeleteSoon(FROM_HERE, self->gpu_vda_context3d_.release()); | 920 ->DeleteSoon(FROM_HERE, self->gpu_vda_context3d_.release()); |
897 } else { | 921 } else { |
(...skipping 378 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1276 | 1300 |
1277 void RenderThreadImpl::SetFlingCurveParameters( | 1301 void RenderThreadImpl::SetFlingCurveParameters( |
1278 const std::vector<float>& new_touchpad, | 1302 const std::vector<float>& new_touchpad, |
1279 const std::vector<float>& new_touchscreen) { | 1303 const std::vector<float>& new_touchscreen) { |
1280 webkit_platform_support_->SetFlingCurveParameters(new_touchpad, | 1304 webkit_platform_support_->SetFlingCurveParameters(new_touchpad, |
1281 new_touchscreen); | 1305 new_touchscreen); |
1282 | 1306 |
1283 } | 1307 } |
1284 | 1308 |
1285 } // namespace content | 1309 } // namespace content |
OLD | NEW |