mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-10 14:10:58 +00:00
Disable shrinking of SNaN constants
When expanding FP constants, we attempt to shrink doubles to floats and perform an extending load. However, on SystemZ, and possibly on other targets (I've only confirmed the problem on SystemZ), the FP extending load instruction may convert SNaN into QNaN, or may cause an exception. So in the general case, we would still like to shrink FP constants, but SNaNs should be left as doubles. Differential Revision: https://reviews.llvm.org/D22685 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@277602 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c3332e48f0
commit
305565bab3
@ -259,19 +259,25 @@ SelectionDAGLegalize::ExpandConstantFP(ConstantFPSDNode *CFP, bool UseCP) {
|
||||
(VT == MVT::f64) ? MVT::i64 : MVT::i32);
|
||||
}
|
||||
|
||||
APFloat APF = CFP->getValueAPF();
|
||||
EVT OrigVT = VT;
|
||||
EVT SVT = VT;
|
||||
while (SVT != MVT::f32 && SVT != MVT::f16) {
|
||||
SVT = (MVT::SimpleValueType)(SVT.getSimpleVT().SimpleTy - 1);
|
||||
if (ConstantFPSDNode::isValueValidForType(SVT, CFP->getValueAPF()) &&
|
||||
// Only do this if the target has a native EXTLOAD instruction from
|
||||
// smaller type.
|
||||
TLI.isLoadExtLegal(ISD::EXTLOAD, OrigVT, SVT) &&
|
||||
TLI.ShouldShrinkFPConstant(OrigVT)) {
|
||||
Type *SType = SVT.getTypeForEVT(*DAG.getContext());
|
||||
LLVMC = cast<ConstantFP>(ConstantExpr::getFPTrunc(LLVMC, SType));
|
||||
VT = SVT;
|
||||
Extend = true;
|
||||
|
||||
// We don't want to shrink SNaNs. Converting the SNaN back to its real type
|
||||
// can cause it to be changed into a QNaN on some platforms (e.g. on SystemZ).
|
||||
if (!APF.isSignaling()) {
|
||||
while (SVT != MVT::f32 && SVT != MVT::f16) {
|
||||
SVT = (MVT::SimpleValueType)(SVT.getSimpleVT().SimpleTy - 1);
|
||||
if (ConstantFPSDNode::isValueValidForType(SVT, APF) &&
|
||||
// Only do this if the target has a native EXTLOAD instruction from
|
||||
// smaller type.
|
||||
TLI.isLoadExtLegal(ISD::EXTLOAD, OrigVT, SVT) &&
|
||||
TLI.ShouldShrinkFPConstant(OrigVT)) {
|
||||
Type *SType = SVT.getTypeForEVT(*DAG.getContext());
|
||||
LLVMC = cast<ConstantFP>(ConstantExpr::getFPTrunc(LLVMC, SType));
|
||||
VT = SVT;
|
||||
Extend = true;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
15
test/CodeGen/SystemZ/fp-const-10.ll
Normal file
15
test/CodeGen/SystemZ/fp-const-10.ll
Normal file
@ -0,0 +1,15 @@
|
||||
; Test loads of SNaN.
|
||||
;
|
||||
; RUN: llc < %s -mtriple=s390x-linux-gnu | FileCheck %s
|
||||
|
||||
; Test that we don't do an FP extending load, as this would result in a
|
||||
; converstion to QNaN.
|
||||
define double @f1() {
|
||||
; CHECK-LABEL: .LCPI0_0
|
||||
; CHECK: .quad 9219994337134247936
|
||||
; CHECK-LABEL: f1:
|
||||
; CHECK: larl %r1, .LCPI0_0
|
||||
; CHECK-NOT: ldeb %f0, 0(%r1)
|
||||
; CHECK: ld %f0, 0(%r1)
|
||||
ret double 0x7FF4000000000000
|
||||
}
|
Loading…
Reference in New Issue
Block a user