fix crash when the malloc/free function is defined or is a declaration with 0 parameters.
this pass doesnt seem to be used, but still it's now a little more correct llvm-svn: 55873
This commit is contained in:
parent
95c2a7848a
commit
421f488cb7
|
@ -51,8 +51,7 @@ bool IndMemRemPass::runOnModule(Module &M) {
|
||||||
//happen through intrinsics.
|
//happen through intrinsics.
|
||||||
bool changed = false;
|
bool changed = false;
|
||||||
if (Function* F = M.getFunction("free")) {
|
if (Function* F = M.getFunction("free")) {
|
||||||
assert(F->isDeclaration() && "free not external?");
|
if (F->isDeclaration() && F->arg_size() == 1 && !F->use_empty()) {
|
||||||
if (!F->use_empty()) {
|
|
||||||
Function* FN = Function::Create(F->getFunctionType(),
|
Function* FN = Function::Create(F->getFunctionType(),
|
||||||
GlobalValue::LinkOnceLinkage,
|
GlobalValue::LinkOnceLinkage,
|
||||||
"free_llvm_bounce", &M);
|
"free_llvm_bounce", &M);
|
||||||
|
@ -66,8 +65,7 @@ bool IndMemRemPass::runOnModule(Module &M) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (Function* F = M.getFunction("malloc")) {
|
if (Function* F = M.getFunction("malloc")) {
|
||||||
assert(F->isDeclaration() && "malloc not external?");
|
if (F->isDeclaration() && F->arg_size() == 1 && !F->use_empty()) {
|
||||||
if (!F->use_empty()) {
|
|
||||||
Function* FN = Function::Create(F->getFunctionType(),
|
Function* FN = Function::Create(F->getFunctionType(),
|
||||||
GlobalValue::LinkOnceLinkage,
|
GlobalValue::LinkOnceLinkage,
|
||||||
"malloc_llvm_bounce", &M);
|
"malloc_llvm_bounce", &M);
|
||||||
|
|
Loading…
Reference in New Issue