mirror of
https://github.com/mpv-player/mpv
synced 2025-01-10 00:49:32 +00:00
e1586585b4
This tries to deal with the crazy EGL situation. The summary is: - using eglGetDisplay() with multiple windowing platforms doesn't really work, but Mesa had an awful hack for it - this hack can be disabled at build time, and some distros sometimes accidentally or intentionally do so - Mesa will probably eventually disable it by default - we switched to eglGetPlatformDisplay(), but this requires EGL 1.5 - the very regrettable graphics company (also known as Nvidia) ships drivers (for old hardware I think) that are EGL 1.4 only - that means even though we "require" EGL 1.5 and link against it, the runtime EGL may be 1.4 - trying to run mpv there crashes in the dynamic linker - so we have to go through some more awful compatibility hacks This commit tries to do it "properly", but using EGL 1.4 as base. The plaform selection mechanism is a messy extension there, which got elevated to core API in 1.5 (but OF COURSE in incompatible ways). I'm not sure whether the EGL 1.5 code path (by parsing the EGL_VERSION) is really needed, but if you ask me, it feels slightly saner not to rely on an EGL 1.4 kludge forever. But maybe this is just an instance of self-harm, since they will most likely never drop or not provide this API. Also, unlike before, we actually check the extension string for the individual platform extensions, because who knows, some EGL implementations might curse us if we pass unknown platform parameters. (But actually, the more I think about this, the more bullshit it is.) X11 and Wayland were the only ones trying to call eglGetPlatformDisplay, so they're the only ones which are adjusted in this commit. Unfortunately, correct function of this commit is unconfirmed. It's possible that it crashes with the old drivers mentioned above. Why didn't they solve it like this: struct native_display { int platform_type; void *native_display; }; Could have kept eglGetDisplay() without all the obnoxious extension BS.
36 lines
1.1 KiB
C
36 lines
1.1 KiB
C
#ifndef MP_GL_EGL_HELPERS_H
|
|
#define MP_GL_EGL_HELPERS_H
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <EGL/egl.h>
|
|
#include <EGL/eglext.h>
|
|
|
|
#include "video/out/gpu/context.h"
|
|
|
|
struct mp_log;
|
|
|
|
bool mpegl_create_context(struct ra_ctx *ctx, EGLDisplay display,
|
|
EGLContext *out_context, EGLConfig *out_config);
|
|
|
|
struct mpegl_cb {
|
|
// if set, pick the desired config from the given list and return its index
|
|
// defaults to 0 (they are sorted by eglChooseConfig). return a negative
|
|
// number to indicate an error condition or that no suitable configs could
|
|
// be found.
|
|
int (*refine_config)(void *user_data, EGLConfig *configs, int num_configs);
|
|
void *user_data;
|
|
};
|
|
|
|
bool mpegl_create_context_cb(struct ra_ctx *ctx, EGLDisplay display,
|
|
struct mpegl_cb cb, EGLContext *out_context,
|
|
EGLConfig *out_config);
|
|
|
|
struct GL;
|
|
void mpegl_load_functions(struct GL *gl, struct mp_log *log);
|
|
|
|
EGLDisplay mpegl_get_display(EGLenum platform, const char *platform_ext_name,
|
|
void *native_display);
|
|
|
|
#endif
|