| ; RUN: opt -bool-ret-to-int -S -o - < %s | FileCheck %s |
| |
| target datalayout = "e-m:e-i64:64-n32:64" |
| target triple = "powerpc64le-unknown-linux-gnu" |
| |
| ; CHECK-LABEL: notBoolRet |
| define signext i32 @notBoolRet() { |
| entry: |
| ; CHECK: ret i32 1 |
| ret i32 1 |
| } |
| |
| ; CHECK-LABEL: find |
| define zeroext i1 @find(i8** readonly %begin, i8** readnone %end, i1 (i8*)* nocapture %hasProp) { |
| entry: |
| %cmp.4 = icmp eq i8** %begin, %end |
| br i1 %cmp.4, label %cleanup, label %for.body.preheader |
| |
| for.body.preheader: ; preds = %entry |
| br label %for.body |
| |
| for.cond: ; preds = %for.body |
| %cmp = icmp eq i8** %incdec.ptr, %end |
| br i1 %cmp, label %cleanup.loopexit, label %for.body |
| |
| for.body: ; preds = %for.body.preheader, %for.cond |
| %curr.05 = phi i8** [ %incdec.ptr, %for.cond ], [ %begin, %for.body.preheader ] |
| %0 = load i8*, i8** %curr.05, align 8 |
| %call = tail call zeroext i1 %hasProp(i8* %0) |
| %incdec.ptr = getelementptr inbounds i8*, i8** %curr.05, i64 1 |
| br i1 %call, label %cleanup.loopexit, label %for.cond |
| |
| cleanup.loopexit: ; preds = %for.body, %for.cond |
| ; CHECK: [[PHI:%.+]] = phi i64 [ 1, %for.body ], [ 0, %for.cond ] |
| %cleanup.dest.slot.0.ph = phi i1 [ true, %for.body ], [ false, %for.cond ] |
| br label %cleanup |
| |
| cleanup: ; preds = %cleanup.loopexit, %entry |
| ; CHECK: = phi i64 [ 0, %entry ], [ [[PHI]], %cleanup.loopexit ] |
| %cleanup.dest.slot.0 = phi i1 [ false, %entry ], [ %cleanup.dest.slot.0.ph, %cleanup.loopexit ] |
| ; CHECK: [[REG:%.+]] = trunc i64 {{%.+}} to i1 |
| ; CHECK: ret i1 [[REG]] |
| ret i1 %cleanup.dest.slot.0 |
| } |
| |
| ; CHECK-LABEL: retFalse |
| define zeroext i1 @retFalse() { |
| entry: |
| ; CHECK: ret i1 false |
| ret i1 false |
| } |
| |
| ; CHECK-LABEL: retCvtFalse |
| define zeroext i1 @retCvtFalse() { |
| entry: |
| ; CHECK: ret i1 false |
| ret i1 trunc(i32 0 to i1) |
| } |
| |
| ; CHECK-LABEL: find_cont |
| define void @find_cont(i8** readonly %begin, i8** readnone %end, i1 (i8*)* nocapture %hasProp, void (i1)* nocapture %cont) { |
| entry: |
| %cmp.4 = icmp eq i8** %begin, %end |
| br i1 %cmp.4, label %cleanup, label %for.body.preheader |
| |
| for.body.preheader: ; preds = %entry |
| br label %for.body |
| |
| for.cond: ; preds = %for.body |
| %cmp = icmp eq i8** %incdec.ptr, %end |
| br i1 %cmp, label %cleanup.loopexit, label %for.body |
| |
| for.body: ; preds = %for.body.preheader, %for.cond |
| %curr.05 = phi i8** [ %incdec.ptr, %for.cond ], [ %begin, %for.body.preheader ] |
| %0 = load i8*, i8** %curr.05, align 8 |
| %call = tail call zeroext i1 %hasProp(i8* %0) |
| %incdec.ptr = getelementptr inbounds i8*, i8** %curr.05, i64 1 |
| br i1 %call, label %cleanup.loopexit, label %for.cond |
| |
| cleanup.loopexit: ; preds = %for.body, %for.cond |
| ; CHECK: [[PHI:%.+]] = phi i64 [ 1, %for.body ], [ 0, %for.cond ] |
| %cleanup.dest.slot.0.ph = phi i1 [ true, %for.body ], [ false, %for.cond ] |
| br label %cleanup |
| |
| cleanup: ; preds = %cleanup.loopexit, %entry |
| ; CHECK: = phi i64 [ 0, %entry ], [ [[PHI]], %cleanup.loopexit ] |
| %cleanup.dest.slot.0 = phi i1 [ false, %entry ], [ %cleanup.dest.slot.0.ph, %cleanup.loopexit ] |
| ; CHECK: [[REG:%.+]] = trunc i64 {{%.+}} to i1 |
| ; CHECK: call void %cont(i1 [[REG]] |
| tail call void %cont(i1 %cleanup.dest.slot.0) |
| ret void |
| } |
| |
| ; CHECK-LABEL: find_cont_ret |
| define zeroext i1 @find_cont_ret(i8** readonly %begin, i8** readnone %end, i1 (i8*)* nocapture %hasProp, void (i1)* nocapture %cont) { |
| entry: |
| %cmp.4 = icmp eq i8** %begin, %end |
| br i1 %cmp.4, label %cleanup, label %for.body.preheader |
| |
| for.body.preheader: ; preds = %entry |
| br label %for.body |
| |
| for.cond: ; preds = %for.body |
| %cmp = icmp eq i8** %incdec.ptr, %end |
| br i1 %cmp, label %cleanup.loopexit, label %for.body |
| |
| for.body: ; preds = %for.body.preheader, %for.cond |
| %curr.05 = phi i8** [ %incdec.ptr, %for.cond ], [ %begin, %for.body.preheader ] |
| %0 = load i8*, i8** %curr.05, align 8 |
| %call = tail call zeroext i1 %hasProp(i8* %0) |
| %incdec.ptr = getelementptr inbounds i8*, i8** %curr.05, i64 1 |
| br i1 %call, label %cleanup.loopexit, label %for.cond |
| |
| cleanup.loopexit: ; preds = %for.body, %for.cond |
| ; CHECK: [[PHI:%.+]] = phi i64 [ 1, %for.body ], [ 0, %for.cond ] |
| %cleanup.dest.slot.0.ph = phi i1 [ true, %for.body ], [ false, %for.cond ] |
| br label %cleanup |
| |
| cleanup: ; preds = %cleanup.loopexit, %entry |
| ; CHECK: = phi i64 [ 0, %entry ], [ [[PHI]], %cleanup.loopexit ] |
| %cleanup.dest.slot.0 = phi i1 [ false, %entry ], [ %cleanup.dest.slot.0.ph, %cleanup.loopexit ] |
| ; CHECK: [[REG:%.+]] = trunc i64 {{%.+}} to i1 |
| ; CHECK: call void %cont(i1 [[REG]] |
| tail call void %cont(i1 %cleanup.dest.slot.0) |
| ; CHECK: [[REG:%.+]] = trunc i64 {{%.+}} to i1 |
| ; CHECK: ret i1 [[REG]] |
| ret i1 %cleanup.dest.slot.0 |
| } |
| |
| ; CHECK-LABEL: arg_operand |
| define zeroext i1 @arg_operand(i1 %operand) { |
| entry: |
| br i1 %operand, label %foo, label %cleanup |
| |
| foo: |
| br label %cleanup |
| |
| cleanup: |
| ; CHECK: [[REG:%.+]] = trunc i64 {{%.+}} to i1 |
| ; CHECK: ret i1 [[REG]] |
| %result = phi i1 [ false, %foo ], [ %operand, %entry ] |
| ret i1 %result |
| } |
| |
| ; CHECK-LABEL: bad_use |
| define zeroext i1 @bad_use(i1 %operand) { |
| entry: |
| br i1 %operand, label %foo, label %cleanup |
| |
| foo: |
| br label %cleanup |
| |
| cleanup: |
| ; CHECK: [[REG:%.+]] = phi i1 |
| ; CHECK: ret i1 [[REG]] |
| %result = phi i1 [ false, %foo], [ true, %entry ] |
| %0 = icmp eq i1 %result, %operand |
| ret i1 %result |
| } |
| |
| ; CHECK-LABEL: bad_use_closure |
| define zeroext i1 @bad_use_closure(i1 %operand) { |
| entry: |
| br i1 %operand, label %foo, label %cleanup |
| |
| foo: |
| %bar = phi i1 [ false, %entry ] |
| %0 = icmp eq i1 %bar, %operand |
| br label %cleanup |
| |
| cleanup: |
| ; CHECK: [[REG:%.+]] = phi i1 [ true |
| ; CHECK: ret i1 [[REG]] |
| %result = phi i1 [ true, %entry ], [ %bar, %foo] |
| ret i1 %result |
| } |
| |
| ; CHECK-LABEL: arg_test |
| define zeroext i1 @arg_test(i1 %operand) { |
| entry: |
| br i1 %operand, label %foo, label %cleanup |
| |
| foo: |
| %bar = phi i1 [ false, %entry ] |
| br label %cleanup |
| |
| ; CHECK-LABEL: cleanup |
| cleanup: |
| ; CHECK: [[REG:%.+]] = trunc i64 {{%.+}} to i1 |
| ; CHECK: ret i1 [[REG]] |
| %result = phi i1 [ %bar, %foo], [ %operand, %entry ] |
| ret i1 %result |
| } |
| |
| declare zeroext i1 @return_i1() |
| |
| ; CHECK-LABEL: call_test |
| define zeroext i1 @call_test() { |
| ; CHECK: [[REG:%.+]] = call i1 |
| %result = call i1 @return_i1() |
| ; CHECK: [[REG:%.+]] = zext i1 {{%.+}} to i64 |
| ; CHECK: [[REG:%.+]] = trunc i64 {{%.+}} to i1 |
| ; CHECK: ret i1 [[REG]] |
| ret i1 %result |
| } |