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 | fd2e13b107fb912fa15ff2226c45b766b1d83281 (patch) | |
tree | 6a43c07fbd8d236b795d67e6edcddea8d765cae8 /llvm/lib/Transforms | |
parent | c20367a5483eef7a0b1cbc036dfaca15a1627405 (diff) | |
download | bcm5719-llvm-fd2e13b107fb912fa15ff2226c45b766b1d83281.tar.gz bcm5719-llvm-fd2e13b107fb912fa15ff2226c45b766b1d83281.zip |
Fix PR820 and Transforms/GlobalOpt/2006-07-07-InlineAsmCrash.ll
llvm-svn: 29071
Diffstat (limited to 'llvm/lib/Transforms')
-rw-r--r-- | llvm/lib/Transforms/IPO/GlobalOpt.cpp | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/IPO/GlobalOpt.cpp b/llvm/lib/Transforms/IPO/GlobalOpt.cpp index 7c212e7b7a3..05217797319 100644 --- a/llvm/lib/Transforms/IPO/GlobalOpt.cpp +++ b/llvm/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. |