mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2025-12-22 22:10:10 +01:00
zink: fix xfb buffer refcounting
we need to always ref the counter buffer to the current batch, not just when using it for resumign xfb Reviewed-by: Erik Faye-Lund <erik.faye-lund@collabora.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/8984>
This commit is contained in:
parent
e163f1c949
commit
eeaf7b51f3
1 changed files with 7 additions and 5 deletions
|
|
@ -717,13 +717,15 @@ zink_draw_vbo(struct pipe_context *pctx,
|
||||||
if (ctx->num_so_targets) {
|
if (ctx->num_so_targets) {
|
||||||
for (unsigned i = 0; i < ctx->num_so_targets; i++) {
|
for (unsigned i = 0; i < ctx->num_so_targets; i++) {
|
||||||
struct zink_so_target *t = zink_so_target(ctx->so_targets[i]);
|
struct zink_so_target *t = zink_so_target(ctx->so_targets[i]);
|
||||||
if (t && t->counter_buffer_valid) {
|
counter_buffers[i] = VK_NULL_HANDLE;
|
||||||
|
if (t) {
|
||||||
struct zink_resource *res = zink_resource(t->counter_buffer);
|
struct zink_resource *res = zink_resource(t->counter_buffer);
|
||||||
zink_batch_reference_resource_rw(batch, res, true);
|
zink_batch_reference_resource_rw(batch, res, true);
|
||||||
|
if (t->counter_buffer_valid) {
|
||||||
counter_buffers[i] = res->buffer;
|
counter_buffers[i] = res->buffer;
|
||||||
counter_buffer_offsets[i] = t->counter_buffer_offset;
|
counter_buffer_offsets[i] = t->counter_buffer_offset;
|
||||||
} else
|
}
|
||||||
counter_buffers[i] = VK_NULL_HANDLE;
|
}
|
||||||
}
|
}
|
||||||
screen->vk_CmdBeginTransformFeedbackEXT(batch->cmdbuf, 0, ctx->num_so_targets, counter_buffers, counter_buffer_offsets);
|
screen->vk_CmdBeginTransformFeedbackEXT(batch->cmdbuf, 0, ctx->num_so_targets, counter_buffers, counter_buffer_offsets);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue