diff options
author | David Airlie <[email protected]> | 2017-08-15 14:02:43 +1000 |
---|---|---|
committer | Bas Nieuwenhuizen <[email protected]> | 2017-09-24 05:50:02 +0200 |
commit | 3e544932658d87beb661a3e762621264733171df (patch) | |
tree | 009acc628e687975b593d8927b7fc2be4bedb6f6 /src | |
parent | 52ed3bca91ff13217378196d6800ca7113641a63 (diff) |
radv: add gfx9 scissor workaround
Reviewed-by: Bas Nieuwenhuizen <[email protected]>
Cc: 17.2 <[email protected]>
Diffstat (limited to 'src')
-rw-r--r-- | src/amd/vulkan/radv_cmd_buffer.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/src/amd/vulkan/radv_cmd_buffer.c b/src/amd/vulkan/radv_cmd_buffer.c index fbbb1b1c68e..1e0e3668209 100644 --- a/src/amd/vulkan/radv_cmd_buffer.c +++ b/src/amd/vulkan/radv_cmd_buffer.c @@ -1010,6 +1010,11 @@ static void radv_emit_scissor(struct radv_cmd_buffer *cmd_buffer) { uint32_t count = cmd_buffer->state.dynamic.scissor.count; + + if (cmd_buffer->device->physical_device->rad_info.chip_class >= GFX9) { + cmd_buffer->state.flush_bits |= RADV_CMD_FLAG_PS_PARTIAL_FLUSH; + si_emit_cache_flush(cmd_buffer); + } si_write_scissors(cmd_buffer->cs, 0, count, cmd_buffer->state.dynamic.scissor.scissors, cmd_buffer->state.dynamic.viewport.viewports, |