LLVM API Documentation
#include <MCJIT.h>
Public Member Functions | |
LinkingMemoryManager (MCJIT *Parent, RTDyldMemoryManager *MM) | |
virtual uint64_t | getSymbolAddress (const std::string &Name) |
virtual uint8_t * | allocateCodeSection (uintptr_t Size, unsigned Alignment, unsigned SectionID, StringRef SectionName) |
virtual uint8_t * | allocateDataSection (uintptr_t Size, unsigned Alignment, unsigned SectionID, StringRef SectionName, bool IsReadOnly) |
virtual void | notifyObjectLoaded (ExecutionEngine *EE, const ObjectImage *Obj) |
virtual void | registerEHFrames (uint8_t *Addr, uint64_t LoadAddr, size_t Size) |
virtual void | deregisterEHFrames (uint8_t *Addr, uint64_t LoadAddr, size_t Size) |
virtual bool | finalizeMemory (std::string *ErrMsg=0) |
![]() | |
RTDyldMemoryManager () | |
virtual | ~RTDyldMemoryManager () |
virtual void * | getPointerToNamedFunction (const std::string &Name, bool AbortOnFailure=true) |
Definition at line 29 of file lib/ExecutionEngine/MCJIT/MCJIT.h.
|
inline |
Definition at line 31 of file lib/ExecutionEngine/MCJIT/MCJIT.h.
|
inlinevirtual |
Allocate a memory block of (at least) the given size suitable for executable code. The SectionID is a unique identifier assigned by the JIT engine, and optionally recorded by the memory manager to access a loaded section.
Implements llvm::RTDyldMemoryManager.
Definition at line 37 of file lib/ExecutionEngine/MCJIT/MCJIT.h.
|
inlinevirtual |
Allocate a memory block of (at least) the given size suitable for data. The SectionID is a unique identifier assigned by the JIT engine, and optionally recorded by the memory manager to access a loaded section.
Implements llvm::RTDyldMemoryManager.
Definition at line 42 of file lib/ExecutionEngine/MCJIT/MCJIT.h.
|
inlinevirtual |
Reimplemented from llvm::RTDyldMemoryManager.
Definition at line 58 of file lib/ExecutionEngine/MCJIT/MCJIT.h.
|
inlinevirtual |
This method is called when object loading is complete and section page permissions can be applied. It is up to the memory manager implementation to decide whether or not to act on this method. The memory manager will typically allocate all sections as read-write and then apply specific permissions when this method is called. Code sections cannot be executed until this function has been called. In addition, any cache coherency operations needed to reliably use the memory are also performed.
Returns true if an error occurred, false otherwise.
Implements llvm::RTDyldMemoryManager.
Definition at line 64 of file lib/ExecutionEngine/MCJIT/MCJIT.h.
Referenced by llvm::MCJIT::finalizeLoadedModules().
|
virtual |
This method returns the address of the specified function or variable. It is used to resolve symbols during module linking.
Reimplemented from llvm::RTDyldMemoryManager.
Definition at line 532 of file MCJIT.cpp.
References llvm::MCJIT::getSymbolAddress().
|
inlinevirtual |
This method is called after an object has been loaded into memory but before relocations are applied to the loaded sections. The object load may have been initiated by MCJIT to resolve an external symbol for another object that is being finalized. In that case, the object about which the memory manager is being notified will be finalized immediately after the memory manager returns from this call.
Memory managers which are preparing code for execution in an external address space can use this call to remap the section addresses for the newly loaded object.
Reimplemented from llvm::RTDyldMemoryManager.
Definition at line 49 of file lib/ExecutionEngine/MCJIT/MCJIT.h.
Referenced by llvm::MCJIT::NotifyObjectEmitted().
|
inlinevirtual |
Register the EH frames with the runtime so that c++ exceptions work.
Addr
parameter provides the local address of the EH frame section data, while LoadAddr
provides the address of the data in the target address space. If the section has not been remapped (which will usually be the case for local execution) these two values will be the same.
Reimplemented from llvm::RTDyldMemoryManager.
Definition at line 54 of file lib/ExecutionEngine/MCJIT/MCJIT.h.