diff options
author | Duncan Sands <baldrick@free.fr> | 2007-12-16 15:51:49 +0000 |
---|---|---|
committer | Duncan Sands <baldrick@free.fr> | 2007-12-16 15:51:49 +0000 |
commit | 8e4847ee957a7c7c434a72fdb7a6010004ca86f4 (patch) | |
tree | 7f801143756656ede3dc607b2abb2472097e0151 /llvm/lib/Transforms/Scalar/InstructionCombining.cpp | |
parent | fcf20857319a52bf9141b470443cd4e9fbb00964 (diff) | |
download | bcm5719-llvm-8e4847ee957a7c7c434a72fdb7a6010004ca86f4.tar.gz bcm5719-llvm-8e4847ee957a7c7c434a72fdb7a6010004ca86f4.zip |
Make instcombine promote inline asm calls to 'nounwind'
calls. Remove special casing of inline asm from the
inliner. There is a potential problem: the verifier
rejects invokes of inline asm (not sure why). If an
asm call is not marked "nounwind" in some .ll, and
instcombine is not run, but the inliner is run, then
an illegal module will be created. This is bad but
I'm not sure what the best approach is. I'm tempted
to remove the check in the verifier...
llvm-svn: 45073
Diffstat (limited to 'llvm/lib/Transforms/Scalar/InstructionCombining.cpp')
-rw-r--r-- | llvm/lib/Transforms/Scalar/InstructionCombining.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp index 653d35e34f4..aa9e932fc52 100644 --- a/llvm/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/llvm/lib/Transforms/Scalar/InstructionCombining.cpp @@ -7972,6 +7972,19 @@ Instruction *InstCombiner::visitCallSite(CallSite CS) { } } + if (isa<InlineAsm>(Callee) && !CS.isNoUnwind()) { + // Inline asm calls cannot throw - mark them 'nounwind'. + const ParamAttrsList *PAL = CS.getParamAttrs(); + uint16_t RAttributes = PAL ? PAL->getParamAttrs(0) : 0; + RAttributes |= ParamAttr::NoUnwind; + + ParamAttrsVector modVec; + modVec.push_back(ParamAttrsWithIndex::get(0, RAttributes)); + PAL = ParamAttrsList::getModified(PAL, modVec); + CS.setParamAttrs(PAL); + Changed = true; + } + return Changed ? CS.getInstruction() : 0; } |