summaryrefslogtreecommitdiff
path: root/source/slang/slang-emit.cpp
diff options
context:
space:
mode:
authordubiousconst282 <87553666+dubiousconst282@users.noreply.github.com>2024-07-24 18:20:06 -0300
committerGitHub <noreply@github.com>2024-07-24 14:20:06 -0700
commitefa8d1ab40c24a15678dd4143c9cc7b7b64e04d8 (patch)
treed2df663078d6058dce9fb30920d1ce3415fbb4a4 /source/slang/slang-emit.cpp
parent639576cbe9d9cf604c554fda8dda48485201704f (diff)
Add generic descriptor indexing intrinsic (#4389)
* Add ResourceArray intrinsic type * Move aliased parameter generation to GLSL legalization * Add DynamicResourceEntry type for proxying layout of GenericResourceArray * Reimplement as DynamicResource * Add reflection test * Don't reuse alias cache between different parameters * Add dynamic cast extensions for buffer types * Minor format fix * Fix VarDecl diagnostics after finding non-appliable initializer candidates --------- Co-authored-by: Yong He <yonghe@outlook.com>
Diffstat (limited to 'source/slang/slang-emit.cpp')
-rw-r--r--source/slang/slang-emit.cpp8
1 files changed, 8 insertions, 0 deletions
diff --git a/source/slang/slang-emit.cpp b/source/slang/slang-emit.cpp
index 417bbf200..9e21ccbfd 100644
--- a/source/slang/slang-emit.cpp
+++ b/source/slang/slang-emit.cpp
@@ -244,6 +244,7 @@ struct RequiredLoweringPassSet
bool glslGlobalVar;
bool glslSSBO;
bool byteAddressBuffer;
+ bool dynamicResource;
};
// Scan the IR module and determine which lowering/legalization passes are needed based
@@ -347,6 +348,9 @@ void calcRequiredLoweringPassSet(RequiredLoweringPassSet& result, CodeGenContext
case kIROp_HLSLByteAddressBufferType:
result.byteAddressBuffer = true;
break;
+ case kIROp_DynamicResourceType:
+ result.dynamicResource = true;
+ break;
}
if (!result.generics || !result.existentialTypeLayout)
{
@@ -1166,6 +1170,10 @@ Result linkAndOptimizeIR(
if(isD3DTarget(targetRequest))
legalizeNonStructParameterToStructForHLSL(irModule);
+ // Create aliases for all dynamic resource parameters.
+ if(requiredLoweringPassSet.dynamicResource && isKhronosTarget(targetRequest))
+ legalizeDynamicResourcesForGLSL(codeGenContext, irModule);
+
legalizeExtractFromTextureAccess(irModule);
// Legalize `ImageSubscript` loads.