mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-22 10:33:23 +00:00
Simplify code a lot by using the Module::getFunction & getOrInsertFunction
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2028 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
49a4b220eb
commit
be591a78cf
@ -13,7 +13,6 @@
|
|||||||
#include "llvm/DerivedTypes.h"
|
#include "llvm/DerivedTypes.h"
|
||||||
#include "llvm/iMemory.h"
|
#include "llvm/iMemory.h"
|
||||||
#include "llvm/iOther.h"
|
#include "llvm/iOther.h"
|
||||||
#include "llvm/SymbolTable.h"
|
|
||||||
#include "llvm/ConstantVals.h"
|
#include "llvm/ConstantVals.h"
|
||||||
#include "llvm/Pass.h"
|
#include "llvm/Pass.h"
|
||||||
#include "TransformInternals.h"
|
#include "TransformInternals.h"
|
||||||
@ -73,37 +72,18 @@ public:
|
|||||||
// This function is always successful.
|
// This function is always successful.
|
||||||
//
|
//
|
||||||
bool LowerAllocations::doInitialization(Module *M) {
|
bool LowerAllocations::doInitialization(Module *M) {
|
||||||
bool Changed = false;
|
const FunctionType *MallocType =
|
||||||
const MethodType *MallocType =
|
FunctionType::get(PointerType::get(Type::SByteTy),
|
||||||
MethodType::get(PointerType::get(Type::SByteTy),
|
vector<const Type*>(1, Type::UIntTy), false);
|
||||||
vector<const Type*>(1, Type::UIntTy), false);
|
const FunctionType *FreeType =
|
||||||
|
FunctionType::get(Type::VoidTy,
|
||||||
|
vector<const Type*>(1, PointerType::get(Type::SByteTy)),
|
||||||
|
false);
|
||||||
|
|
||||||
SymbolTable *SymTab = M->getSymbolTableSure();
|
MallocFunc = M->getOrInsertFunction("malloc", MallocType);
|
||||||
|
FreeFunc = M->getOrInsertFunction("free" , FreeType);
|
||||||
// Check for a definition of malloc
|
|
||||||
if (Value *V = SymTab->lookup(PointerType::get(MallocType), "malloc")) {
|
|
||||||
MallocFunc = cast<Function>(V); // Yup, got it
|
|
||||||
} else { // Nope, add one
|
|
||||||
M->getFunctionList().push_back(MallocFunc = new Function(MallocType, false,
|
|
||||||
"malloc"));
|
|
||||||
Changed = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
const MethodType *FreeType =
|
return false;
|
||||||
MethodType::get(Type::VoidTy,
|
|
||||||
vector<const Type*>(1, PointerType::get(Type::SByteTy)),
|
|
||||||
false);
|
|
||||||
|
|
||||||
// Check for a definition of free
|
|
||||||
if (Value *V = SymTab->lookup(PointerType::get(FreeType), "free")) {
|
|
||||||
FreeFunc = cast<Function>(V); // Yup, got it
|
|
||||||
} else { // Nope, add one
|
|
||||||
FreeFunc = new Function(FreeType, false,"free");
|
|
||||||
M->getFunctionList().push_back(FreeFunc);
|
|
||||||
Changed = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return Changed;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// runOnBasicBlock - This method does the actual work of converting
|
// runOnBasicBlock - This method does the actual work of converting
|
||||||
@ -172,9 +152,6 @@ bool LowerAllocations::runOnBasicBlock(BasicBlock *BB) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bool RaiseAllocations::doInitialization(Module *M) {
|
bool RaiseAllocations::doInitialization(Module *M) {
|
||||||
SymbolTable *ST = M->getSymbolTable();
|
|
||||||
if (!ST) return false;
|
|
||||||
|
|
||||||
// If the module has a symbol table, they might be referring to the malloc
|
// If the module has a symbol table, they might be referring to the malloc
|
||||||
// and free functions. If this is the case, grab the method pointers that
|
// and free functions. If this is the case, grab the method pointers that
|
||||||
// the module is using.
|
// the module is using.
|
||||||
@ -183,20 +160,21 @@ bool RaiseAllocations::doInitialization(Module *M) {
|
|||||||
// don't exist, or are not external, we do not worry about converting calls
|
// don't exist, or are not external, we do not worry about converting calls
|
||||||
// to that function into the appropriate instruction.
|
// to that function into the appropriate instruction.
|
||||||
//
|
//
|
||||||
const PointerType *MallocType = // Get the type for malloc
|
const FunctionType *MallocType = // Get the type for malloc
|
||||||
PointerType::get(MethodType::get(PointerType::get(Type::SByteTy),
|
FunctionType::get(PointerType::get(Type::SByteTy),
|
||||||
vector<const Type*>(1, Type::UIntTy), false));
|
vector<const Type*>(1, Type::UIntTy), false);
|
||||||
MallocFunc = cast_or_null<Function>(ST->lookup(MallocType, "malloc"));
|
|
||||||
if (MallocFunc && !MallocFunc->isExternal())
|
|
||||||
MallocFunc = 0; // Don't mess with locally defined versions of the fn
|
|
||||||
|
|
||||||
const PointerType *FreeType = // Get the type for free
|
const FunctionType *FreeType = // Get the type for free
|
||||||
PointerType::get(MethodType::get(Type::VoidTy,
|
FunctionType::get(Type::VoidTy,
|
||||||
vector<const Type*>(1, PointerType::get(Type::SByteTy)), false));
|
vector<const Type*>(1, PointerType::get(Type::SByteTy)),
|
||||||
FreeFunc = cast_or_null<Function>(ST->lookup(FreeType, "free"));
|
false);
|
||||||
if (FreeFunc && !FreeFunc->isExternal())
|
|
||||||
FreeFunc = 0; // Don't mess with locally defined versions of the fn
|
|
||||||
|
|
||||||
|
MallocFunc = M->getFunction("malloc", MallocType);
|
||||||
|
FreeFunc = M->getFunction("free" , FreeType);
|
||||||
|
|
||||||
|
// Don't mess with locally defined versions of these functions...
|
||||||
|
if (MallocFunc && !MallocFunc->isExternal()) MallocFunc = 0;
|
||||||
|
if (FreeFunc && !FreeFunc->isExternal()) FreeFunc = 0;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user