|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Move to a by-section allocation and relocation scheme. This allows
better support for sections which do not contain externally visible
symbols.
Flesh out the relocation address vs. local storage address separation a
bit more as well. Remote process JITs use this to tell the relocation
resolution code where the code will live when it executes.
The startFunctionBody/endFunctionBody interfaces to the JIT and the
memory manager are deprecated. They'll stick around for as long as the
old JIT does, but the MCJIT doesn't use them anymore.
llvm-svn: 148258 | 
| | 
| 
| 
| | llvm-svn: 120298 | 
| | 
| 
| 
| 
| 
| | readability.
llvm-svn: 100756 | 
| | 
| 
| 
| | llvm-svn: 100709 | 
| | 
| 
| 
| | llvm-svn: 92562 | 
| | 
| 
| 
| | llvm-svn: 86917 | 
| | 
| 
| 
| | llvm-svn: 86606 | 
| | 
| 
| 
| 
| 
| | before freeing them.
llvm-svn: 84859 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | JITEmitter.
I'm gradually making Functions auto-remove themselves from the JIT when they're
destroyed. In this case, the Function needs to be removed from the JITEmitter,
but the map recording which Functions need to be removed lived behind the
JITMemoryManager interface, which made things difficult.
This patch replaces the deallocateMemForFunction(Function*) method with a pair
of methods deallocateFunctionBody(void *) and deallocateExceptionTable(void *)
corresponding to the two startFoo/endFoo pairs.
llvm-svn: 84651 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | members that call methods that read the PoisonMemory member.
This fixes potential spurious (though probably otherwise
harmless) poising of unused memory, and fixes the
associated valgrind error.
llvm-svn: 80192 | 
| | 
| 
| 
| | llvm-svn: 79832 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | bytes.  libgcc doesn't seem to mind, but if you pass this DWARF to GDB, it
doesn't like it.  
Also make the JIT memory manager to initialize it's memory to garbage in debug
mode, so that it's easier to find bugs like these in the future.
llvm-svn: 79674 | 
| | 
| 
| 
| | llvm-svn: 78848 | 
| | 
| 
| 
| 
| 
| 
| | there is no new block added to the free list. Therefore on the next
startFunctionBody call, a new slab must be allocated.
llvm-svn: 77520 | 
| | 
| 
| 
| 
| 
| | bots like the BumpPtrAllocator changes.
llvm-svn: 76902 | 
| | 
| 
| 
| 
| 
| | build failure involving memset.
llvm-svn: 76838 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | out of memory, and also make the default memory manager allocate more memory
when it runs out.
Also, switch function stubs and global data over to using the BumpPtrAllocator.
This makes it so the JIT no longer mmaps (or the equivalent on Windows) 16 MB
of memory, and instead allocates in 512K slabs.  I suspect this size could go
lower, especially on embedded platforms, now that more slabs can be allocated.
llvm-svn: 76828 | 
| | 
| 
| 
| 
| 
| | and abort()/exit() -> llvm_report_error().
llvm-svn: 75363 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | default, this option is not enabled to support clients who rely on
this behavior.
Fixes http://llvm.org/PR4483
A patch to allocate additional memory for globals after we run out is
forthcoming.
Patch by Reid Kleckner!
llvm-svn: 75059 | 
| | 
| 
| 
| | llvm-svn: 72821 | 
| | 
| 
| 
| | llvm-svn: 72783 | 
| | 
| 
| 
| | llvm-svn: 72650 | 
| | 
| 
| 
| 
| 
| 
| | is appropriate. This helps visually differentiate host-oriented
calculations from target-oriented calculations.
llvm-svn: 68227 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | allocating memory in the JIT.  This is insanely inefficient, but
hey, most people implement their own memory managers anyway.
Patch by Eric Yew!
llvm-svn: 66472 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | that has not been JIT'd yet, the callee is put on a list of pending functions
to JIT.  The call is directed through a stub, which is updated with the address
of the function after it has been JIT'd.  A new interface for allocating and
updating empty stubs is provided.
Add support for removing the ModuleProvider the JIT was created with, which
would otherwise invalidate the JIT's PassManager, which is initialized with the
ModuleProvider's Module.
Add support under a new ExecutionEngine flag for emitting the infomration 
necessary to update Function and GlobalVariable stubs after JITing them, by
recording the address of the stub and the name of the GlobalValue.  This allows
code to be copied from one address space to another, where libraries may live
at different virtual addresses, and have the stubs updated with their new
correct target addresses.
llvm-svn: 64906 | 
| | 
| 
| 
| 
| 
| | JITing a variable independently of a function. This lead to sharing memory memory between functions and GVs thus changing the value of a GV could change the code in execution. more details on the ML.
llvm-svn: 57900 | 
| | 
| 
| 
| 
| 
| | Patch by Samuel Tardieu.
llvm-svn: 57291 | 
| | 
| 
| 
| 
| 
| 
| | this handling to work properly for modifying stub functions, relocations
back to entry points after JIT compilation, etc..
llvm-svn: 57013 | 
| | 
| 
| 
| 
| 
| | privilege from read / write to read / executable.
llvm-svn: 56303 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | are allocated in the same buffer as the code,
jump tables, etc.
The default JIT memory manager does not handle buffer
overflow well.  I didn't introduce this and I'm not
attempting to fix it here, but it is more likely to
be hit now since we're putting more stuff in the
buffer.  This affects one test that I know of so far,
MultiSource/Benchmarks/NPB-serial/is.
llvm-svn: 54442 | 
| | 
| 
| 
| 
| 
| | FreeRangeHeader::getMinBlockSize(). Patch by Damien.
llvm-svn: 54152 | 
| | 
| 
| 
| | llvm-svn: 52592 | 
| | 
| 
| 
| 
| 
| 
| 
| | the memory manager which function
the stub will resolve.
llvm-svn: 49814 | 
| | 
| 
| 
| | llvm-svn: 48019 | 
| | 
| 
| 
| 
| 
| | annoying warnings.
llvm-svn: 47367 | 
| | 
| 
| 
| | llvm-svn: 47079 | 
| | 
| 
| 
| | llvm-svn: 45418 | 
| | 
| 
| 
| 
| 
| | same.
llvm-svn: 44651 | 
|  | own JITMemoryManager interface.  There is no functionality change with 
this patch.
llvm-svn: 44640 |