mirror of
https://gitlab.freedesktop.org/xorg/xserver.git
synced 2026-04-18 08:30:37 +02:00
glamor_egl: add helper functions for contexts
This is just a split big glamor_egl_init to 3 smaller functions.
No functional change.
Signed-off-by: Konstantin <ria.freelander@gmail.com>
(cherry picked from commit d5c2a4d3f5)
Part-of: <https://gitlab.freedesktop.org/xorg/xserver/-/merge_requests/1636>
This commit is contained in:
parent
40af9f2d1a
commit
e4f79ed0ad
1 changed files with 87 additions and 68 deletions
|
|
@ -955,6 +955,86 @@ glamor_egl_free_screen(ScrnInfoPtr scrn)
|
|||
}
|
||||
}
|
||||
|
||||
static Bool
|
||||
glamor_egl_try_big_gl_api(ScrnInfoPtr scrn)
|
||||
{
|
||||
struct glamor_egl_screen_private *glamor_egl =
|
||||
glamor_egl_get_screen_private(scrn);
|
||||
|
||||
if (eglBindAPI(EGL_OPENGL_API)) {
|
||||
static const EGLint config_attribs_core[] = {
|
||||
EGL_CONTEXT_OPENGL_PROFILE_MASK_KHR,
|
||||
EGL_CONTEXT_OPENGL_CORE_PROFILE_BIT_KHR,
|
||||
EGL_CONTEXT_MAJOR_VERSION_KHR,
|
||||
GLAMOR_GL_CORE_VER_MAJOR,
|
||||
EGL_CONTEXT_MINOR_VERSION_KHR,
|
||||
GLAMOR_GL_CORE_VER_MINOR,
|
||||
EGL_NONE
|
||||
};
|
||||
static const EGLint config_attribs[] = {
|
||||
EGL_NONE
|
||||
};
|
||||
|
||||
glamor_egl->context = eglCreateContext(glamor_egl->display,
|
||||
EGL_NO_CONFIG_KHR, EGL_NO_CONTEXT,
|
||||
config_attribs_core);
|
||||
|
||||
if (glamor_egl->context == EGL_NO_CONTEXT)
|
||||
glamor_egl->context = eglCreateContext(glamor_egl->display,
|
||||
EGL_NO_CONFIG_KHR,
|
||||
EGL_NO_CONTEXT,
|
||||
config_attribs);
|
||||
}
|
||||
|
||||
if (glamor_egl->context != EGL_NO_CONTEXT) {
|
||||
if (!eglMakeCurrent(glamor_egl->display,
|
||||
EGL_NO_SURFACE, EGL_NO_SURFACE, glamor_egl->context)) {
|
||||
xf86DrvMsg(scrn->scrnIndex, X_ERROR,
|
||||
"Failed to make GL context current\n");
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
if (epoxy_gl_version() < 21) {
|
||||
xf86DrvMsg(scrn->scrnIndex, X_INFO,
|
||||
"glamor: Ignoring GL < 2.1, falling back to GLES.\n");
|
||||
eglDestroyContext(glamor_egl->display, glamor_egl->context);
|
||||
glamor_egl->context = EGL_NO_CONTEXT;
|
||||
}
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
static Bool
|
||||
glamor_egl_try_gles_api(ScrnInfoPtr scrn)
|
||||
{
|
||||
struct glamor_egl_screen_private *glamor_egl =
|
||||
glamor_egl_get_screen_private(scrn);
|
||||
|
||||
static const EGLint config_attribs[] = {
|
||||
EGL_CONTEXT_CLIENT_VERSION, 2,
|
||||
EGL_NONE
|
||||
};
|
||||
if (!eglBindAPI(EGL_OPENGL_ES_API)) {
|
||||
xf86DrvMsg(scrn->scrnIndex, X_ERROR,
|
||||
"glamor: Failed to bind GLES API.\n");
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
glamor_egl->context = eglCreateContext(glamor_egl->display,
|
||||
EGL_NO_CONFIG_KHR, EGL_NO_CONTEXT,
|
||||
config_attribs);
|
||||
|
||||
if (glamor_egl->context != EGL_NO_CONTEXT) {
|
||||
if (!eglMakeCurrent(glamor_egl->display,
|
||||
EGL_NO_SURFACE, EGL_NO_SURFACE, glamor_egl->context)) {
|
||||
xf86DrvMsg(scrn->scrnIndex, X_ERROR,
|
||||
"Failed to make GLES context current\n");
|
||||
return FALSE;
|
||||
}
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
|
||||
Bool
|
||||
glamor_egl_init(ScrnInfoPtr scrn, int fd)
|
||||
{
|
||||
|
|
@ -1005,79 +1085,18 @@ glamor_egl_init(ScrnInfoPtr scrn, int fd)
|
|||
|
||||
GLAMOR_CHECK_EGL_EXTENSION(KHR_surfaceless_context);
|
||||
|
||||
if (eglBindAPI(EGL_OPENGL_API)) {
|
||||
static const EGLint config_attribs_core[] = {
|
||||
EGL_CONTEXT_OPENGL_PROFILE_MASK_KHR,
|
||||
EGL_CONTEXT_OPENGL_CORE_PROFILE_BIT_KHR,
|
||||
EGL_CONTEXT_MAJOR_VERSION_KHR,
|
||||
GLAMOR_GL_CORE_VER_MAJOR,
|
||||
EGL_CONTEXT_MINOR_VERSION_KHR,
|
||||
GLAMOR_GL_CORE_VER_MINOR,
|
||||
EGL_NONE
|
||||
};
|
||||
static const EGLint config_attribs[] = {
|
||||
EGL_NONE
|
||||
};
|
||||
if(!glamor_egl_try_big_gl_api(scrn))
|
||||
goto error;
|
||||
|
||||
glamor_egl->context = eglCreateContext(glamor_egl->display,
|
||||
NULL, EGL_NO_CONTEXT,
|
||||
config_attribs_core);
|
||||
|
||||
if (glamor_egl->context == EGL_NO_CONTEXT)
|
||||
glamor_egl->context = eglCreateContext(glamor_egl->display,
|
||||
NULL, EGL_NO_CONTEXT,
|
||||
config_attribs);
|
||||
}
|
||||
|
||||
if (glamor_egl->context != EGL_NO_CONTEXT) {
|
||||
if (!eglMakeCurrent(glamor_egl->display,
|
||||
EGL_NO_SURFACE, EGL_NO_SURFACE, glamor_egl->context)) {
|
||||
xf86DrvMsg(scrn->scrnIndex, X_ERROR,
|
||||
"Failed to make GL context current\n");
|
||||
if (glamor_egl->context == EGL_NO_CONTEXT) {
|
||||
if(!glamor_egl_try_gles_api(scrn))
|
||||
goto error;
|
||||
}
|
||||
|
||||
if (epoxy_gl_version() < 21) {
|
||||
xf86DrvMsg(scrn->scrnIndex, X_INFO,
|
||||
"glamor: Ignoring GL < 2.1, falling back to GLES.\n");
|
||||
eglDestroyContext(glamor_egl->display, glamor_egl->context);
|
||||
glamor_egl->context = EGL_NO_CONTEXT;
|
||||
}
|
||||
}
|
||||
|
||||
if (glamor_egl->context == EGL_NO_CONTEXT) {
|
||||
static const EGLint config_attribs[] = {
|
||||
EGL_CONTEXT_CLIENT_VERSION, 2,
|
||||
EGL_NONE
|
||||
};
|
||||
if (!eglBindAPI(EGL_OPENGL_ES_API)) {
|
||||
xf86DrvMsg(scrn->scrnIndex, X_ERROR,
|
||||
"glamor: Failed to bind either GL or GLES APIs.\n");
|
||||
goto error;
|
||||
}
|
||||
|
||||
if (!eglChooseConfig(glamor_egl->display, NULL, &egl_config, 1, &n)) {
|
||||
xf86DrvMsg(scrn->scrnIndex, X_ERROR,
|
||||
"glamor: No acceptable EGL configs found\n");
|
||||
goto error;
|
||||
}
|
||||
|
||||
glamor_egl->context = eglCreateContext(glamor_egl->display,
|
||||
egl_config, EGL_NO_CONTEXT,
|
||||
config_attribs);
|
||||
|
||||
if (glamor_egl->context == EGL_NO_CONTEXT) {
|
||||
xf86DrvMsg(scrn->scrnIndex, X_ERROR,
|
||||
"glamor: Failed to create GL or GLES2 contexts\n");
|
||||
goto error;
|
||||
}
|
||||
|
||||
if (!eglMakeCurrent(glamor_egl->display,
|
||||
EGL_NO_SURFACE, EGL_NO_SURFACE, glamor_egl->context)) {
|
||||
xf86DrvMsg(scrn->scrnIndex, X_ERROR,
|
||||
"Failed to make GLES2 context current\n");
|
||||
goto error;
|
||||
}
|
||||
xf86DrvMsg(scrn->scrnIndex, X_ERROR,
|
||||
"glamor: Failed to create GL or GLES2 contexts\n");
|
||||
goto error;
|
||||
}
|
||||
|
||||
renderer = glGetString(GL_RENDERER);
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue