]> granicus.if.org Git - llvm/commitdiff
Add InstCombine::visitFNeg(...)
authorCameron McInally <cameron.mcinally@nyu.edu>
Fri, 10 May 2019 20:01:04 +0000 (20:01 +0000)
committerCameron McInally <cameron.mcinally@nyu.edu>
Fri, 10 May 2019 20:01:04 +0000 (20:01 +0000)
Differential Revision: https://reviews.llvm.org/D61784

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@360461 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/InstCombine/InstCombineAddSub.cpp
lib/Transforms/InstCombine/InstCombineInternal.h
test/Transforms/InstCombine/fneg.ll

index a2313809d28cf3d8db7882c4af45605c56d66dc5..5f5a94e4b256b6b030066c65c4fc61849295dda5 100644 (file)
@@ -1821,6 +1821,15 @@ Instruction *InstCombiner::visitSub(BinaryOperator &I) {
   return Changed ? &I : nullptr;
 }
 
+Instruction *InstCombiner::visitFNeg(UnaryOperator &I) {
+  if (Value *V = SimplifyFNegInst(I.getOperand(0), I.getFastMathFlags(),
+                                  SQ.getWithInstruction(&I)))
+    return replaceInstUsesWith(I, V);
+
+  return nullptr;
+}
+
+
 Instruction *InstCombiner::visitFSub(BinaryOperator &I) {
   if (Value *V = SimplifyFSubInst(I.getOperand(0), I.getOperand(1),
                                   I.getFastMathFlags(),
index 27b8ea81ec0962dafa2aa99afffdd3b617bc3266..c34a71a2251b1e921b8f5b7262f027950bc26dcc 100644 (file)
@@ -347,6 +347,7 @@ public:
   //     I          - Change was made, I is still valid, I may be dead though
   //   otherwise    - Change was made, replace I with returned instruction
   //
+  Instruction *visitFNeg(UnaryOperator &I);
   Instruction *visitAdd(BinaryOperator &I);
   Instruction *visitFAdd(BinaryOperator &I);
   Value *OptimizePointerDifference(Value *LHS, Value *RHS, Type *Ty);
index 6c1fb119d7882a5c3e165c12649fa8be2898e4f8..2fdb1947912e2359ffa7b275672947c80d9ddf79 100644 (file)
@@ -6,9 +6,7 @@ declare void @use(float)
 define float @fneg_fneg(float %a) {
 ;
 ; CHECK-LABEL: @fneg_fneg(
-; CHECK-NEXT:    [[F:%.*]] = fneg float [[A:%.*]]
-; CHECK-NEXT:    [[R:%.*]] = fneg float [[F]]
-; CHECK-NEXT:    ret float [[R]]
+; CHECK-NEXT:    ret float [[A:%.*]]
 ;
   %f = fneg float %a
   %r = fneg float %f