* VkImageViewCreateInfo::subresourceRange::baseArrayLayer.
*/
uint32_t
-radv_meta_get_iview_layer(const struct radv_image *dest_image,
- const VkImageSubresourceLayers *dest_subresource,
- const VkOffset3D *dest_offset)
+radv_meta_get_iview_layer(const struct radv_image *dst_image,
+ const VkImageSubresourceLayers *dst_subresource,
+ const VkOffset3D *dst_offset)
{
- switch (dest_image->vk.image_type) {
+ switch (dst_image->vk.image_type) {
case VK_IMAGE_TYPE_1D:
case VK_IMAGE_TYPE_2D:
- return dest_subresource->baseArrayLayer;
+ return dst_subresource->baseArrayLayer;
case VK_IMAGE_TYPE_3D:
/* HACK: Vulkan does not allow attaching a 3D image to a framebuffer,
* but meta does it anyway. When doing so, we translate the
* destination's z offset into an array offset.
*/
- return dest_offset->z;
+ return dst_offset->z;
default:
assert(!"bad VkImageType");
return 0;
VkImageViewType radv_meta_get_view_type(const struct radv_image *image);
-uint32_t radv_meta_get_iview_layer(const struct radv_image *dest_image,
- const VkImageSubresourceLayers *dest_subresource,
- const VkOffset3D *dest_offset);
+uint32_t radv_meta_get_iview_layer(const struct radv_image *dst_image,
+ const VkImageSubresourceLayers *dst_subresource,
+ const VkOffset3D *dst_offset);
struct radv_meta_blit2d_surf {
/** The size of an element in bytes. */
void radv_meta_resolve_compute_image(struct radv_cmd_buffer *cmd_buffer,
struct radv_image *src_image, VkFormat src_format,
- VkImageLayout src_image_layout, struct radv_image *dest_image,
- VkFormat dest_format, VkImageLayout dest_image_layout,
+ VkImageLayout src_image_layout, struct radv_image *dst_image,
+ VkFormat dst_format, VkImageLayout dst_image_layout,
const VkImageResolve2 *region);
void radv_meta_resolve_fragment_image(struct radv_cmd_buffer *cmd_buffer,
struct radv_image *src_image, VkImageLayout src_image_layout,
- struct radv_image *dest_image,
- VkImageLayout dest_image_layout,
+ struct radv_image *dst_image,
+ VkImageLayout dst_image_layout,
const VkImageResolve2 *region);
void radv_decompress_resolve_rendering_src(struct radv_cmd_buffer *cmd_buffer);
struct blit_region {
VkOffset3D src_offset;
VkExtent3D src_extent;
- VkOffset3D dest_offset;
- VkExtent3D dest_extent;
+ VkOffset3D dst_offset;
+ VkExtent3D dst_extent;
};
static VkResult build_pipeline(struct radv_device *device, VkImageAspectFlagBits aspect,
static void
meta_emit_blit(struct radv_cmd_buffer *cmd_buffer, struct radv_image *src_image,
struct radv_image_view *src_iview, VkImageLayout src_image_layout,
- float src_offset_0[3], float src_offset_1[3], struct radv_image *dest_image,
- struct radv_image_view *dest_iview, VkImageLayout dest_image_layout,
- VkRect2D dest_box, VkSampler sampler)
+ float src_offset_0[3], float src_offset_1[3], struct radv_image *dst_image,
+ struct radv_image_view *dst_iview, VkImageLayout dst_image_layout,
+ VkRect2D dst_box, VkSampler sampler)
{
struct radv_device *device = cmd_buffer->device;
uint32_t src_width = radv_minify(src_iview->image->info.width, src_iview->vk.base_mip_level);
uint32_t src_height = radv_minify(src_iview->image->info.height, src_iview->vk.base_mip_level);
uint32_t src_depth = radv_minify(src_iview->image->info.depth, src_iview->vk.base_mip_level);
- uint32_t dst_width = radv_minify(dest_iview->image->info.width, dest_iview->vk.base_mip_level);
- uint32_t dst_height = radv_minify(dest_iview->image->info.height, dest_iview->vk.base_mip_level);
+ uint32_t dst_width = radv_minify(dst_iview->image->info.width, dst_iview->vk.base_mip_level);
+ uint32_t dst_height = radv_minify(dst_iview->image->info.height, dst_iview->vk.base_mip_level);
- assert(src_image->info.samples == dest_image->info.samples);
+ assert(src_image->info.samples == dst_image->info.samples);
float vertex_push_constants[5] = {
src_offset_0[0] / (float)src_width, src_offset_0[1] / (float)src_height,
switch (src_iview->vk.aspects) {
case VK_IMAGE_ASPECT_COLOR_BIT: {
- fs_key = radv_format_meta_fs_key(device, dest_image->vk.format);
+ fs_key = radv_format_meta_fs_key(device, dst_image->vk.format);
format = radv_fs_key_format_exemplars[fs_key];
switch (src_image->vk.image_type) {
VkRenderingAttachmentInfo color_att;
if (src_iview->image->vk.aspects == VK_IMAGE_ASPECT_COLOR_BIT) {
- unsigned dst_layout = radv_meta_dst_layout_from_layout(dest_image_layout);
+ unsigned dst_layout = radv_meta_dst_layout_from_layout(dst_image_layout);
VkImageLayout layout = radv_meta_dst_layout_to_layout(dst_layout);
color_att = (VkRenderingAttachmentInfo) {
.sType = VK_STRUCTURE_TYPE_RENDERING_ATTACHMENT_INFO,
- .imageView = radv_image_view_to_handle(dest_iview),
+ .imageView = radv_image_view_to_handle(dst_iview),
.imageLayout = layout,
.loadOp = VK_ATTACHMENT_LOAD_OP_LOAD,
.storeOp = VK_ATTACHMENT_STORE_OP_STORE,
VkRenderingAttachmentInfo depth_att;
if (src_iview->image->vk.aspects & VK_IMAGE_ASPECT_DEPTH_BIT) {
- enum radv_blit_ds_layout ds_layout = radv_meta_blit_ds_to_type(dest_image_layout);
+ enum radv_blit_ds_layout ds_layout = radv_meta_blit_ds_to_type(dst_image_layout);
VkImageLayout layout = radv_meta_blit_ds_to_layout(ds_layout);
depth_att = (VkRenderingAttachmentInfo) {
.sType = VK_STRUCTURE_TYPE_RENDERING_ATTACHMENT_INFO,
- .imageView = radv_image_view_to_handle(dest_iview),
+ .imageView = radv_image_view_to_handle(dst_iview),
.imageLayout = layout,
.loadOp = VK_ATTACHMENT_LOAD_OP_LOAD,
.storeOp = VK_ATTACHMENT_STORE_OP_STORE,
VkRenderingAttachmentInfo stencil_att;
if (src_iview->image->vk.aspects & VK_IMAGE_ASPECT_STENCIL_BIT) {
- enum radv_blit_ds_layout ds_layout = radv_meta_blit_ds_to_type(dest_image_layout);
+ enum radv_blit_ds_layout ds_layout = radv_meta_blit_ds_to_type(dst_image_layout);
VkImageLayout layout = radv_meta_blit_ds_to_layout(ds_layout);
stencil_att = (VkRenderingAttachmentInfo) {
.sType = VK_STRUCTURE_TYPE_RENDERING_ATTACHMENT_INFO,
- .imageView = radv_image_view_to_handle(dest_iview),
+ .imageView = radv_image_view_to_handle(dst_iview),
.imageLayout = layout,
.loadOp = VK_ATTACHMENT_LOAD_OP_LOAD,
.storeOp = VK_ATTACHMENT_STORE_OP_STORE,
static void
decode_etc(struct radv_cmd_buffer *cmd_buffer, struct radv_image_view *src_iview,
- struct radv_image_view *dest_iview, const VkOffset3D *offset, const VkExtent3D *extent)
+ struct radv_image_view *dst_iview, const VkOffset3D *offset, const VkExtent3D *extent)
{
struct radv_device *device = cmd_buffer->device;
.pImageInfo = (VkDescriptorImageInfo[]){
{
.sampler = VK_NULL_HANDLE,
- .imageView = radv_image_view_to_handle(dest_iview),
+ .imageView = radv_image_view_to_handle(dst_iview),
.imageLayout = VK_IMAGE_LAYOUT_GENERAL,
},
}}});
default:
store_format = VK_FORMAT_R8G8B8A8_UNORM;
}
- struct radv_image_view dest_iview;
+ struct radv_image_view dst_iview;
radv_image_view_init(
- &dest_iview, cmd_buffer->device,
+ &dst_iview, cmd_buffer->device,
&(VkImageViewCreateInfo){
.sType = VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO,
.image = radv_image_to_handle(image),
},
0, NULL);
- decode_etc(cmd_buffer, &src_iview, &dest_iview, &(VkOffset3D){offset.x, offset.y, base_slice},
+ decode_etc(cmd_buffer, &src_iview, &dst_iview, &(VkOffset3D){offset.x, offset.y, base_slice},
&(VkExtent3D){extent.width, extent.height, slice_count});
radv_image_view_finish(&src_iview);
- radv_image_view_finish(&dest_iview);
+ radv_image_view_finish(&dst_iview);
radv_meta_restore(&saved_state, cmd_buffer);
}
static void
radv_pick_resolve_method_images(struct radv_device *device, struct radv_image *src_image,
- VkFormat src_format, struct radv_image *dest_image,
- unsigned dest_level, VkImageLayout dest_image_layout,
+ VkFormat src_format, struct radv_image *dst_image,
+ unsigned dst_level, VkImageLayout dst_image_layout,
struct radv_cmd_buffer *cmd_buffer,
enum radv_resolve_method *method)
{
- uint32_t queue_mask = radv_image_queue_family_mask(dest_image, cmd_buffer->qf,
+ uint32_t queue_mask = radv_image_queue_family_mask(dst_image, cmd_buffer->qf,
cmd_buffer->qf);
if (vk_format_is_color(src_format)) {
* re-initialize it after resolving using compute.
* TODO: Add support for layered and int to the fragment path.
*/
- if (radv_layout_dcc_compressed(device, dest_image, dest_level, dest_image_layout,
+ if (radv_layout_dcc_compressed(device, dst_image, dst_level, dst_image_layout,
queue_mask)) {
*method = RESOLVE_FRAGMENT;
- } else if (!image_hw_resolve_compat(device, src_image, dest_image)) {
+ } else if (!image_hw_resolve_compat(device, src_image, dst_image)) {
/* The micro tile mode only needs to match for the HW
* resolve path which is the default path for non-DCC
* resolves.
*method = RESOLVE_COMPUTE;
else if (vk_format_is_int(src_format))
*method = RESOLVE_COMPUTE;
- else if (src_image->info.array_size > 1 || dest_image->info.array_size > 1)
+ else if (src_image->info.array_size > 1 || dst_image->info.array_size > 1)
*method = RESOLVE_COMPUTE;
} else {
- if (src_image->info.array_size > 1 || dest_image->info.array_size > 1 ||
- (dest_image->planes[0].surface.flags & RADEON_SURF_NO_RENDER_TARGET))
+ if (src_image->info.array_size > 1 || dst_image->info.array_size > 1 ||
+ (dst_image->planes[0].surface.flags & RADEON_SURF_NO_RENDER_TARGET))
*method = RESOLVE_COMPUTE;
else
*method = RESOLVE_FRAGMENT;
static void
emit_resolve(struct radv_cmd_buffer *cmd_buffer, struct radv_image_view *src_iview,
- struct radv_image_view *dest_iview, const VkOffset2D *src_offset,
- const VkOffset2D *dest_offset, const VkExtent2D *resolve_extent)
+ struct radv_image_view *dst_iview, const VkOffset2D *src_offset,
+ const VkOffset2D *dst_offset, const VkExtent2D *resolve_extent)
{
struct radv_device *device = cmd_buffer->device;
VkPipeline *pipeline;
.pImageInfo = (VkDescriptorImageInfo[]){
{
.sampler = VK_NULL_HANDLE,
- .imageView = radv_image_view_to_handle(dest_iview),
+ .imageView = radv_image_view_to_handle(dst_iview),
.imageLayout = VK_IMAGE_LAYOUT_GENERAL,
},
}}});
unsigned push_constants[4] = {
src_offset->x,
src_offset->y,
- dest_offset->x,
- dest_offset->y,
+ dst_offset->x,
+ dst_offset->y,
};
radv_CmdPushConstants(radv_cmd_buffer_to_handle(cmd_buffer),
device->meta_state.resolve_compute.p_layout, VK_SHADER_STAGE_COMPUTE_BIT,
static void
emit_depth_stencil_resolve(struct radv_cmd_buffer *cmd_buffer, struct radv_image_view *src_iview,
- struct radv_image_view *dest_iview, const VkOffset2D *resolve_offset,
+ struct radv_image_view *dst_iview, const VkOffset2D *resolve_offset,
const VkExtent3D *resolve_extent, VkImageAspectFlags aspects,
VkResolveModeFlagBits resolve_mode)
{
.pImageInfo = (VkDescriptorImageInfo[]){
{
.sampler = VK_NULL_HANDLE,
- .imageView = radv_image_view_to_handle(dest_iview),
+ .imageView = radv_image_view_to_handle(dst_iview),
.imageLayout = VK_IMAGE_LAYOUT_GENERAL,
},
}}});
void
radv_meta_resolve_compute_image(struct radv_cmd_buffer *cmd_buffer, struct radv_image *src_image,
VkFormat src_format, VkImageLayout src_image_layout,
- struct radv_image *dest_image, VkFormat dest_format,
- VkImageLayout dest_image_layout, const VkImageResolve2 *region)
+ struct radv_image *dst_image, VkFormat dst_format,
+ VkImageLayout dst_image_layout, const VkImageResolve2 *region)
{
struct radv_meta_saved_state saved_state;
/* For partial resolves, DCC should be decompressed before resolving
* because the metadata is re-initialized to the uncompressed after.
*/
- uint32_t queue_mask = radv_image_queue_family_mask(dest_image, cmd_buffer->qf,
+ uint32_t queue_mask = radv_image_queue_family_mask(dst_image, cmd_buffer->qf,
cmd_buffer->qf);
- if (!radv_image_use_dcc_image_stores(cmd_buffer->device, dest_image) &&
- radv_layout_dcc_compressed(cmd_buffer->device, dest_image, region->dstSubresource.mipLevel,
- dest_image_layout, queue_mask) &&
+ if (!radv_image_use_dcc_image_stores(cmd_buffer->device, dst_image) &&
+ radv_layout_dcc_compressed(cmd_buffer->device, dst_image, region->dstSubresource.mipLevel,
+ dst_image_layout, queue_mask) &&
(region->dstOffset.x || region->dstOffset.y || region->dstOffset.z ||
- region->extent.width != dest_image->info.width ||
- region->extent.height != dest_image->info.height ||
- region->extent.depth != dest_image->info.depth)) {
- radv_decompress_dcc(cmd_buffer, dest_image,
+ region->extent.width != dst_image->info.width ||
+ region->extent.height != dst_image->info.height ||
+ region->extent.depth != dst_image->info.depth)) {
+ radv_decompress_dcc(cmd_buffer, dst_image,
&(VkImageSubresourceRange){
.aspectMask = region->dstSubresource.aspectMask,
.baseMipLevel = region->dstSubresource.mipLevel,
const uint32_t src_base_layer =
radv_meta_get_iview_layer(src_image, ®ion->srcSubresource, ®ion->srcOffset);
- const uint32_t dest_base_layer =
- radv_meta_get_iview_layer(dest_image, ®ion->dstSubresource, ®ion->dstOffset);
+ const uint32_t dst_base_layer =
+ radv_meta_get_iview_layer(dst_image, ®ion->dstSubresource, ®ion->dstOffset);
const struct VkExtent3D extent = vk_image_sanitize_extent(&src_image->vk, region->extent);
const struct VkOffset3D srcOffset = vk_image_sanitize_offset(&src_image->vk, region->srcOffset);
- const struct VkOffset3D dstOffset = vk_image_sanitize_offset(&dest_image->vk, region->dstOffset);
+ const struct VkOffset3D dstOffset = vk_image_sanitize_offset(&dst_image->vk, region->dstOffset);
for (uint32_t layer = 0; layer < region->srcSubresource.layerCount; ++layer) {
},
0, NULL);
- struct radv_image_view dest_iview;
- radv_image_view_init(&dest_iview, cmd_buffer->device,
+ struct radv_image_view dst_iview;
+ radv_image_view_init(&dst_iview, cmd_buffer->device,
&(VkImageViewCreateInfo){
.sType = VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO,
- .image = radv_image_to_handle(dest_image),
- .viewType = radv_meta_get_view_type(dest_image),
- .format = vk_to_non_srgb_format(dest_format),
+ .image = radv_image_to_handle(dst_image),
+ .viewType = radv_meta_get_view_type(dst_image),
+ .format = vk_to_non_srgb_format(dst_format),
.subresourceRange =
{
.aspectMask = VK_IMAGE_ASPECT_COLOR_BIT,
.baseMipLevel = region->dstSubresource.mipLevel,
.levelCount = 1,
- .baseArrayLayer = dest_base_layer + layer,
+ .baseArrayLayer = dst_base_layer + layer,
.layerCount = 1,
},
},
0, NULL);
- emit_resolve(cmd_buffer, &src_iview, &dest_iview, &(VkOffset2D){srcOffset.x, srcOffset.y},
+ emit_resolve(cmd_buffer, &src_iview, &dst_iview, &(VkOffset2D){srcOffset.x, srcOffset.y},
&(VkOffset2D){dstOffset.x, dstOffset.y},
&(VkExtent2D){extent.width, extent.height});
radv_image_view_finish(&src_iview);
- radv_image_view_finish(&dest_iview);
+ radv_image_view_finish(&dst_iview);
}
radv_meta_restore(&saved_state, cmd_buffer);
- if (!radv_image_use_dcc_image_stores(cmd_buffer->device, dest_image) &&
- radv_layout_dcc_compressed(cmd_buffer->device, dest_image, region->dstSubresource.mipLevel,
- dest_image_layout, queue_mask)) {
+ if (!radv_image_use_dcc_image_stores(cmd_buffer->device, dst_image) &&
+ radv_layout_dcc_compressed(cmd_buffer->device, dst_image, region->dstSubresource.mipLevel,
+ dst_image_layout, queue_mask)) {
cmd_buffer->state.flush_bits |= RADV_CMD_FLAG_CS_PARTIAL_FLUSH | RADV_CMD_FLAG_INV_VCACHE;
.aspectMask = VK_IMAGE_ASPECT_COLOR_BIT,
.baseMipLevel = region->dstSubresource.mipLevel,
.levelCount = 1,
- .baseArrayLayer = dest_base_layer,
+ .baseArrayLayer = dst_base_layer,
.layerCount = region->dstSubresource.layerCount,
};
- cmd_buffer->state.flush_bits |= radv_init_dcc(cmd_buffer, dest_image, &range, 0xffffffff);
+ cmd_buffer->state.flush_bits |= radv_init_dcc(cmd_buffer, dst_image, &range, 0xffffffff);
}
}
static void
emit_resolve(struct radv_cmd_buffer *cmd_buffer, struct radv_image_view *src_iview,
- struct radv_image_view *dest_iview, const VkOffset2D *src_offset,
- const VkOffset2D *dest_offset)
+ struct radv_image_view *dst_iview, const VkOffset2D *src_offset,
+ const VkOffset2D *dst_offset)
{
struct radv_device *device = cmd_buffer->device;
VkCommandBuffer cmd_buffer_h = radv_cmd_buffer_to_handle(cmd_buffer);
cmd_buffer->state.flush_bits |=
radv_dst_access_flush(cmd_buffer, VK_ACCESS_2_SHADER_READ_BIT, src_iview->image) |
- radv_dst_access_flush(cmd_buffer, VK_ACCESS_2_COLOR_ATTACHMENT_WRITE_BIT, dest_iview->image);
+ radv_dst_access_flush(cmd_buffer, VK_ACCESS_2_COLOR_ATTACHMENT_WRITE_BIT, dst_iview->image);
unsigned push_constants[2] = {
- src_offset->x - dest_offset->x,
- src_offset->y - dest_offset->y,
+ src_offset->x - dst_offset->x,
+ src_offset->y - dst_offset->y,
};
radv_CmdPushConstants(radv_cmd_buffer_to_handle(cmd_buffer),
device->meta_state.resolve_fragment.p_layout, VK_SHADER_STAGE_FRAGMENT_BIT,
0, 8, push_constants);
- pipeline = radv_get_resolve_pipeline(cmd_buffer, src_iview, dest_iview);
+ pipeline = radv_get_resolve_pipeline(cmd_buffer, src_iview, dst_iview);
radv_CmdBindPipeline(cmd_buffer_h, VK_PIPELINE_BIND_POINT_GRAPHICS, *pipeline);
radv_CmdDraw(cmd_buffer_h, 3, 1, 0, 0);
cmd_buffer->state.flush_bits |=
- radv_src_access_flush(cmd_buffer, VK_ACCESS_2_COLOR_ATTACHMENT_WRITE_BIT, dest_iview->image);
+ radv_src_access_flush(cmd_buffer, VK_ACCESS_2_COLOR_ATTACHMENT_WRITE_BIT, dst_iview->image);
}
static void
void
radv_meta_resolve_fragment_image(struct radv_cmd_buffer *cmd_buffer, struct radv_image *src_image,
- VkImageLayout src_image_layout, struct radv_image *dest_image,
- VkImageLayout dest_image_layout, const VkImageResolve2 *region)
+ VkImageLayout src_image_layout, struct radv_image *dst_image,
+ VkImageLayout dst_image_layout, const VkImageResolve2 *region)
{
struct radv_meta_saved_state saved_state;
- unsigned dst_layout = radv_meta_dst_layout_from_layout(dest_image_layout);
+ unsigned dst_layout = radv_meta_dst_layout_from_layout(dst_image_layout);
VkImageLayout layout = radv_meta_dst_layout_to_layout(dst_layout);
radv_meta_save(
const uint32_t src_base_layer =
radv_meta_get_iview_layer(src_image, ®ion->srcSubresource, ®ion->srcOffset);
- const uint32_t dest_base_layer =
- radv_meta_get_iview_layer(dest_image, ®ion->dstSubresource, ®ion->dstOffset);
+ const uint32_t dst_base_layer =
+ radv_meta_get_iview_layer(dst_image, ®ion->dstSubresource, ®ion->dstOffset);
const struct VkExtent3D extent = vk_image_sanitize_extent(&src_image->vk, region->extent);
const struct VkOffset3D srcOffset = vk_image_sanitize_offset(&src_image->vk, region->srcOffset);
- const struct VkOffset3D dstOffset = vk_image_sanitize_offset(&dest_image->vk, region->dstOffset);
+ const struct VkOffset3D dstOffset = vk_image_sanitize_offset(&dst_image->vk, region->dstOffset);
VkRect2D resolve_area = {
.offset = { dstOffset.x, dstOffset.y },
},
0, NULL);
- struct radv_image_view dest_iview;
- radv_image_view_init(&dest_iview, cmd_buffer->device,
+ struct radv_image_view dst_iview;
+ radv_image_view_init(&dst_iview, cmd_buffer->device,
&(VkImageViewCreateInfo){
.sType = VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO,
- .image = radv_image_to_handle(dest_image),
- .viewType = radv_meta_get_view_type(dest_image),
- .format = dest_image->vk.format,
+ .image = radv_image_to_handle(dst_image),
+ .viewType = radv_meta_get_view_type(dst_image),
+ .format = dst_image->vk.format,
.subresourceRange =
{
.aspectMask = VK_IMAGE_ASPECT_COLOR_BIT,
.baseMipLevel = region->dstSubresource.mipLevel,
.levelCount = 1,
- .baseArrayLayer = dest_base_layer + layer,
+ .baseArrayLayer = dst_base_layer + layer,
.layerCount = 1,
},
},
const VkRenderingAttachmentInfo color_att = {
.sType = VK_STRUCTURE_TYPE_RENDERING_ATTACHMENT_INFO,
- .imageView = radv_image_view_to_handle(&dest_iview),
+ .imageView = radv_image_view_to_handle(&dst_iview),
.imageLayout = layout,
.loadOp = VK_ATTACHMENT_LOAD_OP_LOAD,
.storeOp = VK_ATTACHMENT_STORE_OP_STORE,
radv_CmdBeginRendering(radv_cmd_buffer_to_handle(cmd_buffer), &rendering_info);
- emit_resolve(cmd_buffer, &src_iview, &dest_iview, &(VkOffset2D){srcOffset.x, srcOffset.y},
+ emit_resolve(cmd_buffer, &src_iview, &dst_iview, &(VkOffset2D){srcOffset.x, srcOffset.y},
&(VkOffset2D){dstOffset.x, dstOffset.y});
radv_CmdEndRendering(radv_cmd_buffer_to_handle(cmd_buffer));
radv_image_view_finish(&src_iview);
- radv_image_view_finish(&dest_iview);
+ radv_image_view_finish(&dst_iview);
}
radv_meta_restore(&saved_state, cmd_buffer);