[Mesa-dev] [PATCH] glxinfo: Add support for GLX_MESA_query_renderer

Brian Paul brianp at vmware.com
Tue Jan 13 09:11:35 PST 2015


On 01/12/2015 12:27 PM, Adam Jackson wrote:
> This just queries our context, it doesn't attempt to enumerate all the
> available renderers.
>
> Signed-off-by: Adam Jackson <ajax at redhat.com>
> ---
>   src/xdemos/glxinfo.c | 49 +++++++++++++++++++++++++++++++++++++++++++++++++
>   1 file changed, 49 insertions(+)
>
> diff --git a/src/xdemos/glxinfo.c b/src/xdemos/glxinfo.c
> index 779aaa7..b75886a 100644
> --- a/src/xdemos/glxinfo.c
> +++ b/src/xdemos/glxinfo.c
> @@ -342,6 +342,53 @@ choose_xvisinfo(Display *dpy, int scrnum)
>   }
>
>
> +static void
> +query_renderer(void)
> +{
> +#ifdef GLX_MESA_query_renderer
> +    PFNGLXQUERYCURRENTRENDERERINTEGERMESAPROC queryInteger;
> +    PFNGLXQUERYCURRENTRENDERERSTRINGMESAPROC queryString;
> +    unsigned int v[3];
> +
> +    queryInteger = (PFNGLXQUERYCURRENTRENDERERINTEGERMESAPROC)
> +	glXGetProcAddressARB((const GLubyte *)
> +			     "glXQueryCurrentRendererIntegerMESA");
> +    queryString = (PFNGLXQUERYCURRENTRENDERERSTRINGMESAPROC)
> +	glXGetProcAddressARB((const GLubyte *)
> +			     "glXQueryCurrentRendererStringMESA");
> +
> +    printf("Extended renderer info (GLX_MESA_query_renderer):\n");
> +    queryInteger(GLX_RENDERER_VENDOR_ID_MESA, v);
> +    printf("    Vendor: %s (0x%x)\n",
> +	   queryString(GLX_RENDERER_VENDOR_ID_MESA), *v);
> +    queryInteger(GLX_RENDERER_DEVICE_ID_MESA, v);
> +    printf("    Device: %s (0x%x)\n",
> +	   queryString(GLX_RENDERER_DEVICE_ID_MESA), *v);
> +    queryInteger(GLX_RENDERER_VERSION_MESA, v);
> +    printf("    Version: %d.%d.%d\n", v[0], v[1], v[2]);
> +    queryInteger(GLX_RENDERER_ACCELERATED_MESA, v);
> +    printf("    Accelerated: %s\n", *v ? "yes" : "no");
> +    queryInteger(GLX_RENDERER_VIDEO_MEMORY_MESA, v);
> +    printf("    Video memory: %dMB\n", *v);
> +    queryInteger(GLX_RENDERER_UNIFIED_MEMORY_ARCHITECTURE_MESA, v);
> +    printf("    Unified memory: %s\n", *v ? "yes" : "no");
> +    queryInteger(GLX_RENDERER_PREFERRED_PROFILE_MESA, v);
> +    printf("    Preferred profile: %s (0x%x)\n",
> +	   *v == GLX_CONTEXT_CORE_PROFILE_BIT_ARB ? "core" :
> +	   *v == GLX_CONTEXT_COMPATIBILITY_PROFILE_BIT_ARB ? "compat" :
> +	   "unknown", *v);
> +    queryInteger(GLX_RENDERER_OPENGL_CORE_PROFILE_VERSION_MESA, v);
> +    printf("    Max core profile version: %d.%d\n", v[0], v[1]);
> +    queryInteger(GLX_RENDERER_OPENGL_COMPATIBILITY_PROFILE_VERSION_MESA, v);
> +    printf("    Max compat profile version: %d.%d\n", v[0], v[1]);
> +    queryInteger(GLX_RENDERER_OPENGL_ES_PROFILE_VERSION_MESA, v);
> +    printf("    Max GLES1 profile version: %d.%d\n", v[0], v[1]);
> +    queryInteger(GLX_RENDERER_OPENGL_ES2_PROFILE_VERSION_MESA, v);
> +    printf("    Max GLES[23] profile version: %d.%d\n", v[0], v[1]);
> +#endif
> +}
> +
> +
>   static Bool
>   print_screen_info(Display *dpy, int scrnum, Bool allowDirect,
>                     Bool coreProfile, Bool es2Profile, Bool limits,
> @@ -493,6 +540,8 @@ print_screen_info(Display *dpy, int scrnum, Bool allowDirect,
>            printf("GLX version: %u.%u\n", glxVersionMajor, glxVersionMinor);
>            printf("GLX extensions:\n");
>            print_extension_list(glxExtensions, singleLine);
> +	 if (strstr(glxExtensions, "GLX_MESA_query_renderer"))
> +	     query_renderer();
>            printf("OpenGL vendor string: %s\n", glVendor);
>            printf("OpenGL renderer string: %s\n", glRenderer);
>         } else
>

Looks OK to me.   Reviewed-by: Brian Paul <brianp at vmware.com>



More information about the mesa-dev mailing list