mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-14 11:32:34 +00:00
Allow targets to have a custom int64->fp expander if desired
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@22001 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
eb99a451e8
commit
a88a260dbd
@ -2176,6 +2176,17 @@ ExpandIntToFP(bool isSigned, MVT::ValueType DestTy, SDOperand Source) {
|
||||
return DAG.getNode(ISD::ADD, DestTy, SignedConv, FudgeInReg);
|
||||
}
|
||||
|
||||
// Check to see if the target has a custom way to lower this. If so, use it.
|
||||
switch (TLI.getOperationAction(ISD::SINT_TO_FP, Source.getValueType())) {
|
||||
default: assert(0 && "This action not implemented for this operation!");
|
||||
case TargetLowering::Legal:
|
||||
case TargetLowering::Expand:
|
||||
break; // This case is handled below.
|
||||
case TargetLowering::Custom:
|
||||
Source = DAG.getNode(ISD::SINT_TO_FP, DestTy, Source);
|
||||
return LegalizeOp(TLI.LowerOperation(Source));
|
||||
}
|
||||
|
||||
// Expand the source, then glue it back together for the call. We must expand
|
||||
// the source in case it is shared (this pass of legalize must traverse it).
|
||||
SDOperand SrcLo, SrcHi;
|
||||
|
Loading…
Reference in New Issue
Block a user