blob: a74c36fabc1b81ea809c5af9ce5e4c2b7865b85f [file] [log] [blame]
//@ run-pass
//@ ignore-emscripten
// Short form of the generic gather/scatter tests,
// verifying simd([*const T; N]) and simd([*mut T; N]) pass typeck and work.
#![feature(repr_simd, core_intrinsics)]
#![allow(non_camel_case_types)]
#[path = "../../auxiliary/minisimd.rs"]
mod minisimd;
use minisimd::*;
use std::intrinsics::simd::{simd_gather, simd_scatter};
type cptrx4<T> = Simd<*const T, 4>;
type mptrx4<T> = Simd<*mut T, 4>;
fn main() {
let mut x = [0_f32, 1., 2., 3., 4., 5., 6., 7.];
let default = f32x4::from_array([-3_f32, -3., -3., -3.]);
let s_strided = f32x4::from_array([0_f32, 2., -3., 6.]);
let mask = i32x4::from_array([-1_i32, -1, 0, -1]);
// reading from *const
unsafe {
let pointer = &x as *const f32;
let pointers = cptrx4::from_array([
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);
}
// writing to *mut
unsafe {
let pointer = &mut x as *mut f32;
let pointers = mptrx4::from_array([
pointer.offset(0) as *mut f32,
pointer.offset(2),
pointer.offset(4),
pointer.offset(6),
]);
let values = f32x4::from_array([42_f32, 43_f32, 44_f32, 45_f32]);
simd_scatter(values, pointers, mask);
assert_eq!(x, [42., 1., 43., 3., 4., 5., 45., 7.]);
}
}