diff options
| author | 2022-03-22 18:34:31 -0400 | |
|---|---|---|
| committer | 2022-03-23 17:57:22 -0400 | |
| commit | 67159e3be76cf468288ae492ea22fc43a77a9d1e (patch) | |
| tree | 1430335870a66823463f56f86cd98de6f8d5c6d8 /src/shader_recompiler/frontend/ir/microinstruction.cpp | |
| parent | shader_recompiler/dead_code_elimination: Add DeadBranchElimination pass (diff) | |
| download | yuzu-67159e3be76cf468288ae492ea22fc43a77a9d1e.tar.gz yuzu-67159e3be76cf468288ae492ea22fc43a77a9d1e.tar.xz yuzu-67159e3be76cf468288ae492ea22fc43a77a9d1e.zip | |
dead_code_elimination_pass: Remove unreachable Phi arguments
Diffstat (limited to 'src/shader_recompiler/frontend/ir/microinstruction.cpp')
| -rw-r--r-- | src/shader_recompiler/frontend/ir/microinstruction.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/src/shader_recompiler/frontend/ir/microinstruction.cpp b/src/shader_recompiler/frontend/ir/microinstruction.cpp index 631446cf7..4a2564f47 100644 --- a/src/shader_recompiler/frontend/ir/microinstruction.cpp +++ b/src/shader_recompiler/frontend/ir/microinstruction.cpp | |||
| @@ -326,6 +326,11 @@ void Inst::AddPhiOperand(Block* predecessor, const Value& value) { | |||
| 326 | phi_args.emplace_back(predecessor, value); | 326 | phi_args.emplace_back(predecessor, value); |
| 327 | } | 327 | } |
| 328 | 328 | ||
| 329 | void Inst::ErasePhiOperand(size_t index) { | ||
| 330 | const auto operand_it{phi_args.begin() + static_cast<ptrdiff_t>(index)}; | ||
| 331 | phi_args.erase(operand_it); | ||
| 332 | } | ||
| 333 | |||
| 329 | void Inst::OrderPhiArgs() { | 334 | void Inst::OrderPhiArgs() { |
| 330 | if (op != Opcode::Phi) { | 335 | if (op != Opcode::Phi) { |
| 331 | throw LogicError("{} is not a Phi instruction", op); | 336 | throw LogicError("{} is not a Phi instruction", op); |