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

Side by Side Diff: components/native_viewport/onscreen_context_provider.cc

Issue 1139673003: Make Mandoline shut down cleanly. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: fix X errors on Linux Created 5 years, 7 months 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
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 "components/native_viewport/onscreen_context_provider.h" 5 #include "components/native_viewport/onscreen_context_provider.h"
6 6
7 #include "base/bind.h"
7 #include "components/gles2/command_buffer_driver.h" 8 #include "components/gles2/command_buffer_driver.h"
8 #include "components/gles2/command_buffer_impl.h" 9 #include "components/gles2/command_buffer_impl.h"
9 #include "components/gles2/gpu_state.h" 10 #include "components/gles2/gpu_state.h"
10 11
11 namespace native_viewport { 12 namespace native_viewport {
12 13
13 OnscreenContextProvider::OnscreenContextProvider( 14 OnscreenContextProvider::OnscreenContextProvider(
14 const scoped_refptr<gles2::GpuState>& state) 15 const scoped_refptr<gles2::GpuState>& state)
15 : state_(state), widget_(gfx::kNullAcceleratedWidget), binding_(this) { 16 : state_(state),
17 widget_(gfx::kNullAcceleratedWidget),
18 binding_(this) {
16 } 19 }
17 20
18 OnscreenContextProvider::~OnscreenContextProvider() { 21 OnscreenContextProvider::~OnscreenContextProvider() {
22 for(const auto& driver : command_buffers_)
Elliot Glaysher 2015/05/14 22:53:40 for (
jam 2015/05/15 02:15:31 Done.
23 driver->DestroyWindow();
19 } 24 }
20 25
21 void OnscreenContextProvider::Bind( 26 void OnscreenContextProvider::Bind(
22 mojo::InterfaceRequest<mojo::ContextProvider> request) { 27 mojo::InterfaceRequest<mojo::ContextProvider> request) {
23 binding_.Bind(request.Pass()); 28 binding_.Bind(request.Pass());
24 } 29 }
25 30
26 void OnscreenContextProvider::SetAcceleratedWidget( 31 void OnscreenContextProvider::SetAcceleratedWidget(
27 gfx::AcceleratedWidget widget) { 32 gfx::AcceleratedWidget widget) {
28 widget_ = widget; 33 widget_ = widget;
29 if (widget_ != gfx::kNullAcceleratedWidget && 34 if (widget_ != gfx::kNullAcceleratedWidget &&
30 !pending_create_callback_.is_null()) 35 !pending_create_callback_.is_null())
31 CreateAndReturnCommandBuffer(); 36 CreateAndReturnCommandBuffer();
32 } 37 }
33 38
34 void OnscreenContextProvider::Create( 39 void OnscreenContextProvider::Create(
35 mojo::ViewportParameterListenerPtr viewport_parameter_listener, 40 mojo::ViewportParameterListenerPtr viewport_parameter_listener,
36 const CreateCallback& callback) { 41 const CreateCallback& callback) {
37 if (!pending_create_callback_.is_null()) 42 if (!pending_create_callback_.is_null())
38 pending_create_callback_.Run(nullptr); 43 pending_create_callback_.Run(nullptr);
39 pending_listener_ = viewport_parameter_listener.Pass(); 44 pending_listener_ = viewport_parameter_listener.Pass();
40 pending_create_callback_ = callback; 45 pending_create_callback_ = callback;
41 46
42 if (widget_ != gfx::kNullAcceleratedWidget) 47 if (widget_ != gfx::kNullAcceleratedWidget)
43 CreateAndReturnCommandBuffer(); 48 CreateAndReturnCommandBuffer();
44 } 49 }
45 50
46 void OnscreenContextProvider::CreateAndReturnCommandBuffer() { 51 void OnscreenContextProvider::CreateAndReturnCommandBuffer() {
47 mojo::CommandBufferPtr cb; 52 mojo::CommandBufferPtr cb;
53 scoped_ptr<gles2::CommandBufferDriver> command_buffer_driver(
54 new gles2::CommandBufferDriver(
55 widget_, state_->share_group(), state_->mailbox_manager(),
56 state_->sync_point_manager(),
57 base::Bind(&OnscreenContextProvider::CommandBufferDestroyed,
58 base::Unretained(this))));
59 command_buffers_.insert(command_buffer_driver.get());
60
48 new gles2::CommandBufferImpl( 61 new gles2::CommandBufferImpl(
49 GetProxy(&cb), pending_listener_.Pass(), state_->control_task_runner(), 62 GetProxy(&cb), pending_listener_.Pass(), state_->control_task_runner(),
50 state_->sync_point_manager(), 63 state_->sync_point_manager(),
51 make_scoped_ptr(new gles2::CommandBufferDriver( 64 command_buffer_driver.Pass());
52 widget_, state_->share_group(), state_->mailbox_manager(),
53 state_->sync_point_manager())));
54 pending_create_callback_.Run(cb.Pass()); 65 pending_create_callback_.Run(cb.Pass());
55 pending_create_callback_.reset(); 66 pending_create_callback_.reset();
56 } 67 }
57 68
69 void OnscreenContextProvider::CommandBufferDestroyed(
70 gles2::CommandBufferDriver* command_buffer) {
71 command_buffers_.erase(command_buffer);
72 }
73
58 } // namespace mojo 74 } // namespace mojo
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698