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"
8 ; CHECK-LABEL: (func $eq_i64
9 ; CHECK-NEXT: (param i64) (param i64) (result i32)
10 ; CHECK-NEXT: (setlocal @0 (argument 1))
11 ; CHECK-NEXT: (setlocal @1 (argument 0))
12 ; CHECK-NEXT: (setlocal @2 (eq @1 @0))
13 ; CHECK-NEXT: (return @2)
14 define i32 @eq_i64(i64 %x, i64 %y) {
15 %a = icmp eq i64 %x, %y
16 %b = zext i1 %a to i32
20 ; CHECK-LABEL: (func $ne_i64
21 ; CHECK: (setlocal @2 (ne @1 @0))
22 define i32 @ne_i64(i64 %x, i64 %y) {
23 %a = icmp ne i64 %x, %y
24 %b = zext i1 %a to i32
28 ; CHECK-LABEL: (func $slt_i64
29 ; CHECK: (setlocal @2 (slt @1 @0))
30 define i32 @slt_i64(i64 %x, i64 %y) {
31 %a = icmp slt i64 %x, %y
32 %b = zext i1 %a to i32
36 ; CHECK-LABEL: (func $sle_i64
37 ; CHECK: (setlocal @2 (sle @1 @0))
38 define i32 @sle_i64(i64 %x, i64 %y) {
39 %a = icmp sle i64 %x, %y
40 %b = zext i1 %a to i32
44 ; CHECK-LABEL: (func $ult_i64
45 ; CHECK: (setlocal @2 (ult @1 @0))
46 define i32 @ult_i64(i64 %x, i64 %y) {
47 %a = icmp ult i64 %x, %y
48 %b = zext i1 %a to i32
52 ; CHECK-LABEL: (func $ule_i64
53 ; CHECK: (setlocal @2 (ule @1 @0))
54 define i32 @ule_i64(i64 %x, i64 %y) {
55 %a = icmp ule i64 %x, %y
56 %b = zext i1 %a to i32
60 ; CHECK-LABEL: (func $sgt_i64
61 ; CHECK: (setlocal @2 (sgt @1 @0))
62 define i32 @sgt_i64(i64 %x, i64 %y) {
63 %a = icmp sgt i64 %x, %y
64 %b = zext i1 %a to i32
68 ; CHECK-LABEL: (func $sge_i64
69 ; CHECK: (setlocal @2 (sge @1 @0))
70 define i32 @sge_i64(i64 %x, i64 %y) {
71 %a = icmp sge i64 %x, %y
72 %b = zext i1 %a to i32
76 ; CHECK-LABEL: (func $ugt_i64
77 ; CHECK: (setlocal @2 (ugt @1 @0))
78 define i32 @ugt_i64(i64 %x, i64 %y) {
79 %a = icmp ugt i64 %x, %y
80 %b = zext i1 %a to i32
84 ; CHECK-LABEL: (func $uge_i64
85 ; CHECK: (setlocal @2 (uge @1 @0))
86 define i32 @uge_i64(i64 %x, i64 %y) {
87 %a = icmp uge i64 %x, %y
88 %b = zext i1 %a to i32