summaryrefslogtreecommitdiffstats
path: root/source/slang/slang-emit.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'source/slang/slang-emit.cpp')
-rw-r--r--source/slang/slang-emit.cpp9
1 files changed, 9 insertions, 0 deletions
diff --git a/source/slang/slang-emit.cpp b/source/slang/slang-emit.cpp
index 58376bbc1..f093104bd 100644
--- a/source/slang/slang-emit.cpp
+++ b/source/slang/slang-emit.cpp
@@ -90,6 +90,7 @@
#include "slang-ir-specialize-buffer-load-arg.h"
#include "slang-ir-specialize-matrix-layout.h"
#include "slang-ir-specialize-resources.h"
+#include "slang-ir-specialize-stage-switch.h"
#include "slang-ir-specialize.h"
#include "slang-ir-ssa-simplification.h"
#include "slang-ir-ssa.h"
@@ -322,6 +323,7 @@ struct RequiredLoweringPassSet
bool dynamicResource;
bool dynamicResourceHeap;
bool resolveVaryingInputRef;
+ bool specializeStageSwitch;
};
// Scan the IR module and determine which lowering/legalization passes are needed based
@@ -444,6 +446,9 @@ void calcRequiredLoweringPassSet(
case kIROp_ResolveVaryingInputRef:
result.resolveVaryingInputRef = true;
break;
+ case kIROp_GetCurrentStage:
+ result.specializeStageSwitch = true;
+ break;
}
if (!result.generics || !result.existentialTypeLayout)
{
@@ -1027,6 +1032,10 @@ Result linkAndOptimizeIR(
cleanupGenerics(targetProgram, irModule, sink);
dumpIRIfEnabled(codeGenContext, irModule, "AFTER-LOWER-GENERICS");
+ // After dynamic dispatch logic is resolved into ordinary function calls,
+ // we can now run our stage specialization logic.
+ if (requiredLoweringPassSet.specializeStageSwitch)
+ specializeStageSwitch(irModule);
if (sink->getErrorCount() != 0)
return SLANG_FAIL;
#if 0