vulkan: Common vk_format_get_component_bits
RADV and PowerVR use the same implementation. Turnip does use a slightly modified version but the helper only has one use -> just inline it and get rid of turnip's vk_format.h. Signed-off-by: Konstantin Seurer <konstantin.seurer@gmail.com> Reviewed-by: Jason Ekstrand <jason.ekstrand@collabora.com> Reviewed-by: Samuel Pitoiset <samuel.pitoiset@gmail.com> Reviewed-by: Emma Anholt <emma@anholt.net> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/17515>
This commit is contained in:

committed by
Marge Bot

parent
2e71e23188
commit
fc26fbde3d
@@ -119,15 +119,6 @@ vk_format_no_srgb(VkFormat format)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline unsigned
|
|
||||||
vk_format_get_component_bits(VkFormat format, enum util_format_colorspace colorspace,
|
|
||||||
unsigned component)
|
|
||||||
{
|
|
||||||
return util_format_get_component_bits(vk_format_to_pipe_format(format),
|
|
||||||
colorspace,
|
|
||||||
component);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline VkFormat
|
static inline VkFormat
|
||||||
vk_to_non_srgb_format(VkFormat format)
|
vk_to_non_srgb_format(VkFormat format)
|
||||||
{
|
{
|
||||||
|
@@ -52,7 +52,6 @@ libtu_files = files(
|
|||||||
'tu_util.c',
|
'tu_util.c',
|
||||||
'tu_util.h',
|
'tu_util.h',
|
||||||
'tu_perfetto.h',
|
'tu_perfetto.h',
|
||||||
'vk_format.h',
|
|
||||||
)
|
)
|
||||||
|
|
||||||
tu_deps = []
|
tu_deps = []
|
||||||
|
@@ -503,6 +503,19 @@ lower_tex_ycbcr(const struct tu_pipeline_layout *layout,
|
|||||||
uint8_t bits = vk_format_get_component_bits(ycbcr_sampler->format,
|
uint8_t bits = vk_format_get_component_bits(ycbcr_sampler->format,
|
||||||
UTIL_FORMAT_COLORSPACE_RGB,
|
UTIL_FORMAT_COLORSPACE_RGB,
|
||||||
PIPE_SWIZZLE_X);
|
PIPE_SWIZZLE_X);
|
||||||
|
|
||||||
|
switch (ycbcr_sampler->format) {
|
||||||
|
case VK_FORMAT_G8B8G8R8_422_UNORM:
|
||||||
|
case VK_FORMAT_B8G8R8G8_422_UNORM:
|
||||||
|
case VK_FORMAT_G8_B8R8_2PLANE_420_UNORM:
|
||||||
|
case VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM:
|
||||||
|
/* util_format_get_component_bits doesn't return what we want */
|
||||||
|
bits = 8;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
uint32_t bpcs[3] = {bits, bits, bits}; /* TODO: use right bpc for each channel ? */
|
uint32_t bpcs[3] = {bits, bits, bits}; /* TODO: use right bpc for each channel ? */
|
||||||
nir_ssa_def *result = nir_convert_ycbcr_to_rgb(builder,
|
nir_ssa_def *result = nir_convert_ycbcr_to_rgb(builder,
|
||||||
ycbcr_sampler->ycbcr_model,
|
ycbcr_sampler->ycbcr_model,
|
||||||
|
@@ -1,57 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright © 2016 Red Hat.
|
|
||||||
* Copyright © 2016 Bas Nieuwenhuizen
|
|
||||||
*
|
|
||||||
* Based on u_format.h which is:
|
|
||||||
* Copyright 2009-2010 VMware, Inc.
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
||||||
* copy of this software and associated documentation files (the "Software"),
|
|
||||||
* to deal in the Software without restriction, including without limitation
|
|
||||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
||||||
* and/or sell copies of the Software, and to permit persons to whom the
|
|
||||||
* Software is furnished to do so, subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice (including the next
|
|
||||||
* paragraph) shall be included in all copies or substantial portions of the
|
|
||||||
* Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
||||||
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
||||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
||||||
* DEALINGS IN THE SOFTWARE.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef VK_FORMAT_H
|
|
||||||
#define VK_FORMAT_H
|
|
||||||
|
|
||||||
#include <assert.h>
|
|
||||||
#include <util/macros.h>
|
|
||||||
#include <util/format/u_format.h>
|
|
||||||
#include <vulkan/util/vk_format.h>
|
|
||||||
|
|
||||||
#include <vulkan/vulkan.h>
|
|
||||||
|
|
||||||
static inline unsigned
|
|
||||||
vk_format_get_component_bits(VkFormat format,
|
|
||||||
enum util_format_colorspace colorspace,
|
|
||||||
unsigned component)
|
|
||||||
{
|
|
||||||
switch (format) {
|
|
||||||
case VK_FORMAT_G8B8G8R8_422_UNORM:
|
|
||||||
case VK_FORMAT_B8G8R8G8_422_UNORM:
|
|
||||||
case VK_FORMAT_G8_B8R8_2PLANE_420_UNORM:
|
|
||||||
case VK_FORMAT_G8_B8_R8_3PLANE_420_UNORM:
|
|
||||||
/* util_format_get_component_bits doesn't return what we want */
|
|
||||||
return 8;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return util_format_get_component_bits(vk_format_to_pipe_format(format),
|
|
||||||
colorspace, component);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* VK_FORMAT_H */
|
|
@@ -75,16 +75,6 @@ static inline bool vk_format_has_32bit_component(VkFormat vk_format)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline uint
|
|
||||||
vk_format_get_component_bits(VkFormat vk_format,
|
|
||||||
enum util_format_colorspace colorspace,
|
|
||||||
uint32_t component)
|
|
||||||
{
|
|
||||||
return util_format_get_component_bits(vk_format_to_pipe_format(vk_format),
|
|
||||||
colorspace,
|
|
||||||
component);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline bool vk_format_is_normalized(VkFormat vk_format)
|
static inline bool vk_format_is_normalized(VkFormat vk_format)
|
||||||
{
|
{
|
||||||
const struct util_format_description *desc =
|
const struct util_format_description *desc =
|
||||||
|
@@ -165,6 +165,15 @@ vk_format_description(VkFormat format)
|
|||||||
return util_format_description(vk_format_to_pipe_format(format));
|
return util_format_description(vk_format_to_pipe_format(format));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline unsigned
|
||||||
|
vk_format_get_component_bits(VkFormat format, enum util_format_colorspace colorspace,
|
||||||
|
unsigned component)
|
||||||
|
{
|
||||||
|
return util_format_get_component_bits(vk_format_to_pipe_format(format),
|
||||||
|
colorspace,
|
||||||
|
component);
|
||||||
|
}
|
||||||
|
|
||||||
static inline unsigned
|
static inline unsigned
|
||||||
vk_format_get_nr_components(VkFormat format)
|
vk_format_get_nr_components(VkFormat format)
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user