[Vulkan] Correct a bunch of incorrect pipeline barrier stages
This commit is contained in:
parent
ad118fa842
commit
cbfaffd9f3
|
@ -372,7 +372,7 @@ std::pair<VkBuffer, VkDeviceSize> BufferCache::UploadVertexBuffer(
|
||||||
source_length,
|
source_length,
|
||||||
};
|
};
|
||||||
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_HOST_BIT,
|
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_HOST_BIT,
|
||||||
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, 0, 0, nullptr, 1,
|
VK_PIPELINE_STAGE_VERTEX_INPUT_BIT, 0, 0, nullptr, 1,
|
||||||
&barrier, 0, nullptr);
|
&barrier, 0, nullptr);
|
||||||
|
|
||||||
CacheTransientData(source_addr, source_length, offset);
|
CacheTransientData(source_addr, source_length, offset);
|
||||||
|
|
|
@ -273,8 +273,10 @@ CachedTileView::CachedTileView(ui::vulkan::VulkanDevice* device,
|
||||||
image_barrier.subresourceRange.baseArrayLayer = 0;
|
image_barrier.subresourceRange.baseArrayLayer = 0;
|
||||||
image_barrier.subresourceRange.layerCount = 1;
|
image_barrier.subresourceRange.layerCount = 1;
|
||||||
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,
|
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,
|
||||||
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, 0, 0, nullptr, 0,
|
key.color_or_depth
|
||||||
nullptr, 1, &image_barrier);
|
? VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT
|
||||||
|
: VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT,
|
||||||
|
0, 0, nullptr, 0, nullptr, 1, &image_barrier);
|
||||||
|
|
||||||
image_layout = image_barrier.newLayout;
|
image_layout = image_barrier.newLayout;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1269,7 +1269,7 @@ bool TextureCache::UploadTexture(VkCommandBuffer command_buffer,
|
||||||
}
|
}
|
||||||
|
|
||||||
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,
|
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,
|
||||||
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, 0, 0, nullptr, 0,
|
VK_PIPELINE_STAGE_TRANSFER_BIT, 0, 0, nullptr, 0,
|
||||||
nullptr, 1, &barrier);
|
nullptr, 1, &barrier);
|
||||||
|
|
||||||
// Now move the converted texture into the destination.
|
// Now move the converted texture into the destination.
|
||||||
|
@ -1285,9 +1285,10 @@ bool TextureCache::UploadTexture(VkCommandBuffer command_buffer,
|
||||||
barrier.dstAccessMask = VK_ACCESS_SHADER_READ_BIT;
|
barrier.dstAccessMask = VK_ACCESS_SHADER_READ_BIT;
|
||||||
barrier.oldLayout = barrier.newLayout;
|
barrier.oldLayout = barrier.newLayout;
|
||||||
barrier.newLayout = VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL;
|
barrier.newLayout = VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL;
|
||||||
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,
|
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_TRANSFER_BIT,
|
||||||
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, 0, 0, nullptr, 0,
|
VK_PIPELINE_STAGE_VERTEX_SHADER_BIT |
|
||||||
nullptr, 1, &barrier);
|
VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT,
|
||||||
|
0, 0, nullptr, 0, nullptr, 1, &barrier);
|
||||||
|
|
||||||
dest->image_layout = barrier.newLayout;
|
dest->image_layout = barrier.newLayout;
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -308,8 +308,8 @@ void VulkanCommandProcessor::CreateSwapImage(VkCommandBuffer setup_buffer,
|
||||||
barrier.subresourceRange = {VK_IMAGE_ASPECT_COLOR_BIT, 0, 1, 0, 1};
|
barrier.subresourceRange = {VK_IMAGE_ASPECT_COLOR_BIT, 0, 1, 0, 1};
|
||||||
|
|
||||||
vkCmdPipelineBarrier(setup_buffer, VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,
|
vkCmdPipelineBarrier(setup_buffer, VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,
|
||||||
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, 0, 0, nullptr, 0,
|
VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT, 0, 0,
|
||||||
nullptr, 1, &barrier);
|
nullptr, 0, nullptr, 1, &barrier);
|
||||||
}
|
}
|
||||||
|
|
||||||
void VulkanCommandProcessor::DestroySwapImage() {
|
void VulkanCommandProcessor::DestroySwapImage() {
|
||||||
|
@ -457,9 +457,11 @@ void VulkanCommandProcessor::PerformSwap(uint32_t frontbuffer_ptr,
|
||||||
barrier.image = texture->image;
|
barrier.image = texture->image;
|
||||||
barrier.subresourceRange = {VK_IMAGE_ASPECT_COLOR_BIT, 0, 1, 0, 1};
|
barrier.subresourceRange = {VK_IMAGE_ASPECT_COLOR_BIT, 0, 1, 0, 1};
|
||||||
|
|
||||||
vkCmdPipelineBarrier(copy_commands, VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT,
|
vkCmdPipelineBarrier(copy_commands,
|
||||||
VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT, 0, 0, nullptr, 0,
|
VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT |
|
||||||
nullptr, 1, &barrier);
|
VK_PIPELINE_STAGE_TRANSFER_BIT,
|
||||||
|
VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT, 0, 0, nullptr,
|
||||||
|
0, nullptr, 1, &barrier);
|
||||||
|
|
||||||
barrier.oldLayout = VK_IMAGE_LAYOUT_GENERAL;
|
barrier.oldLayout = VK_IMAGE_LAYOUT_GENERAL;
|
||||||
barrier.newLayout = VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL;
|
barrier.newLayout = VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL;
|
||||||
|
@ -467,8 +469,8 @@ void VulkanCommandProcessor::PerformSwap(uint32_t frontbuffer_ptr,
|
||||||
barrier.dstAccessMask = VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT;
|
barrier.dstAccessMask = VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT;
|
||||||
barrier.image = swap_fb;
|
barrier.image = swap_fb;
|
||||||
vkCmdPipelineBarrier(copy_commands, VK_PIPELINE_STAGE_TRANSFER_BIT,
|
vkCmdPipelineBarrier(copy_commands, VK_PIPELINE_STAGE_TRANSFER_BIT,
|
||||||
VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT, 0, 0, nullptr, 0,
|
VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT, 0, 0,
|
||||||
nullptr, 1, &barrier);
|
nullptr, 0, nullptr, 1, &barrier);
|
||||||
|
|
||||||
VkRect2D src_rect = {
|
VkRect2D src_rect = {
|
||||||
{0, 0},
|
{0, 0},
|
||||||
|
@ -485,9 +487,9 @@ void VulkanCommandProcessor::PerformSwap(uint32_t frontbuffer_ptr,
|
||||||
std::swap(barrier.oldLayout, barrier.newLayout);
|
std::swap(barrier.oldLayout, barrier.newLayout);
|
||||||
barrier.srcAccessMask = VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT;
|
barrier.srcAccessMask = VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT;
|
||||||
barrier.dstAccessMask = VK_ACCESS_TRANSFER_READ_BIT;
|
barrier.dstAccessMask = VK_ACCESS_TRANSFER_READ_BIT;
|
||||||
vkCmdPipelineBarrier(copy_commands, VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT,
|
vkCmdPipelineBarrier(
|
||||||
VK_PIPELINE_STAGE_TRANSFER_BIT, 0, 0, nullptr, 0,
|
copy_commands, VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT,
|
||||||
nullptr, 1, &barrier);
|
VK_PIPELINE_STAGE_TRANSFER_BIT, 0, 0, nullptr, 0, nullptr, 1, &barrier);
|
||||||
|
|
||||||
std::lock_guard<std::mutex> lock(swap_state_.mutex);
|
std::lock_guard<std::mutex> lock(swap_state_.mutex);
|
||||||
swap_state_.width = frontbuffer_width;
|
swap_state_.width = frontbuffer_width;
|
||||||
|
@ -923,6 +925,7 @@ bool VulkanCommandProcessor::IssueCopy() {
|
||||||
uint32_t copy_surface_slice;
|
uint32_t copy_surface_slice;
|
||||||
}* copy_regs = (decltype(copy_regs)) & regs[XE_GPU_REG_RB_COPY_CONTROL].u32;
|
}* copy_regs = (decltype(copy_regs)) & regs[XE_GPU_REG_RB_COPY_CONTROL].u32;
|
||||||
|
|
||||||
|
// True if the source tile is a color target
|
||||||
bool is_color_source = copy_regs->copy_control.copy_src_select <= 3;
|
bool is_color_source = copy_regs->copy_control.copy_src_select <= 3;
|
||||||
|
|
||||||
// Render targets 0-3, 4 = depth
|
// Render targets 0-3, 4 = depth
|
||||||
|
@ -1092,7 +1095,7 @@ bool VulkanCommandProcessor::IssueCopy() {
|
||||||
image_barrier.srcQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
|
image_barrier.srcQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
|
||||||
image_barrier.dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
|
image_barrier.dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
|
||||||
image_barrier.srcAccessMask = 0;
|
image_barrier.srcAccessMask = 0;
|
||||||
image_barrier.dstAccessMask = VK_ACCESS_TRANSFER_WRITE_BIT;
|
image_barrier.dstAccessMask = 0;
|
||||||
image_barrier.oldLayout = VK_IMAGE_LAYOUT_UNDEFINED;
|
image_barrier.oldLayout = VK_IMAGE_LAYOUT_UNDEFINED;
|
||||||
image_barrier.newLayout = VK_IMAGE_LAYOUT_GENERAL;
|
image_barrier.newLayout = VK_IMAGE_LAYOUT_GENERAL;
|
||||||
image_barrier.image = texture->image;
|
image_barrier.image = texture->image;
|
||||||
|
@ -1103,8 +1106,8 @@ bool VulkanCommandProcessor::IssueCopy() {
|
||||||
: VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT;
|
: VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT;
|
||||||
texture->image_layout = VK_IMAGE_LAYOUT_GENERAL;
|
texture->image_layout = VK_IMAGE_LAYOUT_GENERAL;
|
||||||
|
|
||||||
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT,
|
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,
|
||||||
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, 0, 0, nullptr, 0,
|
VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT, 0, 0, nullptr, 0,
|
||||||
nullptr, 1, &image_barrier);
|
nullptr, 1, &image_barrier);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1129,8 +1132,8 @@ bool VulkanCommandProcessor::IssueCopy() {
|
||||||
is_color_source ? VK_IMAGE_ASPECT_COLOR_BIT
|
is_color_source ? VK_IMAGE_ASPECT_COLOR_BIT
|
||||||
: VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT;
|
: VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT;
|
||||||
|
|
||||||
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT,
|
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_ALL_COMMANDS_BIT,
|
||||||
VK_PIPELINE_STAGE_TRANSFER_BIT, 0, 0, nullptr, 0,
|
VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT, 0, 0, nullptr, 0,
|
||||||
nullptr, 1, &image_barrier);
|
nullptr, 1, &image_barrier);
|
||||||
|
|
||||||
VkOffset2D resolve_offset = {dest_min_x, dest_min_y};
|
VkOffset2D resolve_offset = {dest_min_x, dest_min_y};
|
||||||
|
@ -1173,28 +1176,32 @@ bool VulkanCommandProcessor::IssueCopy() {
|
||||||
|
|
||||||
// Convert the tile view to a sampled image.
|
// Convert the tile view to a sampled image.
|
||||||
// Put a barrier on the tile view.
|
// Put a barrier on the tile view.
|
||||||
VkImageMemoryBarrier image_barrier;
|
VkImageMemoryBarrier tile_image_barrier;
|
||||||
image_barrier.sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER;
|
tile_image_barrier.sType = VK_STRUCTURE_TYPE_IMAGE_MEMORY_BARRIER;
|
||||||
image_barrier.pNext = nullptr;
|
tile_image_barrier.pNext = nullptr;
|
||||||
image_barrier.srcQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
|
tile_image_barrier.srcQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
|
||||||
image_barrier.dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
|
tile_image_barrier.dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
|
||||||
image_barrier.srcAccessMask =
|
tile_image_barrier.srcAccessMask =
|
||||||
is_color_source ? VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT
|
is_color_source ? VK_ACCESS_COLOR_ATTACHMENT_WRITE_BIT
|
||||||
: VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT;
|
: VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_WRITE_BIT;
|
||||||
image_barrier.dstAccessMask = VK_ACCESS_TRANSFER_READ_BIT |
|
tile_image_barrier.dstAccessMask =
|
||||||
VK_ACCESS_COLOR_ATTACHMENT_READ_BIT |
|
VK_ACCESS_TRANSFER_READ_BIT |
|
||||||
VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT;
|
(is_color_source ? VK_ACCESS_COLOR_ATTACHMENT_READ_BIT
|
||||||
image_barrier.oldLayout = view->image_layout;
|
: VK_ACCESS_DEPTH_STENCIL_ATTACHMENT_READ_BIT);
|
||||||
image_barrier.newLayout = view->image_layout;
|
tile_image_barrier.oldLayout = view->image_layout;
|
||||||
image_barrier.image = view->image;
|
tile_image_barrier.newLayout = view->image_layout;
|
||||||
image_barrier.subresourceRange = {0, 0, 1, 0, 1};
|
tile_image_barrier.image = view->image;
|
||||||
image_barrier.subresourceRange.aspectMask =
|
tile_image_barrier.subresourceRange = {0, 0, 1, 0, 1};
|
||||||
|
tile_image_barrier.subresourceRange.aspectMask =
|
||||||
is_color_source
|
is_color_source
|
||||||
? VK_IMAGE_ASPECT_COLOR_BIT
|
? VK_IMAGE_ASPECT_COLOR_BIT
|
||||||
: VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT;
|
: VK_IMAGE_ASPECT_DEPTH_BIT | VK_IMAGE_ASPECT_STENCIL_BIT;
|
||||||
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT,
|
vkCmdPipelineBarrier(
|
||||||
VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT, 0, 0, nullptr,
|
command_buffer, VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT,
|
||||||
0, nullptr, 1, &image_barrier);
|
VK_PIPELINE_STAGE_TRANSFER_BIT |
|
||||||
|
(is_color_source ? VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT
|
||||||
|
: VK_PIPELINE_STAGE_EARLY_FRAGMENT_TESTS_BIT),
|
||||||
|
0, 0, nullptr, 0, nullptr, 1, &tile_image_barrier);
|
||||||
|
|
||||||
auto render_pass =
|
auto render_pass =
|
||||||
blitter_->GetRenderPass(texture->format, is_color_source);
|
blitter_->GetRenderPass(texture->format, is_color_source);
|
||||||
|
@ -1229,12 +1236,16 @@ bool VulkanCommandProcessor::IssueCopy() {
|
||||||
copy_regs->copy_dest_info.copy_dest_swap != 0);
|
copy_regs->copy_dest_info.copy_dest_swap != 0);
|
||||||
|
|
||||||
// Pull the tile view back to a color attachment.
|
// Pull the tile view back to a color attachment.
|
||||||
std::swap(image_barrier.srcAccessMask, image_barrier.dstAccessMask);
|
std::swap(tile_image_barrier.srcAccessMask,
|
||||||
std::swap(image_barrier.oldLayout, image_barrier.newLayout);
|
tile_image_barrier.dstAccessMask);
|
||||||
vkCmdPipelineBarrier(command_buffer,
|
std::swap(tile_image_barrier.oldLayout, tile_image_barrier.newLayout);
|
||||||
VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT,
|
vkCmdPipelineBarrier(
|
||||||
VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT, 0, 0, nullptr, 0,
|
command_buffer,
|
||||||
nullptr, 1, &image_barrier);
|
VK_PIPELINE_STAGE_TRANSFER_BIT |
|
||||||
|
(is_color_source ? VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT
|
||||||
|
: VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT),
|
||||||
|
VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT, 0, 0, nullptr, 0, nullptr, 1,
|
||||||
|
&tile_image_barrier);
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
case CopyCommand::kConstantOne:
|
case CopyCommand::kConstantOne:
|
||||||
|
@ -1248,9 +1259,14 @@ bool VulkanCommandProcessor::IssueCopy() {
|
||||||
image_barrier.dstAccessMask =
|
image_barrier.dstAccessMask =
|
||||||
VK_ACCESS_SHADER_READ_BIT | VK_ACCESS_TRANSFER_READ_BIT;
|
VK_ACCESS_SHADER_READ_BIT | VK_ACCESS_TRANSFER_READ_BIT;
|
||||||
std::swap(image_barrier.newLayout, image_barrier.oldLayout);
|
std::swap(image_barrier.newLayout, image_barrier.oldLayout);
|
||||||
vkCmdPipelineBarrier(command_buffer, VK_PIPELINE_STAGE_TRANSFER_BIT,
|
vkCmdPipelineBarrier(command_buffer,
|
||||||
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, 0, 0, nullptr, 0,
|
is_color_source
|
||||||
nullptr, 1, &image_barrier);
|
? VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT
|
||||||
|
: VK_PIPELINE_STAGE_LATE_FRAGMENT_TESTS_BIT,
|
||||||
|
VK_PIPELINE_STAGE_VERTEX_SHADER_BIT |
|
||||||
|
VK_PIPELINE_STAGE_FRAGMENT_SHADER_BIT |
|
||||||
|
VK_PIPELINE_STAGE_TRANSFER_BIT,
|
||||||
|
0, 0, nullptr, 0, nullptr, 1, &image_barrier);
|
||||||
|
|
||||||
// Perform any requested clears.
|
// Perform any requested clears.
|
||||||
uint32_t copy_depth_clear = regs[XE_GPU_REG_RB_DEPTH_CLEAR].u32;
|
uint32_t copy_depth_clear = regs[XE_GPU_REG_RB_DEPTH_CLEAR].u32;
|
||||||
|
|
|
@ -320,8 +320,8 @@ void VulkanGraphicsSystem::Swap(xe::ui::UIEvent* e) {
|
||||||
barrier.dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
|
barrier.dstQueueFamilyIndex = VK_QUEUE_FAMILY_IGNORED;
|
||||||
barrier.image = front_buffer;
|
barrier.image = front_buffer;
|
||||||
barrier.subresourceRange = {VK_IMAGE_ASPECT_COLOR_BIT, 0, 1, 0, 1};
|
barrier.subresourceRange = {VK_IMAGE_ASPECT_COLOR_BIT, 0, 1, 0, 1};
|
||||||
vkCmdPipelineBarrier(copy_cmd_buffer, VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT,
|
vkCmdPipelineBarrier(copy_cmd_buffer, VK_PIPELINE_STAGE_TRANSFER_BIT,
|
||||||
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, 0, 0, nullptr, 0,
|
VK_PIPELINE_STAGE_TRANSFER_BIT, 0, 0, nullptr, 0,
|
||||||
nullptr, 1, &barrier);
|
nullptr, 1, &barrier);
|
||||||
|
|
||||||
VkImageBlit region;
|
VkImageBlit region;
|
||||||
|
|
|
@ -628,7 +628,7 @@ VkResult VulkanSwapChain::End() {
|
||||||
pre_image_copy_barrier.subresourceRange = {VK_IMAGE_ASPECT_COLOR_BIT, 0, 1, 0,
|
pre_image_copy_barrier.subresourceRange = {VK_IMAGE_ASPECT_COLOR_BIT, 0, 1, 0,
|
||||||
1};
|
1};
|
||||||
vkCmdPipelineBarrier(cmd_buffer_, VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT,
|
vkCmdPipelineBarrier(cmd_buffer_, VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT,
|
||||||
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, 0, 0, nullptr, 0,
|
VK_PIPELINE_STAGE_TRANSFER_BIT, 0, 0, nullptr, 0,
|
||||||
nullptr, 1, &pre_image_copy_barrier);
|
nullptr, 1, &pre_image_copy_barrier);
|
||||||
|
|
||||||
current_buffer.image_layout = VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL;
|
current_buffer.image_layout = VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL;
|
||||||
|
@ -655,8 +655,8 @@ VkResult VulkanSwapChain::End() {
|
||||||
pre_image_memory_barrier.oldLayout = current_buffer.image_layout;
|
pre_image_memory_barrier.oldLayout = current_buffer.image_layout;
|
||||||
pre_image_memory_barrier.newLayout = VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL;
|
pre_image_memory_barrier.newLayout = VK_IMAGE_LAYOUT_COLOR_ATTACHMENT_OPTIMAL;
|
||||||
vkCmdPipelineBarrier(cmd_buffer_, VK_PIPELINE_STAGE_TRANSFER_BIT,
|
vkCmdPipelineBarrier(cmd_buffer_, VK_PIPELINE_STAGE_TRANSFER_BIT,
|
||||||
VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT, 0, 0, nullptr, 0,
|
VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT, 0, 0,
|
||||||
nullptr, 1, &pre_image_memory_barrier);
|
nullptr, 0, nullptr, 1, &pre_image_memory_barrier);
|
||||||
|
|
||||||
current_buffer.image_layout = pre_image_memory_barrier.newLayout;
|
current_buffer.image_layout = pre_image_memory_barrier.newLayout;
|
||||||
|
|
||||||
|
@ -700,7 +700,8 @@ VkResult VulkanSwapChain::End() {
|
||||||
post_image_memory_barrier.subresourceRange.levelCount = 1;
|
post_image_memory_barrier.subresourceRange.levelCount = 1;
|
||||||
post_image_memory_barrier.subresourceRange.baseArrayLayer = 0;
|
post_image_memory_barrier.subresourceRange.baseArrayLayer = 0;
|
||||||
post_image_memory_barrier.subresourceRange.layerCount = 1;
|
post_image_memory_barrier.subresourceRange.layerCount = 1;
|
||||||
vkCmdPipelineBarrier(cmd_buffer_, VK_PIPELINE_STAGE_ALL_GRAPHICS_BIT,
|
vkCmdPipelineBarrier(cmd_buffer_,
|
||||||
|
VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT,
|
||||||
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, 0, 0, nullptr, 0,
|
VK_PIPELINE_STAGE_TOP_OF_PIPE_BIT, 0, 0, nullptr, 0,
|
||||||
nullptr, 1, &post_image_memory_barrier);
|
nullptr, 1, &post_image_memory_barrier);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue