forked from OSchip/llvm-project
d014d576a9
Summary: This patch avoids an assert in IPConstantPropagation when there is a argument count/type mismatch between the caller and the callee. While this is actually UB on C-level (clang emits a warning), the IR verifier seems to accept it. I'm not sure what other frontends/languages might think about this, so simply bailing out to avoid hitting an assert (in CallSiteBase<>::getArgOperand or Value::doRAUW) seems like a simple solution. The problem is exposed by the fact that AbstractCallSites will look through a bitcast at the callee position of a call/invoke. Reviewers: jdoerfert, reames, efriedma Reviewed By: jdoerfert, efriedma Subscribers: eli.friedman, efriedma, llvm-commits Differential Revision: https://reviews.llvm.org/D57052 llvm-svn: 352469 |
||
---|---|---|
.. | ||
2008-06-09-WeakProp.ll | ||
2009-09-24-byval-ptr.ll | ||
PR16052.ll | ||
PR26044.ll | ||
arg-count-mismatch.ll | ||
arg-type-mismatch.ll | ||
comdat-ipo.ll | ||
dangling-block-address.ll | ||
deadarg.ll | ||
fp-bc-icmp-const-fold.ll | ||
global.ll | ||
multiple_callbacks.ll | ||
musttail-call.ll | ||
naked-return.ll | ||
openmp_parallel_for.ll | ||
pthreads.ll | ||
recursion.ll | ||
remove-call-inst.ll | ||
return-argument.ll | ||
return-constant.ll | ||
return-constants.ll | ||
solve-after-each-resolving-undefs-for-function.ll | ||
thread_local_acs.ll | ||
user-with-multiple-uses.ll |