diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/panfrost/midgard/mir_promote_uniforms.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/src/panfrost/midgard/mir_promote_uniforms.c b/src/panfrost/midgard/mir_promote_uniforms.c index 7206cb70165..227b943a8f9 100644 --- a/src/panfrost/midgard/mir_promote_uniforms.c +++ b/src/panfrost/midgard/mir_promote_uniforms.c @@ -67,9 +67,16 @@ midgard_promote_uniforms(compiler_context *ctx, unsigned register_pressure) /* It is, great! Let's promote */ ctx->uniform_cutoff = MAX2(ctx->uniform_cutoff, address + 1); - unsigned promoted = SSA_FIXED_REGISTER(uniform_reg); - mir_rewrite_index_src(ctx, ins->ssa_args.dest, promoted); + + /* We do need the move for safety for a non-SSA dest */ + + if (ins->ssa_args.dest >= ctx->func->impl->ssa_alloc) { + midgard_instruction mov = v_mov(promoted, blank_alu_src, ins->ssa_args.dest); + mir_insert_instruction_before(ins, mov); + } else { + mir_rewrite_index_src(ctx, ins->ssa_args.dest, promoted); + } mir_remove_instruction(ins); } |