From 051607368e8d3dd55d2ad2b2200ef656244ec70d Mon Sep 17 00:00:00 2001 From: Yong He Date: Fri, 17 Feb 2023 13:23:27 -0800 Subject: Fixed crash when lowering IR for no_diff struct member. (#2658) * Fixed crash when lowering IR for no_diff struct member. * Improve `setInsertBeforeOrdinaryInst` and `setInsertAfterOrdinaryInst`. --------- Co-authored-by: Yong He --- source/slang/slang-check-decl.cpp | 12 ++++++++++++ 1 file changed, 12 insertions(+) (limited to 'source/slang/slang-check-decl.cpp') diff --git a/source/slang/slang-check-decl.cpp b/source/slang/slang-check-decl.cpp index 837dcb8eb..381efa2c7 100644 --- a/source/slang/slang-check-decl.cpp +++ b/source/slang/slang-check-decl.cpp @@ -1291,6 +1291,16 @@ namespace Slang { checkExtensionExternVarAttribute(varDecl, extensionExternAttr); } + + // If a var decl has no_diff type, move the no_diff modifier from the type to the var. + if (auto modifiedType = as(varDecl->type.type)) + { + if (auto nodiffModifier = modifiedType->findModifier()) + { + varDecl->type.type = getRemovedModifierType(modifiedType, nodiffModifier); + addModifier(varDecl, m_astBuilder->getOrCreate()); + } + } } void SemanticsDeclHeaderVisitor::visitStructDecl(StructDecl* structDecl) @@ -1527,6 +1537,8 @@ namespace Slang // Go through all var members. for (auto member : context->parentDecl->getMembersOfType()) { + if (member->hasModifier()) + continue; auto diffType = tryGetDifferentialType(m_astBuilder, member->type.type); if (!diffType) continue; -- cgit v1.2.3