blob: 317bc0cf1c65174ecbbd29e771748ed2dbc2c7ac [file] [log] [blame]
Dan Gohman1224c382009-07-20 21:19:07 +00001; RUN: llvm-as < %s | llvm-dis | FileCheck %s
2
3@addr = external global i64
4
5define i64 @add_signed(i64 %x, i64 %y) {
6; CHECK: %z = signed add i64 %x, %y
7 %z = signed add i64 %x, %y
8 ret i64 %z
9}
10
11define i64 @sub_signed(i64 %x, i64 %y) {
12; CHECK: %z = signed sub i64 %x, %y
13 %z = signed sub i64 %x, %y
14 ret i64 %z
15}
16
17define i64 @mul_signed(i64 %x, i64 %y) {
18; CHECK: %z = signed mul i64 %x, %y
19 %z = signed mul i64 %x, %y
20 ret i64 %z
21}
22
23define i64 @add_unsigned(i64 %x, i64 %y) {
24; CHECK: %z = unsigned add i64 %x, %y
25 %z = unsigned add i64 %x, %y
26 ret i64 %z
27}
28
29define i64 @sub_unsigned(i64 %x, i64 %y) {
30; CHECK: %z = unsigned sub i64 %x, %y
31 %z = unsigned sub i64 %x, %y
32 ret i64 %z
33}
34
35define i64 @mul_unsigned(i64 %x, i64 %y) {
36; CHECK: %z = unsigned mul i64 %x, %y
37 %z = unsigned mul i64 %x, %y
38 ret i64 %z
39}
40
41define i64 @add_plain(i64 %x, i64 %y) {
42; CHECK: %z = add i64 %x, %y
43 %z = add i64 %x, %y
44 ret i64 %z
45}
46
47define i64 @sub_plain(i64 %x, i64 %y) {
48; CHECK: %z = sub i64 %x, %y
49 %z = sub i64 %x, %y
50 ret i64 %z
51}
52
53define i64 @mul_plain(i64 %x, i64 %y) {
54; CHECK: %z = mul i64 %x, %y
55 %z = mul i64 %x, %y
56 ret i64 %z
57}
58
59define i64 @add_both(i64 %x, i64 %y) {
60; CHECK: %z = unsigned signed add i64 %x, %y
61 %z = unsigned signed add i64 %x, %y
62 ret i64 %z
63}
64
65define i64 @sub_both(i64 %x, i64 %y) {
66; CHECK: %z = unsigned signed sub i64 %x, %y
67 %z = unsigned signed sub i64 %x, %y
68 ret i64 %z
69}
70
71define i64 @mul_both(i64 %x, i64 %y) {
72; CHECK: %z = unsigned signed mul i64 %x, %y
73 %z = unsigned signed mul i64 %x, %y
74 ret i64 %z
75}
76
77define i64 @add_both_reversed(i64 %x, i64 %y) {
78; CHECK: %z = unsigned signed add i64 %x, %y
79 %z = signed unsigned add i64 %x, %y
80 ret i64 %z
81}
82
83define i64 @sub_both_reversed(i64 %x, i64 %y) {
84; CHECK: %z = unsigned signed sub i64 %x, %y
85 %z = signed unsigned sub i64 %x, %y
86 ret i64 %z
87}
88
89define i64 @mul_both_reversed(i64 %x, i64 %y) {
90; CHECK: %z = unsigned signed mul i64 %x, %y
91 %z = signed unsigned mul i64 %x, %y
92 ret i64 %z
93}
94
95define i64 @sdiv_exact(i64 %x, i64 %y) {
96; CHECK: %z = exact sdiv i64 %x, %y
97 %z = exact sdiv i64 %x, %y
98 ret i64 %z
99}
100
101define i64 @sdiv_plain(i64 %x, i64 %y) {
102; CHECK: %z = sdiv i64 %x, %y
103 %z = sdiv i64 %x, %y
104 ret i64 %z
105}
106
107define i64 @add_both_ce() {
108; CHECK: ret i64 unsigned signed add (i64 ptrtoint (i64* @addr to i64), i64 91)
109 ret i64 signed unsigned add (i64 ptrtoint (i64* @addr to i64), i64 91)
110}
111
112define i64 @sub_both_ce() {
113; CHECK: ret i64 unsigned signed sub (i64 ptrtoint (i64* @addr to i64), i64 91)
114 ret i64 signed unsigned sub (i64 ptrtoint (i64* @addr to i64), i64 91)
115}
116
117define i64 @mul_both_ce() {
118; CHECK: ret i64 unsigned signed mul (i64 ptrtoint (i64* @addr to i64), i64 91)
119 ret i64 unsigned signed mul (i64 ptrtoint (i64* @addr to i64), i64 91)
120}
121
122define i64 @sdiv_exact_ce() {
123; CHECK: ret i64 exact sdiv (i64 ptrtoint (i64* @addr to i64), i64 91)
124 ret i64 exact sdiv (i64 ptrtoint (i64* @addr to i64), i64 91)
125}