[llvm-commits] [dragonegg] r94913 - /dragonegg/trunk/llvm-convert.cpp

Duncan Sands baldrick at free.fr
Sat Jan 30 10:21:56 PST 2010


Author: baldrick
Date: Sat Jan 30 12:21:55 2010
New Revision: 94913

URL: http://llvm.org/viewvc/llvm-project?rev=94913&view=rev
Log:
Port commit 94876 (baldrick) from llvm-gcc:
GCC has a macro, TYPE_OVERFLOW_WRAPS, which checks flag_wrapv and whether
the type is signed or unsigned, like we do explicitly now.  Use the macro.

Modified:
    dragonegg/trunk/llvm-convert.cpp

Modified: dragonegg/trunk/llvm-convert.cpp
URL: http://llvm.org/viewvc/llvm-project/dragonegg/trunk/llvm-convert.cpp?rev=94913&r1=94912&r2=94913&view=diff

==============================================================================
--- dragonegg/trunk/llvm-convert.cpp (original)
+++ dragonegg/trunk/llvm-convert.cpp Sat Jan 30 12:21:55 2010
@@ -5978,7 +5978,7 @@
   if (TREE_CODE(TREE_TYPE(op)) != COMPLEX_TYPE) {
     if (V->getType()->isFPOrFPVector())
       return Builder.CreateFNeg(V);
-    bool HasNSW = !TYPE_UNSIGNED(TREE_TYPE(op)) && !flag_wrapv;
+    bool HasNSW = !TYPE_OVERFLOW_WRAPS(TREE_TYPE(op));
     return HasNSW ? Builder.CreateNSWNeg(V) : Builder.CreateNeg(V);
   }
 
@@ -6135,11 +6135,11 @@
   Value *V;
   if (Opc == Instruction::SDiv && IsExactDiv)
     V = Builder.CreateExactSDiv(LHS, RHS);
-  else if (Opc == Instruction::Add && TyIsSigned && !flag_wrapv)
+  else if (Opc == Instruction::Add && !TYPE_OVERFLOW_WRAPS(type))
     V = Builder.CreateNSWAdd(LHS, RHS);
-  else if (Opc == Instruction::Sub && TyIsSigned && !flag_wrapv)
+  else if (Opc == Instruction::Sub && !TYPE_OVERFLOW_WRAPS(type))
     V = Builder.CreateNSWSub(LHS, RHS);
-  else if (Opc == Instruction::Mul && TyIsSigned && !flag_wrapv)
+  else if (Opc == Instruction::Mul && !TYPE_OVERFLOW_WRAPS(type))
     V = Builder.CreateNSWMul(LHS, RHS);
   else
     V = Builder.CreateBinOp((Instruction::BinaryOps)Opc, LHS, RHS);





More information about the llvm-commits mailing list