summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJason Ekstrand <jason@jlekstrand.net>2020-07-10 16:09:27 -0500
committerEric Engestrom <eric@engestrom.ch>2020-07-22 22:30:04 +0200
commit32d2431a553945ccf44edb419a003c1070eb4694 (patch)
tree36f44a9f4d93cf037cb549079e2aa58235f34852
parentd5fcf18614146c13e1661bc2d0e1e609ab40c2ed (diff)
spirv: Skip phis in unreachable blocks in the second phi pass
Closes: #3253 Fixes: 22fdb2f8551 "nir/spirv: Update to the latest revision" Reviewed-by: Caio Marcelo de Oliveira Filho <caio.oliveira@intel.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/5855> (cherry picked from commit 81773b4b441fbd8ec284de78e4dfdcecdca112dc)
-rw-r--r--.pick_status.json2
-rw-r--r--src/compiler/spirv/vtn_cfg.c9
2 files changed, 9 insertions, 2 deletions
diff --git a/.pick_status.json b/.pick_status.json
index d8a83ddd7ba..7c6813904a8 100644
--- a/.pick_status.json
+++ b/.pick_status.json
@@ -3838,7 +3838,7 @@
"description": "spirv: Skip phis in unreachable blocks in the second phi pass",
"nominated": true,
"nomination_type": 1,
- "resolution": 0,
+ "resolution": 1,
"master_sha": null,
"because_sha": "22fdb2f8551330fea308ce9cfe151ec00201e2b1"
},
diff --git a/src/compiler/spirv/vtn_cfg.c b/src/compiler/spirv/vtn_cfg.c
index 395a5775606..a31047b18b1 100644
--- a/src/compiler/spirv/vtn_cfg.c
+++ b/src/compiler/spirv/vtn_cfg.c
@@ -1003,7 +1003,14 @@ vtn_handle_phi_second_pass(struct vtn_builder *b, SpvOp opcode,
return true;
struct hash_entry *phi_entry = _mesa_hash_table_search(b->phi_table, w);
- vtn_assert(phi_entry);
+
+ /* It's possible that this phi is in an unreachable block in which case it
+ * may never have been emitted and therefore may not be in the hash table.
+ * In this case, there's no var for it and it's safe to just bail.
+ */
+ if (phi_entry == NULL)
+ return true;
+
nir_variable *phi_var = phi_entry->data;
for (unsigned i = 3; i < count; i += 2) {