mirror of
https://github.com/Ryujinx/SDL.git
synced 2025-01-23 05:31:09 +00:00
Import two post-2.0.12 fixes to kmsdrm_legacy:
Fix build breakage without EGL: https://hg.libsdl.org/SDL/rev/f2606fe53654e305ab9badb821d9d3afb7f92f49 Fix KMSDRM_CreateWindow segfault when starting L?VE2D engine (bug 5199) https://hg.libsdl.org/SDL/rev/d2e69a78939463d9ff9448a5f4efd1e208bb97b0
This commit is contained in:
parent
f8839289b0
commit
9940e71088
|
@ -391,7 +391,9 @@ KMSDRM_LEGACY_CreateSurfaces(_THIS, SDL_Window * window)
|
||||||
Uint32 height = dispdata->mode.vdisplay;
|
Uint32 height = dispdata->mode.vdisplay;
|
||||||
Uint32 surface_fmt = GBM_FORMAT_XRGB8888;
|
Uint32 surface_fmt = GBM_FORMAT_XRGB8888;
|
||||||
Uint32 surface_flags = GBM_BO_USE_SCANOUT | GBM_BO_USE_RENDERING;
|
Uint32 surface_flags = GBM_BO_USE_SCANOUT | GBM_BO_USE_RENDERING;
|
||||||
|
#if SDL_VIDEO_OPENGL_EGL
|
||||||
EGLContext egl_context;
|
EGLContext egl_context;
|
||||||
|
#endif
|
||||||
|
|
||||||
if (!KMSDRM_LEGACY_gbm_device_is_format_supported(viddata->gbm, surface_fmt, surface_flags)) {
|
if (!KMSDRM_LEGACY_gbm_device_is_format_supported(viddata->gbm, surface_fmt, surface_flags)) {
|
||||||
SDL_LogWarn(SDL_LOG_CATEGORY_VIDEO, "GBM surface format not supported. Trying anyway.");
|
SDL_LogWarn(SDL_LOG_CATEGORY_VIDEO, "GBM surface format not supported. Trying anyway.");
|
||||||
|
@ -783,6 +785,7 @@ KMSDRM_LEGACY_CreateWindow(_THIS, SDL_Window * window)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Setup driver data for this window */
|
/* Setup driver data for this window */
|
||||||
|
windata->viddata = viddata;
|
||||||
window->driverdata = windata;
|
window->driverdata = windata;
|
||||||
|
|
||||||
if (KMSDRM_LEGACY_CreateSurfaces(_this, window)) {
|
if (KMSDRM_LEGACY_CreateSurfaces(_this, window)) {
|
||||||
|
@ -792,8 +795,6 @@ KMSDRM_LEGACY_CreateWindow(_THIS, SDL_Window * window)
|
||||||
/* Add window to the internal list of tracked windows. Note, while it may
|
/* Add window to the internal list of tracked windows. Note, while it may
|
||||||
seem odd to support multiple fullscreen windows, some apps create an
|
seem odd to support multiple fullscreen windows, some apps create an
|
||||||
extra window as a dummy surface when working with multiple contexts */
|
extra window as a dummy surface when working with multiple contexts */
|
||||||
windata->viddata = viddata;
|
|
||||||
|
|
||||||
if (viddata->num_windows >= viddata->max_windows) {
|
if (viddata->num_windows >= viddata->max_windows) {
|
||||||
int new_max_windows = viddata->max_windows + 1;
|
int new_max_windows = viddata->max_windows + 1;
|
||||||
viddata->windows = (SDL_Window **)SDL_realloc(viddata->windows,
|
viddata->windows = (SDL_Window **)SDL_realloc(viddata->windows,
|
||||||
|
|
Loading…
Reference in a new issue