Fix shuffle index constant not being monomorphized.
This commit is contained in:
parent
1b3fe755ea
commit
4a4ca94151
2 changed files with 46 additions and 2 deletions
|
@ -665,8 +665,12 @@ impl<'a, 'tcx, Bx: BuilderMethods<'a, 'tcx>> FunctionCx<'a, 'tcx, Bx> {
|
||||||
if i == 2 && intrinsic.as_str().starts_with("simd_shuffle") {
|
if i == 2 && intrinsic.as_str().starts_with("simd_shuffle") {
|
||||||
if let mir::Operand::Constant(constant) = arg {
|
if let mir::Operand::Constant(constant) = arg {
|
||||||
let c = self.eval_mir_constant(constant);
|
let c = self.eval_mir_constant(constant);
|
||||||
let (llval, ty) =
|
let (llval, ty) = self.simd_shuffle_indices(
|
||||||
self.simd_shuffle_indices(&bx, constant.span, constant.ty(), c);
|
&bx,
|
||||||
|
constant.span,
|
||||||
|
self.monomorphize(constant.ty()),
|
||||||
|
c,
|
||||||
|
);
|
||||||
return OperandRef {
|
return OperandRef {
|
||||||
val: Immediate(llval),
|
val: Immediate(llval),
|
||||||
layout: bx.layout_of(ty),
|
layout: bx.layout_of(ty),
|
||||||
|
|
40
src/test/ui/simd/monomorphize-shuffle-index.rs
Normal file
40
src/test/ui/simd/monomorphize-shuffle-index.rs
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
//run-pass
|
||||||
|
#![feature(repr_simd, platform_intrinsics)]
|
||||||
|
|
||||||
|
extern "platform-intrinsic" {
|
||||||
|
fn simd_shuffle<T, I, U>(a: T, b: T, i: I) -> U;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Copy, Clone)]
|
||||||
|
#[repr(simd)]
|
||||||
|
struct Simd<T, const N: usize>([T; N]);
|
||||||
|
|
||||||
|
trait Shuffle<const N: usize> {
|
||||||
|
const I: [u32; N];
|
||||||
|
|
||||||
|
unsafe fn shuffle<T, const M: usize>(&self, a: Simd<T, M>, b: Simd<T, M>) -> Simd<T, N> {
|
||||||
|
simd_shuffle(a, b, Self::I)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
struct I1;
|
||||||
|
impl Shuffle<4> for I1 {
|
||||||
|
const I: [u32; 4] = [0, 2, 4, 6];
|
||||||
|
}
|
||||||
|
|
||||||
|
struct I2;
|
||||||
|
impl Shuffle<2> for I2 {
|
||||||
|
const I: [u32; 2] = [1, 5];
|
||||||
|
}
|
||||||
|
|
||||||
|
let a = Simd::<u8, 4>([0, 1, 2, 3]);
|
||||||
|
let b = Simd::<u8, 4>([4, 5, 6, 7]);
|
||||||
|
unsafe {
|
||||||
|
let x: Simd<u8, 4> = I1.shuffle(a, b);
|
||||||
|
assert_eq!(x.0, [0, 2, 4, 6]);
|
||||||
|
|
||||||
|
let y: Simd<u8, 2> = I2.shuffle(a, b);
|
||||||
|
assert_eq!(y.0, [1, 5]);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue