[Mesa-stable] [PATCH] egl/android: Change order of EGLConfig generation (v2)

Emil Velikov emil.l.velikov at gmail.com
Thu Jun 22 13:35:30 UTC 2017


On 20 June 2017 at 23:03, Chad Versace <chadversary at chromium.org> wrote:
> Many Android apps (such as Google's official NDK GLES2 example app), and
> even portions the core framework code (such as SystemServiceManager in
> Nougat), incorrectly choose their EGLConfig.  They neglect to match the
> EGLConfig's EGL_NATIVE_VISUAL_ID against the window's native format, and
> instead choose the first EGLConfig whose channel sizes match those of
> the native window format while ignoring the channel *ordering*.
>
> We can detect such buggy clients in logcat when they call
> eglCreateSurface, by detecting the mismatch between the EGLConfig's
> format and the window's format.
>
> As a workaround, this patch changes the order of EGLConfig generation
> such that all EGLConfigs for HAL pixel format i precede those for HAL
> pixel format i+1. In my (chadversary) testing on Android Nougat, this
> was good enough to pacify the buggy clients.
>
> v2: Rebase to make patch cherry-pickable to stable.
>
> Cc: mesa-stable at lists.freedesktop.org
> Cc: Tomasz Figa <tfiga at chromium.org>
> Cc: Rob Herring <robh at kernel.org>
> Cc: Tapani Pälli <tapani.palli at intel.com>
> Cc: Emil Velikov <emil.velikov at collabora.com>
Thanks Chad.

Reviewed-by: Emil Velikov <emil.velikov at collabora.com>

-Emil


More information about the mesa-stable mailing list