diff options
| author | Ashley Mannix <kodraus@hey.com> | 2020-11-15 09:35:04 +1000 |
|---|---|---|
| committer | Ashley Mannix <kodraus@hey.com> | 2020-11-15 09:35:04 +1000 |
| commit | 75658091631afe5a8b805a340a43bef4c00def11 (patch) | |
| tree | c56711cdefcacf3f515e2fa1d017a2d5277ae40e /src/test | |
| parent | 74f2941a8ebf32a6864ea4596c755a9f65e14f42 (diff) | |
| download | rust-75658091631afe5a8b805a340a43bef4c00def11.tar.gz rust-75658091631afe5a8b805a340a43bef4c00def11.zip | |
add a canary test for complex repr(simd)
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/ui/simd/simd-array-trait.rs | 40 | ||||
| -rw-r--r-- | src/test/ui/simd/simd-array-trait.stderr | 10 |
2 files changed, 50 insertions, 0 deletions
diff --git a/src/test/ui/simd/simd-array-trait.rs b/src/test/ui/simd/simd-array-trait.rs new file mode 100644 index 00000000000..6219e7ca83b --- /dev/null +++ b/src/test/ui/simd/simd-array-trait.rs @@ -0,0 +1,40 @@ +// Figuring out the size of a vector type that depends on traits doesn't ICE + +#![allow(dead_code)] + +// pretty-expanded FIXME #23616 + +#![feature(repr_simd, platform_intrinsics, const_generics)] +#![allow(non_camel_case_types, incomplete_features)] + +pub trait Simd { + type Lane: Clone + Copy; + const SIZE: usize; +} + +pub struct i32x4; +impl Simd for i32x4 { + type Lane = i32; + const SIZE: usize = 4; +} + +#[repr(simd)] +#[derive(Copy, Clone)] +pub struct T<S: Simd>([S::Lane; S::SIZE]); //~ ERROR constant expression depends on a generic parameter + +extern "platform-intrinsic" { + fn simd_insert<T, E>(x: T, idx: u32, y: E) -> T; + fn simd_extract<T, E>(x: T, idx: u32) -> E; +} + +pub fn main() { + let mut t = T::<i32x4>([0; 4]); + unsafe { + for i in 0_i32..4 { + t = simd_insert(t, i as u32, i); + } + for i in 0_i32..4 { + assert_eq!(i, simd_extract(t, i as u32)); + } + } +} diff --git a/src/test/ui/simd/simd-array-trait.stderr b/src/test/ui/simd/simd-array-trait.stderr new file mode 100644 index 00000000000..c100e020c54 --- /dev/null +++ b/src/test/ui/simd/simd-array-trait.stderr @@ -0,0 +1,10 @@ +error: constant expression depends on a generic parameter + --> $DIR/simd-array-trait.rs:23:23 + | +LL | pub struct T<S: Simd>([S::Lane; S::SIZE]); + | ^^^^^^^^^^^^^^^^^^ + | + = note: this may fail depending on what value the parameter takes + +error: aborting due to previous error + |
