summaryrefslogtreecommitdiffstats
path: root/source
diff options
context:
space:
mode:
authorvenkataram-nv <vedavamadath@nvidia.com>2024-07-01 16:01:21 -0700
committerGitHub <noreply@github.com>2024-07-01 16:01:21 -0700
commitfff79c311028cc8a5cff310a9c493b23af68eb0c (patch)
tree3842c4bb724fc1c06b839f314728295a99cae4ca /source
parent6262569c6305468afac8067112b61cc42780464c (diff)
Support HLSL `.sample` operators for MS textures (#4524)
* Add `.sample` operator for MS texture types * Adding filecheck tests for `.sample`
Diffstat (limited to 'source')
-rw-r--r--source/slang/hlsl.meta.slang33
1 files changed, 33 insertions, 0 deletions
diff --git a/source/slang/hlsl.meta.slang b/source/slang/hlsl.meta.slang
index 7c65aec5e..f50c63367 100644
--- a/source/slang/hlsl.meta.slang
+++ b/source/slang/hlsl.meta.slang
@@ -3202,6 +3202,7 @@ struct __TextureMip<T, Shape : __ITextureShape, let isArray : int, let isCombine
get { return tex.Load(__makeVector(pos, mip)); }
}
}
+
struct __TextureMips<T, Shape : __ITextureShape, let isArray : int, let isCombined : int, let format : int>
{
__TextureImpl<T, Shape, isArray, 0 /*isMS*/, 0 /*sampleCount*/, 0 /*access*/, 0 /*isShadow*/, isCombined, format> tex;
@@ -3222,6 +3223,38 @@ extension __TextureImpl<T, Shape, isArray, 0 /*isMS*/, 0 /*sampleCount*/, 0 /*ac
}
}
+// Definitions to support the .sample[][] operator.
+struct __TextureSample<T, Shape : __ITextureShape, let isArray : int, let isCombined : int, let format : int>
+{
+ __TextureImpl<T, Shape, isArray, 1 /*isMS*/, 0 /*sampleCount*/, 0 /*access*/, 0 /*isShadow*/, isCombined, format> tex;
+ int sample;
+ __subscript(vector<int, isArray + Shape.dimensions> pos)->T
+ {
+ [__unsafeForceInlineEarly]
+ get { return tex[pos, sample]; }
+ }
+}
+
+struct __TextureSampleMS<T, Shape : __ITextureShape, let isArray : int, let isCombined : int, let format : int>
+{
+ __TextureImpl<T, Shape, isArray, 1 /*isMS*/, 0 /*sampleCount*/, 0 /*access*/, 0 /*isShadow*/, isCombined, format> tex;
+ __subscript(int sample)->__TextureSample<T, Shape, isArray, isCombined, format>
+ {
+ [__unsafeForceInlineEarly]
+ get { return { tex, sample }; }
+ }
+}
+
+__generic<T, Shape : __ITextureShape, let isArray : int, let isCombined : int, let format : int>
+extension __TextureImpl<T, Shape, isArray, 1 /*isMS*/, 0 /*sampleCount*/, 0 /*access*/, 0 /*isShadow*/, isCombined, format>
+{
+ property __TextureSampleMS<T, Shape, isArray, isCombined, format> sample
+ {
+ [__unsafeForceInlineEarly]
+ get { return { this }; }
+ }
+}
+
// Texture type aliases.
// T, Shape: __ITextureShape, let isArray:int, let isMS:int, let sampleCount:int, let access:int, let isShadow:int, let isCombined:int, let format:int
${{{{