mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-12 07:21:56 +00:00
[Sparc] Respect hasHardQuad parameter correctly when lowering SINT_TO_FP with fp128 operand.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@192015 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
eee74fbbb6
commit
b648122c5f
@ -2046,7 +2046,7 @@ static SDValue LowerSINT_TO_FP(SDValue Op, SelectionDAG &DAG,
|
||||
assert(Op.getOperand(0).getValueType() == MVT::i32);
|
||||
SDValue Tmp = DAG.getNode(ISD::BITCAST, dl, MVT::f32, Op.getOperand(0));
|
||||
// Convert the int value to FP in an FP register.
|
||||
if (Op.getValueType() == MVT::f128 && hasHardQuad)
|
||||
if (Op.getValueType() == MVT::f128 && !hasHardQuad)
|
||||
return TLI.LowerF128Op(Op, DAG,
|
||||
TLI.getLibcallName(RTLIB::SINTTOFP_I32_F128), 1);
|
||||
return DAG.getNode(SPISD::ITOF, dl, Op.getValueType(), Tmp);
|
||||
|
@ -113,3 +113,16 @@ entry:
|
||||
}
|
||||
|
||||
declare fp128 @llvm.fabs.f128(fp128) nounwind readonly
|
||||
|
||||
; HARD-LABEL: int_to_f128
|
||||
; HARD: fitoq
|
||||
|
||||
; SOFT-LABEL: int_to_f128
|
||||
; SOFT: _Q_itoq
|
||||
|
||||
define void @int_to_f128(fp128* noalias sret %scalar.result, i32 %i) {
|
||||
entry:
|
||||
%0 = sitofp i32 %i to fp128
|
||||
store fp128 %0, fp128* %scalar.result, align 8
|
||||
ret void
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user