From fba316f0e7dacc7f93bee3a95fb93b2ab02bdd80 Mon Sep 17 00:00:00 2001 From: Sai Praveen Bangaru <31557731+saipraveenb25@users.noreply.github.com> Date: Thu, 13 Jun 2024 17:30:16 -0400 Subject: Remove `IRHLSLExportDecoration` and `IRKeepAliveDecoration` for non-CUDA/Torch targets (#4364) * Remove `IRHLSLExportDecoration` and `IRKeepAliveDecoration` for non-CUDA/Torch targets * Update hlsl-torch-cross-compile.slang --- source/slang/slang-emit.cpp | 28 ++++++++++++++++++++++++---- 1 file changed, 24 insertions(+), 4 deletions(-) (limited to 'source/slang/slang-emit.cpp') diff --git a/source/slang/slang-emit.cpp b/source/slang/slang-emit.cpp index 38f066c6c..0f53f74cd 100644 --- a/source/slang/slang-emit.cpp +++ b/source/slang/slang-emit.cpp @@ -555,6 +555,17 @@ Result linkAndOptimizeIR( if (requiredLoweringPassSet.optionalType) lowerOptionalType(irModule, sink); + switch (target) + { + case CodeGenTarget::CUDASource: + case CodeGenTarget::PyTorchCppBinding: + break; + + default: + removeTorchAndCUDAEntryPoints(irModule); + break; + } + switch (target) { case CodeGenTarget::CPPSource: @@ -605,10 +616,19 @@ Result linkAndOptimizeIR( if (!targetProgram->getOptionSet().shouldPerformMinimumOptimizations()) fuseCallsToSaturatedCooperation(irModule); - // Generate any requested derivative wrappers - if (requiredLoweringPassSet.derivativePyBindWrapper) - generateDerivativeWrappers(irModule, sink); - + switch (target) + { + case CodeGenTarget::CUDASource: + case CodeGenTarget::PyTorchCppBinding: + { + // Generate any requested derivative wrappers + if (requiredLoweringPassSet.derivativePyBindWrapper) + generateDerivativeWrappers(irModule, sink); + break; + } + default: + break; + } // Next, we need to ensure that the code we emit for // the target doesn't contain any operations that would // be illegal on the target platform. For example, -- cgit v1.2.3