blob: e2bdcad440805243775a39418a4b25d53d0bea9d [file] [log] [blame]
Ulrich Weigand9e3577f2013-05-06 16:17:29 +00001; Test 64-bit comparisons in which the second operand is sign-extended
2; from a PC-relative i32.
3;
4; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s
5
6@g = global i32 1
7
8; Check signed comparison.
9define i64 @f1(i64 %src1) {
10; CHECK: f1:
11; CHECK: cgfrl %r2, g
Richard Sandiford586f4172013-05-21 08:53:17 +000012; CHECK-NEXT: jl
Ulrich Weigand9e3577f2013-05-06 16:17:29 +000013; CHECK: br %r14
14entry:
15 %val = load i32 *@g
16 %src2 = sext i32 %val to i64
17 %cond = icmp slt i64 %src1, %src2
18 br i1 %cond, label %exit, label %mulb
19mulb:
20 %mul = mul i64 %src1, %src1
21 br label %exit
22exit:
23 %res = phi i64 [ %src1, %entry ], [ %mul, %mulb ]
24 ret i64 %res
25}
26
27; Check unsigned comparison, which cannot use CHRL.
28define i64 @f2(i64 %src1) {
29; CHECK: f2:
30; CHECK-NOT: cgfrl
31; CHECK: br %r14
32entry:
33 %val = load i32 *@g
34 %src2 = sext i32 %val to i64
35 %cond = icmp ult i64 %src1, %src2
36 br i1 %cond, label %exit, label %mulb
37mulb:
38 %mul = mul i64 %src1, %src1
39 br label %exit
40exit:
41 %res = phi i64 [ %src1, %entry ], [ %mul, %mulb ]
42 ret i64 %res
43}
44
45; Check equality.
46define i64 @f3(i64 %src1) {
47; CHECK: f3:
48; CHECK: cgfrl %r2, g
Richard Sandiford586f4172013-05-21 08:53:17 +000049; CHECK-NEXT: je
Ulrich Weigand9e3577f2013-05-06 16:17:29 +000050; CHECK: br %r14
51entry:
52 %val = load i32 *@g
53 %src2 = sext i32 %val to i64
54 %cond = icmp eq i64 %src1, %src2
55 br i1 %cond, label %exit, label %mulb
56mulb:
57 %mul = mul i64 %src1, %src1
58 br label %exit
59exit:
60 %res = phi i64 [ %src1, %entry ], [ %mul, %mulb ]
61 ret i64 %res
62}
63
64; Check inequality.
65define i64 @f4(i64 %src1) {
66; CHECK: f4:
67; CHECK: cgfrl %r2, g
Richard Sandiford586f4172013-05-21 08:53:17 +000068; CHECK-NEXT: jlh
Ulrich Weigand9e3577f2013-05-06 16:17:29 +000069; CHECK: br %r14
70entry:
71 %val = load i32 *@g
72 %src2 = sext i32 %val to i64
73 %cond = icmp ne i64 %src1, %src2
74 br i1 %cond, label %exit, label %mulb
75mulb:
76 %mul = mul i64 %src1, %src1
77 br label %exit
78exit:
79 %res = phi i64 [ %src1, %entry ], [ %mul, %mulb ]
80 ret i64 %res
81}