diff options
author | Fernando S <fsahmkow27@gmail.com> | 2022-03-25 03:21:27 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-03-25 03:21:27 +0100 |
commit | d108c2873d8a7ef223ca1bd9244038823484ed37 (patch) | |
tree | e980f9291919199b51152f48d30dc67d38febfe1 /src/shader_recompiler/frontend/ir/microinstruction.cpp | |
parent | 8f2e5f5666608dd466ea8476ac592074fb3fc8ec (diff) | |
parent | 67159e3be76cf468288ae492ea22fc43a77a9d1e (diff) |
Merge pull request #8068 from ameerj/shader-if-false
shader_recompiler/dead_code_elimination: Add DeadBranchElimination pass
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) { phi_args.emplace_back(predecessor, value); } +void Inst::ErasePhiOperand(size_t index) { + const auto operand_it{phi_args.begin() + static_cast<ptrdiff_t>(index)}; + phi_args.erase(operand_it); +} + void Inst::OrderPhiArgs() { if (op != Opcode::Phi) { throw LogicError("{} is not a Phi instruction", op); |