hot-fix: missing fce barrier

This commit is contained in:
psucien 2024-12-23 18:20:37 +01:00
parent 65d1d77dfc
commit 673145d7a4

View file

@ -216,7 +216,7 @@ void Rasterizer::EliminateFastClear() {
const auto& hint = liverpool->last_cb_extent[0]; const auto& hint = liverpool->last_cb_extent[0];
VideoCore::TextureCache::RenderTargetDesc desc(col_buf, hint); VideoCore::TextureCache::RenderTargetDesc desc(col_buf, hint);
const auto& image_view = texture_cache.FindRenderTarget(desc); const auto& image_view = texture_cache.FindRenderTarget(desc);
const auto& image = texture_cache.GetImage(image_view.image_id); auto& image = texture_cache.GetImage(image_view.image_id);
const vk::ImageSubresourceRange range = { const vk::ImageSubresourceRange range = {
.aspectMask = vk::ImageAspectFlagBits::eColor, .aspectMask = vk::ImageAspectFlagBits::eColor,
.baseMipLevel = 0, .baseMipLevel = 0,
@ -225,7 +225,8 @@ void Rasterizer::EliminateFastClear() {
.layerCount = col_buf.view.slice_max - col_buf.view.slice_start + 1, .layerCount = col_buf.view.slice_max - col_buf.view.slice_start + 1,
}; };
scheduler.EndRendering(); scheduler.EndRendering();
scheduler.CommandBuffer().clearColorImage(image.image, vk::ImageLayout::eColorAttachmentOptimal, image.Transit(vk::ImageLayout::eTransferDstOptimal, vk::AccessFlagBits2::eTransferWrite, {});
scheduler.CommandBuffer().clearColorImage(image.image, image.last_state.layout,
LiverpoolToVK::ColorBufferClearValue(col_buf).color, LiverpoolToVK::ColorBufferClearValue(col_buf).color,
range); range);
} }