From: Rob Clark Date: Mon, 2 Sep 2019 17:08:37 +0000 (-0700) Subject: freedreno/ir3: assert that only single address X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=e59bfc820bdf8531c941150de2ea56fb83b6b28f;p=mesa.git freedreno/ir3: assert that only single address An instruction can reference only a single address register value. Add an assert to catch bugs. Also, address value should also be local to the same block as the instruction. (The one spot where changing the instruction address is actually legit needs to clear the address first.) Signed-off-by: Rob Clark Reviewed-by: Eric Anholt --- diff --git a/src/freedreno/ir3/ir3.c b/src/freedreno/ir3/ir3.c index 5c049a5936f..feec723abd0 100644 --- a/src/freedreno/ir3/ir3.c +++ b/src/freedreno/ir3/ir3.c @@ -1041,6 +1041,10 @@ ir3_instr_set_address(struct ir3_instruction *instr, { if (instr->address != addr) { struct ir3 *ir = instr->block->shader; + + debug_assert(!instr->address); + debug_assert(instr->block == addr->block); + instr->address = addr; array_insert(ir, ir->indirects, instr); } diff --git a/src/freedreno/ir3/ir3_sched.c b/src/freedreno/ir3/ir3_sched.c index 9a544a8e651..96897f60e92 100644 --- a/src/freedreno/ir3/ir3_sched.c +++ b/src/freedreno/ir3/ir3_sched.c @@ -709,6 +709,7 @@ split_addr(struct ir3_sched_ctx *ctx) /* original addr is scheduled, but new one isn't: */ new_addr->flags &= ~IR3_INSTR_MARK; } + indirect->address = NULL; ir3_instr_set_address(indirect, new_addr); } }