summaryrefslogtreecommitdiff
path: root/tests/autodiff
diff options
context:
space:
mode:
authorSai Praveen Bangaru <31557731+saipraveenb25@users.noreply.github.com>2023-09-25 18:30:34 -0400
committerGitHub <noreply@github.com>2023-09-25 15:30:34 -0700
commit6c991942ac4ec2e2abf6abe73a2429183172af84 (patch)
tree1179e99a3b583b233bb1acbca21e0744454b790b /tests/autodiff
parent56c4a8cba30b463fdcab21d33680f8ba70b452e0 (diff)
Add test for vector-element contiguity error (#3235)
Diffstat (limited to 'tests/autodiff')
-rw-r--r--tests/autodiff/autopybind-vector-element-type.slang29
1 files changed, 29 insertions, 0 deletions
diff --git a/tests/autodiff/autopybind-vector-element-type.slang b/tests/autodiff/autopybind-vector-element-type.slang
new file mode 100644
index 000000000..78c503466
--- /dev/null
+++ b/tests/autodiff/autopybind-vector-element-type.slang
@@ -0,0 +1,29 @@
+//TEST:SIMPLE(filecheck=CUDA): -target cuda -line-directive-mode none
+//TEST:SIMPLE(filecheck=TORCH): -target torch -line-directive-mode none
+
+// CUDA: __global__ void __kernel__myKernel(TensorView inValues_[[#]], TensorView outValues_[[#]])
+[AutoPyBindCUDA]
+[CudaKernel]
+void myKernel(TensorView<float> inValues, TensorView<float2> outValues)
+{
+ if (cudaThreadIdx().x > 0)
+ return;
+ outValues.store(cudaThreadIdx().x, sin(inValues.load(cudaThreadIdx().x)));
+}
+
+// TORCH: {{^SLANG_PRELUDE_EXPORT$}}
+// TORCH-NEXT: void __kernel__myKernel(TensorView {{[[:alnum:]_]+}}, TensorView {{[[:alnum:]_]+}});
+
+// TORCH: {{^SLANG_PRELUDE_EXPORT$}}
+// TORCH-NEXT: void myKernel(std::tuple<uint32_t, uint32_t, uint32_t> {{[[:alnum:]_]+}}, std::tuple<uint32_t, uint32_t, uint32_t> {{[[:alnum:]_]+}}, torch::Tensor {{[[:alnum:]_]+}}, torch::Tensor {{[[:alnum:]_]+}})
+
+// TORCH: TensorView {{[[:alnum:]_]+}} = make_tensor_view({{[[:alnum:]_]+}}, "outValues", torch::kFloat32, true);
+
+// TORCH: TensorView {{[[:alnum:]_]+}} = make_tensor_view({{[[:alnum:]_]+}}, "inValues", torch::kFloat32, false);
+
+// TORCH: {{^SLANG_PRELUDE_EXPORT$}}
+// TORCH-NEXT: std::tuple<std::tuple<const char*, const char*, const char*, const char*>, std::tuple<const char*, const char*>, const char*, const char*> __funcinfo__myKernel()
+
+// TORCH: m.def("myKernel", &myKernel, "myKernel");
+
+// TORCH: m.def("__funcinfo__myKernel", &__funcinfo__myKernel, "__funcinfo__myKernel"); \ No newline at end of file