about summary refs log tree commit diff
path: root/src/test/codegen
diff options
context:
space:
mode:
authorHans Kratz <hans@appfour.com>2021-07-21 13:20:35 +0200
committerHans Kratz <hans@appfour.com>2021-08-04 23:36:14 +0200
commit4a8202c4a68ec6161dbc31dcb5b0ec51d84c9d87 (patch)
treedeb629ce2801d303788e12577db19675ff2c23b8 /src/test/codegen
parent50be80b22d5edf508198fa757a0a88316b009af6 (diff)
downloadrust-4a8202c4a68ec6161dbc31dcb5b0ec51d84c9d87.tar.gz
rust-4a8202c4a68ec6161dbc31dcb5b0ec51d84c9d87.zip
Add testcase for proper LLVM representation of SIMD types.
Testcase to make sure that no 0-sized padding is inserted in structs and that structs are represented as expected by Neon intrinsics in LLVM.
Diffstat (limited to 'src/test/codegen')
-rw-r--r--src/test/codegen/unpadded-simd.rs14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/test/codegen/unpadded-simd.rs b/src/test/codegen/unpadded-simd.rs
new file mode 100644
index 00000000000..eb44dbd9313
--- /dev/null
+++ b/src/test/codegen/unpadded-simd.rs
@@ -0,0 +1,14 @@
+// Make sure that no 0-sized padding is inserted in structs and that
+// structs are represented as expected by Neon intrinsics in LLVM.
+// See #87254.
+
+#![crate_type = "lib"]
+#![feature(repr_simd)]
+
+#[derive(Copy, Clone, Debug)]
+#[repr(simd)]
+pub struct int16x4_t(pub i16, pub i16, pub i16, pub i16);
+
+#[derive(Copy, Clone, Debug)]
+pub struct int16x4x2_t(pub int16x4_t, pub int16x4_t);
+// CHECK: %int16x4x2_t = type { <4 x i16>, <4 x i16> }