diff options
author | Chris Lattner <sabre@nondot.org> | 2006-07-07 21:37:01 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2006-07-07 21:37:01 +0000 |
commit | 7cd580f0b7cf5f49ccd75bb747d6627292c8fe73 (patch) | |
tree | ffb13a15a53b7085b30794521729a1434c666385 /lib/Transforms | |
parent | e89121be21953f98726620af13f2904647a25c83 (diff) |
Fix PR820 and Transforms/GlobalOpt/2006-07-07-InlineAsmCrash.ll
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@29071 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms')
-rw-r--r-- | lib/Transforms/IPO/GlobalOpt.cpp | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/lib/Transforms/IPO/GlobalOpt.cpp b/lib/Transforms/IPO/GlobalOpt.cpp index 7c212e7b7a..0521779731 100644 --- a/lib/Transforms/IPO/GlobalOpt.cpp +++ b/lib/Transforms/IPO/GlobalOpt.cpp @@ -1450,6 +1450,9 @@ static bool EvaluateFunction(Function *F, Constant *&RetVal, AI->getName())); InstResult = AllocaTmps.back(); } else if (CallInst *CI = dyn_cast<CallInst>(CurInst)) { + // Cannot handle inline asm. + if (isa<InlineAsm>(CI->getOperand(0))) return false; + // Resolve function pointers. Function *Callee = dyn_cast<Function>(getVal(Values, CI->getOperand(0))); if (!Callee) return false; // Cannot resolve. |