mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-13 15:11:39 +00:00
calling a function with the wrong CC is undefined, turn it into an unreachable
instruction. This is useful for catching optimizers that don't preserve calling conventions llvm-svn: 21928
This commit is contained in:
parent
5cd760d12d
commit
b06ee3dd65
@ -4115,6 +4115,20 @@ Instruction *InstCombiner::visitCallSite(CallSite CS) {
|
||||
|
||||
Value *Callee = CS.getCalledValue();
|
||||
|
||||
if (Function *CalleeF = dyn_cast<Function>(Callee))
|
||||
if (CalleeF->getCallingConv() != CS.getCallingConv()) {
|
||||
Instruction *OldCall = CS.getInstruction();
|
||||
// If the call and callee calling conventions don't match, this call must
|
||||
// be unreachable, as the call is undefined.
|
||||
new StoreInst(ConstantBool::True,
|
||||
UndefValue::get(PointerType::get(Type::BoolTy)), OldCall);
|
||||
if (!OldCall->use_empty())
|
||||
OldCall->replaceAllUsesWith(UndefValue::get(OldCall->getType()));
|
||||
if (isa<CallInst>(OldCall)) // Not worth removing an invoke here.
|
||||
return EraseInstFromFunction(*OldCall);
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (isa<ConstantPointerNull>(Callee) || isa<UndefValue>(Callee)) {
|
||||
// This instruction is not reachable, just remove it. We insert a store to
|
||||
// undef so that we know that this code is not reachable, despite the fact
|
||||
|
Loading…
x
Reference in New Issue
Block a user