summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xui/gl/generate_bindings.py4
-rw-r--r--ui/gl/gl_fence.cc51
-rw-r--r--ui/gl/gl_fence.h1
3 files changed, 51 insertions, 5 deletions
diff --git a/ui/gl/generate_bindings.py b/ui/gl/generate_bindings.py
index 968ec77..173845d 100755
--- a/ui/gl/generate_bindings.py
+++ b/ui/gl/generate_bindings.py
@@ -678,6 +678,10 @@ GL_FUNCTIONS = [
'GLsync sync, GLenum pname, GLsizei bufSize, GLsizei* length,'
'GLint* values', },
{ 'return_type': 'void',
+ 'names': ['glClientWaitSync'],
+ 'arguments':
+ 'GLsync sync, GLbitfield flags, GLuint64 timeout', },
+{ 'return_type': 'void',
'names': ['glDrawArraysInstancedANGLE', 'glDrawArraysInstancedARB'],
'arguments': 'GLenum mode, GLint first, GLsizei count, GLsizei primcount', },
{ 'return_type': 'void',
diff --git a/ui/gl/gl_fence.cc b/ui/gl/gl_fence.cc
index 9a40ec2..68aa88b 100644
--- a/ui/gl/gl_fence.cc
+++ b/ui/gl/gl_fence.cc
@@ -32,6 +32,10 @@ class GLFenceNVFence: public gfx::GLFence {
return !!glTestFenceNV(fence_);
}
+ virtual void ClientWait() OVERRIDE {
+ glFinishFenceNV(fence_);
+ }
+
private:
virtual ~GLFenceNVFence() {
glDeleteFencesNV(1, &fence_);
@@ -62,6 +66,10 @@ class GLFenceARBSync: public gfx::GLFence {
return length == 1 && value == GL_SIGNALED;
}
+ virtual void ClientWait() OVERRIDE {
+ glClientWaitSync(sync_, GL_SYNC_FLUSH_COMMANDS_BIT, GL_TIMEOUT_IGNORED);
+ }
+
private:
virtual ~GLFenceARBSync() {
glDeleteSync(sync_);
@@ -70,6 +78,37 @@ class GLFenceARBSync: public gfx::GLFence {
GLsync sync_;
};
+#if !defined(OS_MACOSX)
+class EGLFenceSync : public gfx::GLFence {
+ public:
+ EGLFenceSync() {
+ display_ = eglGetCurrentDisplay();
+ sync_ = eglCreateSyncKHR(display_, EGL_SYNC_FENCE_KHR, NULL);
+ }
+
+ virtual bool HasCompleted() OVERRIDE {
+ EGLint value = 0;
+ eglGetSyncAttribKHR(display_, sync_, EGL_SYNC_STATUS_KHR, &value);
+ DCHECK(value == EGL_SIGNALED_KHR || value == EGL_UNSIGNALED_KHR);
+ return !value || value == EGL_SIGNALED_KHR;
+ }
+
+ virtual void ClientWait() OVERRIDE {
+ EGLint flags = EGL_SYNC_FLUSH_COMMANDS_BIT_KHR;
+ EGLTimeKHR time = EGL_FOREVER_KHR;
+ eglClientWaitSyncKHR(display_, sync_, flags, time);
+ }
+
+ private:
+ virtual ~EGLFenceSync() {
+ eglDestroySyncKHR(display_, sync_);
+ }
+
+ EGLSyncKHR sync_;
+ EGLDisplay display_;
+};
+#endif // !OS_MACOSX
+
} // namespace
namespace gfx {
@@ -82,13 +121,15 @@ GLFence::~GLFence() {
// static
GLFence* GLFence::Create() {
- if (gfx::g_driver_gl.ext.b_GL_NV_fence) {
+#if !defined(OS_MACOSX)
+ if (gfx::g_driver_egl.ext.b_EGL_KHR_fence_sync)
+ return new EGLFenceSync();
+#endif
+ if (gfx::g_driver_gl.ext.b_GL_NV_fence)
return new GLFenceNVFence();
- } else if (gfx::g_driver_gl.ext.b_GL_ARB_sync) {
+ if (gfx::g_driver_gl.ext.b_GL_ARB_sync)
return new GLFenceARBSync();
- } else {
- return NULL;
- }
+ return NULL;
}
} // namespace gfx
diff --git a/ui/gl/gl_fence.h b/ui/gl/gl_fence.h
index 6dec821..d4f3218 100644
--- a/ui/gl/gl_fence.h
+++ b/ui/gl/gl_fence.h
@@ -17,6 +17,7 @@ class GL_EXPORT GLFence {
static GLFence* Create();
virtual bool HasCompleted() = 0;
+ virtual void ClientWait() = 0;
protected:
static bool IsContextLost();