blob: f359b44cec4a1d1245081599195128225e6fef07 [file]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
; RUN: llc --mtriple=loongarch32 --mattr=+32s,+lsx < %s | FileCheck %s
; RUN: llc --mtriple=loongarch64 --mattr=+lsx < %s | FileCheck %s
define <4 x i32> @xor_shl_splat_vec_one(i32 %x, <4 x i32> %y) nounwind {
; CHECK-LABEL: xor_shl_splat_vec_one:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: vreplgr2vr.w $vr1, $a0
; CHECK-NEXT: vsll.w $vr0, $vr1, $vr0
; CHECK-NEXT: vbitrevi.w $vr0, $vr0, 0
; CHECK-NEXT: ret
entry:
%ins = insertelement <4 x i32> poison, i32 %x, i64 0
%splat = shufflevector <4 x i32> %ins, <4 x i32> poison, <4 x i32> zeroinitializer
%shl = shl <4 x i32> %splat, %y
%xor = xor <4 x i32> %shl, splat (i32 1)
ret <4 x i32> %xor
}