[WebAssembly] Enable register coloring and register stackifying.
[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: i64.eq $push[[NUM:[0-9]+]], $0, $1{{$}}
13 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
14 define i32 @eq_i64(i64 %x, i64 %y) {
15   %a = icmp eq i64 %x, %y
16   %b = zext i1 %a to i32
17   ret i32 %b
18 }
19
20 ; CHECK-LABEL: ne_i64:
21 ; CHECK: i64.ne $push[[NUM:[0-9]+]], $0, $1{{$}}
22 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
23 define i32 @ne_i64(i64 %x, i64 %y) {
24   %a = icmp ne i64 %x, %y
25   %b = zext i1 %a to i32
26   ret i32 %b
27 }
28
29 ; CHECK-LABEL: slt_i64:
30 ; CHECK: i64.lt_s $push[[NUM:[0-9]+]], $0, $1{{$}}
31 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
32 define i32 @slt_i64(i64 %x, i64 %y) {
33   %a = icmp slt i64 %x, %y
34   %b = zext i1 %a to i32
35   ret i32 %b
36 }
37
38 ; CHECK-LABEL: sle_i64:
39 ; CHECK: i64.le_s $push[[NUM:[0-9]+]], $0, $1{{$}}
40 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
41 define i32 @sle_i64(i64 %x, i64 %y) {
42   %a = icmp sle i64 %x, %y
43   %b = zext i1 %a to i32
44   ret i32 %b
45 }
46
47 ; CHECK-LABEL: ult_i64:
48 ; CHECK: i64.lt_u $push[[NUM:[0-9]+]], $0, $1{{$}}
49 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
50 define i32 @ult_i64(i64 %x, i64 %y) {
51   %a = icmp ult i64 %x, %y
52   %b = zext i1 %a to i32
53   ret i32 %b
54 }
55
56 ; CHECK-LABEL: ule_i64:
57 ; CHECK: i64.le_u $push[[NUM:[0-9]+]], $0, $1{{$}}
58 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
59 define i32 @ule_i64(i64 %x, i64 %y) {
60   %a = icmp ule i64 %x, %y
61   %b = zext i1 %a to i32
62   ret i32 %b
63 }
64
65 ; CHECK-LABEL: sgt_i64:
66 ; CHECK: i64.gt_s $push[[NUM:[0-9]+]], $0, $1{{$}}
67 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
68 define i32 @sgt_i64(i64 %x, i64 %y) {
69   %a = icmp sgt i64 %x, %y
70   %b = zext i1 %a to i32
71   ret i32 %b
72 }
73
74 ; CHECK-LABEL: sge_i64:
75 ; CHECK: i64.ge_s $push[[NUM:[0-9]+]], $0, $1{{$}}
76 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
77 define i32 @sge_i64(i64 %x, i64 %y) {
78   %a = icmp sge i64 %x, %y
79   %b = zext i1 %a to i32
80   ret i32 %b
81 }
82
83 ; CHECK-LABEL: ugt_i64:
84 ; CHECK: i64.gt_u $push[[NUM:[0-9]+]], $0, $1{{$}}
85 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
86 define i32 @ugt_i64(i64 %x, i64 %y) {
87   %a = icmp ugt i64 %x, %y
88   %b = zext i1 %a to i32
89   ret i32 %b
90 }
91
92 ; CHECK-LABEL: uge_i64:
93 ; CHECK: i64.ge_u $push[[NUM:[0-9]+]], $0, $1{{$}}
94 ; CHECK-NEXT: return $pop[[NUM]]{{$}}
95 define i32 @uge_i64(i64 %x, i64 %y) {
96   %a = icmp uge i64 %x, %y
97   %b = zext i1 %a to i32
98   ret i32 %b
99 }