Made ClassIMPCache a ModulePass (it shouldn't be a FunctionPass because it adds globals).

main
theraven 16 years ago
parent 60f87bc4ad
commit beb8356367

@ -14,31 +14,29 @@ using std::string;
namespace namespace
{ {
class ClassIMPCachePass : public FunctionPass class ClassIMPCachePass : public ModulePass
{ {
GNUstep::IMPCacher *cacher;
Module *M;
const IntegerType *IntTy; const IntegerType *IntTy;
public: public:
static char ID; static char ID;
ClassIMPCachePass() : FunctionPass((intptr_t)&ID) {} ClassIMPCachePass() : ModulePass((intptr_t)&ID) {}
~ClassIMPCachePass() { delete cacher; }
virtual bool doInitialization(Module &Mod) { virtual bool runOnModule(Module &M) {
M = &Mod; GNUstep::IMPCacher cacher = GNUstep::IMPCacher(M.getContext(), this);
cacher = new GNUstep::IMPCacher(Mod.getContext(), this);
// FIXME: ILP64 // FIXME: ILP64
IntTy = Type::getInt32Ty(Mod.getContext()); IntTy = Type::getInt32Ty(M.getContext());
return false;
}
virtual bool runOnFunction(Function &F) {
bool modified = false; bool modified = false;
for (Module::iterator F=M.begin(), fend=M.end() ;
F != fend ; ++F) {
if (F->isDeclaration()) { continue; }
SmallVector<CallInst*, 16> Lookups; SmallVector<CallInst*, 16> Lookups;
BasicBlock *entry = &F.getEntryBlock(); BasicBlock *entry = &F->getEntryBlock();
for (Function::iterator i=F.begin(), end=F.end() ; for (Function::iterator i=F->begin(), end=F->end() ;
i != end ; ++i) { i != end ; ++i) {
for (BasicBlock::iterator b=i->begin(), last=i->end() ; for (BasicBlock::iterator b=i->begin(), last=i->end() ;
b != last ; ++b) { b != last ; ++b) {
@ -82,13 +80,14 @@ namespace
e=Lookups.end() ; e!=i ; i++) { e=Lookups.end() ; e!=i ; i++) {
const Type *SlotPtrTy = (*i)->getType(); const Type *SlotPtrTy = (*i)->getType();
Value *slot = new GlobalVariable(*M, SlotPtrTy, false, Value *slot = new GlobalVariable(M, SlotPtrTy, false,
GlobalValue::PrivateLinkage, Constant::getNullValue(SlotPtrTy), GlobalValue::PrivateLinkage, Constant::getNullValue(SlotPtrTy),
"slot"); "slot");
Value *version = new GlobalVariable(*M, IntTy, false, Value *version = new GlobalVariable(M, IntTy, false,
GlobalValue::PrivateLinkage, Constant::getNullValue(IntTy), GlobalValue::PrivateLinkage, Constant::getNullValue(IntTy),
"version"); "version");
cacher->CacheLookup(*i, slot, version); cacher.CacheLookup(*i, slot, version);
}
} }
return modified; return modified;
} }
@ -99,7 +98,7 @@ namespace
"Cache IMPs for class messages"); "Cache IMPs for class messages");
} }
FunctionPass *createClassIMPCachePass(void) ModulePass *createClassIMPCachePass(void)
{ {
return new ClassIMPCachePass(); return new ClassIMPCachePass();
} }

Loading…
Cancel
Save