diff options
| author | Hans Kratz <hans@appfour.com> | 2021-07-21 13:20:35 +0200 |
|---|---|---|
| committer | Hans Kratz <hans@appfour.com> | 2021-08-04 23:36:14 +0200 |
| commit | 4a8202c4a68ec6161dbc31dcb5b0ec51d84c9d87 (patch) | |
| tree | deb629ce2801d303788e12577db19675ff2c23b8 /src/test/codegen | |
| parent | 50be80b22d5edf508198fa757a0a88316b009af6 (diff) | |
| download | rust-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.rs | 14 |
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> } |
