summaryrefslogtreecommitdiff
path: root/source/slang/slang-legalize-types.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'source/slang/slang-legalize-types.cpp')
-rw-r--r--source/slang/slang-legalize-types.cpp19
1 files changed, 14 insertions, 5 deletions
diff --git a/source/slang/slang-legalize-types.cpp b/source/slang/slang-legalize-types.cpp
index 5e8390cef..6009ef33e 100644
--- a/source/slang/slang-legalize-types.cpp
+++ b/source/slang/slang-legalize-types.cpp
@@ -287,6 +287,11 @@ struct TupleTypeBuilder
{
specialType = legalFieldType;
}
+
+ // `void` is currently legalized to simple, but we don't want to add a
+ // `void` field to the struct.
+ if (legalLeafType.getSimple()->getOp() == kIROp_VoidType)
+ return;
}
break;
@@ -419,7 +424,6 @@ struct TupleTypeBuilder
bool isSpecialField = context->isSpecialType(fieldType);
auto legalFieldType = legalizeType(context, fieldType);
-
addField(
field->getKey(),
legalFieldType,
@@ -1385,10 +1389,15 @@ LegalType legalizeTypeImpl(
context,
arrayType->getElementType());
- // If element type hasn't change, return original type.
- if (legalElementType.flavor == LegalType::Flavor::simple &&
- legalElementType.getSimple() == arrayType->getElementType())
- return LegalType::simple(arrayType);
+ if (legalElementType.flavor == LegalType::Flavor::simple)
+ {
+ if (legalElementType.getSimple()->getOp() == kIROp_VoidType)
+ return LegalType();
+
+ // If element type hasn't change, return original type.
+ if (legalElementType.getSimple() == arrayType->getElementType())
+ return LegalType::simple(arrayType);
+ }
ArrayLegalTypeWrapper wrapper;
wrapper.arrayType = arrayType;