From: Dan Gohman Date: Mon, 8 Feb 2010 22:19:11 +0000 (+0000) Subject: ConstantFoldConstantExpression can theoretically return the original X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=54e72eca0c5d012546fcc6d1fdac7ee56c90686c;p=oota-llvm.git ConstantFoldConstantExpression can theoretically return the original expression; don't go into an infinite loop if it does. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@95591 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/lib/CodeGen/AsmPrinter/AsmPrinter.cpp index 5f730e03c6f..2fbd8dc098a 100644 --- a/lib/CodeGen/AsmPrinter/AsmPrinter.cpp +++ b/lib/CodeGen/AsmPrinter/AsmPrinter.cpp @@ -892,8 +892,10 @@ static const MCExpr *LowerConstant(const Constant *CV, AsmPrinter &AP) { // If the code isn't optimized, there may be outstanding folding // opportunities. Attempt to fold the expression using TargetData as a // last resort before giving up. - if (Constant *C = ConstantFoldConstantExpression(CE, AP.TM.getTargetData())) - return LowerConstant(C, AP); + if (Constant *C = + ConstantFoldConstantExpression(CE, AP.TM.getTargetData())) + if (C != CE) + return LowerConstant(C, AP); #ifndef NDEBUG CE->dump(); #endif