mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-07 11:51:13 +00:00
dacd0807cc
In PPCBoolRetToInt bool value is changed to i32 type. On ppc64 it may introduce an extra zero extension for the return value. This patch changes the integer type to i64 to avoid the zero extension on ppc64. This patch fixed PR32442. Differential Revision: https://reviews.llvm.org/D31407 llvm-svn: 305001
206 lines
6.6 KiB
LLVM
206 lines
6.6 KiB
LLVM
; 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
|
|
}
|