glx/dri3: rework __DRIextension handling

Use a const array with the extensions, rather than assigning each
one to a fixed size array at runtime.

Signed-off-by: Emil Velikov <emil.l.velikov@gmail.com>
Reviewed-by: Ian Romanick <ian.d.romanick@intel.com>
This commit is contained in:
Emil Velikov 2014-03-16 01:17:46 +00:00
parent 4be3874c97
commit ecfe986120
2 changed files with 9 additions and 10 deletions

View File

@ -1307,6 +1307,12 @@ static const __DRIimageLoaderExtension imageLoaderExtension = {
.flushFrontBuffer = dri3_flush_front_buffer,
};
static const __DRIextension *loader_extensions[] = {
&imageLoaderExtension.base,
&systemTimeExtension.base,
NULL
};
/** dri3_swap_buffers
*
* Make the current back buffer visible using the present extension
@ -1689,8 +1695,7 @@ dri3_create_screen(int screen, struct glx_display * priv)
psc->driScreen =
psc->image_driver->createNewScreen2(screen, psc->fd,
(const __DRIextension **)
&pdp->loader_extensions[0],
pdp->loader_extensions,
extensions,
&driver_configs, psc);
@ -1807,7 +1812,6 @@ _X_HIDDEN __GLXDRIdisplay *
dri3_create_display(Display * dpy)
{
struct dri3_display *pdp;
int i;
xcb_connection_t *c = XGetXCBConnection(dpy);
xcb_dri3_query_version_cookie_t dri3_cookie;
xcb_dri3_query_version_reply_t *dri3_reply;
@ -1863,13 +1867,8 @@ dri3_create_display(Display * dpy)
pdp->base.createScreen = dri3_create_screen;
loader_set_logger(dri_message);
i = 0;
pdp->loader_extensions[i++] = &imageLoaderExtension.base;
pdp->loader_extensions[i++] = &systemTimeExtension.base;
pdp->loader_extensions[i++] = NULL;
pdp->loader_extensions = loader_extensions;
return &pdp->base;
no_extension:

View File

@ -106,7 +106,7 @@ struct dri3_display
{
__GLXDRIdisplay base;
const __DRIextension *loader_extensions[8];
const __DRIextension **loader_extensions;
/* DRI3 bits */
int dri3Major;