vulkan: add vk_ahb_format_to_image_format
There should be no functional change. Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/22619>
This commit is contained in:
@@ -387,17 +387,6 @@ static inline VkFormat
|
|||||||
vk_format_from_android(unsigned android_format, unsigned android_usage)
|
vk_format_from_android(unsigned android_format, unsigned android_usage)
|
||||||
{
|
{
|
||||||
switch (android_format) {
|
switch (android_format) {
|
||||||
case AHARDWAREBUFFER_FORMAT_R8G8B8A8_UNORM:
|
|
||||||
case AHARDWAREBUFFER_FORMAT_R8G8B8X8_UNORM:
|
|
||||||
return VK_FORMAT_R8G8B8A8_UNORM;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_R8G8B8_UNORM:
|
|
||||||
return VK_FORMAT_R8G8B8_UNORM;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_R5G6B5_UNORM:
|
|
||||||
return VK_FORMAT_R5G6B5_UNORM_PACK16;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_R16G16B16A16_FLOAT:
|
|
||||||
return VK_FORMAT_R16G16B16A16_SFLOAT;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_R10G10B10A2_UNORM:
|
|
||||||
return VK_FORMAT_A2B10G10R10_UNORM_PACK32;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_Y8Cb8Cr8_420:
|
case AHARDWAREBUFFER_FORMAT_Y8Cb8Cr8_420:
|
||||||
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
||||||
case AHARDWAREBUFFER_FORMAT_IMPLEMENTATION_DEFINED:
|
case AHARDWAREBUFFER_FORMAT_IMPLEMENTATION_DEFINED:
|
||||||
@@ -405,9 +394,8 @@ vk_format_from_android(unsigned android_format, unsigned android_usage)
|
|||||||
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
||||||
else
|
else
|
||||||
return VK_FORMAT_R8G8B8_UNORM;
|
return VK_FORMAT_R8G8B8_UNORM;
|
||||||
case AHARDWAREBUFFER_FORMAT_BLOB:
|
|
||||||
default:
|
default:
|
||||||
return VK_FORMAT_UNDEFINED;
|
return vk_ahb_format_to_image_format(android_format);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -114,17 +114,8 @@ inline VkFormat
|
|||||||
vk_format_from_android(unsigned android_format, unsigned android_usage)
|
vk_format_from_android(unsigned android_format, unsigned android_usage)
|
||||||
{
|
{
|
||||||
switch (android_format) {
|
switch (android_format) {
|
||||||
case AHARDWAREBUFFER_FORMAT_R8G8B8A8_UNORM:
|
|
||||||
return VK_FORMAT_R8G8B8A8_UNORM;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_R8G8B8X8_UNORM:
|
case AHARDWAREBUFFER_FORMAT_R8G8B8X8_UNORM:
|
||||||
case AHARDWAREBUFFER_FORMAT_R8G8B8_UNORM:
|
|
||||||
return VK_FORMAT_R8G8B8_UNORM;
|
return VK_FORMAT_R8G8B8_UNORM;
|
||||||
case AHARDWAREBUFFER_FORMAT_R5G6B5_UNORM:
|
|
||||||
return VK_FORMAT_R5G6B5_UNORM_PACK16;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_R16G16B16A16_FLOAT:
|
|
||||||
return VK_FORMAT_R16G16B16A16_SFLOAT;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_R10G10B10A2_UNORM:
|
|
||||||
return VK_FORMAT_A2B10G10R10_UNORM_PACK32;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_Y8Cb8Cr8_420:
|
case AHARDWAREBUFFER_FORMAT_Y8Cb8Cr8_420:
|
||||||
case HAL_PIXEL_FORMAT_NV12_Y_TILED_INTEL:
|
case HAL_PIXEL_FORMAT_NV12_Y_TILED_INTEL:
|
||||||
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
||||||
@@ -133,9 +124,8 @@ vk_format_from_android(unsigned android_format, unsigned android_usage)
|
|||||||
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
||||||
else
|
else
|
||||||
return VK_FORMAT_R8G8B8_UNORM;
|
return VK_FORMAT_R8G8B8_UNORM;
|
||||||
case AHARDWAREBUFFER_FORMAT_BLOB:
|
|
||||||
default:
|
default:
|
||||||
return VK_FORMAT_UNDEFINED;
|
return vk_ahb_format_to_image_format(android_format);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -114,17 +114,8 @@ inline VkFormat
|
|||||||
vk_format_from_android(unsigned android_format, unsigned android_usage)
|
vk_format_from_android(unsigned android_format, unsigned android_usage)
|
||||||
{
|
{
|
||||||
switch (android_format) {
|
switch (android_format) {
|
||||||
case AHARDWAREBUFFER_FORMAT_R8G8B8A8_UNORM:
|
|
||||||
return VK_FORMAT_R8G8B8A8_UNORM;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_R8G8B8X8_UNORM:
|
case AHARDWAREBUFFER_FORMAT_R8G8B8X8_UNORM:
|
||||||
case AHARDWAREBUFFER_FORMAT_R8G8B8_UNORM:
|
|
||||||
return VK_FORMAT_R8G8B8_UNORM;
|
return VK_FORMAT_R8G8B8_UNORM;
|
||||||
case AHARDWAREBUFFER_FORMAT_R5G6B5_UNORM:
|
|
||||||
return VK_FORMAT_R5G6B5_UNORM_PACK16;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_R16G16B16A16_FLOAT:
|
|
||||||
return VK_FORMAT_R16G16B16A16_SFLOAT;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_R10G10B10A2_UNORM:
|
|
||||||
return VK_FORMAT_A2B10G10R10_UNORM_PACK32;
|
|
||||||
case AHARDWAREBUFFER_FORMAT_Y8Cb8Cr8_420:
|
case AHARDWAREBUFFER_FORMAT_Y8Cb8Cr8_420:
|
||||||
case HAL_PIXEL_FORMAT_NV12_Y_TILED_INTEL:
|
case HAL_PIXEL_FORMAT_NV12_Y_TILED_INTEL:
|
||||||
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
||||||
@@ -133,9 +124,8 @@ vk_format_from_android(unsigned android_format, unsigned android_usage)
|
|||||||
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
|
||||||
else
|
else
|
||||||
return VK_FORMAT_R8G8B8_UNORM;
|
return VK_FORMAT_R8G8B8_UNORM;
|
||||||
case AHARDWAREBUFFER_FORMAT_BLOB:
|
|
||||||
default:
|
default:
|
||||||
return VK_FORMAT_UNDEFINED;
|
return vk_ahb_format_to_image_format(android_format);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -61,6 +61,44 @@
|
|||||||
#define AHARDWAREBUFFER_USAGE_GPU_FRAMEBUFFER AHARDWAREBUFFER_USAGE_GPU_COLOR_OUTPUT
|
#define AHARDWAREBUFFER_USAGE_GPU_FRAMEBUFFER AHARDWAREBUFFER_USAGE_GPU_COLOR_OUTPUT
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* Convert an AHB format to a VkFormat, based on the "AHardwareBuffer Format
|
||||||
|
* Equivalence" table in Vulkan spec.
|
||||||
|
*
|
||||||
|
* Note that this only covers a subset of AHB formats defined in NDK. Drivers
|
||||||
|
* can support more AHB formats, including private ones.
|
||||||
|
*/
|
||||||
|
VkFormat
|
||||||
|
vk_ahb_format_to_image_format(uint32_t ahb_format)
|
||||||
|
{
|
||||||
|
switch (ahb_format) {
|
||||||
|
case AHARDWAREBUFFER_FORMAT_R8G8B8A8_UNORM:
|
||||||
|
case AHARDWAREBUFFER_FORMAT_R8G8B8X8_UNORM:
|
||||||
|
return VK_FORMAT_R8G8B8A8_UNORM;
|
||||||
|
case AHARDWAREBUFFER_FORMAT_R8G8B8_UNORM:
|
||||||
|
return VK_FORMAT_R8G8B8_UNORM;
|
||||||
|
case AHARDWAREBUFFER_FORMAT_R5G6B5_UNORM:
|
||||||
|
return VK_FORMAT_R5G6B5_UNORM_PACK16;
|
||||||
|
case AHARDWAREBUFFER_FORMAT_R16G16B16A16_FLOAT:
|
||||||
|
return VK_FORMAT_R16G16B16A16_SFLOAT;
|
||||||
|
case AHARDWAREBUFFER_FORMAT_R10G10B10A2_UNORM:
|
||||||
|
return VK_FORMAT_A2B10G10R10_UNORM_PACK32;
|
||||||
|
case AHARDWAREBUFFER_FORMAT_D16_UNORM:
|
||||||
|
return VK_FORMAT_D16_UNORM;
|
||||||
|
case AHARDWAREBUFFER_FORMAT_D24_UNORM:
|
||||||
|
return VK_FORMAT_X8_D24_UNORM_PACK32;
|
||||||
|
case AHARDWAREBUFFER_FORMAT_D24_UNORM_S8_UINT:
|
||||||
|
return VK_FORMAT_D24_UNORM_S8_UINT;
|
||||||
|
case AHARDWAREBUFFER_FORMAT_D32_FLOAT:
|
||||||
|
return VK_FORMAT_D32_SFLOAT;
|
||||||
|
case AHARDWAREBUFFER_FORMAT_D32_FLOAT_S8_UINT:
|
||||||
|
return VK_FORMAT_D32_SFLOAT_S8_UINT;
|
||||||
|
case AHARDWAREBUFFER_FORMAT_S8_UINT:
|
||||||
|
return VK_FORMAT_S8_UINT;
|
||||||
|
default:
|
||||||
|
return VK_FORMAT_UNDEFINED;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Construct ahw usage mask from image usage bits, see
|
/* Construct ahw usage mask from image usage bits, see
|
||||||
* 'AHardwareBuffer Usage Equivalence' in Vulkan spec.
|
* 'AHardwareBuffer Usage Equivalence' in Vulkan spec.
|
||||||
*/
|
*/
|
||||||
|
@@ -31,6 +31,8 @@ extern "C" {
|
|||||||
|
|
||||||
#if ANDROID_API_LEVEL >= 26
|
#if ANDROID_API_LEVEL >= 26
|
||||||
|
|
||||||
|
VkFormat vk_ahb_format_to_image_format(uint32_t ahb_format);
|
||||||
|
|
||||||
uint64_t vk_image_usage_to_ahb_usage(const VkImageCreateFlags vk_create,
|
uint64_t vk_image_usage_to_ahb_usage(const VkImageCreateFlags vk_create,
|
||||||
const VkImageUsageFlags vk_usage);
|
const VkImageUsageFlags vk_usage);
|
||||||
|
|
||||||
@@ -39,6 +41,12 @@ vk_alloc_ahardware_buffer(const VkMemoryAllocateInfo *pAllocateInfo);
|
|||||||
|
|
||||||
#else /* ANDROID_API_LEVEL >= 26 */
|
#else /* ANDROID_API_LEVEL >= 26 */
|
||||||
|
|
||||||
|
static inline VkFormat
|
||||||
|
vk_ahb_format_to_image_format(uint32_t ahb_format)
|
||||||
|
{
|
||||||
|
return VK_FORMAT_UNDEFINED;
|
||||||
|
}
|
||||||
|
|
||||||
static inline uint64_t
|
static inline uint64_t
|
||||||
vk_image_usage_to_ahb_usage(const VkImageCreateFlags vk_create,
|
vk_image_usage_to_ahb_usage(const VkImageCreateFlags vk_create,
|
||||||
const VkImageUsageFlags vk_usage)
|
const VkImageUsageFlags vk_usage)
|
||||||
|
Reference in New Issue
Block a user