summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRafael Antognolli <rafael.antognolli@intel.com>2016-11-07 15:05:06 -0800
committerRafael Antognolli <rafael.antognolli@intel.com>2017-06-27 11:15:55 -0700
commit335606a5aea8ef2ba2a88572aa40e5bb2cbe4773 (patch)
tree50a846ffb42ad8385169f7b427d3a0955543a4e2
parentf09201bc4f8992e7bf36145bf756d93a4c9b05f3 (diff)
egl_khr_fence_sync: Verify eglDupNativeFenceFDANDROID.
Verify that eglDupNativeFenceFDANDROID() correctly returns a new file descriptor. Signed-off-by: Rafael Antognolli <rafael.antognolli@intel.com> Reviewed-by: Eric Anholt <eric@anholt.net>
-rw-r--r--tests/egl/spec/egl_khr_fence_sync/egl_khr_fence_sync.c47
1 files changed, 47 insertions, 0 deletions
diff --git a/tests/egl/spec/egl_khr_fence_sync/egl_khr_fence_sync.c b/tests/egl/spec/egl_khr_fence_sync/egl_khr_fence_sync.c
index d59b0a895..54fee6637 100644
--- a/tests/egl/spec/egl_khr_fence_sync/egl_khr_fence_sync.c
+++ b/tests/egl/spec/egl_khr_fence_sync/egl_khr_fence_sync.c
@@ -48,6 +48,7 @@
#include <inttypes.h>
#include <stdarg.h>
#include <stdio.h>
+#include <unistd.h>
#ifdef PIGLIT_HAS_PTHREADS
#include <pthread.h>
@@ -66,6 +67,7 @@ EGLBoolean (*peglDestroySyncKHR)(EGLDisplay dpy, EGLSyncKHR sync);
EGLint (*peglClientWaitSyncKHR)(EGLDisplay dpy, EGLSyncKHR sync, EGLint flags, EGLTimeKHR timeout);
EGLint (*peglWaitSyncKHR)(EGLDisplay dpy, EGLSyncKHR sync, EGLint flags);
EGLBoolean (*peglGetSyncAttribKHR)(EGLDisplay dpy, EGLSyncKHR sync, EGLint attribute, EGLint *value);
+EGLint (*peglDupNativeFenceFDANDROID)(EGLDisplay dpy, EGLSyncKHR sync);
static const EGLint canary = 0x31415926;
static EGLDisplay g_dpy = 0;
@@ -1486,6 +1488,44 @@ cleanup:
return result;
}
+static enum piglit_result
+test_eglCreateSyncKHR_native_dup_fence(void *test_data)
+{
+ enum piglit_result result = PIGLIT_PASS;
+ EGLSyncKHR sync = 0;
+ int sync_fd = canary;
+ struct test_profile *profile = test_data;
+
+ result = test_setup(profile);
+ if (result != PIGLIT_PASS) {
+ return result;
+ }
+
+ sync = peglCreateSyncKHR(g_dpy, profile->sync_type, NULL);
+ if (sync == EGL_NO_SYNC_KHR) {
+ piglit_loge("eglCreateSyncKHR(%s) failed", profile->sync_str);
+ result = PIGLIT_FAIL;
+ goto cleanup;
+ }
+
+ glFlush();
+
+ /* Verify that we can get an fd back from eglDupFenceFD(). */
+ sync_fd = peglDupNativeFenceFDANDROID(g_dpy, sync);
+ if (sync_fd == -1) {
+ piglit_loge("eglDupNativeFenceFDANDROID() failed"
+ "returned %d but expected >= 0", sync_fd);
+ result = PIGLIT_FAIL;
+ goto cleanup;
+ }
+
+ close(sync_fd);
+
+cleanup:
+ test_cleanup(sync, &result);
+ return result;
+}
+
static const struct piglit_subtest fence_android_native_subtests[] = {
{
"eglCreateSyncKHR_default_attributes",
@@ -1535,6 +1575,12 @@ static const struct piglit_subtest fence_android_native_subtests[] = {
test_eglCreateSyncKHR_native_from_fd,
&fence_android_native,
},
+ {
+ "eglCreateSyncKHR_native_dup_fence",
+ "eglCreateSyncKHR_native_dup_fence",
+ test_eglCreateSyncKHR_native_dup_fence,
+ &fence_android_native,
+ },
{0},
};
@@ -1591,6 +1637,7 @@ init_egl_extension_funcs(void)
peglClientWaitSyncKHR = (void*) eglGetProcAddress("eglClientWaitSyncKHR");
peglWaitSyncKHR = (void*) eglGetProcAddress("eglWaitSyncKHR");
peglGetSyncAttribKHR = (void*) eglGetProcAddress("eglGetSyncAttribKHR");
+ peglDupNativeFenceFDANDROID = (void*) eglGetProcAddress("eglDupNativeFenceFDANDROID");
}
int