diff options
| author | Julius Ikkala <julius.ikkala@gmail.com> | 2025-06-26 19:49:11 +0300 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-06-26 16:49:11 +0000 |
| commit | a58675b161d9fea8a73a6ded15e5a79b1fc020ef (patch) | |
| tree | 9c4ed05d5c3f8855413e0f54f003378faa762c83 /source/slang/slang-ir-layout.cpp | |
| parent | 83c7b7c7716c31596d9e2829d4afa708ce23a182 (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.cpp | 11 |
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; |
