summaryrefslogtreecommitdiffstats
path: root/source/slang/slang-emit.cpp
diff options
context:
space:
mode:
authorYong He <yonghe@outlook.com>2025-03-06 14:26:34 -0800
committerGitHub <noreply@github.com>2025-03-06 14:26:34 -0800
commit4485cf3eaf142cfd5f8470e86739acc67d4e12ea (patch)
treec6ce220dfe5f3ab25ea558f2512f3761c9565c69 /source/slang/slang-emit.cpp
parent55dd2deaff82bbdb72e125ba4b350030b7e5f427 (diff)
Update SPIRV-Tools and fix new validation errors. (#6511)
* Update SPIRV-Tools and fix new validation errors. * Implement pointers for glsl target. * Reworked packStorage/unpackStorage code gen to operate on pointers rather than values.
Diffstat (limited to 'source/slang/slang-emit.cpp')
-rw-r--r--source/slang/slang-emit.cpp5
1 files changed, 3 insertions, 2 deletions
diff --git a/source/slang/slang-emit.cpp b/source/slang/slang-emit.cpp
index 94ea66d71..4fb33ccc2 100644
--- a/source/slang/slang-emit.cpp
+++ b/source/slang/slang-emit.cpp
@@ -1644,10 +1644,11 @@ Result linkAndOptimizeIR(
bufferElementTypeLoweringOptions.use16ByteArrayElementForConstantBuffer =
isWGPUTarget(targetRequest);
lowerBufferElementTypeToStorageType(targetProgram, irModule, bufferElementTypeLoweringOptions);
+ performForceInlining(irModule);
// Rewrite functions that return arrays to return them via `out` parameter,
// since our target languages doesn't allow returning arrays.
- if (!isMetalTarget(targetRequest))
+ if (!isMetalTarget(targetRequest) && !isSPIRV(target))
legalizeArrayReturnType(irModule);
if (isKhronosTarget(targetRequest) || target == CodeGenTarget::HLSL)
@@ -1669,8 +1670,8 @@ Result linkAndOptimizeIR(
if (emitSpirvDirectly)
{
performIntrinsicFunctionInlining(irModule);
- eliminateDeadCode(irModule, deadCodeEliminationOptions);
}
+
eliminateMultiLevelBreak(irModule);
if (!fastIRSimplificationOptions.minimalOptimization)