about summary refs log tree commit diff
path: root/src/test
diff options
context:
space:
mode:
authorAshley Mannix <kodraus@hey.com>2020-11-15 09:35:04 +1000
committerAshley Mannix <kodraus@hey.com>2020-11-15 09:35:04 +1000
commit75658091631afe5a8b805a340a43bef4c00def11 (patch)
treec56711cdefcacf3f515e2fa1d017a2d5277ae40e /src/test
parent74f2941a8ebf32a6864ea4596c755a9f65e14f42 (diff)
downloadrust-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.rs40
-rw-r--r--src/test/ui/simd/simd-array-trait.stderr10
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
+