[Mesa-dev] [PATCH 04/15] anv: add from/to helpers with android and vulkan formats
Tapani Pälli
tapani.palli at intel.com
Tue Dec 11 11:32:00 UTC 2018
On 12/11/18 12:56 PM, Lionel Landwerlin wrote:
> On 27/11/2018 10:53, Tapani Pälli wrote:
>> v2: handle R8G8B8X8 as R8G8B8_UNORM (Jason)
>> v3: add HAL_PIXEL_FORMAT_NV12_Y_TILED_INTEL, we make it define
>> for now to avoid direct dependency to minigbm headers
>>
>> Signed-off-by: Tapani Pälli <tapani.palli at intel.com>
>> ---
>> src/intel/vulkan/vk_format_info.h | 50 +++++++++++++++++++++++++++++++
>> 1 file changed, 50 insertions(+)
>>
>> diff --git a/src/intel/vulkan/vk_format_info.h
>> b/src/intel/vulkan/vk_format_info.h
>> index a1cc6952c8f..555c67704bc 100644
>> --- a/src/intel/vulkan/vk_format_info.h
>> +++ b/src/intel/vulkan/vk_format_info.h
>> @@ -27,6 +27,56 @@
>> #include <stdbool.h>
>> #include <vulkan/vulkan.h>
>> +#ifdef ANDROID
>> +#include <vndk/hardware_buffer.h>
>> +/* See i915_private_android_types.h in minigbm. */
>> +#define HAL_PIXEL_FORMAT_NV12_Y_TILED_INTEL 0x100
>> +
>> +static inline VkFormat
>> +vk_format_from_android(unsigned android_format)
>> +{
>> + switch (android_format) {
>> + case AHARDWAREBUFFER_FORMAT_R8G8B8A8_UNORM:
>> + return VK_FORMAT_R8G8B8A8_UNORM;
>> + case AHARDWAREBUFFER_FORMAT_R8G8B8X8_UNORM:
>> + case AHARDWAREBUFFER_FORMAT_R8G8B8_UNORM:
>> + return VK_FORMAT_R8G8B8_UNORM;
>
>
> Hm... I think you could run into issue with a linear buffer
> AHARDWAREBUFFER_FORMAT_R8G8B8X8_UNORM.
>
> It seems anv will actually select R8G8B8 in that case and that probably
> won't match.
Thinking here was that these would be handled in similar way, both have
alpha 1.0 channel. Right now these are not required though so I can also
remove them from the list if this is preferred?
>
>> + 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;
>
>
> Is the android naming inconsistent or are all the other formats backwards?
I took these from Vulkan spec 'AHardwareBuffer Format Equivalence' so
seems to be what is wanted.
>
>> + case HAL_PIXEL_FORMAT_NV12_Y_TILED_INTEL:
>> + return VK_FORMAT_G8_B8R8_2PLANE_420_UNORM;
>> + case AHARDWAREBUFFER_FORMAT_BLOB:
>> + default:
>> + return VK_FORMAT_UNDEFINED;
>> + }
>> +}
>> +
>> +static inline unsigned
>> +android_format_from_vk(unsigned vk_format)
>> +{
>> + switch (vk_format) {
>> + case VK_FORMAT_R8G8B8A8_UNORM:
>> + return AHARDWAREBUFFER_FORMAT_R8G8B8A8_UNORM;
>> + case VK_FORMAT_R8G8B8_UNORM:
>> + return AHARDWAREBUFFER_FORMAT_R8G8B8_UNORM;
>> + case VK_FORMAT_R5G6B5_UNORM_PACK16:
>> + return AHARDWAREBUFFER_FORMAT_R5G6B5_UNORM;
>> + case VK_FORMAT_R16G16B16A16_SFLOAT:
>> + return AHARDWAREBUFFER_FORMAT_R16G16B16A16_FLOAT;
>> + case VK_FORMAT_A2B10G10R10_UNORM_PACK32:
>> + return AHARDWAREBUFFER_FORMAT_R10G10B10A2_UNORM;
>> + case VK_FORMAT_G8_B8R8_2PLANE_420_UNORM:
>> + return HAL_PIXEL_FORMAT_NV12_Y_TILED_INTEL;
>> + default:
>> + return AHARDWAREBUFFER_FORMAT_BLOB;
>> + }
>> +}
>> +#endif
>> +
>> static inline VkImageAspectFlags
>> vk_format_aspects(VkFormat format)
>> {
>
>
More information about the mesa-dev
mailing list