summaryrefslogtreecommitdiff
path: root/source/slang/slang-emit-spirv.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'source/slang/slang-emit-spirv.cpp')
-rw-r--r--source/slang/slang-emit-spirv.cpp26
1 files changed, 26 insertions, 0 deletions
diff --git a/source/slang/slang-emit-spirv.cpp b/source/slang/slang-emit-spirv.cpp
index 9088e959a..a2da4801e 100644
--- a/source/slang/slang-emit-spirv.cpp
+++ b/source/slang/slang-emit-spirv.cpp
@@ -3933,6 +3933,17 @@ struct SPIRVEmitContext
}
break;
}
+ case kIROp_DownstreamModuleExportDecoration:
+ {
+ requireSPIRVCapability(SpvCapabilityLinkage);
+ auto name = decoration->getParent()->findDecoration<IRExportDecoration>()->getMangledName();
+ emitInst(getSection(SpvLogicalSectionID::Annotations),
+ decoration,
+ SpvOpDecorate,
+ dstID,
+ SpvDecorationLinkageAttributes, name, SpvLinkageTypeExport);
+ break;
+ }
// ...
}
@@ -6847,12 +6858,27 @@ SlangResult emitSPIRVFromIR(
#endif
auto shouldPreserveParams = codeGenContext->getTargetProgram()->getOptionSet().getBoolOption(CompilerOptionName::PreserveParameters);
+ auto generateWholeProgram = codeGenContext->getTargetProgram()->getOptionSet().getBoolOption(CompilerOptionName::GenerateWholeProgram);
for (auto inst : irModule->getGlobalInsts())
{
if (as<IRDebugSource>(inst))
+ {
context.ensureInst(inst);
+ }
if (shouldPreserveParams && as<IRGlobalParam>(inst))
+ {
context.ensureInst(inst);
+ }
+ if (generateWholeProgram)
+ {
+ if (auto func = as<IRFunc>(inst))
+ {
+ if (func->findDecoration<IRDownstreamModuleExportDecoration>())
+ {
+ context.ensureInst(inst);
+ }
+ }
+ }
}
// Emit source language info.