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/renderer_webkitplatformsupport_impl.h" | 5 #include "content/renderer/renderer_webkitplatformsupport_impl.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/files/file_path.h" | 8 #include "base/files/file_path.h" |
9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
10 #include "base/logging.h" | 10 #include "base/logging.h" |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
74 #include "third_party/WebKit/public/platform/WebPluginListBuilder.h" | 74 #include "third_party/WebKit/public/platform/WebPluginListBuilder.h" |
75 #include "third_party/WebKit/public/platform/WebURL.h" | 75 #include "third_party/WebKit/public/platform/WebURL.h" |
76 #include "third_party/WebKit/public/platform/WebVector.h" | 76 #include "third_party/WebKit/public/platform/WebVector.h" |
77 #include "ui/gfx/color_profile.h" | 77 #include "ui/gfx/color_profile.h" |
78 #include "url/gurl.h" | 78 #include "url/gurl.h" |
79 #include "webkit/common/gpu/context_provider_web_context.h" | 79 #include "webkit/common/gpu/context_provider_web_context.h" |
80 | 80 |
81 #if defined(OS_ANDROID) | 81 #if defined(OS_ANDROID) |
82 #include "content/renderer/android/synchronous_compositor_factory.h" | 82 #include "content/renderer/android/synchronous_compositor_factory.h" |
83 #include "content/renderer/media/android/audio_decoder_android.h" | 83 #include "content/renderer/media/android/audio_decoder_android.h" |
84 #include "webkit/common/gpu/webgraphicscontext3d_in_process_command_buffer_impl. h" | |
84 #endif | 85 #endif |
85 | 86 |
86 #if defined(OS_MACOSX) | 87 #if defined(OS_MACOSX) |
87 #include "content/common/mac/font_descriptor.h" | 88 #include "content/common/mac/font_descriptor.h" |
88 #include "content/common/mac/font_loader.h" | 89 #include "content/common/mac/font_loader.h" |
89 #include "content/renderer/webscrollbarbehavior_impl_mac.h" | 90 #include "content/renderer/webscrollbarbehavior_impl_mac.h" |
90 #include "third_party/WebKit/public/platform/mac/WebSandboxSupport.h" | 91 #include "third_party/WebKit/public/platform/mac/WebSandboxSupport.h" |
91 #endif | 92 #endif |
92 | 93 |
93 #if defined(OS_POSIX) | 94 #if defined(OS_POSIX) |
(...skipping 851 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
945 return createOffscreenGraphicsContext3D(attributes, NULL); | 946 return createOffscreenGraphicsContext3D(attributes, NULL); |
946 } | 947 } |
947 | 948 |
948 blink::WebGraphicsContext3D* | 949 blink::WebGraphicsContext3D* |
949 RendererWebKitPlatformSupportImpl::createOffscreenGraphicsContext3D( | 950 RendererWebKitPlatformSupportImpl::createOffscreenGraphicsContext3D( |
950 const blink::WebGraphicsContext3D::Attributes& attributes, | 951 const blink::WebGraphicsContext3D::Attributes& attributes, |
951 blink::WebGraphicsContext3D* share_context) { | 952 blink::WebGraphicsContext3D* share_context) { |
952 if (!RenderThreadImpl::current()) | 953 if (!RenderThreadImpl::current()) |
953 return NULL; | 954 return NULL; |
954 | 955 |
955 scoped_ptr<webkit::gpu::WebGraphicsContext3DImpl> context; | |
956 bool must_use_synchronous_factory = false; | |
957 #if defined(OS_ANDROID) | 956 #if defined(OS_ANDROID) |
957 scoped_ptr<webkit::gpu::WebGraphicsContext3DInProcessCommandBufferImpl> | |
958 context; | |
958 if (SynchronousCompositorFactory* factory = | 959 if (SynchronousCompositorFactory* factory = |
959 SynchronousCompositorFactory::GetInstance()) { | 960 SynchronousCompositorFactory::GetInstance()) { |
960 context.reset(factory->CreateOffscreenGraphicsContext3D(attributes)); | 961 context.reset(factory->CreateOffscreenGraphicsContext3D(attributes)); |
961 must_use_synchronous_factory = true; | |
962 } | 962 } |
jamesr
2014/09/29 18:00:57
this is not correct.
in the previous code on OS_A
| |
963 #else | |
964 scoped_ptr<WebGraphicsContext3DCommandBufferImpl> context; | |
965 scoped_refptr<GpuChannelHost> gpu_channel_host( | |
966 RenderThreadImpl::current()->EstablishGpuChannelSync( | |
967 CAUSE_FOR_GPU_LAUNCH_WEBGRAPHICSCONTEXT3DCOMMANDBUFFERIMPL_INITIALIZE) ); | |
968 | |
969 WebGraphicsContext3DCommandBufferImpl::SharedMemoryLimits limits; | |
970 bool lose_context_when_out_of_memory = false; | |
971 context.reset(WebGraphicsContext3DCommandBufferImpl::CreateOffscreenContext( | |
972 gpu_channel_host.get(), | |
973 attributes, | |
974 lose_context_when_out_of_memory, | |
975 GURL(attributes.topDocumentURL), | |
976 limits, | |
977 static_cast<WebGraphicsContext3DCommandBufferImpl*>(share_context))); | |
963 #endif | 978 #endif |
964 if (!must_use_synchronous_factory) { | |
965 scoped_refptr<GpuChannelHost> gpu_channel_host( | |
966 RenderThreadImpl::current()->EstablishGpuChannelSync( | |
967 CAUSE_FOR_GPU_LAUNCH_WEBGRAPHICSCONTEXT3DCOMMANDBUFFERIMPL_INITIALIZ E)); | |
968 | |
969 WebGraphicsContext3DCommandBufferImpl::SharedMemoryLimits limits; | |
970 bool lose_context_when_out_of_memory = false; | |
971 context.reset(WebGraphicsContext3DCommandBufferImpl::CreateOffscreenContext( | |
972 gpu_channel_host.get(), | |
973 attributes, | |
974 lose_context_when_out_of_memory, | |
975 GURL(attributes.topDocumentURL), | |
976 limits, | |
977 static_cast<WebGraphicsContext3DCommandBufferImpl*>(share_context))); | |
978 } | |
979 // Most likely the GPU process exited and the attempt to reconnect to it | 979 // Most likely the GPU process exited and the attempt to reconnect to it |
980 // failed. Need to try to restore the context again later. | 980 // failed. Need to try to restore the context again later. |
981 if (!context || !context->InitializeOnCurrentThread()) | 981 if (!context || !context->InitializeOnCurrentThread()) |
982 return NULL; | 982 return NULL; |
983 return context.release(); | 983 return context.release(); |
984 } | 984 } |
985 | 985 |
986 //------------------------------------------------------------------------------ | 986 //------------------------------------------------------------------------------ |
987 | 987 |
988 blink::WebGraphicsContext3DProvider* RendererWebKitPlatformSupportImpl:: | 988 blink::WebGraphicsContext3DProvider* RendererWebKitPlatformSupportImpl:: |
(...skipping 193 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1182 void RendererWebKitPlatformSupportImpl::MockBatteryStatusChangedForTesting( | 1182 void RendererWebKitPlatformSupportImpl::MockBatteryStatusChangedForTesting( |
1183 const blink::WebBatteryStatus& status) { | 1183 const blink::WebBatteryStatus& status) { |
1184 PlatformEventObserverBase* observer = | 1184 PlatformEventObserverBase* observer = |
1185 platform_event_observers_.Lookup(blink::WebPlatformEventBattery); | 1185 platform_event_observers_.Lookup(blink::WebPlatformEventBattery); |
1186 if (!observer) | 1186 if (!observer) |
1187 return; | 1187 return; |
1188 observer->SendFakeDataForTesting((void*)&status); | 1188 observer->SendFakeDataForTesting((void*)&status); |
1189 } | 1189 } |
1190 | 1190 |
1191 } // namespace content | 1191 } // namespace content |
OLD | NEW |