<div dir="ltr">Hi Christian,<div><br></div><div>At the moment we support PIC in the sense that you can, through the RTDyldMemoryManager, map text/data sections wherever you like. Once they've been laid down however, the current JIT infrastructure treats them as fixed. It sounds like you want to go further than that and slide text/data around during garbage collection? You might be able to do that with the current infrastructure by holding on to the relocatable objects and re-emitting text sections to new locations as needed (the data sections you would have to move manually so as not to overwrite away any changes). Unfortunately this would double your memory overhead since you would have two copies of all your sections: The emitted version and the cached, relocatable version. With a bit of work you could teach the JIT linker (RuntimeDyld) to optionally hold on to the necessary relocations and so eliminate that overhead too.</div><div><br></div><div>So, I don't think you can do this today, but with a bit of effort I think it could be made to work. It certainly sounds like an interesting idea.</div><div><br></div><div>Cheers,</div><div>Lang.</div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Feb 16, 2015 at 12:20 PM, Christian Schafmeister <span dir="ltr"><<a href="mailto:chris.schaf@verizon.net" target="_blank">chris.schaf@verizon.net</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><div><br></div>David,<div><br></div><div>Well, thank you very much! I’ll be very interested to talk with Lang. I CC’d him on this email.</div><div>I have a fully functional Common Lisp compiler that uses the LLVM C++ API extensively and does all sorts of weird and wonderful things with it.</div><div><br></div><div>My use-case of the LLVM-JIT code may be one of the furthest “out-there” of any compiler so far.</div><div><br></div><div><br></div><div>Best,</div><div><br></div><div>.Chris.</div><div><br></div><div><br></div><div><div><div>On Feb 16, 2015, at 3:14 PM, David Blaikie <<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@gmail.com</a>> wrote:</div><br><blockquote type="cite"><div dir="ltr">I was just cc'ing Lang Hames, one of the LLVM developers, onto this thread to bring it to his attention.<br><br>He's taken ownership of the JIT recently and has been experimenting with a new JIT API (called ORC) that is designed to be a composable system providing infrastructure for a variety of JIT use cases. I don't know that he's considered the use case you have, but I'm sure he'll be glad to give it some thought.</div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Feb 16, 2015 at 12:12 PM, Christian Schafmeister <span dir="ltr"><<a href="mailto:chris.schaf@verizon.net" target="_blank">chris.schaf@verizon.net</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word">David,<div><br></div><div>What’s +Lang? I googled “llvm +Lang” and found a few random posts but nothing concrete.</div><div>Is it the final resting place of strange JIT requirements/requests?</div><div><br></div><div>Best,</div><div><br></div><div>.Chris.</div><div><div class="h5"><div><div><div><br></div><div><br></div><div><br><div><div>On Feb 16, 2015, at 3:06 PM, David Blaikie <<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@gmail.com</a>> wrote:</div><br><blockquote type="cite"><div dir="ltr">+Lang, collector of strange JIT requirements</div><div class="gmail_extra"><br><div class="gmail_quote">On Mon, Feb 16, 2015 at 11:47 AM, Christian Schafmeister <span dir="ltr"><<a href="mailto:chris.schaf@verizon.net" target="_blank">chris.schaf@verizon.net</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><br>
Hello everyone,<br>
<br>
<br>
Is fully relocatable/position-independent JITted code on the horizon or currently possible with LLVM?<br>
<br>
I’ve written a Common Lisp compiler (currently called Clasp: <a href="https://github.com/drmeister/clasp" target="_blank">https://github.com/drmeister/clasp</a>) in C++ that uses LLVM as the backend and interoperates with C++. It uses copying garbage collection via the Memory Pool System (MPS) garbage collector by Ravenbrook. This garbage collector is precise on the heap and conservative on the stack.<br>
<br>
Currently I JIT code to wherever LLVM drops the code and it remains fixed in memory. This causes some problems for implementing a dynamic language like Common Lisp because CL considers data and code to be equivalent.<br>
<br>
I’d like to move the code into the MPS managed memory and be able to apply copying garbage collection to it. Is this possible? Will it ever be possible?<br>
<br>
Best,<br>
<br>
Christian Schafmeister<br>
Professor<br>
Chemistry Department<br>
Temple University<br>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:LLVMdev@cs.uiuc.edu" target="_blank">LLVMdev@cs.uiuc.edu</a> <a href="http://llvm.cs.uiuc.edu/" target="_blank">http://llvm.cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev</a><br>
</blockquote></div><br></div>
</blockquote></div><br></div></div></div></div></div></div></blockquote></div><br></div>
</blockquote></div><br></div></div></blockquote></div><br></div>