test: dont optimize to invalid bitcasts
This commit is contained in:
parent
5a3e2a4e92
commit
ac670721c9
17
tests/ui/simd/dont-invalid-bitcast-masks.rs
Normal file
17
tests/ui/simd/dont-invalid-bitcast-masks.rs
Normal file
@ -0,0 +1,17 @@
|
||||
//@ build-pass
|
||||
//@ compile-flags: -Copt-level=3
|
||||
|
||||
// regression test for https://github.com/rust-lang/rust/issues/110722
|
||||
// in --release we were optimizing to invalid bitcasts, due to a combination of MIR inlining and
|
||||
// mostly bad repr(simd) lowering which prevented even basic splats from working
|
||||
#![crate_type = "rlib"]
|
||||
#![feature(portable_simd)]
|
||||
use std::simd::*;
|
||||
use std::simd::num::*;
|
||||
|
||||
pub unsafe fn mask_to_array(mask: u8) -> [i32; 8] {
|
||||
let mut output = [0; 8];
|
||||
let m = masksizex8::from_bitmask(mask as _);
|
||||
output.copy_from_slice(&m.to_int().cast::<i32>().to_array());
|
||||
output
|
||||
}
|
27
tests/ui/simd/dont-invalid-bitcast-x86_64.rs
Normal file
27
tests/ui/simd/dont-invalid-bitcast-x86_64.rs
Normal file
@ -0,0 +1,27 @@
|
||||
//@ build-pass
|
||||
//@ compile-flags: -Copt-level=3
|
||||
//@ only-x86_64
|
||||
// ignore-tidy-linelength
|
||||
|
||||
// regression test for https://github.com/rust-lang/rust/issues/110707
|
||||
// in --release we were optimizing to invalid bitcasts, due to a combination of MIR inlining and
|
||||
// mostly bad repr(simd) lowering which prevented even basic splats from working
|
||||
|
||||
#![crate_type = "rlib"]
|
||||
#![feature(portable_simd)]
|
||||
use std::simd::*;
|
||||
use std::arch::x86_64::*;
|
||||
|
||||
#[target_feature(enable = "sse4.1")]
|
||||
pub unsafe fn fast_round_sse(i: f32x8) -> f32x8 {
|
||||
let a = i.to_array();
|
||||
let [low, high]: [[f32; 4]; 2] =
|
||||
unsafe { std::mem::transmute::<[f32; 8], [[f32; 4]; 2]>(a) };
|
||||
|
||||
let low = f32x4::from(_mm_round_ps::<{_MM_FROUND_TO_NEAREST_INT | _MM_FROUND_NO_EXC}>(f32x4::from_array(low).into()));
|
||||
let high = f32x4::from(_mm_round_ps::<{_MM_FROUND_TO_NEAREST_INT | _MM_FROUND_NO_EXC}>(f32x4::from_array(high).into()));
|
||||
|
||||
let a: [f32; 8] =
|
||||
unsafe { std::mem::transmute::<[[f32; 4]; 2], [f32; 8]>([low.to_array(), high.to_array()]) };
|
||||
f32x8::from_array(a)
|
||||
}
|
Loading…
Reference in New Issue
Block a user