[InstCombine] Signed saturation patterns
[llvm-complete.git] / test / CodeGen / SystemZ / cond-move-07.ll
blob2bee8919b519878b0aeef185bd973b0decaf2d10
1 ; Test SELFHR.
2 ; See comments in asm-18.ll about testing high-word operations.
4 ; RUN: llc < %s -verify-machineinstrs -mtriple=s390x-linux-gnu -mcpu=z15 \
5 ; RUN:   -no-integrated-as | FileCheck %s
7 define void @f1(i32 %limit) {
8 ; CHECK-LABEL: f1:
9 ; CHECK-DAG: stepa [[REG1:%r[0-5]]]
10 ; CHECK-DAG: stepb [[REG2:%r[0-5]]]
11 ; CHECK-DAG: clfi %r2, 42
12 ; CHECK: selfhrl [[REG3:%r[0-5]]], [[REG1]], [[REG2]]
13 ; CHECK: stepc [[REG3]]
14 ; CHECK: br %r14
15   %a = call i32 asm sideeffect "stepa $0", "=h"()
16   %b = call i32 asm sideeffect "stepb $0", "=h"()
17   %cond = icmp ult i32 %limit, 42
18   %res = select i1 %cond, i32 %a, i32 %b
19   call void asm sideeffect "stepc $0", "h"(i32 %res)
20   call void asm sideeffect "use $0", "h"(i32 %a)
21   call void asm sideeffect "use $0", "h"(i32 %b)
22   ret void
25 ; Check that we also get SELFHR as a result of early if-conversion.
26 define void @f2(i32 %limit) {
27 ; CHECK-LABEL: f2:
28 ; CHECK-DAG: stepa [[REG1:%r[0-5]]]
29 ; CHECK-DAG: stepb [[REG2:%r[0-5]]]
30 ; CHECK-DAG: clfi %r2, 41
31 ; CHECK: selfhrh [[REG3:%r[0-5]]], [[REG2]], [[REG1]]
32 ; CHECK: stepc [[REG3]]
33 ; CHECK: br %r14
34 entry:
35   %a = call i32 asm sideeffect "stepa $0", "=h"()
36   %b = call i32 asm sideeffect "stepb $0", "=h"()
37   %cond = icmp ult i32 %limit, 42
38   br i1 %cond, label %if.then, label %return
40 if.then:
41   br label %return
43 return:
44   %res = phi i32 [ %a, %if.then ], [ %b, %entry ]
45   call void asm sideeffect "stepc $0", "h"(i32 %res)
46   call void asm sideeffect "use $0", "h"(i32 %a)
47   call void asm sideeffect "use $0", "h"(i32 %b)
48   ret void
51 ; Check that inverting the condition works as well.
52 define void @f3(i32 %limit) {
53 ; CHECK-LABEL: f3:
54 ; CHECK-DAG: stepa [[REG1:%r[0-5]]]
55 ; CHECK-DAG: stepb [[REG2:%r[0-5]]]
56 ; CHECK-DAG: clfi %r2, 41
57 ; CHECK: selfhrh [[REG3:%r[0-5]]], [[REG1]], [[REG2]]
58 ; CHECK: stepc [[REG3]]
59 ; CHECK: br %r14
60 entry:
61   %a = call i32 asm sideeffect "stepa $0", "=h"()
62   %b = call i32 asm sideeffect "stepb $0", "=h"()
63   %cond = icmp ult i32 %limit, 42
64   br i1 %cond, label %if.then, label %return
66 if.then:
67   br label %return
69 return:
70   %res = phi i32 [ %b, %if.then ], [ %a, %entry ]
71   call void asm sideeffect "stepc $0", "h"(i32 %res)
72   call void asm sideeffect "use $0", "h"(i32 %a)
73   call void asm sideeffect "use $0", "h"(i32 %b)
74   ret void