On Thursday 09 August 2018, Andres Gomez wrote:
> Fredrik, which is the status of this series? Several patches got R-b
> but nothing has landed so far. Are you in need of more reviews for the
> rest of the patches in the series?

The master branch has diverged quite a bit as a result of the
VK_KHR_create_renderpass2 support, so most of the patches
need to be reworked (and re-tested).

I hope to get to that in the next couple of days.

> On Tue, 2018-06-26 at 23:49 +0200, Fredrik Höglund wrote:
> > The Vulkan specification says:
> > 
> >    "An execution dependency with only VK_PIPELINE_STAGE_BOTTOM_OF_-
> >     PIPE_BIT in the destination stage mask [...] does not delay
> >     processing of subsequent commands."
> > 
> > Cc: <[email protected]>
> > Signed-off-by: Fredrik Höglund <[email protected]>
> > ---
> >  src/amd/vulkan/radv_cmd_buffer.c | 3 ++-
> >  src/amd/vulkan/radv_pass.c       | 6 ++++--
> >  2 files changed, 6 insertions(+), 3 deletions(-)
> > 
> > diff --git a/src/amd/vulkan/radv_cmd_buffer.c 
> > b/src/amd/vulkan/radv_cmd_buffer.c
> > index 110a9a960a9..5bfcba28d83 100644
> > --- a/src/amd/vulkan/radv_cmd_buffer.c
> > +++ b/src/amd/vulkan/radv_cmd_buffer.c
> > @@ -4197,7 +4197,8 @@ void radv_CmdPipelineBarrier(
> >                                                     image);
> >     }
> >  
> > -   radv_stage_flush(cmd_buffer, srcStageMask);
> > +   if (destStageMask != VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT)
> > +           radv_stage_flush(cmd_buffer, srcStageMask);
> >     cmd_buffer->state.flush_bits |= src_flush_bits;
> >  
> >     for (uint32_t i = 0; i < imageMemoryBarrierCount; i++) {
> > diff --git a/src/amd/vulkan/radv_pass.c b/src/amd/vulkan/radv_pass.c
> > index 15fee444cdc..7a0dca09496 100644
> > --- a/src/amd/vulkan/radv_pass.c
> > +++ b/src/amd/vulkan/radv_pass.c
> > @@ -174,11 +174,13 @@ VkResult radv_CreateRenderPass(
> >     for (unsigned i = 0; i < pCreateInfo->dependencyCount; ++i) {
> >             uint32_t dst = pCreateInfo->pDependencies[i].dstSubpass;
> >             if (dst == VK_SUBPASS_EXTERNAL) {
> > -                   pass->end_barrier.src_stage_mask = 
> > pCreateInfo->pDependencies[i].srcStageMask;
> > +                   if (pCreateInfo->pDependencies[i].dstStageMask != 
> > VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT)
> > +                           pass->end_barrier.src_stage_mask = 
> > pCreateInfo->pDependencies[i].srcStageMask;
> >                     pass->end_barrier.src_access_mask = 
> > pCreateInfo->pDependencies[i].srcAccessMask;
> >                     pass->end_barrier.dst_access_mask = 
> > pCreateInfo->pDependencies[i].dstAccessMask;
> >             } else {
> > -                   pass->subpasses[dst].start_barrier.src_stage_mask = 
> > pCreateInfo->pDependencies[i].srcStageMask;
> > +                   if (pCreateInfo->pDependencies[i].dstStageMask != 
> > VK_PIPELINE_STAGE_BOTTOM_OF_PIPE_BIT)
> > +                           
> > pass->subpasses[dst].start_barrier.src_stage_mask = 
> > pCreateInfo->pDependencies[i].srcStageMask;
> >                     pass->subpasses[dst].start_barrier.src_access_mask = 
> > pCreateInfo->pDependencies[i].srcAccessMask;
> >                     pass->subpasses[dst].start_barrier.dst_access_mask = 
> > pCreateInfo->pDependencies[i].dstAccessMask;
> >             }
> 

_______________________________________________
mesa-dev mailing list
[email protected]
https://lists.freedesktop.org/mailman/listinfo/mesa-dev

Reply via email to