mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-11-01 15:11:24 +00:00
If unsafe FP optimization is not set, don't allow -(A-B) => B-A because
when A==B, -0.0 != +0.0. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@63474 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
9729c5ad34
commit
a7b6cff99f
@ -2357,7 +2357,8 @@ SDValue SelectionDAG::getNode(unsigned Opcode, DebugLoc DL,
|
|||||||
return Operand.getOperand(0);
|
return Operand.getOperand(0);
|
||||||
break;
|
break;
|
||||||
case ISD::FNEG:
|
case ISD::FNEG:
|
||||||
if (OpOpcode == ISD::FSUB) // -(X-Y) -> (Y-X)
|
// -(X-Y) -> (Y-X) is unsafe because when X==Y, -0.0 != +0.0
|
||||||
|
if (UnsafeFPMath && OpOpcode == ISD::FSUB)
|
||||||
return getNode(ISD::FSUB, VT, Operand.getNode()->getOperand(1),
|
return getNode(ISD::FSUB, VT, Operand.getNode()->getOperand(1),
|
||||||
Operand.getNode()->getOperand(0));
|
Operand.getNode()->getOperand(0));
|
||||||
if (OpOpcode == ISD::FNEG) // --X -> X
|
if (OpOpcode == ISD::FNEG) // --X -> X
|
||||||
|
12
test/CodeGen/X86/neg_fp.ll
Normal file
12
test/CodeGen/X86/neg_fp.ll
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
; RUN: llvm-as < %s | llc -march=x86 -mattr=+sse41 -o %t -f
|
||||||
|
; RUN: grep xorps %t | count 1
|
||||||
|
|
||||||
|
; Test that when we don't -enable-unsafe-fp-math, we don't do the optimization
|
||||||
|
; -0 - (A - B) to (B - A) because A==B, -0 != 0
|
||||||
|
|
||||||
|
define float @negfp(float %a, float %b) {
|
||||||
|
entry:
|
||||||
|
%sub = sub float %a, %b ; <float> [#uses=1]
|
||||||
|
%neg = sub float -0.000000e+00, %sub ; <float> [#uses=1]
|
||||||
|
ret float %neg
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user