Add explicit -mtriple=arm-unknown to llvm/test/CodeGen/ARM/disable-tail-calls.ll...
[oota-llvm.git] / test / CodeGen / ARM / fast-isel-mvn.ll
1 ; RUN: llc -O0 -verify-machineinstrs -fast-isel-abort=1 -relocation-model=dynamic-no-pic -arm-use-movt=false -mtriple=armv7-apple-ios     < %s | FileCheck %s --check-prefix=CHECK --check-prefix=ARM
2 ; RUN: llc -O0 -verify-machineinstrs -fast-isel-abort=1 -relocation-model=dynamic-no-pic -arm-use-movt=false -mtriple=armv7-linux-gnueabi < %s | FileCheck %s --check-prefix=CHECK --check-prefix=ARM
3 ; RUN: llc -O0 -verify-machineinstrs -fast-isel-abort=1 -relocation-model=dynamic-no-pic -arm-use-movt=false -mtriple=thumbv7-apple-ios   < %s | FileCheck %s --check-prefix=CHECK --check-prefix=ARM
4 ; RUN: llc -O0 -verify-machineinstrs -fast-isel-abort=1 -relocation-model=dynamic-no-pic -arm-use-movt=true  -mtriple=thumbv7-apple-ios   < %s | FileCheck %s --check-prefix=CHECK --check-prefix=THUMB
5 ; RUN: llc -O0 -verify-machineinstrs -fast-isel-abort=1 -relocation-model=dynamic-no-pic -arm-use-movt=true  -mtriple=armv7-apple-ios     < %s | FileCheck %s --check-prefix=MOVT
6 ; rdar://10412592
7
8 define void @t1() nounwind {
9 entry:
10 ; CHECK-LABEL: t1
11 ; CHECK:       mvn r0, #0
12   call void @foo(i32 -1)
13   ret void
14 }
15
16 declare void @foo(i32)
17
18 define void @t2() nounwind {
19 entry:
20 ; CHECK-LABEL: t2
21 ; CHECK:       mvn r0, #233
22   call void @foo(i32 -234)
23   ret void
24 }
25
26 define void @t3() nounwind {
27 entry:
28 ; CHECK-LABEL: t3
29 ; CHECK:       mvn r0, #256
30   call void @foo(i32 -257)
31   ret void
32 }
33
34 ; Load from constant pool
35 define void @t4() nounwind {
36 entry:
37 ; ARM-LABEL:   t4
38 ; ARM:         ldr r0
39 ; THUMB-LABEL: t4
40 ; THUMB:       movw r0, #65278
41 ; THUMB:       movt r0, #65535
42   call void @foo(i32 -258)
43   ret void
44 }
45
46 define void @t5() nounwind {
47 entry:
48 ; CHECK-LABEL: t5
49 ; CHECK:       mvn r0, #65280
50   call void @foo(i32 -65281)
51   ret void
52 }
53
54 define void @t6() nounwind {
55 entry:
56 ; CHECK-LABEL: t6
57 ; CHECK:       mvn r0, #978944
58   call void @foo(i32 -978945)
59   ret void
60 }
61
62 define void @t7() nounwind {
63 entry:
64 ; CHECK-LABEL: t7
65 ; CHECK:       mvn r0, #267386880
66   call void @foo(i32 -267386881)
67   ret void
68 }
69
70 define void @t8() nounwind {
71 entry:
72 ; CHECK-LABEL: t8
73 ; CHECK:       mvn r0, #65280
74   call void @foo(i32 -65281)
75   ret void
76 }
77
78 define void @t9() nounwind {
79 entry:
80 ; CHECK-LABEL: t9
81 ; CHECK:       mvn r0, #2130706432
82   call void @foo(i32 -2130706433)
83   ret void
84 }
85
86 ; Load from constant pool.
87 define i32 @t10(i32 %a) {
88 ; MOVT-LABEL: t10
89 ; MOVT:       ldr
90   %1 = xor i32 -1998730207, %a
91   ret i32 %1
92 }
93