commit | 4da49ff09b5199798eb246b80aacdb9c09949587 | [log] [tgz] |
---|---|---|
author | Andy Candet <Andy.Candet@imgtec.com> | Sat Apr 16 21:16:53 2022 +0100 |
committer | Matthew Netsch <quic_mnetsch@quicinc.com> | Thu Jun 02 21:21:49 2022 +0000 |
tree | 31dc381d685c89cd0d892b1754ec8b1615f4f90e | |
parent | f7bd056a21c1d134b75f97fb9aea0cc75701fc3c [diff] |
Fix extension checks for EGL external image tests Commit 2090c97 extended dEQP-EGL.functional.image.modify.* with new actions to test sampling from an external image. The actions implement getRequiredExtension, so they were likely intended to be skipped if GL_OES_EGL_image_external is not available. However, extension checks are only performed for actions invoked through ImageFormatCase. These actions are invoked one level down the call stack, through RenderTryAll. The result is that 22 tests in dEQP-EGL.functional.image.modify.* fail during shader compilation if the extension is not available. This commit adds an extension check to RenderTryAll::invokeGLES. Actions will be skipped if the check fails. This is probably what was intended in the first place, since RenderTryAll ignores NotSupported results. Affects: dEQP-EGL.functional.image.modify.* Components: EGL Change-Id: Id1106d69fbe71d39695fc32513d80d23f1e94b40
This repository contains a GPU testing suite called dEQP (drawElements Quality Program). dEQP contains tests for several graphics APIs, including OpenGL ES, EGL, and Vulkan.
Up-to-date documentation for the dEQP is available at Android Open Source Project site.
The .qpa logs generated by the conformance tests may contain embedded PNG images of the results. These can be viewed with scripts/qpa_image_viewer.html
, by opening the file with a web browser and following its instructions, or using the Cherry tool.
This repository includes Khronos Vulkan CTS under external/vulkancts
directory. For more information see Vulkan CTS README.
This repository includes Khronos OpenGL / OpenGL ES CTS under external/openglcts
directory. For more information see OpenGL / OpenGL ES CTS README.
ANGLE can be built for Android by following the instructions here.
The resulting ANGLE shared object libraries can be linked against and embedded into dEQP.apk
with the --angle-path
option. This will cause dEQP.apk
to use the ANGLE libraries for OpenGL ES calls, rather than the native drivers.
An ABI must be specified and the directory structure containing the ANGLE shared objects must match it so the build system can find the correct *.so
files.
Assuming ANGLE shared objects are generated into ~/chromium/src/out/Release/
and dEQP.apk
will be generated with --abis arm64-v8a
, issue the following commands:
cd ~/chromium/src/out/Release/ mkdir arm64-v8a && cd arm64-v8a cp ../lib*_angle.so .
The --angle-path ~/chromium/src/out/Release/
option can then be used to link against and embed the ANGLE shared object files. The full command would be:
python scripts/android/build_apk.py --sdk <path to Android SDK> --ndk <path to Android NDK> --abis arm64-v8a --angle-path ~/chromium/src/out/Release/