1 ; RUN: llc < %s -asm-verbose=false | FileCheck %s
3 ; Test that basic 64-bit integer comparison operations assemble as expected.
5 target datalayout = "e-p:32:32-i64:64-n32:64-S128"
6 target triple = "wasm32-unknown-unknown"
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
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
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
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
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
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
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
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
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
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