aboutsummaryrefslogtreecommitdiff
path: root/src/shader_recompiler/frontend/ir/microinstruction.cpp
diff options
context:
space:
mode:
authorReinUsesLisp <reinuseslisp@airmail.cc>2021-03-17 01:30:23 -0300
committerameerj <52414509+ameerj@users.noreply.github.com>2021-07-22 21:51:23 -0400
commit8dd0acfaeba9396fb5c1e142a431a2a29f345855 (patch)
treede90d9ab871c892008267b33493d1d8c0e9e17d5 /src/shader_recompiler/frontend/ir/microinstruction.cpp
parentfa2f6e38f4d465ba6e5efe6c6bd23d8ef39b080d (diff)
shader: Fix instruction transitions in and out of Phi
Diffstat (limited to 'src/shader_recompiler/frontend/ir/microinstruction.cpp')
-rw-r--r--src/shader_recompiler/frontend/ir/microinstruction.cpp20
1 files changed, 11 insertions, 9 deletions
diff --git a/src/shader_recompiler/frontend/ir/microinstruction.cpp b/src/shader_recompiler/frontend/ir/microinstruction.cpp
index 88e186f215..5946105d2f 100644
--- a/src/shader_recompiler/frontend/ir/microinstruction.cpp
+++ b/src/shader_recompiler/frontend/ir/microinstruction.cpp
@@ -182,7 +182,7 @@ void Inst::AddPhiOperand(Block* predecessor, const Value& value) {
void Inst::Invalidate() {
ClearArgs();
- op = Opcode::Void;
+ ReplaceOpcode(Opcode::Void);
}
void Inst::ClearArgs() {
@@ -206,20 +206,22 @@ void Inst::ClearArgs() {
void Inst::ReplaceUsesWith(Value replacement) {
Invalidate();
-
- op = Opcode::Identity;
-
+ ReplaceOpcode(Opcode::Identity);
if (!replacement.IsImmediate()) {
Use(replacement);
}
- if (op == Opcode::Phi) {
- phi_args[0].second = replacement;
- } else {
- args[0] = replacement;
- }
+ args[0] = replacement;
}
void Inst::ReplaceOpcode(IR::Opcode opcode) {
+ if (opcode == IR::Opcode::Phi) {
+ throw LogicError("Cannot transition into Phi");
+ }
+ if (op == Opcode::Phi) {
+ // Transition out of phi arguments into non-phi
+ std::destroy_at(&phi_args);
+ std::construct_at(&args);
+ }
op = opcode;
}