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 "mojo/cc/context_provider_mojo.h" | 5 #include "mojo/cc/context_provider_mojo.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "mojo/public/cpp/environment/environment.h" |
8 | 9 |
9 namespace mojo { | 10 namespace mojo { |
10 | 11 |
11 ContextProviderMojo::ContextProviderMojo( | 12 ContextProviderMojo::ContextProviderMojo( |
12 ScopedMessagePipeHandle command_buffer_handle) | 13 ScopedMessagePipeHandle command_buffer_handle) |
13 : command_buffer_handle_(command_buffer_handle.Pass()), | 14 : command_buffer_handle_(command_buffer_handle.Pass()), |
14 context_lost_(false) { | 15 context_lost_(false) { |
15 } | 16 } |
16 | 17 |
17 bool ContextProviderMojo::BindToCurrentThread() { | 18 bool ContextProviderMojo::BindToCurrentThread() { |
18 DCHECK(command_buffer_handle_.is_valid()); | 19 DCHECK(command_buffer_handle_.is_valid()); |
19 context_ = MojoGLES2CreateContext( | 20 context_ = MojoGLES2CreateContext( |
20 command_buffer_handle_.release().value(), | 21 command_buffer_handle_.release().value(), |
21 &ContextLostThunk, | 22 &ContextLostThunk, |
22 this); | 23 this, |
| 24 Environment::GetDefaultAsyncWaiter()); |
23 return !!context_; | 25 return !!context_; |
24 } | 26 } |
25 | 27 |
26 gpu::gles2::GLES2Interface* ContextProviderMojo::ContextGL() { | 28 gpu::gles2::GLES2Interface* ContextProviderMojo::ContextGL() { |
27 if (!context_) | 29 if (!context_) |
28 return NULL; | 30 return NULL; |
29 return static_cast<gpu::gles2::GLES2Interface*>( | 31 return static_cast<gpu::gles2::GLES2Interface*>( |
30 MojoGLES2GetGLES2Interface(context_)); | 32 MojoGLES2GetGLES2Interface(context_)); |
31 } | 33 } |
32 | 34 |
(...skipping 18 matching lines...) Expand all Loading... |
51 ContextProviderMojo::~ContextProviderMojo() { | 53 ContextProviderMojo::~ContextProviderMojo() { |
52 if (context_) | 54 if (context_) |
53 MojoGLES2DestroyContext(context_); | 55 MojoGLES2DestroyContext(context_); |
54 } | 56 } |
55 | 57 |
56 void ContextProviderMojo::ContextLost() { | 58 void ContextProviderMojo::ContextLost() { |
57 context_lost_ = true; | 59 context_lost_ = true; |
58 } | 60 } |
59 | 61 |
60 } // namespace mojo | 62 } // namespace mojo |
OLD | NEW |