]> git.lizzy.rs Git - rust.git/blob - src/test/ui/consts/const-eval/simd/insert_extract.rs
Fix maximum SIMD lane count, and expose it to other crates. Disallow SIMD vectors...
[rust.git] / src / test / ui / consts / const-eval / simd / insert_extract.rs
1 // run-pass
2 #![feature(const_fn)]
3 #![feature(repr_simd)]
4 #![feature(platform_intrinsics)]
5 #![feature(staged_api)]
6 #![stable(feature = "foo", since = "1.33.7")]
7 #![allow(non_camel_case_types)]
8
9 #[repr(simd)] struct i8x1(i8);
10 #[repr(simd)] struct u16x2(u16, u16);
11 #[repr(simd)] struct f32x4(f32, f32, f32, f32);
12
13 extern "platform-intrinsic" {
14     #[rustc_const_stable(feature = "foo", since = "1.3.37")]
15     fn simd_insert<T, U>(x: T, idx: u32, val: U) -> T;
16     #[rustc_const_stable(feature = "foo", since = "1.3.37")]
17     fn simd_extract<T, U>(x: T, idx: u32) -> U;
18 }
19
20 fn main() {
21     {
22         const U: i8x1 = i8x1(13);
23         const V: i8x1 = unsafe { simd_insert(U, 0_u32, 42_i8) };
24         const X0: i8 = V.0;
25         const Y0: i8 = unsafe { simd_extract(V, 0) };
26         assert_eq!(X0, 42);
27         assert_eq!(Y0, 42);
28     }
29     {
30         const U: u16x2 = u16x2(13, 14);
31         const V: u16x2 = unsafe { simd_insert(U, 1_u32, 42_u16) };
32         const X0: u16 = V.0;
33         const X1: u16 = V.1;
34         const Y0: u16 = unsafe { simd_extract(V, 0) };
35         const Y1: u16 = unsafe { simd_extract(V, 1) };
36         assert_eq!(X0, 13);
37         assert_eq!(X1, 42);
38         assert_eq!(Y0, 13);
39         assert_eq!(Y1, 42);
40     }
41     {
42         const U: f32x4 = f32x4(13., 14., 15., 16.);
43         const V: f32x4 = unsafe { simd_insert(U, 1_u32, 42_f32) };
44         const X0: f32 = V.0;
45         const X1: f32 = V.1;
46         const X2: f32 = V.2;
47         const X3: f32 = V.3;
48         const Y0: f32 = unsafe { simd_extract(V, 0) };
49         const Y1: f32 = unsafe { simd_extract(V, 1) };
50         const Y2: f32 = unsafe { simd_extract(V, 2) };
51         const Y3: f32 = unsafe { simd_extract(V, 3) };
52         assert_eq!(X0, 13.);
53         assert_eq!(X1, 42.);
54         assert_eq!(X2, 15.);
55         assert_eq!(X3, 16.);
56         assert_eq!(Y0, 13.);
57         assert_eq!(Y1, 42.);
58         assert_eq!(Y2, 15.);
59         assert_eq!(Y3, 16.);
60     }
61 }