From b507d881ca47135bfa46237767e7183f61e7d8e3 Mon Sep 17 00:00:00 2001 From: Yong He Date: Fri, 15 Dec 2023 17:05:32 -0800 Subject: Add ConstBufferPointer::subscript. (#3415) Co-authored-by: Yong He --- source/slang/slang-ir-specialize.cpp | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) (limited to 'source/slang/slang-ir-specialize.cpp') diff --git a/source/slang/slang-ir-specialize.cpp b/source/slang/slang-ir-specialize.cpp index e1a563b04..3f75a8b32 100644 --- a/source/slang/slang-ir-specialize.cpp +++ b/source/slang/slang-ir-specialize.cpp @@ -47,15 +47,17 @@ struct SpecializationContext // we are specializing. IRModule* module; DiagnosticSink* sink; + TargetRequest* targetRequest; bool changed = false; - SpecializationContext(IRModule* inModule) + SpecializationContext(IRModule* inModule, TargetRequest* target) : workList(*inModule->getContainerPool().getList()) , workListSet(*inModule->getContainerPool().getHashSet()) , cleanInsts(*module->getContainerPool().getHashSet()) , module(inModule) + , targetRequest(target) { } @@ -1511,7 +1513,7 @@ struct SpecializationContext // addToWorkList(newFunc); - simplifyFunc(newFunc, IRSimplificationOptions::getFast()); + simplifyFunc(targetRequest, newFunc, IRSimplificationOptions::getFast()); return newFunc; } @@ -2230,11 +2232,12 @@ struct SpecializationContext }; bool specializeModule( + TargetRequest* target, IRModule* module, DiagnosticSink* sink) { SLANG_PROFILE; - SpecializationContext context(module); + SpecializationContext context(module, target); context.sink = sink; context.processModule(); return context.changed; @@ -2369,7 +2372,7 @@ IRInst* specializeGenericImpl( // the same thing. if (auto func = as(specializedVal)) { - simplifyFunc(func, IRSimplificationOptions::getFast()); + simplifyFunc(context->targetRequest, func, IRSimplificationOptions::getFast()); } return specializedVal; -- cgit v1.2.3