summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rw-r--r--tests/language-feature/bit-cast/struct-bit-cast.slang68
-rw-r--r--tests/language-feature/bit-cast/struct-bit-cast.slang.expected.txt4
2 files changed, 72 insertions, 0 deletions
diff --git a/tests/language-feature/bit-cast/struct-bit-cast.slang b/tests/language-feature/bit-cast/struct-bit-cast.slang
new file mode 100644
index 000000000..9c4a039c0
--- /dev/null
+++ b/tests/language-feature/bit-cast/struct-bit-cast.slang
@@ -0,0 +1,68 @@
+// struct-bit-cast.slang
+
+//TEST(compute):COMPARE_COMPUTE: -shaderobj
+
+// Test that bit_cast works for bit-reinterpreting one struct type as another.
+
+struct Foo
+{
+ uint a;
+ float b;
+ float2 fvec;
+}
+
+struct Inner
+{
+ int v;
+ uint s;
+}
+
+struct Bar
+{
+ int u;
+ Inner i;
+ uint t;
+}
+
+int test0(int val)
+{
+ Bar b;
+ b.u = val;
+ b.i.v = asint(2.0f);
+ b.i.s = asuint(1.25);
+ b.t = asuint(0.25);
+ Foo f = bit_cast<Foo, Bar>(b);
+ return f.a + (int)f.b + int(float(f.fvec.x / f.fvec.y)); // val + 2 + 5
+}
+
+struct Smaller
+{
+ int s;
+}
+
+struct Larger
+{
+ int x, y;
+}
+
+int test1()
+{
+ Smaller s = {1};
+ int v0 = bit_cast<Larger, Smaller>(s).y; // 0.
+ Larger l = {1, 2};
+ int v1 = bit_cast<Smaller, Larger>(l).s; // 1.
+ return v0 + v1;
+}
+
+
+//TEST_INPUT:ubuffer(data=[0 0 0 0], stride=4):out,name=outputBuffer
+RWStructuredBuffer<int> outputBuffer;
+
+[numthreads(4, 1, 1)]
+void computeMain(uint3 dispatchThreadID : SV_DispatchThreadID)
+{
+ uint tid = dispatchThreadID.x;
+ int inVal = tid;
+ int outVal = test0(inVal) + test1();
+ outputBuffer[tid] = outVal;
+}
diff --git a/tests/language-feature/bit-cast/struct-bit-cast.slang.expected.txt b/tests/language-feature/bit-cast/struct-bit-cast.slang.expected.txt
new file mode 100644
index 000000000..9ace6947d
--- /dev/null
+++ b/tests/language-feature/bit-cast/struct-bit-cast.slang.expected.txt
@@ -0,0 +1,4 @@
+8
+9
+A
+B