summaryrefslogtreecommitdiff
path: root/source/slang/slang-emit.cpp
diff options
context:
space:
mode:
authoryum <yum.food.vr@gmail.com>2025-10-11 13:34:03 -0700
committeryum <yum.food.vr@gmail.com>2025-10-17 18:37:45 -0700
commit482914e1b42dd44f4696b48c834136631672cebe (patch)
tree4d9ef2a7044d25d208daa07b2b1c909210492c53 /source/slang/slang-emit.cpp
parentff064b9a0f1316007f46710432f854777a520fdf (diff)
Optionally disable entry point param cbuffer transform
Diffstat (limited to 'source/slang/slang-emit.cpp')
-rw-r--r--source/slang/slang-emit.cpp8
1 files changed, 6 insertions, 2 deletions
diff --git a/source/slang/slang-emit.cpp b/source/slang/slang-emit.cpp
index bdd7dfe10..e8be11973 100644
--- a/source/slang/slang-emit.cpp
+++ b/source/slang/slang-emit.cpp
@@ -830,6 +830,7 @@ Result linkAndOptimizeIR(
// TODO: We should skip this step for CUDA targets.
// (NM): we actually do need to do this step for OptiX based CUDA targets
//
+ if (!targetProgram->getOptionSet().getBoolOption(CompilerOptionName::PlainFunctionEntryPoints))
{
CollectEntryPointUniformParamsOptions passOptions;
passOptions.targetReq = targetRequest;
@@ -862,10 +863,13 @@ Result linkAndOptimizeIR(
switch (target)
{
default:
- moveEntryPointUniformParamsToGlobalScope(irModule);
+ if (!targetProgram->getOptionSet().getBoolOption(CompilerOptionName::PlainFunctionEntryPoints))
+ {
+ moveEntryPointUniformParamsToGlobalScope(irModule);
#if 0
- dumpIRIfEnabled(codeGenContext, irModule, "ENTRY POINT UNIFORMS MOVED");
+ dumpIRIfEnabled(codeGenContext, irModule, "ENTRY POINT UNIFORMS MOVED");
#endif
+ }
validateIRModuleIfEnabled(codeGenContext, irModule);
break;
case CodeGenTarget::HostCPPSource: