diff options
Diffstat (limited to 'source/slang/slang-type-layout.cpp')
| -rw-r--r-- | source/slang/slang-type-layout.cpp | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/source/slang/slang-type-layout.cpp b/source/slang/slang-type-layout.cpp index 98a324d96..d7b303535 100644 --- a/source/slang/slang-type-layout.cpp +++ b/source/slang/slang-type-layout.cpp @@ -2523,7 +2523,7 @@ SourceLanguage getIntermediateSourceLanguageForTarget(TargetProgram* targetProgr bool areResourceTypesBindlessOnTarget(TargetRequest* targetReq) { - return isCPUTarget(targetReq) || isCUDATarget(targetReq); + return isCPUTarget(targetReq) || isCUDATarget(targetReq) || isMetalTarget(targetReq); } static bool isD3D11Target(TargetRequest*) @@ -4802,6 +4802,15 @@ static TypeLayoutResult _createTypeLayout(TypeLayoutContext& context, Type* type type, rules); } + else if (auto resPtrType = as<DescriptorHandleType>(type)) + { + if (areResourceTypesBindlessOnTarget(context.targetReq)) + return _createTypeLayout(context, resPtrType->getElementType()); + auto uint2Type = context.astBuilder->getVectorType( + context.astBuilder->getUIntType(), + context.astBuilder->getIntVal(context.astBuilder->getIntType(), 2)); + return _createTypeLayout(context, uint2Type); + } else if (auto optionalType = as<OptionalType>(type)) { // OptionalType should be laid out the same way as Tuple<T, bool>. |
