]> git.lizzy.rs Git - rust.git/blob - src/test/ui/simd/simd-intrinsic-float-minmax.rs
5f0aa11af5fb8db540b5869bbd3796f9369c73c0
[rust.git] / src / test / ui / simd / simd-intrinsic-float-minmax.rs
1 // run-pass
2 // ignore-emscripten
3
4 // Test that the simd_f{min,max} intrinsics produce the correct results.
5
6 #![feature(repr_simd, platform_intrinsics)]
7 #![allow(non_camel_case_types)]
8
9 #[repr(simd)]
10 #[derive(Copy, Clone, PartialEq, Debug)]
11 struct f32x4(pub f32, pub f32, pub f32, pub f32);
12
13 extern "platform-intrinsic" {
14     fn simd_fmin<T>(x: T, y: T) -> T;
15     fn simd_fmax<T>(x: T, y: T) -> T;
16 }
17
18 fn main() {
19     let x = f32x4(1.0, 2.0, 3.0, 4.0);
20     let y = f32x4(2.0, 1.0, 4.0, 3.0);
21
22     #[cfg(not(any(target_arch = "mips", target_arch = "mips64")))]
23     let nan = ::std::f32::NAN;
24     // MIPS hardware treats f32::NAN as SNAN. Clear the signaling bit.
25     // See https://github.com/rust-lang/rust/issues/52746.
26     #[cfg(any(target_arch = "mips", target_arch = "mips64"))]
27     let nan = f32::from_bits(::std::f32::NAN.to_bits() - 1);
28
29     let n = f32x4(nan, nan, nan, nan);
30
31     unsafe {
32         let min0 = simd_fmin(x, y);
33         let min1 = simd_fmin(y, x);
34         assert_eq!(min0, min1);
35         let e = f32x4(1.0, 1.0, 3.0, 3.0);
36         assert_eq!(min0, e);
37         let minn = simd_fmin(x, n);
38         assert_eq!(minn, x);
39         let minn = simd_fmin(y, n);
40         assert_eq!(minn, y);
41
42         let max0 = simd_fmax(x, y);
43         let max1 = simd_fmax(y, x);
44         assert_eq!(max0, max1);
45         let e = f32x4(2.0, 2.0, 4.0, 4.0);
46         assert_eq!(max0, e);
47         let maxn = simd_fmax(x, n);
48         assert_eq!(maxn, x);
49         let maxn = simd_fmax(y, n);
50         assert_eq!(maxn, y);
51     }
52 }