24 lines
903 B
LLVM
24 lines
903 B
LLVM
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
||
|
; RUN: llc -mtriple=armv7-none-linux-gnueabi < %s | FileCheck %s
|
||
|
|
||
|
define <3 x i64> @shuffle(i1 %dec1, i1 %dec0, <3 x i64> %b) {
|
||
|
; CHECK-LABEL: shuffle:
|
||
|
; CHECK: @ %bb.0: @ %entry
|
||
|
; CHECK-NEXT: tst r1, #1
|
||
|
; CHECK-NEXT: moveq r1, #0
|
||
|
; CHECK-NEXT: vmoveq d16, r1, r1
|
||
|
; CHECK-NEXT: vldrne d16, [sp]
|
||
|
; CHECK-NEXT: tst r2, #1
|
||
|
; CHECK-NEXT: moveq r1, #0
|
||
|
; CHECK-NEXT: vmoveq d18, r1, r1
|
||
|
; CHECK-NEXT: vldrne d18, [sp, #8]
|
||
|
; CHECK-NEXT: vorr d17, d18, d18
|
||
|
; CHECK-NEXT: vst1.64 {d16, d17}, [r0:128]
|
||
|
; CHECK-NEXT: bx lr
|
||
|
entry:
|
||
|
%.sink = select i1 %dec1, <3 x i64> %b, <3 x i64> zeroinitializer
|
||
|
%.sink15 = select i1 %dec0, <3 x i64> %b, <3 x i64> zeroinitializer
|
||
|
%vecinit7 = shufflevector <3 x i64> %.sink, <3 x i64> %.sink15, <3 x i32> <i32 0, i32 4, i32 undef>
|
||
|
ret <3 x i64> %vecinit7
|
||
|
}
|