summaryrefslogtreecommitdiffstats
path: root/llvm/lib/ExecutionEngine
diff options
context:
space:
mode:
authorAndrew Lenharth <andrewl@lenharth.org>2005-07-22 20:48:12 +0000
committerAndrew Lenharth <andrewl@lenharth.org>2005-07-22 20:48:12 +0000
commit940b07c7fa39be0ace6db8901aede48ace7869b8 (patch)
treeb9fb9e60514c3540e2c2c3ee279f3cd45241d1f6 /llvm/lib/ExecutionEngine
parentcf5cf4dfcdb309035a3c3822eba708d4028fa849 (diff)
downloadbcm5719-llvm-940b07c7fa39be0ace6db8901aede48ace7869b8.tar.gz
bcm5719-llvm-940b07c7fa39be0ace6db8901aede48ace7869b8.zip
the JIT memory manager will construct a GOT if you want it too. Also, it places the constants in the allocated memory, rather than a malloc area
llvm-svn: 22497
Diffstat (limited to 'llvm/lib/ExecutionEngine')
-rw-r--r--llvm/lib/ExecutionEngine/JIT/JITEmitter.cpp60
1 files changed, 51 insertions, 9 deletions
diff --git a/llvm/lib/ExecutionEngine/JIT/JITEmitter.cpp b/llvm/lib/ExecutionEngine/JIT/JITEmitter.cpp
index b38e778bfc7..70479fcaa82 100644
--- a/llvm/lib/ExecutionEngine/JIT/JITEmitter.cpp
+++ b/llvm/lib/ExecutionEngine/JIT/JITEmitter.cpp
@@ -52,8 +52,9 @@ namespace {
unsigned char *FunctionBase; // Start of the function body area
unsigned char *ConstantPool; // Memory allocated for constant pools
unsigned char *CurStubPtr, *CurFunctionPtr, *CurConstantPtr;
+ unsigned char *GOTBase; //Target Specific reserved memory
public:
- JITMemoryManager();
+ JITMemoryManager(bool useGOT);
~JITMemoryManager();
inline unsigned char *allocateStub(unsigned StubSize);
@@ -61,26 +62,34 @@ namespace {
unsigned Alignment);
inline unsigned char *startFunctionBody();
inline void endFunctionBody(unsigned char *FunctionEnd);
+ inline unsigned char* getGOTBase() const;
+
+ inline bool isManagingGOT() const;
};
}
-JITMemoryManager::JITMemoryManager() {
+JITMemoryManager::JITMemoryManager(bool useGOT) {
// Allocate a 16M block of memory...
MemBlock = sys::Memory::AllocateRWX((16 << 20));
MemBase = reinterpret_cast<unsigned char*>(MemBlock.base());
- FunctionBase = MemBase + 512*1024; // Use 512k for stubs
+ ConstantPool = MemBase;
+ GOTBase = ConstantPool + 512*1024; //512 for constants
+ //8k number of entries in the GOT
+ FunctionBase = GOTBase + 8192 * sizeof(void*) + 512*1024; // Use 512k for stubs
+
+ //make it easier to tell if we are managing the GOT
+ if (!useGOT)
+ GOTBase = NULL;
// Allocate stubs backwards from the function base, allocate functions forward
// from the function base.
CurStubPtr = CurFunctionPtr = FunctionBase;
- ConstantPool = new unsigned char [512*1024]; // Use 512k for constant pools
CurConstantPtr = ConstantPool + 512*1024;
}
JITMemoryManager::~JITMemoryManager() {
sys::Memory::ReleaseRWX(MemBlock);
- delete[] ConstantPool;
}
unsigned char *JITMemoryManager::allocateStub(unsigned StubSize) {
@@ -117,6 +126,14 @@ void JITMemoryManager::endFunctionBody(unsigned char *FunctionEnd) {
CurFunctionPtr = FunctionEnd;
}
+unsigned char* JITMemoryManager::getGOTBase() const {
+ return GOTBase;
+}
+
+bool JITMemoryManager::isManagingGOT() const {
+ return GOTBase != NULL;
+}
+
//===----------------------------------------------------------------------===//
// JIT lazy compilation code.
//
@@ -320,8 +337,17 @@ namespace {
/// Relocations - These are the relocations that the function needs, as
/// emitted.
std::vector<MachineRelocation> Relocations;
+
public:
- JITEmitter(JIT &jit) { TheJIT = &jit; }
+ JITEmitter(JIT &jit)
+ :MemMgr(jit.getJITInfo().needsGOT()),
+ nextGOTIndex(0)
+ {
+ TheJIT = &jit;
+ DEBUG(std::cerr <<
+ (MemMgr.isManagingGOT() ? "JIT is managing GOT\n"
+ : "JIT is not managing GOT\n"));
+ }
virtual void startFunction(MachineFunction &F);
virtual void finishFunction(MachineFunction &F);
@@ -342,6 +368,8 @@ namespace {
private:
void *getPointerToGlobal(GlobalValue *GV, void *Reference, bool NoNeedStub);
+ unsigned nextGOTIndex;
+ std::map<void*, unsigned> revGOTMap;
};
}
@@ -388,7 +416,6 @@ void JITEmitter::startFunction(MachineFunction &F) {
void JITEmitter::finishFunction(MachineFunction &F) {
MemMgr.endFunctionBody(CurByte);
- ConstantPoolAddresses.clear();
NumBytes += CurByte-CurBlock;
if (!Relocations.empty()) {
@@ -404,15 +431,29 @@ void JITEmitter::finishFunction(MachineFunction &F) {
// If the target REALLY wants a stub for this function, emit it now.
if (!MR.doesntNeedFunctionStub())
ResultPtr = getJITResolver(this).getExternalFunctionStub(ResultPtr);
- } else
+ } else if (MR.isGlobalValue())
ResultPtr = getPointerToGlobal(MR.getGlobalValue(),
CurBlock+MR.getMachineCodeOffset(),
MR.doesntNeedFunctionStub());
+ else //ConstantPoolIndex
+ ResultPtr =
+ (void*)getConstantPoolEntryAddress(MR.getConstantPoolIndex());
+
MR.setResultPointer(ResultPtr);
+
+ // if we are managing the got, check to see if this pointer has all ready
+ // been allocated a GOT entry. If not, give it the next one.
+ if (MemMgr.isManagingGOT()) {
+ if (!revGOTMap[ResultPtr])
+ revGOTMap[ResultPtr] = ++nextGOTIndex;
+ ((void**)MemMgr.getGOTBase())[revGOTMap[ResultPtr]] = ResultPtr;
+ if(MR.isGOTRelative())
+ MR.setGOTIndex(revGOTMap[ResultPtr]);
+ }
}
TheJIT->getJITInfo().relocate(CurBlock, &Relocations[0],
- Relocations.size());
+ Relocations.size(), MemMgr.getGOTBase());
}
DEBUG(std::cerr << "JIT: Finished CodeGen of [" << (void*)CurBlock
@@ -420,6 +461,7 @@ void JITEmitter::finishFunction(MachineFunction &F) {
<< ": " << CurByte-CurBlock << " bytes of text, "
<< Relocations.size() << " relocations\n");
Relocations.clear();
+ ConstantPoolAddresses.clear();
}
void JITEmitter::emitConstantPool(MachineConstantPool *MCP) {
OpenPOWER on IntegriCloud