Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(229)

Side by Side Diff: services/ui/public/cpp/gpu/gpu_service.cc

Issue 2516943002: mus-gpu: Fix a couple of issues with MojoGpuMemoryBufferManager. (Closed)
Patch Set: Created 4 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | services/ui/public/cpp/gpu/mojo_gpu_memory_buffer_manager.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "services/ui/public/cpp/gpu/gpu_service.h" 5 #include "services/ui/public/cpp/gpu/gpu_service.h"
6 6
7 #include "base/command_line.h" 7 #include "base/command_line.h"
8 #include "base/memory/singleton.h" 8 #include "base/memory/singleton.h"
9 #include "base/threading/thread_task_runner_handle.h" 9 #include "base/threading/thread_task_runner_handle.h"
10 #include "build/build_config.h" 10 #include "build/build_config.h"
11 #include "mojo/public/cpp/bindings/sync_call_restrictions.h" 11 #include "mojo/public/cpp/bindings/sync_call_restrictions.h"
12 #include "mojo/public/cpp/system/platform_handle.h" 12 #include "mojo/public/cpp/system/platform_handle.h"
13 #include "services/service_manager/public/cpp/connector.h" 13 #include "services/service_manager/public/cpp/connector.h"
14 #include "services/ui/common/switches.h" 14 #include "services/ui/common/switches.h"
15 #include "services/ui/public/cpp/gpu/mojo_gpu_memory_buffer_manager.h" 15 #include "services/ui/public/cpp/gpu/mojo_gpu_memory_buffer_manager.h"
16 #include "services/ui/public/interfaces/constants.mojom.h" 16 #include "services/ui/public/interfaces/constants.mojom.h"
17 #include "services/ui/public/interfaces/gpu_service.mojom.h" 17 #include "services/ui/public/interfaces/gpu_service.mojom.h"
18 18
19 namespace ui { 19 namespace ui {
20 20
21 GpuService::GpuService(service_manager::Connector* connector, 21 GpuService::GpuService(service_manager::Connector* connector,
22 scoped_refptr<base::SingleThreadTaskRunner> task_runner) 22 scoped_refptr<base::SingleThreadTaskRunner> task_runner)
23 : main_task_runner_(base::ThreadTaskRunnerHandle::Get()), 23 : main_task_runner_(base::ThreadTaskRunnerHandle::Get()),
24 io_task_runner_(std::move(task_runner)), 24 io_task_runner_(std::move(task_runner)),
25 connector_(connector), 25 connector_(connector),
26 shutdown_event_(base::WaitableEvent::ResetPolicy::AUTOMATIC, 26 shutdown_event_(base::WaitableEvent::ResetPolicy::AUTOMATIC,
27 base::WaitableEvent::InitialState::NOT_SIGNALED), 27 base::WaitableEvent::InitialState::NOT_SIGNALED) {
28 gpu_memory_buffer_manager_(new MojoGpuMemoryBufferManager(connector_)) {
29 DCHECK(main_task_runner_); 28 DCHECK(main_task_runner_);
30 DCHECK(connector_); 29 DCHECK(connector_);
30 mojom::GpuServicePtr gpu_service_ptr;
31 connector_->ConnectToInterface(ui::mojom::kServiceName, &gpu_service_ptr);
32 gpu_memory_buffer_manager_ =
33 base::MakeUnique<MojoGpuMemoryBufferManager>(std::move(gpu_service_ptr));
31 if (!io_task_runner_) { 34 if (!io_task_runner_) {
32 io_thread_.reset(new base::Thread("GPUIOThread")); 35 io_thread_.reset(new base::Thread("GPUIOThread"));
33 base::Thread::Options thread_options(base::MessageLoop::TYPE_IO, 0); 36 base::Thread::Options thread_options(base::MessageLoop::TYPE_IO, 0);
34 thread_options.priority = base::ThreadPriority::NORMAL; 37 thread_options.priority = base::ThreadPriority::NORMAL;
35 CHECK(io_thread_->StartWithOptions(thread_options)); 38 CHECK(io_thread_->StartWithOptions(thread_options));
36 io_task_runner_ = io_thread_->task_runner(); 39 io_task_runner_ = io_thread_->task_runner();
37 } 40 }
38 } 41 }
39 42
40 GpuService::~GpuService() { 43 GpuService::~GpuService() {
(...skipping 106 matching lines...) Expand 10 before | Expand all | Expand 10 after
147 MojoResult result = mojo::UnwrapSharedMemoryHandle( 150 MojoResult result = mojo::UnwrapSharedMemoryHandle(
148 std::move(handle), &platform_handle, &shared_memory_size, &readonly); 151 std::move(handle), &platform_handle, &shared_memory_size, &readonly);
149 if (result != MOJO_RESULT_OK) 152 if (result != MOJO_RESULT_OK)
150 return nullptr; 153 return nullptr;
151 DCHECK_EQ(shared_memory_size, size); 154 DCHECK_EQ(shared_memory_size, size);
152 155
153 return base::MakeUnique<base::SharedMemory>(platform_handle, readonly); 156 return base::MakeUnique<base::SharedMemory>(platform_handle, readonly);
154 } 157 }
155 158
156 } // namespace ui 159 } // namespace ui
OLDNEW
« no previous file with comments | « no previous file | services/ui/public/cpp/gpu/mojo_gpu_memory_buffer_manager.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698