mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-04 14:22:26 +00:00
Add a target lowering hook to control whether it's worthwhile to compress fp constant.
For x86, if sse2 is available, it's not a good idea since cvtss2sd is slower than a movsd load and it prevents load folding. On x87, it's important to shrink fp constant since fldt is very expensive. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@47931 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
d19189e990
commit
6fd599fa69
@ -467,6 +467,11 @@ public:
|
|||||||
assert(0 && "Unsupported extended type!");
|
assert(0 && "Unsupported extended type!");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// ShouldShrinkFPConstant - If true, then instruction selection should
|
||||||
|
/// seek to shrink the FP constant of the specified type to a smaller type
|
||||||
|
/// in order to save space and / or reduce runtime.
|
||||||
|
virtual bool ShouldShrinkFPConstant(MVT::ValueType VT) const { return true; }
|
||||||
|
|
||||||
/// hasTargetDAGCombine - If true, the target has custom DAG combine
|
/// hasTargetDAGCombine - If true, the target has custom DAG combine
|
||||||
/// transformations that it can perform for the specified node.
|
/// transformations that it can perform for the specified node.
|
||||||
bool hasTargetDAGCombine(ISD::NodeType NT) const {
|
bool hasTargetDAGCombine(ISD::NodeType NT) const {
|
||||||
|
@ -504,7 +504,8 @@ static SDOperand ExpandConstantFP(ConstantFPSDNode *CFP, bool UseCP,
|
|||||||
if (CFP->isValueValidForType(SVT, CFP->getValueAPF()) &&
|
if (CFP->isValueValidForType(SVT, CFP->getValueAPF()) &&
|
||||||
// Only do this if the target has a native EXTLOAD instruction from
|
// Only do this if the target has a native EXTLOAD instruction from
|
||||||
// smaller type.
|
// smaller type.
|
||||||
TLI.isLoadXLegal(ISD::EXTLOAD, SVT)) {
|
TLI.isLoadXLegal(ISD::EXTLOAD, SVT) &&
|
||||||
|
TLI.ShouldShrinkFPConstant(VT)) {
|
||||||
const Type *SType = MVT::getTypeForValueType(SVT);
|
const Type *SType = MVT::getTypeForValueType(SVT);
|
||||||
LLVMC = cast<ConstantFP>(ConstantExpr::getFPTrunc(LLVMC, SType));
|
LLVMC = cast<ConstantFP>(ConstantExpr::getFPTrunc(LLVMC, SType));
|
||||||
VT = SVT;
|
VT = SVT;
|
||||||
|
@ -434,6 +434,16 @@ namespace llvm {
|
|||||||
virtual bool isVectorClearMaskLegal(std::vector<SDOperand> &BVOps,
|
virtual bool isVectorClearMaskLegal(std::vector<SDOperand> &BVOps,
|
||||||
MVT::ValueType EVT,
|
MVT::ValueType EVT,
|
||||||
SelectionDAG &DAG) const;
|
SelectionDAG &DAG) const;
|
||||||
|
|
||||||
|
/// ShouldShrinkFPConstant - If true, then instruction selection should
|
||||||
|
/// seek to shrink the FP constant of the specified type to a smaller type
|
||||||
|
/// in order to save space and / or reduce runtime.
|
||||||
|
virtual bool ShouldShrinkFPConstant(MVT::ValueType VT) const {
|
||||||
|
// Don't shrink FP constpool if SSE2 is available since cvtss2sd is more
|
||||||
|
// expensive than a straight movsd. On the other hand, it's important to
|
||||||
|
// shrink long double fp constant since fldt is very slow.
|
||||||
|
return !X86ScalarSSEf64 || VT == MVT::f80;
|
||||||
|
}
|
||||||
|
|
||||||
/// IsEligibleForTailCallOptimization - Check whether the call is eligible
|
/// IsEligibleForTailCallOptimization - Check whether the call is eligible
|
||||||
/// for tail call optimization. Target which want to do tail call
|
/// for tail call optimization. Target which want to do tail call
|
||||||
|
7
test/CodeGen/X86/shrink-fp-const1.ll
Normal file
7
test/CodeGen/X86/shrink-fp-const1.ll
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
; RUN: llvm-as < %s | llc -march=x86-64 -mattr=+sse2 | not grep cvtss2sd
|
||||||
|
; PR1264
|
||||||
|
|
||||||
|
define double @foo(double %x) {
|
||||||
|
%y = mul double %x, 5.000000e-01
|
||||||
|
ret double %y
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user