mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-29 06:30:39 +00:00
f698d7775a
On cores without fpcvt support, we cannot promote int_to_fp i1 operations, because there is nothing to promote them to. The most straightforward implementation of this uses a select to choose between the two possible resulting floating-point values (and that's what is done here). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@203015 91177308-0d34-0410-b5e6-96231b3b80d8
22 lines
473 B
LLVM
22 lines
473 B
LLVM
; RUN: llc -march=ppc32 -mcpu=ppc32 -mtriple=powerpc-unknown-linux-gnu < %s | FileCheck %s
|
|
define double @test(i1 %X) {
|
|
%Y = uitofp i1 %X to double
|
|
ret double %Y
|
|
}
|
|
|
|
; CHECK-LABEL: @test
|
|
|
|
; CHECK: andi. {{[0-9]+}}, 3, 1
|
|
; CHECK: bc 12, 1,
|
|
|
|
; CHECK: li 3, .LCP[[L1:[A-Z0-9_]+]]@l
|
|
; CHECK: addis 3, 3, .LCP[[L1]]@ha
|
|
; CHECK: lfs 1, 0(3)
|
|
; CHECK: blr
|
|
|
|
; CHECK: li 3, .LCP[[L2:[A-Z0-9_]+]]@l
|
|
; CHECK: addis 3, 3, .LCP[[L2]]@ha
|
|
; CHECK: lfs 1, 0(3)
|
|
; CHECK: blr
|
|
|