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

Side by Side Diff: webkit/common/gpu/grcontext_for_webgraphicscontext3d.cc

Issue 470973002: gpu: Remove WebGraphicsContext3D::makeContextCurrent() (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: build fix in unittests Created 6 years, 3 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 (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2013 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 "webkit/common/gpu/grcontext_for_webgraphicscontext3d.h" 5 #include "webkit/common/gpu/grcontext_for_webgraphicscontext3d.h"
6 6
7 #include "base/debug/trace_event.h" 7 #include "base/debug/trace_event.h"
8 #include "third_party/WebKit/public/platform/WebGraphicsContext3D.h" 8 #include "base/lazy_instance.h"
9 #include "gpu/command_buffer/client/gles2_lib.h"
9 #include "third_party/skia/include/gpu/GrContext.h" 10 #include "third_party/skia/include/gpu/GrContext.h"
10 #include "third_party/skia/include/gpu/gl/GrGLInterface.h" 11 #include "third_party/skia/include/gpu/gl/GrGLInterface.h"
12 #include "webkit/common/gpu/webgraphicscontext3d_impl.h"
11 13
12 namespace webkit { 14 namespace webkit {
13 namespace gpu { 15 namespace gpu {
14 16
15 static void BindWebGraphicsContext3DGLContextCallback( 17 namespace {
16 const GrGLInterface* interface) { 18
17 reinterpret_cast<blink::WebGraphicsContext3D*>( 19 // Singleton used to initialize and terminate the gles2 library.
18 interface->fCallbackData)->makeContextCurrent(); 20 class GLES2Initializer {
21 public:
22 GLES2Initializer() { gles2::Initialize(); }
23
24 ~GLES2Initializer() { gles2::Terminate(); }
25
26 private:
27 DISALLOW_COPY_AND_ASSIGN(GLES2Initializer);
28 };
29
30 base::LazyInstance<GLES2Initializer> g_gles2_initializer =
31 LAZY_INSTANCE_INITIALIZER;
32
33 void BindWebGraphicsContext3DGLContextCallback(const GrGLInterface* interface) {
34 gles2::SetGLContext(reinterpret_cast<WebGraphicsContext3DImpl*>(
35 interface->fCallbackData)->GetGLInterface());
19 } 36 }
20 37
38 } // namespace anonymous
39
21 GrContextForWebGraphicsContext3D::GrContextForWebGraphicsContext3D( 40 GrContextForWebGraphicsContext3D::GrContextForWebGraphicsContext3D(
22 blink::WebGraphicsContext3D* context3d) { 41 WebGraphicsContext3DImpl* context3d) {
23 if (!context3d) 42 if (!context3d)
24 return; 43 return;
25 44
45 // Ensure the gles2 library is initialized first in a thread safe way.
46 g_gles2_initializer.Get();
47 gles2::SetGLContext(context3d->GetGLInterface());
26 skia::RefPtr<GrGLInterface> interface = skia::AdoptRef( 48 skia::RefPtr<GrGLInterface> interface = skia::AdoptRef(
27 context3d->createGrGLInterface()); 49 context3d->createGrGLInterface());
28 if (!interface) 50 if (!interface)
29 return; 51 return;
30 52
31 interface->fCallback = BindWebGraphicsContext3DGLContextCallback; 53 interface->fCallback = BindWebGraphicsContext3DGLContextCallback;
32 interface->fCallbackData = 54 interface->fCallbackData =
33 reinterpret_cast<GrGLInterfaceCallbackData>(context3d); 55 reinterpret_cast<GrGLInterfaceCallbackData>(context3d);
34 56
35 gr_context_ = skia::AdoptRef(GrContext::Create( 57 gr_context_ = skia::AdoptRef(GrContext::Create(
(...skipping 23 matching lines...) Expand all
59 void GrContextForWebGraphicsContext3D::FreeGpuResources() { 81 void GrContextForWebGraphicsContext3D::FreeGpuResources() {
60 if (gr_context_) { 82 if (gr_context_) {
61 TRACE_EVENT_INSTANT0("gpu", "GrContext::freeGpuResources", \ 83 TRACE_EVENT_INSTANT0("gpu", "GrContext::freeGpuResources", \
62 TRACE_EVENT_SCOPE_THREAD); 84 TRACE_EVENT_SCOPE_THREAD);
63 gr_context_->freeGpuResources(); 85 gr_context_->freeGpuResources();
64 } 86 }
65 } 87 }
66 88
67 } // namespace gpu 89 } // namespace gpu
68 } // namespace webkit 90 } // namespace webkit
OLDNEW
« no previous file with comments | « webkit/common/gpu/grcontext_for_webgraphicscontext3d.h ('k') | webkit/common/gpu/webgraphicscontext3d_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698