<div dir="ltr"><br><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Feb 15, 2018 at 5:44 PM, Anuj Phogat <span dir="ltr"><<a href="mailto:anuj.phogat@gmail.com" target="_blank">anuj.phogat@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">The PIPE_CONTROL command description says:<br>
<br>
"Whenever a Binding Table Index (BTI) used by a Render Taget Message<br>
points to a different RENDER_SURFACE_STATE, SW must issue a Render<br>
Target Cache Flush by enabling this bit. When render target flush<br>
is set due to new association of BTI, PS Scoreboard Stall bit must<br>
be set in this packet."<br>
<br>
Signed-off-by: Anuj Phogat <<a href="mailto:anuj.phogat@gmail.com">anuj.phogat@gmail.com</a>><br>
---<br>
 src/intel/vulkan/genX_cmd_<wbr>buffer.c | 21 +++++++++++++++++++++<br>
 1 file changed, 21 insertions(+)<br>
<br>
diff --git a/src/intel/vulkan/genX_cmd_<wbr>buffer.c b/src/intel/vulkan/genX_cmd_<wbr>buffer.c<br>
index ce47b8a1cc..e2b6c281e4 100644<br>
--- a/src/intel/vulkan/genX_cmd_<wbr>buffer.c<br>
+++ b/src/intel/vulkan/genX_cmd_<wbr>buffer.c<br>
@@ -2001,6 +2001,27 @@ emit_binding_table(struct anv_cmd_buffer *cmd_buffer,<br>
  out:<br>
    anv_state_flush(cmd_buffer-><wbr>device, *bt_state);<br>
<br>
+#if GEN_GEN >= 11<br>
+   /* The PIPE_CONTROL command description says:<br>
+    *<br>
+    * "Whenever a Binding Table Index (BTI) used by a Render Taget Message<br>
+    *  points to a different RENDER_SURFACE_STATE, SW must issue a Render<br>
+    *  Target Cache Flush by enabling this bit. When render target flush<br>
+    *  is set due to new association of BTI, PS Scoreboard Stall bit must<br>
+    *  be set in this packet."<br></blockquote><div><br></div><div>We usually indent block quotes like this.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
+    *<br>
+    *  FINISHME: Currently we shuffle around the surface states in the<br>
+    *  binding table based on if they are getting used or not. So, we've<br>
+    *  to do below pipe control flush for every binding table upload.<br>
+    *  Make changes so that we do it only when we modify render target<br>
+    *  surface states.<br>
+    */<br>
+   anv_batch_emit(&cmd_buffer-><wbr>batch, GENX(PIPE_CONTROL), pc) {<br>
+      pc.<wbr>RenderTargetCacheFlushEnable  = true;<br>
+      pc.StallAtPixelScoreboard        = true;<br>
+   }<br>
+#endif<br>
+<br>
    return VK_SUCCESS;<br>
 }<br>
<span class="HOEnZb"><font color="#888888"><br>
--<br>
2.13.6<br>
<br>
______________________________<wbr>_________________<br>
mesa-dev mailing list<br>
<a href="mailto:mesa-dev@lists.freedesktop.org">mesa-dev@lists.freedesktop.org</a><br>
<a href="https://lists.freedesktop.org/mailman/listinfo/mesa-dev" rel="noreferrer" target="_blank">https://lists.freedesktop.org/<wbr>mailman/listinfo/mesa-dev</a><br>
</font></span></blockquote></div><br></div></div>