commit | 717c051d4bcc9b71f13bc6b223e9926dcf9b7bd5 | [log] [tgz] |
---|---|---|
author | Hyunjun Ko <zzoon@igalia.com> | Fri Jan 20 11:11:02 2023 +0900 |
committer | Piotr Byszewski <piotr.byszewski@mobica.com> | Fri Jan 27 08:36:42 2023 +0000 |
tree | 75cb0598c45ffdfbdacb17e5c92725688f88e321 | |
parent | 10df72abd005896aec6000e70be0453b1f880f96 [diff] |
Do not allow to call vkSetEvent after submission, which is invalid. The spec says: "If a command buffer submission waits for any events to be signaled, the application must ensure that command buffer submissions will be able to complete without any subsequent operations by the application. Events signaled by the host must be signaled before the command buffer waits on those events." This means it's not valid to signal an event on the host after submission of a command buffer containing a wait for the event. Also it forces the command buffer to stop for an unknown amount of time, as much as the time needed for the host to signal the event with vkSetEvent. However there were some CTS tests doing like this, which should be fixed. For vktApiExternalMemoryTests.cpp, There was a vkSetEvent call after submission to hold a command to be executed before signaling to get a native file descriptor, which is not valid. So the tests should allow to get -1. Also we do an atomic calculation to avoid singalling right after submit when trying to get a native fd. The simple atomic calculation is evaluated to take about 10ms. For vktApiExternalMemoryTests.cpp and vktMemoryExternalMemoryHostTests.cpp, replace vkSetEvent with timeline semaphore to signal from the host. Affects: dEQP-VK.api.external.semaphore.* dEQP-VK.api.external.fence.* dEQP-VK.api.command_buffers.secondary_execute_twice dEQP-VK.memory.external_memory_host.synchronization.synchronization VK-GL-CTS Issue: 4075 Components: Vulkan Change-Id: I5544bb15a418bbbbd6552ca04bec673a56ca3109
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/