mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2025-01-12 05:41:10 +01:00
Fixed bug 4349 - SDL_CreateWindow fails with KMS/DRM after upgrading Mesa to 18.2.3
Rainer Sabelka After I did an upgrade of my arch Linux installation (resulting in an update of Mesa to version 18.2.3), all my SDL2 applications which use the KMS/DRM driver stopped working. Reason: Creating a Window with SDL_CreateWindow failed because the call to EGL eglCreateWindowSurface() returns an error "EGL_BAD_MATCH". After investigating with the debugger I figured, that the configuration, which has been selected from the output of eglChooseConfig(), has an "EGL_NATIVE_VISUAL_ID" which does not match the "format" of the underlying gbm surface. The attached patch fixes the problem. It does so, by mimicking Weston's behavior. All configurations returned from eglChooseConfig() which have an visual_id different from the gbm format are discarded, and only from the remaining ones the "best" match is selected.
This commit is contained in:
parent
9af581bd75
commit
aeee424f65
@ -449,6 +449,12 @@ SDL_EGL_LoadLibrary(_THIS, const char *egl_path, NativeDisplayType native_displa
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
SDL_EGL_SetRequiredVisualId(_THIS, int visual_id)
|
||||||
|
{
|
||||||
|
_this->egl_data->egl_required_visual_id=visual_id;
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef DUMP_EGL_CONFIG
|
#ifdef DUMP_EGL_CONFIG
|
||||||
|
|
||||||
#define ATTRIBUTE(_attr) { _attr, #_attr }
|
#define ATTRIBUTE(_attr) { _attr, #_attr }
|
||||||
@ -513,14 +519,8 @@ SDL_EGL_ChooseConfig(_THIS)
|
|||||||
/* 64 seems nice. */
|
/* 64 seems nice. */
|
||||||
EGLint attribs[64];
|
EGLint attribs[64];
|
||||||
EGLint found_configs = 0, value;
|
EGLint found_configs = 0, value;
|
||||||
#ifdef SDL_VIDEO_DRIVER_KMSDRM
|
|
||||||
/* Intel EGL on KMS/DRM (al least) returns invalid configs that confuse the bitdiff search used */
|
|
||||||
/* later in this function, so we simply use the first one when using the KMSDRM driver for now. */
|
|
||||||
EGLConfig configs[1];
|
|
||||||
#else
|
|
||||||
/* 128 seems even nicer here */
|
/* 128 seems even nicer here */
|
||||||
EGLConfig configs[128];
|
EGLConfig configs[128];
|
||||||
#endif
|
|
||||||
int i, j, best_bitdiff = -1, bitdiff;
|
int i, j, best_bitdiff = -1, bitdiff;
|
||||||
|
|
||||||
if (!_this->egl_data) {
|
if (!_this->egl_data) {
|
||||||
@ -603,6 +603,16 @@ SDL_EGL_ChooseConfig(_THIS)
|
|||||||
/* From those, we select the one that matches our requirements more closely via a makeshift algorithm */
|
/* From those, we select the one that matches our requirements more closely via a makeshift algorithm */
|
||||||
|
|
||||||
for (i = 0; i < found_configs; i++ ) {
|
for (i = 0; i < found_configs; i++ ) {
|
||||||
|
if (_this->egl_data->egl_required_visual_id)
|
||||||
|
{
|
||||||
|
EGLint format;
|
||||||
|
_this->egl_data->eglGetConfigAttrib(_this->egl_data->egl_display,
|
||||||
|
configs[i],
|
||||||
|
EGL_NATIVE_VISUAL_ID, &format);
|
||||||
|
if (_this->egl_data->egl_required_visual_id != format)
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
bitdiff = 0;
|
bitdiff = 0;
|
||||||
for (j = 0; j < SDL_arraysize(attribs) - 1; j += 2) {
|
for (j = 0; j < SDL_arraysize(attribs) - 1; j += 2) {
|
||||||
if (attribs[j] == EGL_NONE) {
|
if (attribs[j] == EGL_NONE) {
|
||||||
|
@ -37,6 +37,7 @@ typedef struct SDL_EGL_VideoData
|
|||||||
int egl_swapinterval;
|
int egl_swapinterval;
|
||||||
int egl_surfacetype;
|
int egl_surfacetype;
|
||||||
int egl_version_major, egl_version_minor;
|
int egl_version_major, egl_version_minor;
|
||||||
|
EGLint egl_required_visual_id;
|
||||||
|
|
||||||
EGLDisplay(EGLAPIENTRY *eglGetDisplay) (NativeDisplayType display);
|
EGLDisplay(EGLAPIENTRY *eglGetDisplay) (NativeDisplayType display);
|
||||||
EGLDisplay(EGLAPIENTRY *eglGetPlatformDisplay) (EGLenum platform,
|
EGLDisplay(EGLAPIENTRY *eglGetPlatformDisplay) (EGLenum platform,
|
||||||
@ -102,6 +103,7 @@ extern int SDL_EGL_GetAttribute(_THIS, SDL_GLattr attrib, int *value);
|
|||||||
extern int SDL_EGL_LoadLibrary(_THIS, const char *path, NativeDisplayType native_display, EGLenum platform);
|
extern int SDL_EGL_LoadLibrary(_THIS, const char *path, NativeDisplayType native_display, EGLenum platform);
|
||||||
extern void *SDL_EGL_GetProcAddress(_THIS, const char *proc);
|
extern void *SDL_EGL_GetProcAddress(_THIS, const char *proc);
|
||||||
extern void SDL_EGL_UnloadLibrary(_THIS);
|
extern void SDL_EGL_UnloadLibrary(_THIS);
|
||||||
|
extern void SDL_EGL_SetRequiredVisualId(_THIS, int visual_id);
|
||||||
extern int SDL_EGL_ChooseConfig(_THIS);
|
extern int SDL_EGL_ChooseConfig(_THIS);
|
||||||
extern int SDL_EGL_SetSwapInterval(_THIS, int interval);
|
extern int SDL_EGL_SetSwapInterval(_THIS, int interval);
|
||||||
extern int SDL_EGL_GetSwapInterval(_THIS);
|
extern int SDL_EGL_GetSwapInterval(_THIS);
|
||||||
|
@ -587,6 +587,7 @@ KMSDRM_CreateWindow(_THIS, SDL_Window * window)
|
|||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
SDL_EGL_SetRequiredVisualId(_this, surface_fmt);
|
||||||
wdata->egl_surface = SDL_EGL_CreateSurface(_this, (NativeWindowType) wdata->gs);
|
wdata->egl_surface = SDL_EGL_CreateSurface(_this, (NativeWindowType) wdata->gs);
|
||||||
|
|
||||||
if (wdata->egl_surface == EGL_NO_SURFACE) {
|
if (wdata->egl_surface == EGL_NO_SURFACE) {
|
||||||
|
Loading…
Reference in New Issue
Block a user