| 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 "base/command_line.h" | 5 #include "base/command_line.h" |
| 6 #include "base/logging.h" | 6 #include "base/logging.h" |
| 7 #include "base/trace_event/trace_event.h" | 7 #include "base/trace_event/trace_event.h" |
| 8 #include "ui/events/devices/device_data_manager.h" | 8 #include "ui/events/devices/device_data_manager.h" |
| 9 #include "ui/ozone/platform_object.h" | 9 #include "ui/ozone/platform_object.h" |
| 10 #include "ui/ozone/platform_selection.h" | 10 #include "ui/ozone/platform_selection.h" |
| (...skipping 22 matching lines...) Expand all Loading... |
| 33 } | 33 } |
| 34 | 34 |
| 35 // static | 35 // static |
| 36 void OzonePlatform::InitializeForUI() { | 36 void OzonePlatform::InitializeForUI() { |
| 37 const InitParams params; | 37 const InitParams params; |
| 38 OzonePlatform::InitializeForUI(params); | 38 OzonePlatform::InitializeForUI(params); |
| 39 } | 39 } |
| 40 | 40 |
| 41 // static | 41 // static |
| 42 void OzonePlatform::InitializeForUI(const InitParams& args) { | 42 void OzonePlatform::InitializeForUI(const InitParams& args) { |
| 43 CreateInstance(); | 43 EnsureInstance(); |
| 44 if (g_platform_initialized_ui) | 44 if (g_platform_initialized_ui) |
| 45 return; | 45 return; |
| 46 g_platform_initialized_ui = true; | 46 g_platform_initialized_ui = true; |
| 47 instance_->InitializeUI(args); | 47 instance_->InitializeUI(args); |
| 48 // This is deliberately created after initializing so that the platform can | 48 // This is deliberately created after initializing so that the platform can |
| 49 // create its own version of DDM. | 49 // create its own version of DDM. |
| 50 DeviceDataManager::CreateInstance(); | 50 DeviceDataManager::CreateInstance(); |
| 51 } | 51 } |
| 52 | 52 |
| 53 // static | 53 // static |
| 54 void OzonePlatform::InitializeForGPU() { | 54 void OzonePlatform::InitializeForGPU() { |
| 55 const InitParams params; | 55 const InitParams params; |
| 56 OzonePlatform::InitializeForGPU(params); | 56 OzonePlatform::InitializeForGPU(params); |
| 57 } | 57 } |
| 58 | 58 |
| 59 // static | 59 // static |
| 60 void OzonePlatform::InitializeForGPU(const InitParams& args) { | 60 void OzonePlatform::InitializeForGPU(const InitParams& args) { |
| 61 CreateInstance(); | 61 EnsureInstance(); |
| 62 if (g_platform_initialized_gpu) | 62 if (g_platform_initialized_gpu) |
| 63 return; | 63 return; |
| 64 g_platform_initialized_gpu = true; | 64 g_platform_initialized_gpu = true; |
| 65 instance_->InitializeGPU(args); | 65 instance_->InitializeGPU(args); |
| 66 } | 66 } |
| 67 | 67 |
| 68 // static | 68 // static |
| 69 OzonePlatform* OzonePlatform::GetInstance() { | 69 OzonePlatform* OzonePlatform::GetInstance() { |
| 70 DCHECK(instance_) << "OzonePlatform is not initialized"; | 70 DCHECK(instance_) << "OzonePlatform is not initialized"; |
| 71 return instance_; | 71 return instance_; |
| 72 } | 72 } |
| 73 | 73 |
| 74 // static | 74 // static |
| 75 void OzonePlatform::CreateInstance() { | 75 OzonePlatform* OzonePlatform::EnsureInstance() { |
| 76 if (!instance_) { | 76 if (!instance_) { |
| 77 TRACE_EVENT1("ozone", | 77 TRACE_EVENT1("ozone", |
| 78 "OzonePlatform::Initialize", | 78 "OzonePlatform::Initialize", |
| 79 "platform", | 79 "platform", |
| 80 GetOzonePlatformName()); | 80 GetOzonePlatformName()); |
| 81 std::unique_ptr<OzonePlatform> platform = | 81 std::unique_ptr<OzonePlatform> platform = |
| 82 PlatformObject<OzonePlatform>::Create(); | 82 PlatformObject<OzonePlatform>::Create(); |
| 83 | 83 |
| 84 // TODO(spang): Currently need to leak this object. | 84 // TODO(spang): Currently need to leak this object. |
| 85 OzonePlatform* pl = platform.release(); | 85 OzonePlatform* pl = platform.release(); |
| 86 DCHECK_EQ(instance_, pl); | 86 DCHECK_EQ(instance_, pl); |
| 87 } | 87 } |
| 88 return instance_; |
| 88 } | 89 } |
| 89 | 90 |
| 90 // static | 91 // static |
| 91 OzonePlatform* OzonePlatform::instance_; | 92 OzonePlatform* OzonePlatform::instance_; |
| 92 | 93 |
| 93 // Convenience methods to facilitate transitionning to new API. | 94 // Convenience methods to facilitate transitionning to new API. |
| 94 void OzonePlatform::InitializeUI(const InitParams& args) { | 95 void OzonePlatform::InitializeUI(const InitParams& args) { |
| 95 InitializeUI(); | 96 InitializeUI(); |
| 96 } | 97 } |
| 98 |
| 97 void OzonePlatform::InitializeGPU(const InitParams& args) { | 99 void OzonePlatform::InitializeGPU(const InitParams& args) { |
| 98 InitializeGPU(); | 100 InitializeGPU(); |
| 99 } | 101 } |
| 100 | 102 |
| 101 IPC::MessageFilter* OzonePlatform::GetGpuMessageFilter() { | 103 IPC::MessageFilter* OzonePlatform::GetGpuMessageFilter() { |
| 102 return nullptr; | 104 return nullptr; |
| 103 } | 105 } |
| 106 |
| 107 base::MessageLoop::Type OzonePlatform::GetMessageLoopTypeForGpu() { |
| 108 return base::MessageLoop::TYPE_DEFAULT; |
| 109 } |
| 110 |
| 104 void OzonePlatform::AddInterfaces( | 111 void OzonePlatform::AddInterfaces( |
| 105 service_manager::InterfaceRegistry* registry) {} | 112 service_manager::InterfaceRegistry* registry) {} |
| 106 | 113 |
| 107 } // namespace ui | 114 } // namespace ui |
| OLD | NEW |