Chromium Code Reviews| 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_accelerator_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/media/webrtc_identity_service.h" | 75 #include "content/renderer/media/webrtc_identity_service.h" |
| 75 #include "content/renderer/memory_benchmarking_extension.h" | 76 #include "content/renderer/memory_benchmarking_extension.h" |
| 76 #include "content/renderer/p2p/socket_dispatcher.h" | 77 #include "content/renderer/p2p/socket_dispatcher.h" |
| 77 #include "content/renderer/plugin_channel_host.h" | 78 #include "content/renderer/plugin_channel_host.h" |
| 78 #include "content/renderer/render_process_impl.h" | 79 #include "content/renderer/render_process_impl.h" |
| 79 #include "content/renderer/render_process_visibility_manager.h" | 80 #include "content/renderer/render_process_visibility_manager.h" |
| 80 #include "content/renderer/render_view_impl.h" | 81 #include "content/renderer/render_view_impl.h" |
| 81 #include "content/renderer/renderer_webkitplatformsupport_impl.h" | 82 #include "content/renderer/renderer_webkitplatformsupport_impl.h" |
| 82 #include "content/renderer/skia_benchmarking_extension.h" | 83 #include "content/renderer/skia_benchmarking_extension.h" |
| 83 #include "grit/content_resources.h" | 84 #include "grit/content_resources.h" |
| 84 #include "ipc/ipc_channel_handle.h" | 85 #include "ipc/ipc_channel_handle.h" |
| 85 #include "ipc/ipc_forwarding_message_filter.h" | 86 #include "ipc/ipc_forwarding_message_filter.h" |
| 86 #include "ipc/ipc_platform_file.h" | 87 #include "ipc/ipc_platform_file.h" |
| 87 #include "media/base/audio_hardware_config.h" | 88 #include "media/base/audio_hardware_config.h" |
| 88 #include "media/base/media.h" | 89 #include "media/base/media.h" |
| 89 #include "media/filters/gpu_video_decoder_factories.h" | 90 #include "media/filters/gpu_video_accelerator_factories.h" |
| 90 #include "net/base/net_errors.h" | 91 #include "net/base/net_errors.h" |
| 91 #include "net/base/net_util.h" | 92 #include "net/base/net_util.h" |
| 92 #include "third_party/WebKit/public/platform/WebString.h" | 93 #include "third_party/WebKit/public/platform/WebString.h" |
| 93 #include "third_party/WebKit/public/web/WebColorName.h" | 94 #include "third_party/WebKit/public/web/WebColorName.h" |
| 94 #include "third_party/WebKit/public/web/WebDatabase.h" | 95 #include "third_party/WebKit/public/web/WebDatabase.h" |
| 95 #include "third_party/WebKit/public/web/WebDocument.h" | 96 #include "third_party/WebKit/public/web/WebDocument.h" |
| 96 #include "third_party/WebKit/public/web/WebFrame.h" | 97 #include "third_party/WebKit/public/web/WebFrame.h" |
| 97 #include "third_party/WebKit/public/web/WebImageCache.h" | 98 #include "third_party/WebKit/public/web/WebImageCache.h" |
| 98 #include "third_party/WebKit/public/web/WebKit.h" | 99 #include "third_party/WebKit/public/web/WebKit.h" |
| 99 #include "third_party/WebKit/public/web/WebNetworkStateNotifier.h" | 100 #include "third_party/WebKit/public/web/WebNetworkStateNotifier.h" |
| (...skipping 793 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 893 bool RenderThreadImpl::ResolveProxy(const GURL& url, std::string* proxy_list) { | 894 bool RenderThreadImpl::ResolveProxy(const GURL& url, std::string* proxy_list) { |
| 894 bool result = false; | 895 bool result = false; |
| 895 Send(new ViewHostMsg_ResolveProxy(url, &result, proxy_list)); | 896 Send(new ViewHostMsg_ResolveProxy(url, &result, proxy_list)); |
| 896 return result; | 897 return result; |
| 897 } | 898 } |
| 898 | 899 |
| 899 void RenderThreadImpl::PostponeIdleNotification() { | 900 void RenderThreadImpl::PostponeIdleNotification() { |
| 900 idle_notifications_to_skip_ = 2; | 901 idle_notifications_to_skip_ = 2; |
| 901 } | 902 } |
| 902 | 903 |
| 903 scoped_refptr<RendererGpuVideoDecoderFactories> | 904 scoped_refptr<media::GpuVideoAcceleratorFactories> |
| 904 RenderThreadImpl::GetGpuFactories( | 905 RenderThreadImpl::GetGpuFactories( |
| 905 const scoped_refptr<base::MessageLoopProxy>& factories_loop) { | 906 const scoped_refptr<base::MessageLoopProxy>& factories_loop) { |
| 906 DCHECK(IsMainThread()); | 907 DCHECK(IsMainThread()); |
| 907 | 908 |
| 908 const CommandLine* cmd_line = CommandLine::ForCurrentProcess(); | 909 const CommandLine* cmd_line = CommandLine::ForCurrentProcess(); |
| 909 scoped_refptr<RendererGpuVideoDecoderFactories> gpu_factories; | 910 scoped_refptr<media::GpuVideoAcceleratorFactories> gpu_factories; |
| 910 WebGraphicsContext3DCommandBufferImpl* context3d = NULL; | 911 WebGraphicsContext3DCommandBufferImpl* context3d = NULL; |
| 911 if (!cmd_line->HasSwitch(switches::kDisableAcceleratedVideoDecode)) | 912 if (!cmd_line->HasSwitch(switches::kDisableAcceleratedVideoDecode)) |
| 912 context3d = GetGpuVDAContext3D(); | 913 context3d = GetGpuVDAContext3D(); |
| 913 if (context3d) { | 914 GpuChannelHost* gpu_channel_host = GetGpuChannel(); |
| 914 GpuChannelHost* gpu_channel_host = GetGpuChannel(); | 915 if (gpu_channel_host) { |
| 915 if (gpu_channel_host) { | 916 gpu_factories = new RendererGpuVideoAcceleratorFactories( |
| 916 gpu_factories = new RendererGpuVideoDecoderFactories( | 917 gpu_channel_host, factories_loop, context3d); |
|
Ami GONE FROM CHROMIUM
2013/07/31 23:01:12
What's the use of allocating a RendererGpuVideoAcc
sheu
2013/08/02 01:27:49
HW-accelerated decoding requires a context, since
| |
| 917 gpu_channel_host, factories_loop, context3d); | |
| 918 } | |
| 919 } | 918 } |
| 920 return gpu_factories; | 919 return gpu_factories; |
| 921 } | 920 } |
| 922 | 921 |
| 923 /* static */ | 922 /* static */ |
| 924 void RenderThreadImpl::OnGpuVDAContextLoss() { | 923 void RenderThreadImpl::OnGpuVDAContextLoss() { |
| 925 RenderThreadImpl* self = RenderThreadImpl::current(); | 924 RenderThreadImpl* self = RenderThreadImpl::current(); |
| 926 DCHECK(self); | 925 DCHECK(self); |
| 927 if (!self->gpu_vda_context3d_) | 926 if (!self->gpu_vda_context3d_) |
| 928 return; | 927 return; |
| (...skipping 386 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1315 | 1314 |
| 1316 void RenderThreadImpl::SetFlingCurveParameters( | 1315 void RenderThreadImpl::SetFlingCurveParameters( |
| 1317 const std::vector<float>& new_touchpad, | 1316 const std::vector<float>& new_touchpad, |
| 1318 const std::vector<float>& new_touchscreen) { | 1317 const std::vector<float>& new_touchscreen) { |
| 1319 webkit_platform_support_->SetFlingCurveParameters(new_touchpad, | 1318 webkit_platform_support_->SetFlingCurveParameters(new_touchpad, |
| 1320 new_touchscreen); | 1319 new_touchscreen); |
| 1321 | 1320 |
| 1322 } | 1321 } |
| 1323 | 1322 |
| 1324 } // namespace content | 1323 } // namespace content |
| OLD | NEW |