1 ; Test 32-bit comparisons in which the second operand is zero-extended 2 ; from a PC-relative i16. 3 ; 4 ; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s 5 6 @g = global i16 1 7 @h = global i16 1, align 1, section "foo" 8 9 ; Check unsigned comparison. 10 define i32 @f1(i32 %src1) { 11 ; CHECK-LABEL: f1: 12 ; CHECK: clhrl %r2, g 13 ; CHECK-NEXT: jl 14 ; CHECK: br %r14 15 entry: 16 %val = load i16 *@g 17 %src2 = zext i16 %val to i32 18 %cond = icmp ult i32 %src1, %src2 19 br i1 %cond, label %exit, label %mulb 20 mulb: 21 %mul = mul i32 %src1, %src1 22 br label %exit 23 exit: 24 %res = phi i32 [ %src1, %entry ], [ %mul, %mulb ] 25 ret i32 %res 26 } 27 28 ; Check signed comparison. 29 define i32 @f2(i32 %src1) { 30 ; CHECK-LABEL: f2: 31 ; CHECK-NOT: clhrl 32 ; CHECK: br %r14 33 entry: 34 %val = load i16 *@g 35 %src2 = zext i16 %val to i32 36 %cond = icmp slt i32 %src1, %src2 37 br i1 %cond, label %exit, label %mulb 38 mulb: 39 %mul = mul i32 %src1, %src1 40 br label %exit 41 exit: 42 %res = phi i32 [ %src1, %entry ], [ %mul, %mulb ] 43 ret i32 %res 44 } 45 46 ; Check equality. 47 define i32 @f3(i32 %src1) { 48 ; CHECK-LABEL: f3: 49 ; CHECK: clhrl %r2, g 50 ; CHECK-NEXT: je 51 ; CHECK: br %r14 52 entry: 53 %val = load i16 *@g 54 %src2 = zext i16 %val to i32 55 %cond = icmp eq i32 %src1, %src2 56 br i1 %cond, label %exit, label %mulb 57 mulb: 58 %mul = mul i32 %src1, %src1 59 br label %exit 60 exit: 61 %res = phi i32 [ %src1, %entry ], [ %mul, %mulb ] 62 ret i32 %res 63 } 64 65 ; Check inequality. 66 define i32 @f4(i32 %src1) { 67 ; CHECK-LABEL: f4: 68 ; CHECK: clhrl %r2, g 69 ; CHECK-NEXT: jlh 70 ; CHECK: br %r14 71 entry: 72 %val = load i16 *@g 73 %src2 = zext i16 %val to i32 74 %cond = icmp ne i32 %src1, %src2 75 br i1 %cond, label %exit, label %mulb 76 mulb: 77 %mul = mul i32 %src1, %src1 78 br label %exit 79 exit: 80 %res = phi i32 [ %src1, %entry ], [ %mul, %mulb ] 81 ret i32 %res 82 } 83 84 ; Repeat f1 with an unaligned address. 85 define i32 @f5(i32 %src1) { 86 ; CHECK-LABEL: f5: 87 ; CHECK: lgrl [[REG:%r[0-5]]], h@GOT 88 ; CHECK: llh [[VAL:%r[0-5]]], 0([[REG]]) 89 ; CHECK: clrjl %r2, [[VAL]], 90 ; CHECK: br %r14 91 entry: 92 %val = load i16 *@h, align 1 93 %src2 = zext i16 %val to i32 94 %cond = icmp ult i32 %src1, %src2 95 br i1 %cond, label %exit, label %mulb 96 mulb: 97 %mul = mul i32 %src1, %src1 98 br label %exit 99 exit: 100 %res = phi i32 [ %src1, %entry ], [ %mul, %mulb ] 101 ret i32 %res 102 } 103 104 ; Check the comparison can be reversed if that allows CLHRL to be used. 105 define i32 @f6(i32 %src2) { 106 ; CHECK-LABEL: f6: 107 ; CHECK: clhrl %r2, g 108 ; CHECK-NEXT: jh {{\.L.*}} 109 ; CHECK: br %r14 110 entry: 111 %val = load i16 *@g 112 %src1 = zext i16 %val to i32 113 %cond = icmp ult i32 %src1, %src2 114 br i1 %cond, label %exit, label %mulb 115 mulb: 116 %mul = mul i32 %src2, %src2 117 br label %exit 118 exit: 119 %res = phi i32 [ %src2, %entry ], [ %mul, %mulb ] 120 ret i32 %res 121 } 122