freedreno/ir3: fix crash with samgq workaround
authorRob Clark <robdclark@chromium.org>
Wed, 26 Feb 2020 00:37:26 +0000 (16:37 -0800)
committerMarge Bot <eric+marge@anholt.net>
Fri, 28 Feb 2020 16:53:41 +0000 (16:53 +0000)
Need to list_delinit() before we clone the instruction to split it into
individual samgpN instructions, otherwise we get list corruption.

Tested-by: Eduardo Lima Mitev <elima@igalia.com>
Signed-off-by: Rob Clark <robdclark@chromium.org>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/3989>

src/freedreno/ir3/ir3_legalize.c

index 9c349bf27457eea2e199a1c770295f7fc5551f07..d5cdd6d444376e5b3ca5d370a535275227743a6f 100644 (file)
@@ -215,13 +215,14 @@ legalize_block(struct ir3_legalize_ctx *ctx, struct ir3_block *block)
                        ctx->type == MESA_SHADER_VERTEX && n->opc == OPC_SAMGQ) {
                        struct ir3_instruction *samgp;
 
+                       list_delinit(&n->node);
+
                        for (i = 0; i < 4; i++) {
                                samgp = ir3_instr_clone(n);
                                samgp->opc = OPC_SAMGP0 + i;
                                if (i > 1)
                                        samgp->flags |= IR3_INSTR_SY;
                        }
-                       list_delinit(&n->node);
                } else {
                        list_addtail(&n->node, &block->instr_list);
                }