From 1ab727add7fcdb0881eceaaa891f1aa8faeb122e Mon Sep 17 00:00:00 2001 From: Icecream95 Date: Tue, 15 Feb 2022 20:24:01 +1300 Subject: [PATCH] panfrost: Set dirty state in set_shader_buffers Otherwise the pointer (which is uploaded as a sysval) won't be updated when a new SSBO is bound. Fixes: c34b760b9f9 ("panfrost: Dirty track constant buffers") Part-of: (cherry picked from commit b164ee0d7b1777f40bb3c5b26236ee5dde53536d) --- .pick_status.json | 2 +- src/gallium/drivers/panfrost/pan_context.c | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/.pick_status.json b/.pick_status.json index 21dc62733f5..8dedc5e5b51 100644 --- a/.pick_status.json +++ b/.pick_status.json @@ -625,7 +625,7 @@ "description": "panfrost: Set dirty state in set_shader_buffers", "nominated": true, "nomination_type": 1, - "resolution": 0, + "resolution": 1, "main_sha": null, "because_sha": "c34b760b9f99ecbf1218e7b612a32ce43c7283bf" }, diff --git a/src/gallium/drivers/panfrost/pan_context.c b/src/gallium/drivers/panfrost/pan_context.c index f7089c4cbc5..b2795fbb337 100644 --- a/src/gallium/drivers/panfrost/pan_context.c +++ b/src/gallium/drivers/panfrost/pan_context.c @@ -667,6 +667,8 @@ panfrost_set_shader_buffers( util_set_shader_buffers_mask(ctx->ssbo[shader], &ctx->ssbo_mask[shader], buffers, start, count); + + ctx->dirty_shader[shader] |= PAN_DIRTY_STAGE_SSBO; } static void