OLD | NEW |
1 ; This is a very early test that just checks the representation of i32 | 1 ; This is a very early test that just checks the representation of i32 |
2 ; arithmetic instructions. No assembly tests are done. | 2 ; arithmetic instructions. No assembly tests are done. |
3 | 3 |
4 ; REQUIRES: allow_dump | 4 ; REQUIRES: allow_dump |
5 | 5 |
6 ; RUN: %p2i -i %s --filetype=asm --args --verbose inst -threads=0 | FileCheck %s | 6 ; RUN: %p2i -i %s --filetype=asm --args --verbose inst -threads=0 \ |
| 7 ; RUN: -allow-externally-defined-symbols | FileCheck %s |
7 | 8 |
8 define i32 @Add(i32 %a, i32 %b) { | 9 define internal i32 @Add(i32 %a, i32 %b) { |
9 ; CHECK: define i32 @Add | 10 ; CHECK: define internal i32 @Add |
10 entry: | 11 entry: |
11 %add = add i32 %b, %a | 12 %add = add i32 %b, %a |
12 ; CHECK: add | 13 ; CHECK: add |
13 tail call void @Use(i32 %add) | 14 tail call void @Use(i32 %add) |
14 ; CHECK: call Use | 15 ; CHECK: call Use |
15 ret i32 %add | 16 ret i32 %add |
16 } | 17 } |
17 | 18 |
18 declare void @Use(i32) | 19 declare void @Use(i32) |
19 | 20 |
20 define i32 @And(i32 %a, i32 %b) { | 21 define internal i32 @And(i32 %a, i32 %b) { |
21 ; CHECK: define i32 @And | 22 ; CHECK: define internal i32 @And |
22 entry: | 23 entry: |
23 %and = and i32 %b, %a | 24 %and = and i32 %b, %a |
24 ; CHECK: and | 25 ; CHECK: and |
25 tail call void @Use(i32 %and) | 26 tail call void @Use(i32 %and) |
26 ; CHECK: call Use | 27 ; CHECK: call Use |
27 ret i32 %and | 28 ret i32 %and |
28 } | 29 } |
29 | 30 |
30 define i32 @Or(i32 %a, i32 %b) { | 31 define internal i32 @Or(i32 %a, i32 %b) { |
31 ; CHECK: define i32 @Or | 32 ; CHECK: define internal i32 @Or |
32 entry: | 33 entry: |
33 %or = or i32 %b, %a | 34 %or = or i32 %b, %a |
34 ; CHECK: or | 35 ; CHECK: or |
35 tail call void @Use(i32 %or) | 36 tail call void @Use(i32 %or) |
36 ; CHECK: call Use | 37 ; CHECK: call Use |
37 ret i32 %or | 38 ret i32 %or |
38 } | 39 } |
39 | 40 |
40 define i32 @Xor(i32 %a, i32 %b) { | 41 define internal i32 @Xor(i32 %a, i32 %b) { |
41 ; CHECK: define i32 @Xor | 42 ; CHECK: define internal i32 @Xor |
42 entry: | 43 entry: |
43 %xor = xor i32 %b, %a | 44 %xor = xor i32 %b, %a |
44 ; CHECK: xor | 45 ; CHECK: xor |
45 tail call void @Use(i32 %xor) | 46 tail call void @Use(i32 %xor) |
46 ; CHECK: call Use | 47 ; CHECK: call Use |
47 ret i32 %xor | 48 ret i32 %xor |
48 } | 49 } |
49 | 50 |
50 define i32 @Sub(i32 %a, i32 %b) { | 51 define internal i32 @Sub(i32 %a, i32 %b) { |
51 ; CHECK: define i32 @Sub | 52 ; CHECK: define internal i32 @Sub |
52 entry: | 53 entry: |
53 %sub = sub i32 %a, %b | 54 %sub = sub i32 %a, %b |
54 ; CHECK: sub | 55 ; CHECK: sub |
55 tail call void @Use(i32 %sub) | 56 tail call void @Use(i32 %sub) |
56 ; CHECK: call Use | 57 ; CHECK: call Use |
57 ret i32 %sub | 58 ret i32 %sub |
58 } | 59 } |
59 | 60 |
60 define i32 @Mul(i32 %a, i32 %b) { | 61 define internal i32 @Mul(i32 %a, i32 %b) { |
61 ; CHECK: define i32 @Mul | 62 ; CHECK: define internal i32 @Mul |
62 entry: | 63 entry: |
63 %mul = mul i32 %b, %a | 64 %mul = mul i32 %b, %a |
64 ; CHECK: imul | 65 ; CHECK: imul |
65 tail call void @Use(i32 %mul) | 66 tail call void @Use(i32 %mul) |
66 ; CHECK: call Use | 67 ; CHECK: call Use |
67 ret i32 %mul | 68 ret i32 %mul |
68 } | 69 } |
69 | 70 |
70 define i32 @Sdiv(i32 %a, i32 %b) { | 71 define internal i32 @Sdiv(i32 %a, i32 %b) { |
71 ; CHECK: define i32 @Sdiv | 72 ; CHECK: define internal i32 @Sdiv |
72 entry: | 73 entry: |
73 %div = sdiv i32 %a, %b | 74 %div = sdiv i32 %a, %b |
74 ; CHECK: cdq | 75 ; CHECK: cdq |
75 ; CHECK: idiv | 76 ; CHECK: idiv |
76 tail call void @Use(i32 %div) | 77 tail call void @Use(i32 %div) |
77 ; CHECK: call Use | 78 ; CHECK: call Use |
78 ret i32 %div | 79 ret i32 %div |
79 } | 80 } |
80 | 81 |
81 define i32 @Srem(i32 %a, i32 %b) { | 82 define internal i32 @Srem(i32 %a, i32 %b) { |
82 ; CHECK: define i32 @Srem | 83 ; CHECK: define internal i32 @Srem |
83 entry: | 84 entry: |
84 %rem = srem i32 %a, %b | 85 %rem = srem i32 %a, %b |
85 ; CHECK: cdq | 86 ; CHECK: cdq |
86 ; CHECK: idiv | 87 ; CHECK: idiv |
87 tail call void @Use(i32 %rem) | 88 tail call void @Use(i32 %rem) |
88 ; CHECK: call Use | 89 ; CHECK: call Use |
89 ret i32 %rem | 90 ret i32 %rem |
90 } | 91 } |
91 | 92 |
92 define i32 @Udiv(i32 %a, i32 %b) { | 93 define internal i32 @Udiv(i32 %a, i32 %b) { |
93 ; CHECK: define i32 @Udiv | 94 ; CHECK: define internal i32 @Udiv |
94 entry: | 95 entry: |
95 %div = udiv i32 %a, %b | 96 %div = udiv i32 %a, %b |
96 ; CHECK: div | 97 ; CHECK: div |
97 tail call void @Use(i32 %div) | 98 tail call void @Use(i32 %div) |
98 ; CHECK: call Use | 99 ; CHECK: call Use |
99 ret i32 %div | 100 ret i32 %div |
100 } | 101 } |
101 | 102 |
102 define i32 @Urem(i32 %a, i32 %b) { | 103 define internal i32 @Urem(i32 %a, i32 %b) { |
103 ; CHECK: define i32 @Urem | 104 ; CHECK: define internal i32 @Urem |
104 entry: | 105 entry: |
105 %rem = urem i32 %a, %b | 106 %rem = urem i32 %a, %b |
106 ; CHECK: div | 107 ; CHECK: div |
107 tail call void @Use(i32 %rem) | 108 tail call void @Use(i32 %rem) |
108 ; CHECK: call Use | 109 ; CHECK: call Use |
109 ret i32 %rem | 110 ret i32 %rem |
110 } | 111 } |
111 | 112 |
112 ; Check for a valid addressing mode in the x86-32 mul instruction when | 113 ; Check for a valid addressing mode in the x86-32 mul instruction when |
113 ; the second source operand is an immediate. | 114 ; the second source operand is an immediate. |
114 define i64 @MulImm() { | 115 define internal i64 @MulImm() { |
115 entry: | 116 entry: |
116 %mul = mul i64 3, 4 | 117 %mul = mul i64 3, 4 |
117 ret i64 %mul | 118 ret i64 %mul |
118 } | 119 } |
119 ; CHECK-LABEL: MulImm | 120 ; CHECK-LABEL: MulImm |
120 ; CHECK-NOT: mul {{[0-9]+}} | 121 ; CHECK-NOT: mul {{[0-9]+}} |
OLD | NEW |