summaryrefslogtreecommitdiff
path: root/source/slang/slang-ir-layout.cpp
diff options
context:
space:
mode:
authorJulius Ikkala <julius.ikkala@gmail.com>2025-06-26 19:49:11 +0300
committerGitHub <noreply@github.com>2025-06-26 16:49:11 +0000
commita58675b161d9fea8a73a6ded15e5a79b1fc020ef (patch)
tree9c4ed05d5c3f8855413e0f54f003378faa762c83 /source/slang/slang-ir-layout.cpp
parent83c7b7c7716c31596d9e2829d4afa708ce23a182 (diff)
Fix tuple AST & IR layout size queries (#7502)
* Fix tuple AST & IR layout size queries * Don't peephole sizeof if size is still indeterminate
Diffstat (limited to 'source/slang/slang-ir-layout.cpp')
-rw-r--r--source/slang/slang-ir-layout.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/source/slang/slang-ir-layout.cpp b/source/slang/slang-ir-layout.cpp
index 795f47f55..ac0c79601 100644
--- a/source/slang/slang-ir-layout.cpp
+++ b/source/slang/slang-ir-layout.cpp
@@ -275,15 +275,26 @@ static Result _calcSizeAndAlignment(
{
auto tupleType = cast<IRTupleType>(type);
IRSizeAndAlignment resultLayout;
+ IRIntegerValue lastFieldAlignment = 0;
+ IRType* lastFieldType = NULL;
for (UInt i = 0; i < tupleType->getOperandCount(); i++)
{
auto elementType = tupleType->getOperand(i);
IRSizeAndAlignment fieldTypeLayout;
SLANG_RETURN_ON_FAIL(
getSizeAndAlignment(optionSet, rules, (IRType*)elementType, &fieldTypeLayout));
+ resultLayout.size = rules->adjustOffset(
+ resultLayout.size,
+ fieldTypeLayout.size,
+ lastFieldType,
+ lastFieldAlignment);
resultLayout.size = align(resultLayout.size, fieldTypeLayout.alignment);
resultLayout.alignment =
std::max(resultLayout.alignment, fieldTypeLayout.alignment);
+
+ resultLayout.size += fieldTypeLayout.size;
+ lastFieldType = as<IRType>(elementType);
+ lastFieldAlignment = fieldTypeLayout.alignment;
}
*outSizeAndAlignment = rules->alignCompositeElement(resultLayout);
return SLANG_OK;