2019-12-25 10:50:37 +10:00
|
|
|
// This used to cause assert_10_13 to unexpectingly fail, due to simd_shuffle_indices being passed
|
|
|
|
// the wrong Instance, causing issues with inlining. See #67557.
|
|
|
|
//
|
|
|
|
// run-pass
|
2021-03-04 10:21:13 -03:00
|
|
|
// compile-flags: -Zmir-opt-level=4
|
2020-02-20 16:00:39 -08:00
|
|
|
#![feature(platform_intrinsics, repr_simd)]
|
2019-12-25 10:50:37 +10:00
|
|
|
|
|
|
|
extern "platform-intrinsic" {
|
2023-07-10 13:03:48 +00:00
|
|
|
fn simd_shuffle<T, I, U>(x: T, y: T, idx: I) -> U;
|
2019-12-25 10:50:37 +10:00
|
|
|
}
|
|
|
|
|
|
|
|
#[repr(simd)]
|
|
|
|
#[derive(Debug, PartialEq)]
|
|
|
|
struct Simd2(u8, u8);
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
unsafe {
|
2021-05-12 17:08:45 +02:00
|
|
|
const IDX: [u32; 2] = [0, 1];
|
2023-07-10 13:03:48 +00:00
|
|
|
let p_res: Simd2 = simd_shuffle(Simd2(10, 11), Simd2(12, 13), IDX);
|
2019-12-25 10:50:37 +10:00
|
|
|
let a_res: Simd2 = inline_me();
|
|
|
|
|
|
|
|
assert_10_11(p_res);
|
|
|
|
assert_10_13(a_res);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline(never)]
|
|
|
|
fn assert_10_11(x: Simd2) {
|
|
|
|
assert_eq!(x, Simd2(10, 11));
|
|
|
|
}
|
|
|
|
|
|
|
|
#[inline(never)]
|
|
|
|
fn assert_10_13(x: Simd2) {
|
|
|
|
assert_eq!(x, Simd2(10, 13));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[inline(always)]
|
|
|
|
unsafe fn inline_me() -> Simd2 {
|
2021-05-12 17:08:45 +02:00
|
|
|
const IDX: [u32; 2] = [0, 3];
|
2023-07-10 13:03:48 +00:00
|
|
|
simd_shuffle(Simd2(10, 11), Simd2(12, 13), IDX)
|
2019-12-25 10:50:37 +10:00
|
|
|
}
|