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

Side by Side Diff: ui/gl/gl_fence.cc

Issue 723343002: Update from https://crrev.com/304121 (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 6 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 | « ui/gl/gl_context_egl.cc ('k') | ui/gl/gl_fence_apple.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 (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 "ui/gl/gl_fence.h" 5 #include "ui/gl/gl_fence.h"
6 6
7 #include "base/compiler_specific.h" 7 #include "base/compiler_specific.h"
8 #include "ui/gl/gl_bindings.h" 8 #include "ui/gl/gl_bindings.h"
9 #include "ui/gl/gl_context.h" 9 #include "ui/gl/gl_context.h"
10 #include "ui/gl/gl_fence_arb.h" 10 #include "ui/gl/gl_fence_arb.h"
11 #include "ui/gl/gl_fence_egl.h" 11 #include "ui/gl/gl_fence_egl.h"
12 #include "ui/gl/gl_fence_nv.h" 12 #include "ui/gl/gl_fence_nv.h"
13 #include "ui/gl/gl_gl_api_implementation.h" 13 #include "ui/gl/gl_gl_api_implementation.h"
14 #include "ui/gl/gl_version_info.h" 14 #include "ui/gl/gl_version_info.h"
15 15
16 #if defined(OS_MACOSX)
17 #include "ui/gl/gl_fence_apple.h"
18 #endif
19
16 namespace gfx { 20 namespace gfx {
17 21
18 namespace { 22 namespace {
19 23
20 // static 24 // static
21 GLFence* CreateFence(bool flush) { 25 GLFence* CreateFence(bool flush) {
22 DCHECK(GLContext::GetCurrent()) 26 DCHECK(GLContext::GetCurrent())
23 << "Trying to create fence with no context"; 27 << "Trying to create fence with no context";
24 28
25 scoped_ptr<GLFence> fence; 29 scoped_ptr<GLFence> fence;
26 // Prefer ARB_sync which supports server-side wait. 30 // Prefer ARB_sync which supports server-side wait.
27 if (g_driver_gl.ext.b_GL_ARB_sync || 31 if (g_driver_gl.ext.b_GL_ARB_sync ||
28 GetGLVersionInfo()->is_es3) { 32 GetGLVersionInfo()->is_es3) {
29 fence.reset(new GLFenceARB(flush)); 33 fence.reset(new GLFenceARB(flush));
30 #if !defined(OS_MACOSX) 34 #if defined(OS_MACOSX)
35 } else if (g_driver_gl.ext.b_GL_APPLE_fence) {
36 fence.reset(new GLFenceAPPLE(flush));
37 #else
31 } else if (g_driver_egl.ext.b_EGL_KHR_fence_sync) { 38 } else if (g_driver_egl.ext.b_EGL_KHR_fence_sync) {
32 fence.reset(new GLFenceEGL(flush)); 39 fence.reset(new GLFenceEGL(flush));
33 #endif 40 #endif
34 } else if (g_driver_gl.ext.b_GL_NV_fence) { 41 } else if (g_driver_gl.ext.b_GL_NV_fence) {
35 fence.reset(new GLFenceNV(flush)); 42 fence.reset(new GLFenceNV(flush));
36 } 43 }
37 44
38 DCHECK_EQ(!!fence.get(), GLFence::IsSupported()); 45 DCHECK_EQ(!!fence.get(), GLFence::IsSupported());
39 return fence.release(); 46 return fence.release();
40 } 47 }
41 48
42 } // namespace 49 } // namespace
43 50
44 GLFence::GLFence() { 51 GLFence::GLFence() {
45 } 52 }
46 53
47 GLFence::~GLFence() { 54 GLFence::~GLFence() {
48 } 55 }
49 56
50 bool GLFence::IsSupported() { 57 bool GLFence::IsSupported() {
51 DCHECK(GetGLVersionInfo()); 58 DCHECK(GetGLVersionInfo());
52 return g_driver_gl.ext.b_GL_ARB_sync || GetGLVersionInfo()->is_es3 || 59 return g_driver_gl.ext.b_GL_ARB_sync || GetGLVersionInfo()->is_es3 ||
53 #if !defined(OS_MACOSX) 60 #if defined(OS_MACOSX)
61 g_driver_gl.ext.b_GL_APPLE_fence ||
62 #else
54 g_driver_egl.ext.b_EGL_KHR_fence_sync || 63 g_driver_egl.ext.b_EGL_KHR_fence_sync ||
55 #endif 64 #endif
56 g_driver_gl.ext.b_GL_NV_fence; 65 g_driver_gl.ext.b_GL_NV_fence;
57 } 66 }
58 67
59 GLFence* GLFence::Create() { 68 GLFence* GLFence::Create() {
60 return CreateFence(true); 69 return CreateFence(true);
61 } 70 }
62 71
63 GLFence* GLFence::CreateWithoutFlush() { 72 GLFence* GLFence::CreateWithoutFlush() {
64 return CreateFence(false); 73 return CreateFence(false);
65 } 74 }
66 75
67 } // namespace gfx 76 } // namespace gfx
OLDNEW
« no previous file with comments | « ui/gl/gl_context_egl.cc ('k') | ui/gl/gl_fence_apple.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698