<div dir="ltr">Hi Sean,<div><br></div><div>This is great, but it couples LogicalDylib too tightly to CompileOnDemandLayer. Does this alternative implementation of <span style="color:rgb(51,51,51);font-size:12.800000190734863px">getLogicalModuleResourcesForSy</span><font color="#333333"><span style="font-size:12.800000190734863px">mbol work for you (unfortunately I don't have a local test case for this yet):</span></font></div><div>                                                                                                                                                                                                                                                                                                                                                     <br></div><div><div><font face="monospace, monospace">  LogicalModuleResources*</font></div><div><font face="monospace, monospace">  getLogicalModuleResourcesForSymbol(const std::string &Name,</font></div><div><font face="monospace, monospace">                                     bool ExportedSymbolsOnly) {</font></div><div><font face="monospace, monospace">    for (auto LMI = LogicalModules.begin(), LME = LogicalModules.end();</font></div><div><font face="monospace, monospace">         LMI != LME; ++LMI)</font></div><div><font face="monospace, monospace">      if (auto Sym = LMI->Resources.findSymbol(Name, ExportedSymbolsOnly))</font></div><div><font face="monospace, monospace">        return &LMI->Resources;</font></div><div><font face="monospace, monospace">    return nullptr;</font></div><div><font face="monospace, monospace">  }</font></div></div><div><br></div><div>If so I'd be happy to commit this on your behalf.</div><div><br></div><div>It might be nice to plumb support for this to the Orc C-bindings too: that would enable testing of this via the C-Bindings unit tests.</div><div><br></div><div>Thanks very much for working on this!</div><div><br></div><div>Cheers,</div><div>Lang.</div><div><br></div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Fri, Jul 29, 2016 at 8:10 AM, David Blaikie <span dir="ltr"><<a href="mailto:dblaikie@gmail.com" target="_blank">dblaikie@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><a href="mailto:lhames@gmail.com" target="_blank">+Lang Hames</a>, Master Regent of the Three <No, Two sir> JITs<br><br><div class="gmail_quote"><div><div class="h5"><div dir="ltr">On Thu, Jul 28, 2016 at 12:31 PM Sean Ogden via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br></div></div></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div><div class="h5"><div dir="ltr">I needed to be able to update stub pointers for hot functions that get recompiled in a lazy JIT that uses CompileOnDemandLayer.  In order to do this I added a method that allows pointers to be updated but does not expose any of the other internals of the COD layer.<div><br></div><div>Does anyone have a cleaner way to do this?  Has something to facilitate this already been added?  Would it be possible to merge this in?<br><div><br></div><div><div><font color="#333333">diff --git a/CompileOnDemandLayer.h b/CompileOnDemandLayer.h</font></div><div><font color="#333333">index bd192b8..4aa3362 100644</font></div><div><font color="#333333">--- a/CompileOnDemandLayer.h</font></div><div><font color="#333333">+++ b/CompileOnDemandLayer.h</font></div><div><font color="#333333">@@ -429,6 +429,28 @@ private:</font></div><div><font color="#333333">     return CalledAddr;</font></div><div><font color="#333333">   }</font></div><div><font color="#333333"><br></font></div><div><font color="#333333">+public:</font></div><div><font color="#333333">+  TargetAddress updatePointer(std::string FuncName, TargetAddress FnBodyAddr) {</font></div><div><font color="#333333">+    //Find out which logical dylib contains our symbol</font></div><div><font color="#333333">+    auto LDI = LogicalDylibs.begin();</font></div><div><font color="#333333">+    for (auto LDE = LogicalDylibs.end(); LDI != LDE; ++LDI) {</font></div><div><font color="#333333">+        if (auto LMResources = LDI->getLogicalModuleResourcesForSymbol(FuncName, false)) {</font></div><div><font color="#333333">+            Module &SrcM = LMResources->SourceModule->getResource();</font></div><div><font color="#333333">+            std::string CalledFnName = mangle(FuncName, SrcM.getDataLayout());</font></div><div><font color="#333333">+            if (auto EC = LMResources->StubsMgr->updatePointer(CalledFnName, FnBodyAddr)) {</font></div><div><font color="#333333">+                return 0;</font></div><div><font color="#333333">+            }</font></div><div><font color="#333333">+            else</font></div><div><font color="#333333">+                return FnBodyAddr;</font></div><div><font color="#333333">+        }</font></div><div><font color="#333333">+    }</font></div><div><font color="#333333">+    return 0;</font></div><div><font color="#333333">+  }</font></div><div><font color="#333333">+</font></div><div><font color="#333333">+private:</font></div></div><div><font color="#333333"><br></font></div><div><font color="#333333"><br></font></div><div><font color="#333333"><div>diff --git a/LogicalDylib.h b/LogicalDylib.h</div><div>index 84e3bf5..2e35cfd 100644</div><div>--- a/LogicalDylib.h</div><div>+++ b/LogicalDylib.h</div><div>@@ -17,6 +17,8 @@</div><div> #include "JITSymbol.h"</div><div> #include <string></div><div> #include <vector></div><div>+#include "llvm/IR/Mangler.h"</div><div>+#include "llvm/Support/raw_ostream.h"</div><div><br></div><div> namespace llvm {</div><div> namespace orc {</div><div>@@ -77,6 +79,24 @@ public:</div><div>     return LMH->Resources;</div><div>   }</div><div><br></div><div>+  static std::string mangle(StringRef Name, const DataLayout &DL) {</div><div>+    std::string MangledName;</div><div>+    {</div><div>+      raw_string_ostream MangledNameStream(MangledName);</div><div>+      Mangler::getNameWithPrefix(MangledNameStream, Name, DL);</div><div>+    }</div><div>+    return MangledName;</div><div>+  }</div><div>+</div><div>+  LogicalModuleResources* getLogicalModuleResourcesForSymbol(const std::string &Name, bool ExportedSymbolsOnly) {</div><div>+    for (auto LMI = LogicalModules.begin(), LME = LogicalModules.end();</div><div>+         LMI != LME; ++LMI)</div><div>+      if (auto Sym = findSymbolInLogicalModule(LMI, mangle(Name,LMI->Resources.SourceModule->getResource().getDataLayout()), ExportedSymbolsOnly))</div><div>+          return &LMI->Resources;</div><div>+    return nullptr;</div><div>+  }</div><div>+</div><div>+</div><div><br></div><div><br></div><div><br></div></font></div><div><br></div></div></div></div></div>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a><br>
<a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
</blockquote></div></div>
</blockquote></div><br></div>