Commit ed546bf1 authored by Zhiyi Zhang's avatar Zhiyi Zhang Committed by Alexandre Julliard

winex11.drv: Handle X errors from glXCopyContext().

glxCopyContext() may throw X errors and cause the current process to exit. For example, Mesa doesn't support glxCopyContext() for direct rendering contexts and ends up using the code path for indirect rendering contexts. When Xorg receives such requests, it rejects them because they're for direct rendering contexts and reports an X error. We also can't use indirect rendering context because it needs to be explicitly enabled in xorg.conf and has poor performance. So handle this error before graphics drivers implement the support. Fix Cladun X2 crash at start. Signed-off-by: 's avatarZhiyi Zhang <zzhang@codeweavers.com>
parent e386cc8f
......@@ -1711,9 +1711,21 @@ static BOOL WINAPI glxdrv_wglCopyContext(struct wgl_context *src, struct wgl_con
{
TRACE("%p -> %p mask %#x\n", src, dst, mask);
pglXCopyContext(gdi_display, src->ctx, dst->ctx, mask);
X11DRV_expect_error( gdi_display, GLXErrorHandler, NULL );
pglXCopyContext( gdi_display, src->ctx, dst->ctx, mask );
XSync( gdi_display, False );
if (X11DRV_check_error())
{
static unsigned int once;
if (!once++)
{
ERR("glXCopyContext failed. glXCopyContext() for direct rendering contexts not "
"implemented in the host graphics driver?\n");
}
return FALSE;
}
/* As opposed to wglCopyContext, glXCopyContext doesn't return anything, so hopefully we passed */
return TRUE;
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment