[Piglit] [PATCH piglit] egl_khr_create_context: Proper invalid attributes for EGL 1.5

Miguel Angel Vico mvicomoya at nvidia.com
Thu Aug 30 19:56:03 UTC 2018


Any takers?

Thanks!


On Wed, 22 Aug 2018 07:34:09 -0700
"Miguel A. Vico" <mvicomoya at nvidia.com> wrote:

> When EGL_KHR_create_context was originally written,
> EGL_CONTEXT_OPENGL_RESET_NOTIFICATION_STRATEGY_KHR was an invalid
> attribute for OpenGL ES.
> 
> After moving the extension to core EGL 1.5, the aforementioned
> attribute was made valid for both OpenGL and OpenGL ES.
> 
> Check whether the EGL version is lower than 1.5 before checking
> EGL_CONTEXT_OPENGL_RESET_NOTIFICATION_STRATEGY_KHR is an invalid
> attribute.
> 
> Signed-off-by: Miguel A Vico Moya <mvicomoya at nvidia.com>
> ---
>  .../egl/spec/egl_khr_create_context/common.c  |  5 ++--
>  .../egl/spec/egl_khr_create_context/common.h  |  8 +++++++
>  .../invalid-attribute-gles.c                  | 24 +++++++++++++++++++
>  3 files changed, 35 insertions(+), 2 deletions(-)
> 
> diff --git a/tests/egl/spec/egl_khr_create_context/common.c b/tests/egl/spec/egl_khr_create_context/common.c
> index a443ced97..ba0311bff 100644
> --- a/tests/egl/spec/egl_khr_create_context/common.c
> +++ b/tests/egl/spec/egl_khr_create_context/common.c
> @@ -27,6 +27,8 @@
>  
>  static Display *dpy = NULL;
>  EGLDisplay egl_dpy;
> +EGLint egl_major;
> +EGLint egl_minor;
>  EGLConfig cfg;
>  EGLContext ctx;
>  
> @@ -87,7 +89,6 @@ EGL_KHR_create_context_setup(EGLint renderable_type_mask)
>  		EGL_NONE
>  	};
>  	EGLint count;
> -	EGLint major, minor;
>  
>  	dpy = XOpenDisplay(NULL);
>  	if (dpy == NULL) {
> @@ -101,7 +102,7 @@ EGL_KHR_create_context_setup(EGLint renderable_type_mask)
>  		piglit_report_result(PIGLIT_FAIL);
>  	}
>  
> -	if (!eglInitialize(egl_dpy, &major, &minor)) {
> +	if (!eglInitialize(egl_dpy, &egl_major, &egl_minor)) {
>  		fprintf(stderr, "eglInitialize() failed\n");
>  		piglit_report_result(PIGLIT_FAIL);
>  	}
> diff --git a/tests/egl/spec/egl_khr_create_context/common.h b/tests/egl/spec/egl_khr_create_context/common.h
> index f4f42760c..269610f01 100644
> --- a/tests/egl/spec/egl_khr_create_context/common.h
> +++ b/tests/egl/spec/egl_khr_create_context/common.h
> @@ -51,6 +51,8 @@
>  #endif
>  
>  extern EGLDisplay egl_dpy;
> +extern EGLint egl_major;
> +extern EGLint egl_minor;
>  extern EGLConfig cfg;
>  extern EGLContext ctx;
>  
> @@ -75,3 +77,9 @@ version_is_valid_for_context(int ctx_major, int major, int minor)
>  	}
>  	return false;
>  }
> +
> +static inline bool
> +check_egl_version(int major, int minor)
> +{
> +	return ((egl_major > major) || ((egl_major == major) && (egl_minor >= minor)));
> +}
> diff --git a/tests/egl/spec/egl_khr_create_context/invalid-attribute-gles.c b/tests/egl/spec/egl_khr_create_context/invalid-attribute-gles.c
> index 7d23e5673..d2b98818c 100644
> --- a/tests/egl/spec/egl_khr_create_context/invalid-attribute-gles.c
> +++ b/tests/egl/spec/egl_khr_create_context/invalid-attribute-gles.c
> @@ -79,6 +79,22 @@ int main(int argc, char **argv)
>  	 *    attribute is only meaningful for OpenGL contexts, and specifying it
>  	 *    for other types of contexts, including OpenGL ES contexts, will
>  	 *    generate an error."
> +	 *
> +	 * However, after making the extension part of core EGL 1.5,
> +	 * EGL_CONTEXT_OPENGL_RESET_NOTIFICATION_STRATEGY_KHR was made a valid
> +	 * attribute for OpenGL ES contexts:
> +	 *
> +	 *    "The attribute EGL_CONTEXT_OPENGL_RESET_NOTIFICATION_STRATEGY
> +	 *    specifies reset notification behavior for a context supporting
> +	 *    robust buffer access.  The attribute value may be either
> +	 *    EGL_NO_RESET_NOTIFICATION or EGL_LOSE_CONTEXT_ON_RESET, which
> +	 *    respectively result in reset notification behavior of
> +	 *    GL_NO_RESET_NOTIFICATION_ARB and GL_LOSE_CONTEXT_ON_RESET_ARB, as
> +	 *    described by the OpenGL GL_ARB_robustness extension, or by
> +	 *    equivalent functionality.
> +	 *
> +	 *    This attribute is supported only for OpenGL and OpenGL ES
> +	 *    contexts."
>  	 */
>  	EGLint bad_attributes[] = {
>  		0xffff0000,
> @@ -97,6 +113,14 @@ int main(int argc, char **argv)
>  	}
>  
>  	for (i = 0; i < ARRAY_SIZE(bad_attributes); i++) {
> +		/* Skip EGL_CONTEXT_OPENGL_RESET_NOTIFICATION_STRATEGY_KHR if
> +		 * it's EGL 1.5+
> +		 */
> +		if ((bad_attributes[i] == EGL_CONTEXT_OPENGL_RESET_NOTIFICATION_STRATEGY_KHR) &&
> +		    check_egl_version(1, 5)) {
> +			continue;
> +		}
> +
>  		pass = try_attribute(bad_attributes[i]) && pass;
>  	}
>  
> -- 
> 2.18.0
> 


-- 
Miguel




More information about the Piglit mailing list