[Mesa-dev] [PATCH 07/12] nir: update fixup_phi_srcs() to handle registers
Timothy Arceri
timothy.arceri at collabora.com
Mon Dec 19 05:47:32 UTC 2016
We need to do this because we partially get out of SSA when unrolling
and cloning loops.
---
src/compiler/nir/nir_clone.c | 13 +++++++++----
1 file changed, 9 insertions(+), 4 deletions(-)
diff --git a/src/compiler/nir/nir_clone.c b/src/compiler/nir/nir_clone.c
index fb1558c..91ffe62 100644
--- a/src/compiler/nir/nir_clone.c
+++ b/src/compiler/nir/nir_clone.c
@@ -603,12 +603,17 @@ fixup_phi_srcs(clone_state *state)
{
list_for_each_entry_safe(nir_phi_src, src, &state->phi_srcs, src.use_link) {
src->pred = remap_local(state, src->pred);
- assert(src->src.is_ssa);
- src->src.ssa = remap_local(state, src->src.ssa);
- /* Remove from this list and place in the uses of the SSA def */
+ /* Remove from this list */
list_del(&src->src.use_link);
- list_addtail(&src->src.use_link, &src->src.ssa->uses);
+
+ if (src->src.is_ssa) {
+ src->src.ssa = remap_local(state, src->src.ssa);
+ list_addtail(&src->src.use_link, &src->src.ssa->uses);
+ } else {
+ src->src.reg.reg = remap_reg(state, src->src.reg.reg);
+ list_addtail(&src->src.use_link, &src->src.reg.reg->uses);
+ }
}
assert(list_empty(&state->phi_srcs));
}
--
2.9.3
More information about the mesa-dev
mailing list