[WebAssembly] Reapply r252858, with svn add for the new file.
[oota-llvm.git] / test / CodeGen / WebAssembly / comparisons_i64.ll
1 ; RUN: llc < %s -asm-verbose=false | FileCheck %s
2
3 ; Test that basic 64-bit integer comparison operations assemble as expected.
4
5 target datalayout = "e-p:32:32-i64:64-n32:64-S128"
6 target triple = "wasm32-unknown-unknown"
7
8 ; CHECK-LABEL: eq_i64:
9 ; CHECK-NEXT: .param i64{{$}}
10 ; CHECK-NEXT: .param i64{{$}}
11 ; CHECK-NEXT: .result i32{{$}}
12 ; CHECK-NEXT: .local i64, i64, i32{{$}}
13 ; CHECK-NEXT: i64.eq $push, (get_local 0), (get_local 1){{$}}
14 ; CHECK-NEXT: set_local 2, $pop{{$}}
15 ; CHECK-NEXT: return (get_local 2){{$}}
16 define i32 @eq_i64(i64 %x, i64 %y) {
17   %a = icmp eq i64 %x, %y
18   %b = zext i1 %a to i32
19   ret i32 %b
20 }
21
22 ; CHECK-LABEL: ne_i64:
23 ; CHECK: i64.ne $push, (get_local 0), (get_local 1){{$}}
24 ; CHECK-NEXT: set_local 2, $pop{{$}}
25 define i32 @ne_i64(i64 %x, i64 %y) {
26   %a = icmp ne i64 %x, %y
27   %b = zext i1 %a to i32
28   ret i32 %b
29 }
30
31 ; CHECK-LABEL: slt_i64:
32 ; CHECK: i64.lt_s $push, (get_local 0), (get_local 1){{$}}
33 ; CHECK-NEXT: set_local 2, $pop{{$}}
34 define i32 @slt_i64(i64 %x, i64 %y) {
35   %a = icmp slt i64 %x, %y
36   %b = zext i1 %a to i32
37   ret i32 %b
38 }
39
40 ; CHECK-LABEL: sle_i64:
41 ; CHECK: i64.le_s $push, (get_local 0), (get_local 1){{$}}
42 ; CHECK-NEXT: set_local 2, $pop{{$}}
43 define i32 @sle_i64(i64 %x, i64 %y) {
44   %a = icmp sle i64 %x, %y
45   %b = zext i1 %a to i32
46   ret i32 %b
47 }
48
49 ; CHECK-LABEL: ult_i64:
50 ; CHECK: i64.lt_u $push, (get_local 0), (get_local 1){{$}}
51 ; CHECK-NEXT: set_local 2, $pop{{$}}
52 define i32 @ult_i64(i64 %x, i64 %y) {
53   %a = icmp ult i64 %x, %y
54   %b = zext i1 %a to i32
55   ret i32 %b
56 }
57
58 ; CHECK-LABEL: ule_i64:
59 ; CHECK: i64.le_u $push, (get_local 0), (get_local 1){{$}}
60 ; CHECK-NEXT: set_local 2, $pop{{$}}
61 define i32 @ule_i64(i64 %x, i64 %y) {
62   %a = icmp ule i64 %x, %y
63   %b = zext i1 %a to i32
64   ret i32 %b
65 }
66
67 ; CHECK-LABEL: sgt_i64:
68 ; CHECK: i64.gt_s $push, (get_local 0), (get_local 1){{$}}
69 ; CHECK-NEXT: set_local 2, $pop{{$}}
70 define i32 @sgt_i64(i64 %x, i64 %y) {
71   %a = icmp sgt i64 %x, %y
72   %b = zext i1 %a to i32
73   ret i32 %b
74 }
75
76 ; CHECK-LABEL: sge_i64:
77 ; CHECK: i64.ge_s $push, (get_local 0), (get_local 1){{$}}
78 ; CHECK-NEXT: set_local 2, $pop{{$}}
79 define i32 @sge_i64(i64 %x, i64 %y) {
80   %a = icmp sge i64 %x, %y
81   %b = zext i1 %a to i32
82   ret i32 %b
83 }
84
85 ; CHECK-LABEL: ugt_i64:
86 ; CHECK: i64.gt_u $push, (get_local 0), (get_local 1){{$}}
87 ; CHECK-NEXT: set_local 2, $pop{{$}}
88 define i32 @ugt_i64(i64 %x, i64 %y) {
89   %a = icmp ugt i64 %x, %y
90   %b = zext i1 %a to i32
91   ret i32 %b
92 }
93
94 ; CHECK-LABEL: uge_i64:
95 ; CHECK: i64.ge_u $push, (get_local 0), (get_local 1){{$}}
96 ; CHECK-NEXT: set_local 2, $pop{{$}}
97 define i32 @uge_i64(i64 %x, i64 %y) {
98   %a = icmp uge i64 %x, %y
99   %b = zext i1 %a to i32
100   ret i32 %b
101 }