mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-05-02 23:09:05 +02:00
Spec requires apps to use the size returned from vkGetAndroidHardwareBufferPropertiesANDROID for AHB import, which includes dedicated image/buffer import and non-dedicated buffer import. Spec requires venus to use the size from image and buffer memory requirement for dma_buf fd import if it's dedicated. If not dedicated, the actual payload size should be used. For AHB export allocation of VkImage, the app provided size will be 0, and internally we must use the size from image memory requirement. For AHB export allocation of VkBuffer, the app provided size comes from buffer memory requirements and it can be smaller than the actual AHB size due to page alignment. Internally that's the size we must use. For AHB import, app must use the size from AHB prop query. Internally, we have to override that with the size from memory requirement if the import operation is dedicated to a VkImage or a VkBuffer. If not dedicated, the actual payload size should be used. The not working scenario is: 1. App creates an AHB backed VkBuffer, and the exported AHB size is larger than the buffer memory requirement (very common). 2. App imports the AHB without a dedicated VkBuffer. Then the entire AHB payload will be imported and the mmap_size might increase. Test: dEQP-VK.api.external.memory.android_hardware_buffer.* Signed-off-by: Yiwei Zhang <zzyiwei@chromium.org> Reviewed-by: Chia-I Wu <olvaffe@gmail.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/11055> |
||
|---|---|---|
| .. | ||
| venus-protocol | ||
| virtio-gpu | ||
| vtest | ||
| vulkan | ||
| meson.build | ||