diff --git a/test/Feature/HLSLLib/asint.test b/test/Feature/HLSLLib/asint.test new file mode 100644 index 00000000..1c539d32 --- /dev/null +++ b/test/Feature/HLSLLib/asint.test @@ -0,0 +1,141 @@ +#--- source.hlsl + +StructuredBuffer In1 : register(t0); +StructuredBuffer In2 : register(t1); +StructuredBuffer In3 : register(t2); +RWStructuredBuffer Out1 : register(u3); +RWStructuredBuffer Out2 : register(u4); +RWStructuredBuffer Out3 : register(u5); + +[numthreads(1,1,1)] +void main() { + // int + Out1[0] = asint(In1[0]); + int4 Tmp = {asint(In1[0].xyz), asint(In1[0].w)}; + Out1[1] = Tmp; + Out1[2].xy = asint(In1[0].xy); + + // uint + Out2[0] = asint(In2[0]); + int4 Tmp2 = {asint(In2[0].xyz), asint(In2[0].w)}; + Out2[1] = Tmp2; + Out2[2].xy = asint(In2[0].xy); + + // float + Out3[0] = asint(In3[0]); + int4 Tmp3 = {asint(In3[0].xyz), asint(In3[0].w)}; + Out3[1] = Tmp3; + Out3[2].xy = asint(In3[0].xy); + +} + +//--- pipeline.yaml + +--- +Shaders: + - Stage: Compute + Entry: main + DispatchSize: [1, 1, 1] +Buffers: + - Name: In1 + Format: Int32 + Stride: 16 + Data: [-1, 0, -2147483648, 2147483647] + - Name: In2 + Format: UInt32 + Stride: 16 + Data: [0xffffffff, 0, 0x80000000, 0x7FFFFFFF] + - Name: In3 + Format: Float32 + Stride: 16 + Data: [-nan, 0, -0, nan] + - Name: Out1 + Format: Int32 + Stride: 16 + ZeroInitSize: 48 + - Name: ExpectedOut1 # The result we expect + Format: Int32 + Stride: 16 + Data: [-1, 0, -2147483648, 2147483647, -1, 0, -2147483648, 2147483647, -1, 0, 0, 0] + - Name: Out2 + Format: Int32 + Stride: 16 + ZeroInitSize: 48 + - Name: ExpectedOut2 # The result we expect + Format: Int32 + Stride: 16 + Data: [-1, 0, -2147483648, 2147483647, -1, 0, -2147483648, 2147483647, -1, 0, 0, 0] + - Name: Out3 + Format: Int32 + Stride: 16 + ZeroInitSize: 48 + - Name: ExpectedOut3 # The result we expect + Format: Int32 + Stride: 16 + Data: [-1, 0, -2147483648, 2147483647, -1, 0, -2147483648, 2147483647, -1, 0, 0, 0] +Results: + - Result: Test1 + Rule: BufferExact + Actual: Out1 + Expected: ExpectedOut1 + - Result: Test2 + Rule: BufferExact + Actual: Out2 + Expected: ExpectedOut2 + - Result: Test3 + Rule: BufferExact + Actual: Out3 + Expected: ExpectedOut3 +DescriptorSets: + - Resources: + - Name: In1 + Kind: StructuredBuffer + DirectXBinding: + Register: 0 + Space: 0 + VulkanBinding: + Binding: 0 + - Name: In2 + Kind: StructuredBuffer + DirectXBinding: + Register: 1 + Space: 0 + VulkanBinding: + Binding: 1 + - Name: In3 + Kind: StructuredBuffer + DirectXBinding: + Register: 2 + Space: 0 + VulkanBinding: + Binding: 2 + - Name: Out1 + Kind: RWStructuredBuffer + DirectXBinding: + Register: 3 + Space: 0 + VulkanBinding: + Binding: 3 + - Name: Out2 + Kind: RWStructuredBuffer + DirectXBinding: + Register: 4 + Space: 0 + VulkanBinding: + Binding: 4 + - Name: Out3 + Kind: RWStructuredBuffer + DirectXBinding: + Register: 5 + Space: 0 + VulkanBinding: + Binding: 5 +... +#--- end + +# https://github.com/llvm/llvm-project/issues/146942 +# XFAIL: Clang-Vulkan + +# RUN: split-file %s %t +# RUN: %dxc_target -T cs_6_5 -Fo %t.o %t/source.hlsl +# RUN: %offloader %t/pipeline.yaml %t.o