| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/browser/compositor/gpu_process_transport_factory.h" | 5 #include "content/browser/compositor/gpu_process_transport_factory.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 46 #include "gpu/command_buffer/client/gles2_interface.h" | 46 #include "gpu/command_buffer/client/gles2_interface.h" |
| 47 #include "gpu/command_buffer/common/mailbox.h" | 47 #include "gpu/command_buffer/common/mailbox.h" |
| 48 #include "third_party/khronos/GLES2/gl2.h" | 48 #include "third_party/khronos/GLES2/gl2.h" |
| 49 #include "ui/compositor/compositor.h" | 49 #include "ui/compositor/compositor.h" |
| 50 #include "ui/compositor/compositor_constants.h" | 50 #include "ui/compositor/compositor_constants.h" |
| 51 #include "ui/compositor/compositor_switches.h" | 51 #include "ui/compositor/compositor_switches.h" |
| 52 #include "ui/compositor/layer.h" | 52 #include "ui/compositor/layer.h" |
| 53 #include "ui/gfx/geometry/size.h" | 53 #include "ui/gfx/geometry/size.h" |
| 54 #include "ui/gfx/native_widget_types.h" | 54 #include "ui/gfx/native_widget_types.h" |
| 55 | 55 |
| 56 #if defined(MOJO_RUNNER_CLIENT) |
| 57 #include "content/common/mojo/mojo_shell_connection_impl.h" |
| 58 #endif |
| 59 |
| 56 #if defined(OS_WIN) | 60 #if defined(OS_WIN) |
| 57 #include "content/browser/compositor/software_output_device_win.h" | 61 #include "content/browser/compositor/software_output_device_win.h" |
| 58 #elif defined(USE_OZONE) | 62 #elif defined(USE_OZONE) |
| 59 #include "content/browser/compositor/browser_compositor_overlay_candidate_valida
tor_ozone.h" | 63 #include "content/browser/compositor/browser_compositor_overlay_candidate_valida
tor_ozone.h" |
| 60 #include "content/browser/compositor/software_output_device_ozone.h" | 64 #include "content/browser/compositor/software_output_device_ozone.h" |
| 61 #include "ui/ozone/public/overlay_candidates_ozone.h" | 65 #include "ui/ozone/public/overlay_candidates_ozone.h" |
| 62 #include "ui/ozone/public/overlay_manager_ozone.h" | 66 #include "ui/ozone/public/overlay_manager_ozone.h" |
| 63 #include "ui/ozone/public/ozone_platform.h" | 67 #include "ui/ozone/public/ozone_platform.h" |
| 64 #include "ui/ozone/public/ozone_switches.h" | 68 #include "ui/ozone/public/ozone_switches.h" |
| 65 #elif defined(USE_X11) | 69 #elif defined(USE_X11) |
| (...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 143 scoped_refptr<GpuChannelHost> gpu_channel_host( | 147 scoped_refptr<GpuChannelHost> gpu_channel_host( |
| 144 BrowserGpuChannelHostFactory::instance()->EstablishGpuChannelSync(cause)); | 148 BrowserGpuChannelHostFactory::instance()->EstablishGpuChannelSync(cause)); |
| 145 return CreateContextCommon(gpu_channel_host, 0); | 149 return CreateContextCommon(gpu_channel_host, 0); |
| 146 #endif // OS_ANDROID | 150 #endif // OS_ANDROID |
| 147 } | 151 } |
| 148 | 152 |
| 149 scoped_ptr<cc::SoftwareOutputDevice> | 153 scoped_ptr<cc::SoftwareOutputDevice> |
| 150 GpuProcessTransportFactory::CreateSoftwareOutputDevice( | 154 GpuProcessTransportFactory::CreateSoftwareOutputDevice( |
| 151 ui::Compositor* compositor) { | 155 ui::Compositor* compositor) { |
| 152 #if defined(MOJO_RUNNER_CLIENT) | 156 #if defined(MOJO_RUNNER_CLIENT) |
| 153 if (base::CommandLine::ForCurrentProcess()->HasSwitch( | 157 if (IsRunningInMojoShell()) { |
| 154 "mojo-platform-channel-handle")) { | |
| 155 return scoped_ptr<cc::SoftwareOutputDevice>( | 158 return scoped_ptr<cc::SoftwareOutputDevice>( |
| 156 new SoftwareOutputDeviceMus(compositor)); | 159 new SoftwareOutputDeviceMus(compositor)); |
| 157 } | 160 } |
| 158 #endif | 161 #endif |
| 159 | 162 |
| 160 #if defined(OS_WIN) | 163 #if defined(OS_WIN) |
| 161 return scoped_ptr<cc::SoftwareOutputDevice>( | 164 return scoped_ptr<cc::SoftwareOutputDevice>( |
| 162 new SoftwareOutputDeviceWin(software_backing_.get(), compositor)); | 165 new SoftwareOutputDeviceWin(software_backing_.get(), compositor)); |
| 163 #elif defined(USE_OZONE) | 166 #elif defined(USE_OZONE) |
| 164 return scoped_ptr<cc::SoftwareOutputDevice>(new SoftwareOutputDeviceOzone( | 167 return scoped_ptr<cc::SoftwareOutputDevice>(new SoftwareOutputDeviceOzone( |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 197 new BrowserCompositorOverlayCandidateValidatorMac(widget)); | 200 new BrowserCompositorOverlayCandidateValidatorMac(widget)); |
| 198 } | 201 } |
| 199 #endif | 202 #endif |
| 200 return scoped_ptr<BrowserCompositorOverlayCandidateValidator>(); | 203 return scoped_ptr<BrowserCompositorOverlayCandidateValidator>(); |
| 201 } | 204 } |
| 202 | 205 |
| 203 static bool ShouldCreateGpuOutputSurface(ui::Compositor* compositor) { | 206 static bool ShouldCreateGpuOutputSurface(ui::Compositor* compositor) { |
| 204 #if defined(MOJO_RUNNER_CLIENT) | 207 #if defined(MOJO_RUNNER_CLIENT) |
| 205 // Chrome running as a mojo app currently can only use software compositing. | 208 // Chrome running as a mojo app currently can only use software compositing. |
| 206 // TODO(rjkroege): http://crbug.com/548451 | 209 // TODO(rjkroege): http://crbug.com/548451 |
| 207 // TODO(rjkroege): Make IsRunningInMojoRunner callable from content. | 210 if (IsRunningInMojoShell()) { |
| 208 if (base::CommandLine::ForCurrentProcess()->HasSwitch( | |
| 209 "mojo-platform-channel-handle")) { | |
| 210 return false; | 211 return false; |
| 211 } | 212 } |
| 212 #endif | 213 #endif |
| 213 | 214 |
| 214 #if defined(OS_CHROMEOS) | 215 #if defined(OS_CHROMEOS) |
| 215 // Software fallback does not happen on Chrome OS. | 216 // Software fallback does not happen on Chrome OS. |
| 216 return true; | 217 return true; |
| 217 #endif | 218 #endif |
| 218 | 219 |
| 219 #if defined(OS_WIN) | 220 #if defined(OS_WIN) |
| (...skipping 451 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 671 FOR_EACH_OBSERVER(ImageTransportFactoryObserver, | 672 FOR_EACH_OBSERVER(ImageTransportFactoryObserver, |
| 672 observer_list_, | 673 observer_list_, |
| 673 OnLostResources()); | 674 OnLostResources()); |
| 674 | 675 |
| 675 // Kill things that use the shared context before killing the shared context. | 676 // Kill things that use the shared context before killing the shared context. |
| 676 lost_gl_helper.reset(); | 677 lost_gl_helper.reset(); |
| 677 lost_shared_main_thread_contexts = NULL; | 678 lost_shared_main_thread_contexts = NULL; |
| 678 } | 679 } |
| 679 | 680 |
| 680 } // namespace content | 681 } // namespace content |
| OLD | NEW |