From: Dave Airlie Date: Mon, 21 Aug 2017 03:58:27 +0000 (+1000) Subject: radv/image: don't rescale width/height if the format isn't changing X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a74d98743115b928eaeabc0d58b63174158aa209;p=mesa.git radv/image: don't rescale width/height if the format isn't changing If the image view has the same format, we don't need to rescale the w/h. Reviewed-by: Bas Nieuwenhuizen Cc: "17.2" Signed-off-by: Dave Airlie --- diff --git a/src/amd/vulkan/radv_image.c b/src/amd/vulkan/radv_image.c index 5e380411701..ddf15bc8361 100644 --- a/src/amd/vulkan/radv_image.c +++ b/src/amd/vulkan/radv_image.c @@ -947,10 +947,12 @@ radv_image_view_init(struct radv_image_view *iview, .depth = radv_minify(image->info.depth , range->baseMipLevel), }; - iview->extent.width = round_up_u32(iview->extent.width * vk_format_get_blockwidth(iview->vk_format), - vk_format_get_blockwidth(image->vk_format)); - iview->extent.height = round_up_u32(iview->extent.height * vk_format_get_blockheight(iview->vk_format), - vk_format_get_blockheight(image->vk_format)); + if (iview->vk_format != image->vk_format) { + iview->extent.width = round_up_u32(iview->extent.width * vk_format_get_blockwidth(iview->vk_format), + vk_format_get_blockwidth(image->vk_format)); + iview->extent.height = round_up_u32(iview->extent.height * vk_format_get_blockheight(iview->vk_format), + vk_format_get_blockheight(image->vk_format)); + } iview->base_layer = range->baseArrayLayer; iview->layer_count = radv_get_layerCount(image, range);