<div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div>Hi Andres,</div><div><br></div><div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">Cool!I assume this works on "non-native" jitlink platforms as well? Or<br>just mach?</blockquote></div><div dir="ltr"><br></div><div>This framework is totally materializer agnostic -- It works for ObjectLinkingLayer (JITLink), RTDyldObjectLinkingLayer (RuntimeDyld), and even materializers that aren't emitted via a linker (e.g. stubs and callbacks).</div><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex"> Looks like there's not yet a C API yet - not a problem, just checking.</blockquote><div><br></div>No C API yet, but I'll add one as soon as the C++ API settles down (probably in a week or so).</div><div dir="ltr"><br></div><div dir="ltr"><div dir="ltr">Currently it looks like only the main jit dylib is exposed via C, right?</div><div dir="ltr">We can't really do the same for resource trackers, if I understand this</div><div dir="ltr">correctly. Sketching out what I'd need to do to test postgres, so I</div><div dir="ltr">don't waste time going in the wrong direction:</div><div dir="ltr"><br></div></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">Currently it looks like only the main jit dylib is exposed via C, right?</blockquote><div><br></div><div>That was true -- I just hadn't gotten around to it. Your question seems as good an excuse as any to take a minute out and do that, so I've added them in 9a0d1b66730. :)</div><div><br></div><div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">We can't really do the same for resource trackers, if I understand this<br>correctly. Sketching out what I'd need to do to test postgres, so I<br>don't waste time going in the wrong direction:</blockquote><div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">1) Add API for management (create, destroy) a non-default resource tracker<br> (i.e. JITDylib::createResourceTracker)<br>3) Add JITDylib::clear() wrapper<br>2) LLVMOrcLLJITAdd{LLVMIRModule,ObjectFile} would need a new argument<br> (defaulting to NULL for the default resource tracker?) to specify the<br> resource tracker<br>4) LLJIT would need to grow the underlying support methods</blockquote></div><div dir="ltr"><br></div><div>That's all spot-on. It should not require much code either: Both the C API and LLJIT itself are pretty thin wrappers around the core APIs -- each of these wrappers should just be a few lines.</div><div><br></div><div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">I assume it is not legal to use the same resource tracker with two different JITDylib's?</blockquote></div><div><br></div><div>That's correct -- ResourceTrackers are bound to the JITDylib they're created from. They should assert if you use them with the wrong JITDylib, though I'm not sure how good the coverage on those asserts are yet.</div><div><br></div><div>I think this system could be generalized to enable cross-dylib tracking at the cost of a few dozen extra bytes per tracker. Do you have a use-case for this?</div><div dir="ltr"><br></div><div>Regards,</div><div>Lang.</div><div dir="ltr"><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Sep 16, 2020 at 12:48 PM Andres Freund <<a href="mailto:andres@anarazel.de" target="_blank">andres@anarazel.de</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-style:solid;border-left-color:rgb(204,204,204);padding-left:1ex">Hi,<br>
<br>
On 2020-09-16 11:52:11 -0700, Lang Hames wrote:<br>
> I've updated the orcv1 removal branch (<br>
> <a href="https://github.com/lhames/llvm-project/tree/orcv1-removal" rel="noreferrer" target="_blank">https://github.com/lhames/llvm-project/tree/orcv1-removal</a>) with an initial<br>
> patch for removable code. If anyone wants to follow along with the<br>
> development or share thoughts on the design you're very welcome to.<br>
<br>
Cool!I assume this works on "non-native" jitlink platforms as well? Or<br>
just mach?<br>
<br>
Looks like there's not yet a C API yet - not a problem, just checking.<br>
<br>
Currently it looks like only the main jit dylib is exposed via C, right?<br>
We can't really do the same for resource trackers, if I understand this<br>
correctly. Sketching out what I'd need to do to test postgres, so I<br>
don't waste time going in the wrong direction:<br>
<br>
1) Add API for management (create, destroy) a non-default resource tracker<br>
(i.e. JITDylib::createResourceTracker)<br>
3) Add JITDylib::clear() wrapper<br>
2) LLVMOrcLLJITAdd{LLVMIRModule,ObjectFile} would need a new argument<br>
(defaulting to NULL for the default resource tracker?) to specify the<br>
resource tracker<br>
4) LLJIT would need to grow the underlying support methods<br>
<br>
Does that sound roughly right?<br>
<br>
Independent questions about the current C API:<br>
- Would be nice to document [non-]mangling behaviour of<br>
LLVMOrcLLJITLookup()<br>
- Do I understand correctly that there's no way to keep a memory buffer<br>
with an object file alive after adding it with<br>
LLVMOrcLLJITAddObjectFile()? But that it's fine to create multiple<br>
buffers for the same memory with LLVMCreateMemoryBufferWithMemoryRange()?<br>
<br>
<br>
> You can call ResourceTracker::remove at any time to remove all symbols and<br>
> resources associated with a tracker. Any active compiles associated with<br>
> the tracker will receive an error when they try to update the JIT state via<br>
> their MaterializationResponsibility, and will not be able to associate<br>
> resources with the tracker's associated ResourceKey.<br>
><br>
> You can call ResourceTracker::transferTo at any time. This will transfer<br>
> tracking of all associated symbols and resources to the destination<br>
> tracker. Any active compiles associated with the tracker will be<br>
> reassociated with the destination tracker, and all future resources will be<br>
> associated with the destination tracker. Merging trackers can reduce<br>
> administrative overhead, especially when merging onto the default tracker<br>
> for the JITDylib, which has a more compact representation for ownership of<br>
> symbols.<br>
> <br>
> Calling JITDylib::clear() will call remove on all trackers created by the<br>
> JITDylib (including the default one).<br>
> <br>
> ResourceTrackers have shared ownership, but the ExecutionSession and<br>
> JITDylib do not retain ownership (except for the default tracker). If you<br>
> release all pointers to a tracker its resources will be automatically<br>
> transferred (via transferTo) to the default tracker for the JITDylib.<br>
<br>
I assume it is not legal to use the same resource tracker with two<br>
different JITDylib's?<br>
<br>
<br>
Greetings,<br>
<br>
Andres Freund<br>
</blockquote></div></div></div></div></div></div></div></div></div></div>