diff options
author | Rafael Antognolli <rafael.antognolli@intel.com> | 2016-11-07 15:05:06 -0800 |
---|---|---|
committer | Rafael Antognolli <rafael.antognolli@intel.com> | 2017-06-27 11:15:55 -0700 |
commit | 335606a5aea8ef2ba2a88572aa40e5bb2cbe4773 (patch) | |
tree | 50a846ffb42ad8385169f7b427d3a0955543a4e2 /tests/egl | |
parent | f09201bc4f8992e7bf36145bf756d93a4c9b05f3 (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>
Diffstat (limited to 'tests/egl')
-rw-r--r-- | tests/egl/spec/egl_khr_fence_sync/egl_khr_fence_sync.c | 47 |
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 |