]> git.lizzy.rs Git - rust.git/commitdiff
add gather/scatter run-time test
authorgnzlbg <gonzalobg88@gmail.com>
Wed, 9 May 2018 14:47:38 +0000 (16:47 +0200)
committergnzlbg <gonzalobg88@gmail.com>
Thu, 24 May 2018 14:04:39 +0000 (16:04 +0200)
src/test/codegen/simd-intrinsic-generic-gather.rs
src/test/codegen/simd-intrinsic-generic-scatter.rs
src/test/run-pass/simd-intrinsic-generic-gather.rs [new file with mode: 0644]

index 605a952e8ff051e85858a5efa5aead868dc882ef..6c47bf3e321fbb3eb19afb6bb564f9d9f558f2f5 100644 (file)
@@ -10,6 +10,7 @@
 
 // ignore-emscripten
 // ignore-tidy-linelength
+// min-llvm-version 6.0
 
 // compile-flags: -C no-prepopulate-passes
 
index 752265412f0c23285f858d0e1a2af846eab51e2f..7b5b2e55e2949986fc9ffec3a7ee46acaa9a0ec5 100644 (file)
@@ -10,6 +10,7 @@
 
 // ignore-emscripten
 // ignore-tidy-linelength
+// min-llvm-version 6.0
 
 // compile-flags: -C no-prepopulate-passes
 
@@ -38,6 +39,7 @@ pub unsafe fn scatter_f32x2(pointers: Vec2<*mut f32>, mask: Vec2<i32>,
     simd_scatter(values, pointers, mask)
 }
 
+
 // CHECK-LABEL: @scatter_pf32x2
 #[no_mangle]
 pub unsafe fn scatter_pf32x2(pointers: Vec2<*mut *const f32>, mask: Vec2<i32>,
diff --git a/src/test/run-pass/simd-intrinsic-generic-gather.rs b/src/test/run-pass/simd-intrinsic-generic-gather.rs
new file mode 100644 (file)
index 0000000..dbc5221
--- /dev/null
@@ -0,0 +1,80 @@
+// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+// ignore-emscripten
+// min-llvm-version 6.0
+
+// Test that the simd_{gather,scatter} intrinsics produce the correct results.
+
+#![feature(repr_simd, platform_intrinsics)]
+#![allow(non_camel_case_types)]
+
+#[repr(simd)]
+#[derive(Copy, Clone, PartialEq, Debug)]
+struct x4<T>(pub T, pub T, pub T, pub T);
+
+extern "platform-intrinsic" {
+    fn simd_gather<T, U, V>(x: T, y: U, z: V) -> T;
+    fn simd_scatter<T, U, V>(x: T, y: U, z: V) -> ();
+}
+
+fn main() {
+    let mut x = [0_f32, 1., 2., 3., 4., 5., 6., 7.];
+
+    let default = x4(-3_f32, -3., -3., -3.);
+    let s_strided = x4(0_f32, 2., -3., 6.);
+    let mask = x4(-1_i32, -1, 0, -1);
+
+    // reading from *const
+    unsafe {
+        let pointer = &x[0] as *const f32;
+        let pointers =  x4(
+            pointer.offset(0) as *const f32,
+            pointer.offset(2),
+            pointer.offset(4),
+            pointer.offset(6)
+        );
+
+        let r_strided = simd_gather(default, pointers, mask);
+
+        assert_eq!(r_strided, s_strided);
+    }
+
+    // reading from *mut
+    unsafe {
+        let pointer = &mut x[0] as *mut f32;
+        let pointers = x4(
+            pointer.offset(0) as *mut f32,
+            pointer.offset(2),
+            pointer.offset(4),
+            pointer.offset(6)
+        );
+
+        let r_strided = simd_gather(default, pointers, mask);
+
+        assert_eq!(r_strided, s_strided);
+    }
+
+    // writing to *mut
+    unsafe {
+        let pointer = &mut x[0] as *mut f32;
+        let pointers = x4(
+            pointer.offset(0) as *mut f32,
+            pointer.offset(2),
+            pointer.offset(4),
+            pointer.offset(6)
+        );
+
+        let values = x4(42_f32, 43_f32, 44_f32, 45_f32);
+        simd_scatter(values, pointers, mask);
+
+        assert_eq!(x, [42., 1., 43., 3., 4., 5., 45., 7.]);
+    }
+}