[ARM] Do not use vtrn for vectorshuffle if the order is reversed
[oota-llvm.git] / test / CodeGen / ARM / mvn.ll
1 ; RUN: llc -mtriple=arm-eabi %s -o - | FileCheck %s
2
3 define i32 @f1() {
4 entry:
5         ret i32 -1
6 }
7
8 define i32 @f2(i32 %a) {
9 entry:
10         %tmpnot = xor i32 %a, -1                ; <i32> [#uses=1]
11         ret i32 %tmpnot
12 }
13
14 define i32 @f3(i32 %a) {
15 entry:
16         %tmp1 = shl i32 %a, 2           ; <i32> [#uses=1]
17         %tmp1not = xor i32 %tmp1, -1            ; <i32> [#uses=1]
18         ret i32 %tmp1not
19 }
20
21 define i32 @f4(i32 %a, i8 %b) {
22 entry:
23         %shift.upgrd.1 = zext i8 %b to i32              ; <i32> [#uses=1]
24         %tmp3 = shl i32 %a, %shift.upgrd.1              ; <i32> [#uses=1]
25         %tmp3not = xor i32 %tmp3, -1            ; <i32> [#uses=1]
26         ret i32 %tmp3not
27 }
28
29 define i32 @f5(i32 %a) {
30 entry:
31         %tmp1 = lshr i32 %a, 2          ; <i32> [#uses=1]
32         %tmp1not = xor i32 %tmp1, -1            ; <i32> [#uses=1]
33         ret i32 %tmp1not
34 }
35
36 define i32 @f6(i32 %a, i8 %b) {
37 entry:
38         %shift.upgrd.2 = zext i8 %b to i32              ; <i32> [#uses=1]
39         %tmp2 = lshr i32 %a, %shift.upgrd.2             ; <i32> [#uses=1]
40         %tmp2not = xor i32 %tmp2, -1            ; <i32> [#uses=1]
41         ret i32 %tmp2not
42 }
43
44 define i32 @f7(i32 %a) {
45 entry:
46         %tmp1 = ashr i32 %a, 2          ; <i32> [#uses=1]
47         %tmp1not = xor i32 %tmp1, -1            ; <i32> [#uses=1]
48         ret i32 %tmp1not
49 }
50
51 define i32 @f8(i32 %a, i8 %b) {
52 entry:
53         %shift.upgrd.3 = zext i8 %b to i32              ; <i32> [#uses=1]
54         %tmp3 = ashr i32 %a, %shift.upgrd.3             ; <i32> [#uses=1]
55         %tmp3not = xor i32 %tmp3, -1            ; <i32> [#uses=1]
56         ret i32 %tmp3not
57 }
58
59 define i32 @f9() {
60 entry:
61         %tmp4845 = add i32 0, 0         ; <i32> [#uses=1]
62         br label %cond_true4848
63
64 cond_true4848:          ; preds = %entry
65         %tmp4851 = sub i32 -3, 0                ; <i32> [#uses=1]
66         %abc = add i32 %tmp4851, %tmp4845               ; <i32> [#uses=1]
67         ret i32 %abc
68 }
69
70 define i1 @f10(i32 %a) {
71 entry:
72         %tmp102 = icmp eq i32 -2, %a            ; <i1> [#uses=1]
73         ret i1 %tmp102
74 }
75
76 ; CHECK-LABEL: mvn.ll
77 ; CHECK-LABEL: @f1
78 ; CHECK: mvn
79 ; CHECK: mvn
80 ; CHECK: mvn
81 ; CHECK: mvn
82 ; CHECK: mvn
83 ; CHECK: mvn
84 ; CHECK: mvn
85 ; CHECK: mvn
86 ; CHECK: mvn
87 ; CHECK-NOT: mvn
88