From 0366c18d87f8c60ff6a99db668a7f2d810aaeeb0 Mon Sep 17 00:00:00 2001 From: Fernando Sahmkow Date: Wed, 21 Aug 2019 11:54:47 -0400 Subject: Shader_IR: mark labels as unused for partial decompile. --- src/video_core/shader/ast.cpp | 4 +--- src/video_core/shader/ast.h | 8 ++++++++ 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/src/video_core/shader/ast.cpp b/src/video_core/shader/ast.cpp index 14c50e1c6..74b9a8f9a 100644 --- a/src/video_core/shader/ast.cpp +++ b/src/video_core/shader/ast.cpp @@ -497,9 +497,7 @@ void ASTManager::Decompile() { } } if (can_remove) { - auto& manager = label->GetManager(); - manager.Remove(label); - labels.erase(it); + label->MarkLabelUnused(); } } } diff --git a/src/video_core/shader/ast.h b/src/video_core/shader/ast.h index 849d0612c..07deb58e4 100644 --- a/src/video_core/shader/ast.h +++ b/src/video_core/shader/ast.h @@ -112,6 +112,7 @@ class ASTLabel { public: ASTLabel(u32 index) : index{index} {} u32 index; + bool unused{}; }; class ASTGoto { @@ -204,6 +205,13 @@ public: return nullptr; } + void MarkLabelUnused() const { + auto inner = std::get_if(&data); + if (inner) { + inner->unused = true; + } + } + Expr GetIfCondition() const { auto inner = std::get_if(&data); if (inner) { -- cgit v1.2.3