egl: Add EGL_FRAMEBUFFER_TARGET_ANDROID attribute
This is used by Android to select an eglconfig compatible with HWComposer. Cc: mesa-stable@lists.freedesktop.org Signed-off-by: Rob Herring <robh@kernel.org> [Emil Velikov: add the _eglIsConfigAttribValid check] Signed-off-by: Emil Velikov <emil.velikov@collabora.com>
This commit is contained in:

committed by
Emil Velikov

parent
2d9e0f24e1
commit
8975527f58
@@ -381,6 +381,7 @@ _eglCreateExtensionsString(_EGLDisplay *dpy)
|
|||||||
char *exts = dpy->ExtensionsString;
|
char *exts = dpy->ExtensionsString;
|
||||||
|
|
||||||
/* Please keep these sorted alphabetically. */
|
/* Please keep these sorted alphabetically. */
|
||||||
|
_EGL_CHECK_EXTENSION(ANDROID_framebuffer_target);
|
||||||
_EGL_CHECK_EXTENSION(ANDROID_image_native_buffer);
|
_EGL_CHECK_EXTENSION(ANDROID_image_native_buffer);
|
||||||
|
|
||||||
_EGL_CHECK_EXTENSION(CHROMIUM_sync_control);
|
_EGL_CHECK_EXTENSION(CHROMIUM_sync_control);
|
||||||
|
@@ -245,7 +245,10 @@ static const struct {
|
|||||||
/* extensions */
|
/* extensions */
|
||||||
{ EGL_Y_INVERTED_NOK, ATTRIB_TYPE_BOOLEAN,
|
{ EGL_Y_INVERTED_NOK, ATTRIB_TYPE_BOOLEAN,
|
||||||
ATTRIB_CRITERION_EXACT,
|
ATTRIB_CRITERION_EXACT,
|
||||||
EGL_DONT_CARE }
|
EGL_DONT_CARE },
|
||||||
|
{ EGL_FRAMEBUFFER_TARGET_ANDROID, ATTRIB_TYPE_BOOLEAN,
|
||||||
|
ATTRIB_CRITERION_EXACT,
|
||||||
|
EGL_DONT_CARE },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@@ -488,6 +491,8 @@ _eglIsConfigAttribValid(_EGLConfig *conf, EGLint attr)
|
|||||||
switch (attr) {
|
switch (attr) {
|
||||||
case EGL_Y_INVERTED_NOK:
|
case EGL_Y_INVERTED_NOK:
|
||||||
return conf->Display->Extensions.NOK_texture_from_pixmap;
|
return conf->Display->Extensions.NOK_texture_from_pixmap;
|
||||||
|
case EGL_FRAMEBUFFER_TARGET_ANDROID:
|
||||||
|
return conf->Display->Extensions.ANDROID_framebuffer_target;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@@ -86,6 +86,7 @@ struct _egl_config
|
|||||||
|
|
||||||
/* extensions */
|
/* extensions */
|
||||||
EGLint YInvertedNOK;
|
EGLint YInvertedNOK;
|
||||||
|
EGLint FramebufferTargetAndroid;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@@ -133,6 +134,7 @@ _eglOffsetOfConfig(EGLint attr)
|
|||||||
ATTRIB_MAP(EGL_CONFORMANT, Conformant);
|
ATTRIB_MAP(EGL_CONFORMANT, Conformant);
|
||||||
/* extensions */
|
/* extensions */
|
||||||
ATTRIB_MAP(EGL_Y_INVERTED_NOK, YInvertedNOK);
|
ATTRIB_MAP(EGL_Y_INVERTED_NOK, YInvertedNOK);
|
||||||
|
ATTRIB_MAP(EGL_FRAMEBUFFER_TARGET_ANDROID, FramebufferTargetAndroid);
|
||||||
#undef ATTRIB_MAP
|
#undef ATTRIB_MAP
|
||||||
default:
|
default:
|
||||||
return -1;
|
return -1;
|
||||||
|
@@ -90,6 +90,7 @@ struct _egl_resource
|
|||||||
struct _egl_extensions
|
struct _egl_extensions
|
||||||
{
|
{
|
||||||
/* Please keep these sorted alphabetically. */
|
/* Please keep these sorted alphabetically. */
|
||||||
|
EGLBoolean ANDROID_framebuffer_target;
|
||||||
EGLBoolean ANDROID_image_native_buffer;
|
EGLBoolean ANDROID_image_native_buffer;
|
||||||
|
|
||||||
EGLBoolean CHROMIUM_sync_control;
|
EGLBoolean CHROMIUM_sync_control;
|
||||||
|
Reference in New Issue
Block a user