On 11/09/2017 06:22 PM, Bas Nieuwenhuizen wrote:
Nack. We had that and Andres removed it due to high priority interactions.

Ah right, missed that.


On 9 Nov 2017 18:01, "Samuel Pitoiset" <[email protected] <mailto:[email protected]>> wrote:

    Copied from RadeonSI.

    Signed-off-by: Samuel Pitoiset <[email protected]
    <mailto:[email protected]>>
    ---
      src/amd/vulkan/si_cmd_buffer.c | 18 ++++++++++++------
      1 file changed, 12 insertions(+), 6 deletions(-)

    diff --git a/src/amd/vulkan/si_cmd_buffer.c
    b/src/amd/vulkan/si_cmd_buffer.c
    index 89ee399817..f5c04c07a8 100644
    --- a/src/amd/vulkan/si_cmd_buffer.c
    +++ b/src/amd/vulkan/si_cmd_buffer.c
    @@ -973,12 +973,18 @@ si_cs_emit_cache_flush(struct radeon_winsys_cs
    *cs,
                     radeon_emit(cs,
    EVENT_TYPE(V_028A90_FLUSH_AND_INV_DB_META) | EVENT_INDEX(0));
             }

    -       if (flush_bits & RADV_CMD_FLAG_PS_PARTIAL_FLUSH) {
    -               radeon_emit(cs, PKT3(PKT3_EVENT_WRITE, 0, 0));
    -               radeon_emit(cs,
    EVENT_TYPE(V_028A90_PS_PARTIAL_FLUSH) | EVENT_INDEX(4));
    -       } else if (flush_bits & RADV_CMD_FLAG_VS_PARTIAL_FLUSH) {
    -               radeon_emit(cs, PKT3(PKT3_EVENT_WRITE, 0, 0));
    -               radeon_emit(cs,
    EVENT_TYPE(V_028A90_VS_PARTIAL_FLUSH) | EVENT_INDEX(4));
    +       /* Wait for shader engines to go idle.
    +        * VS and PS waits are unnecessary if SURFACE_SYNC is going
    to wait
    +        * for everything including CB/DB cache flushes.
    +        */
    +       if (!flush_cb_db) {
    +               if (flush_bits & RADV_CMD_FLAG_PS_PARTIAL_FLUSH) {
    +                       radeon_emit(cs, PKT3(PKT3_EVENT_WRITE, 0, 0));
    +                       radeon_emit(cs,
    EVENT_TYPE(V_028A90_PS_PARTIAL_FLUSH) | EVENT_INDEX(4));
    +               } else if (flush_bits &
    RADV_CMD_FLAG_VS_PARTIAL_FLUSH) {
    +                       radeon_emit(cs, PKT3(PKT3_EVENT_WRITE, 0, 0));
    +                       radeon_emit(cs,
    EVENT_TYPE(V_028A90_VS_PARTIAL_FLUSH) | EVENT_INDEX(4));
    +               }
             }

             if (flush_bits & RADV_CMD_FLAG_CS_PARTIAL_FLUSH) {
    --
    2.15.0

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


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

Reply via email to