mirror of
https://github.com/skyline-emu/skyline.git
synced 2025-01-28 02:17:54 +03:00
Loosen some texture WaR sync when possible
By keeping track of the stages reading the image we can do more fine-grained WaR prevention, as opposed to waiting for all commands to complete.
This commit is contained in:
parent
6ee8a919e5
commit
d45f9e4d26
@ -151,7 +151,7 @@ namespace skyline::gpu::interconnect {
|
|||||||
std::array<TextureView *, 1> sampledImages{srcTextureView.get()};
|
std::array<TextureView *, 1> sampledImages{srcTextureView.get()};
|
||||||
executor.AddSubpass(std::move(executionCallback), {{static_cast<i32>(dstRectX), static_cast<i32>(dstRectY)}, {dstRectWidth, dstRectHeight} },
|
executor.AddSubpass(std::move(executionCallback), {{static_cast<i32>(dstRectX), static_cast<i32>(dstRectY)}, {dstRectWidth, dstRectHeight} },
|
||||||
sampledImages, {}, {dst}, {}, false,
|
sampledImages, {}, {dst}, {}, false,
|
||||||
vk::PipelineStageFlagBits::eAllCommands, vk::PipelineStageFlagBits::eAllCommands);
|
vk::PipelineStageFlagBits::eAllGraphics, vk::PipelineStageFlagBits::eAllGraphics);
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
@ -1007,22 +1007,31 @@ namespace skyline::gpu {
|
|||||||
lastRenderPassUsage = renderPassUsage;
|
lastRenderPassUsage = renderPassUsage;
|
||||||
lastRenderPassIndex = renderPassIndex;
|
lastRenderPassIndex = renderPassIndex;
|
||||||
|
|
||||||
if (renderPassUsage == texture::RenderPassUsage::RenderTarget)
|
if (renderPassUsage == texture::RenderPassUsage::RenderTarget) {
|
||||||
pendingStageMask = vk::PipelineStageFlagBits::eVertexShader |
|
pendingStageMask = vk::PipelineStageFlagBits::eVertexShader |
|
||||||
vk::PipelineStageFlagBits::eTessellationControlShader |
|
vk::PipelineStageFlagBits::eTessellationControlShader |
|
||||||
vk::PipelineStageFlagBits::eTessellationEvaluationShader |
|
vk::PipelineStageFlagBits::eTessellationEvaluationShader |
|
||||||
vk::PipelineStageFlagBits::eGeometryShader |
|
vk::PipelineStageFlagBits::eGeometryShader |
|
||||||
vk::PipelineStageFlagBits::eFragmentShader |
|
vk::PipelineStageFlagBits::eFragmentShader |
|
||||||
vk::PipelineStageFlagBits::eComputeShader;
|
vk::PipelineStageFlagBits::eComputeShader;
|
||||||
else if (renderPassUsage == texture::RenderPassUsage::None)
|
readStageMask = {};
|
||||||
|
} else if (renderPassUsage == texture::RenderPassUsage::None) {
|
||||||
pendingStageMask = {};
|
pendingStageMask = {};
|
||||||
|
readStageMask = {};
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
texture::RenderPassUsage Texture::GetLastRenderPassUsage() {
|
texture::RenderPassUsage Texture::GetLastRenderPassUsage() {
|
||||||
return lastRenderPassUsage;
|
return lastRenderPassUsage;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
vk::PipelineStageFlags Texture::GetReadStageMask() {
|
||||||
|
return readStageMask;
|
||||||
|
}
|
||||||
|
|
||||||
void Texture::PopulateReadBarrier(vk::PipelineStageFlagBits dstStage, vk::PipelineStageFlags &srcStageMask, vk::PipelineStageFlags &dstStageMask) {
|
void Texture::PopulateReadBarrier(vk::PipelineStageFlagBits dstStage, vk::PipelineStageFlags &srcStageMask, vk::PipelineStageFlags &dstStageMask) {
|
||||||
|
readStageMask |= dstStage;
|
||||||
|
|
||||||
if (!(pendingStageMask & dstStage))
|
if (!(pendingStageMask & dstStage))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -411,6 +411,7 @@ namespace skyline::gpu {
|
|||||||
u32 lastRenderPassIndex{}; //!< The index of the last render pass that used this texture
|
u32 lastRenderPassIndex{}; //!< The index of the last render pass that used this texture
|
||||||
texture::RenderPassUsage lastRenderPassUsage{texture::RenderPassUsage::None}; //!< The type of usage in the last render pass
|
texture::RenderPassUsage lastRenderPassUsage{texture::RenderPassUsage::None}; //!< The type of usage in the last render pass
|
||||||
vk::PipelineStageFlags pendingStageMask{}; //!< List of pipeline stages that are yet to be flushed for reads since the last time this texture was used an an RT
|
vk::PipelineStageFlags pendingStageMask{}; //!< List of pipeline stages that are yet to be flushed for reads since the last time this texture was used an an RT
|
||||||
|
vk::PipelineStageFlags readStageMask{}; //!< Set of pipeline stages that this texture has been read in since it was last used as an RT
|
||||||
|
|
||||||
friend TextureManager;
|
friend TextureManager;
|
||||||
friend TextureView;
|
friend TextureView;
|
||||||
@ -613,6 +614,11 @@ namespace skyline::gpu {
|
|||||||
*/
|
*/
|
||||||
texture::RenderPassUsage GetLastRenderPassUsage();
|
texture::RenderPassUsage GetLastRenderPassUsage();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return The set of stages this texture has been read in since it was last used as an RT
|
||||||
|
*/
|
||||||
|
vk::PipelineStageFlags GetReadStageMask();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Populates the input src and dst stage masks with appropriate read barrier parameters for the current texture state
|
* @brief Populates the input src and dst stage masks with appropriate read barrier parameters for the current texture state
|
||||||
*/
|
*/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user