<html><head><meta http-equiv="Content-Type" content="text/html charset=iso-8859-1"><base href="x-msg://11156/"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">Looks good to me. Thanks!<div><br></div><div>-Jim</div><div><br><div><div>On May 15, 2012, at 6:20 PM, Danil Malyshev <<a href="mailto:dmalyshev@accesssoftek.com">dmalyshev@accesssoftek.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div ocsi="x" style="font-family: Helvetica; font-size: medium; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: 2; text-align: -webkit-auto; text-indent: 0px; text-transform: none; white-space: normal; widows: 2; word-spacing: 0px; -webkit-text-size-adjust: auto; -webkit-text-stroke-width: 0px; "><div style="font-family: Tahoma; direction: ltr; font-size: x-small; "><div>Hi Jim,</div><div><font face="tahoma"></font> </div><div><font face="tahoma"></font> </div><div><font face="tahoma">Thank you for your detailed review.</font></div><div><font face="tahoma">Please look the attached patch, it's contains changes that you wrote about.</font></div><div><font face="tahoma"></font> </div><div><font face="tahoma"></font> </div><div><font face="tahoma">Regards,</font></div><div><font face="tahoma">Danil</font></div><div dir="ltr"><font size="2" face="Tahoma"></font> </div><div id="divRpF35947" style="direction: ltr; "><hr tabindex="-1"><font size="2" face="Tahoma"><b>From:</b><span class="Apple-converted-space"> </span>Jim Grosbach [<a href="mailto:grosbach@apple.com">grosbach@apple.com</a>]<br><b>Sent:</b><span class="Apple-converted-space"> </span>Tuesday, May 15, 2012 2:00 PM<br><b>To:</b><span class="Apple-converted-space"> </span>Danil Malyshev<br><b>Cc:</b><span class="Apple-converted-space"> </span><a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br><b>Subject:</b><span class="Apple-converted-space"> </span>Re: [llvm-commits] [llvm] [Patch] Add RuntimeDyld.invalidateEmittedSectionsCache()<br></font><br></div><div></div><div><div>Hi Danil,</div><div><br></div><div>OK. This is definitely much more consistent with what we're looking to do. It's using features of the primary JIT memory managers that will (probably) go away when we remove the old JIT, but that's fine for now. Moving the logic into this memory manager will be part of that process and will provide a good example for what's expected of other applications in that regard.</div><div><br></div><div>More specific comments below. Mostly just style and format nitpicks.</div><div><br></div><div>With these changes, this is good for commit. Sorry again for the initial confusion. Entirely my fault.</div><div><br></div><div>-Jim</div><div><br></div><div><br><blockquote type="cite"><div>Index: lib/ExecutionEngine/MCJIT/MCJITMemoryManager.h</div><div>===================================================================</div><div>--- lib/ExecutionEngine/MCJIT/MCJITMemoryManager.h<span class="Apple-tab-span" style="white-space: pre; ">
</span>(revision 156826)</div><div>+++ lib/ExecutionEngine/MCJIT/MCJITMemoryManager.h<span class="Apple-tab-span" style="white-space: pre; ">
</span>(working copy)</div><div>@@ -34,12 +34,12 @@</div><div> </div><div> uint8_t *allocateDataSection(uintptr_t Size, unsigned Alignment,</div><div> unsigned SectionID) {</div><div>- return JMM->allocateSpace(Size, Alignment);</div><div>+ return JMM->allocateDataSection(Size, Alignment, SectionID);</div><div> }</div><div> </div><div> uint8_t *allocateCodeSection(uintptr_t Size, unsigned Alignment,</div><div> unsigned SectionID) {</div><div>- return JMM->allocateSpace(Size, Alignment);</div><div>+ return JMM->allocateCodeSection(Size, Alignment, SectionID);</div><div> }</div></blockquote><blockquote type="cite"><div> </div><div> virtual void *getPointerToNamedFunction(const std::string &Name,</div><div>Index: tools/lli/lli.cpp</div><div>===================================================================</div><div>--- tools/lli/lli.cpp<span class="Apple-tab-span" style="white-space: pre; "> </span><span class="Apple-converted-space"> </span>(revision 156826)</div><div>+++ tools/lli/lli.cpp<span class="Apple-tab-span" style="white-space: pre; "> </span><span class="Apple-converted-space"> </span>(working copy)</div><div>@@ -35,8 +35,18 @@</div><div> #include "llvm/Support/Process.h"</div><div> #include "llvm/Support/Signals.h"</div><div> #include "llvm/Support/TargetSelect.h"</div><div>+#include "llvm/Support/DynamicLibrary.h"</div><div>+#include "llvm/Support/Memory.h"</div><div> #include <cerrno></div><div> </div><div>+#ifdef __linux__</div><div>+#ifdef HAVE_SYS_STAT_H</div><div>+#include <sys/stat.h></div><div>+#endif</div><div>+#include <fcntl.h></div><div>+#include <unistd.h></div><div>+#endif</div><div>+</div></blockquote><div><br></div><div>This is so we get declarations for the specially handled symbols below? Assuming so, a comment to that effect would be good. We generally try to wrap platform specific stuff in llvm/Support/*, but given the very specific nature of this glibc trickery, I'm not sure that works well here, so we just need to comment about it.</div><div><br></div><blockquote type="cite"><div> #ifdef __CYGWIN__</div><div> #include <cygwin/version.h></div><div> #if defined(CYGWIN_VERSION_DLL_MAJOR) && CYGWIN_VERSION_DLL_MAJOR<1007</div><div>@@ -175,6 +185,157 @@</div><div> #endif</div><div> }</div><div> </div><div>+// Memory manager for MCJIT</div><div>+class LLIMCJITMemoryManager : public JITMemoryManager {</div><div>+public:</div><div>+ SmallVector<sys::MemoryBlock, 16> AllocatedDataMem;</div><div>+ SmallVector<sys::MemoryBlock, 16> AllocatedCodeMem;</div><div>+ SmallVector<sys::MemoryBlock, 16> FreeCodeMem;</div><div>+</div><div>+ LLIMCJITMemoryManager() { };</div><div>+ ~LLIMCJITMemoryManager();</div><div>+</div><div>+ virtual uint8_t *allocateCodeSection(uintptr_t Size, unsigned Alignment,</div><div>+ unsigned SectionID);</div><div>+</div><div>+ virtual uint8_t *allocateDataSection(uintptr_t Size, unsigned Alignment,</div><div>+ unsigned SectionID);</div><div>+</div><div>+ virtual void *getPointerToNamedFunction(const std::string &Name,</div><div>+ bool AbortOnFailure = true);</div></blockquote><blockquote type="cite"><div>+</div><div>+ // We need do it before execute on some platforms.</div><div>+ virtual void invalidateInstructionCache();</div><div>+</div><div>+ // The MCJITMemoryManager doesn't use the following functions, so we don't</div><div>+ // need implement them.</div><div>+ virtual void setMemoryWritable() {};</div><div>+ virtual void setMemoryExecutable() {};</div><div>+ virtual void setPoisonMemory(bool poison) {};</div><div>+ virtual void AllocateGOT() {};</div></blockquote><blockquote type="cite"><div>+ virtual uint8_t *getGOTBase() const { return 0; };</div><div>+ virtual uint8_t *startFunctionBody(const Function *F,</div><div>+ uintptr_t &ActualSize){ return 0; };</div><div>+ virtual uint8_t *allocateStub(const GlobalValue* F, unsigned StubSize,</div><div>+ unsigned Alignment) { return 0; };</div><div>+ virtual void endFunctionBody(const Function *F, uint8_t *FunctionStart,</div><div>+ uint8_t *FunctionEnd) { };</div><div>+ virtual uint8_t *allocateSpace(intptr_t Size, unsigned Alignment) { return 0; };</div><div>+ virtual uint8_t *allocateGlobal(uintptr_t Size, unsigned Alignment) { return 0; };</div><div>+ virtual void deallocateFunctionBody(void *Body) { };</div><div>+ virtual uint8_t* startExceptionTable(const Function* F,</div><div>+ uintptr_t &ActualSize) { return 0; };</div><div>+ virtual void endExceptionTable(const Function *F, uint8_t *TableStart,</div><div>+ uint8_t *TableEnd, uint8_t* FrameRegister) { };</div><div>+ virtual void deallocateExceptionTable(void *ET){ };</div></blockquote><div><br></div><div><div>If these are unused, we should put an llvm_unreachable() inside them, or an assert() at least. Since we don't expect them to be called, we want the system to complain loudly if anything breaks our assumptions.</div><div><br></div><div>If they're used, but we have nothing useful to do in them, then the comment should be updated to be more clear on that point.</div><br><blockquote type="cite"></blockquote></div><div>It's not clear to me which is which from what's here. Since lli is often used as a reference point for others developing their own JIT drivers, it's helpful to spell things out as explicitly as we can both what we're doing and why.</div><br><blockquote type="cite"><div>+};</div><div>+</div><div>+uint8_t *LLIMCJITMemoryManager::allocateDataSection(uintptr_t Size,</div><div>+ unsigned Alignment,</div><div>+ unsigned SectionID) {</div></blockquote><div><br></div><div>Indentation on the following arguments is off by a space for this and the next function.</div><br><blockquote type="cite"><div>+ if (!Alignment)</div><div>+ Alignment = 1;</div></blockquote><div><br></div><div>We want alignment, for certain. The sections need to be aligned to the greatest alignment of anything contained in them. One would hope that the caller (via whatever created the object file) would know that and would be passing in a non-zero alignment. I'm not sure that's true in all cases, though, so using a generous default alignment is a reasonable fallback. I believe 16-byte alignment is typical for lots of targets, and is larger than those that differ, so that's probably a reasonable default.</div><br><blockquote type="cite"><div>+ uint8_t *Addr = (uint8_t*)calloc((Size+Alignment-1)/Alignment,Alignment);</div><div>+ AllocatedDataMem.push_back(sys::MemoryBlock(Addr, Size));</div><div>+ return Addr;</div><div>+}</div><div>+</div><div>+uint8_t *LLIMCJITMemoryManager::allocateCodeSection(uintptr_t Size,</div><div>+ unsigned Alignment,</div><div>+ unsigned SectionID) {</div></blockquote><blockquote type="cite"><div>+ if (!Alignment)</div><div>+ Alignment = 1;</div></blockquote><div><br></div><div>We could probably have a smaller default alignment for code than for data, but there's really not a lot of point to being that picky. I'd just use 16 here as well for simplicity.</div><div><br></div><blockquote type="cite"><div>+</div><div>+ unsigned NeedAllocate = Alignment*((Size+Alignment-1)/Alignment+1);</div><div>+ uintptr_t Addr = 0;</div><div>+ // Lookup free memory block with the enough size.</div></blockquote><div><br></div><div>I suggest a bit more verbose comment here. Something like:</div><div><br></div><div>"Look in the list of free code memory regions and use a block there if one is available."</div><br><blockquote type="cite"><div>+ for (int i = 0, e = FreeCodeMem.size(); i != e; ++i) {</div><div>+ sys::MemoryBlock &MB = FreeCodeMem[i];</div><div>+ if (MB.size() >= NeedAllocate) {</div><div>+ Addr = (uintptr_t)MB.base();</div><div>+ uintptr_t EndOfBlock = Addr + MB.size();</div><div>+ // Allign the address.</div></blockquote><div><br></div><div>s/Allign/Align/</div><br><blockquote type="cite"><div>+ Addr = (Addr + Alignment-1) & ~(uintptr_t)(Alignment-1);</div><div>+ // Store cutted free memory block.</div><div>+ FreeCodeMem[i] = sys::MemoryBlock((void*)(Addr+Size),</div><div>+ EndOfBlock-Addr-Size);</div><div>+ break;</div></blockquote><div><br></div><div>Just return the address directly here rather than breaking out of the loop.</div><br><blockquote type="cite"><div>+ }</div><div>+ }</div><div>+ if (!Addr) {</div></blockquote><div><br></div><div>With the early return above when we find a free block, we don't need this conditional at all.</div><br><blockquote type="cite">+ // If existed block not found, allocate new block.</blockquote><div><br></div><div>I'd expand this a touch. Something like, "No pre-allocated free block was large enough. Allocate a new memory region."</div><br><blockquote type="cite"><div>+ sys::MemoryBlock MB = sys::Memory::AllocateRWX(NeedAllocate, 0, 0);</div><div>+</div><div>+ AllocatedCodeMem.push_back(MB);</div><div>+ Addr = (uintptr_t)MB.base();</div><div>+ uintptr_t EndOfBlock = Addr + MB.size();</div><div>+ // Allign the address.</div><div>+ Addr = (Addr + Alignment-1) & ~(uintptr_t)(Alignment-1);</div><div>+ // The AllocateRWX may allocate much more memory than we need. In this</div><div>+ // case we will store unused memory as free memory block.</div></blockquote><div><br></div><div>Grammar tweak:</div><div><br></div><div>"In this case, we store the unused memory as a free memory block."</div><br><blockquote type="cite"><div>+ unsigned FreeSize = EndOfBlock-Addr-Size;</div><div>+ if (FreeSize > 16) {</div><div>+ FreeCodeMem.push_back(sys::MemoryBlock((void*)(Addr+Size), FreeSize));</div><div>+ }</div></blockquote><div><br></div><div>No need for enclosing compound statement braces here since the body is a single statement.</div><br><blockquote type="cite"><div>+ }</div><div>+ // Return alligned address</div><div>+ return (uint8_t*)Addr;</div><div>+}</div><div>+</div><div>+void LLIMCJITMemoryManager::invalidateInstructionCache() {</div><div>+ for (int i = 0, e = AllocatedCodeMem.size(); i != e; ++i) {</div><div>+ sys::Memory::InvalidateInstructionCache(AllocatedCodeMem[i].base(),</div><div>+ AllocatedCodeMem[i].size());</div><div>+ }</div></blockquote><div><br></div><div>No need for enclosing compound statement braces.</div><br><blockquote type="cite"><div>+}</div><div>+</div><div>+void *LLIMCJITMemoryManager::getPointerToNamedFunction(const std::string &Name,</div><div>+ bool AbortOnFailure) {</div><div>+#if defined(__linux__)</div><div>+ //===--------------------------------------------------------------------===//</div><div>+ // Function stubs that are invoked instead of certain library calls</div><div>+ //</div><div>+ // Force the following functions to be linked in to anything that uses the</div><div>+ // JIT. This is a hack designed to work around the all-too-clever Glibc</div><div>+ // strategy of making these functions work differently when inlined vs. when</div><div>+ // not inlined, and hiding their real definitions in a separate archive file</div><div>+ // that the dynamic linker can't see. For more info, search for</div><div>+ // 'libc_nonshared.a' on Google, or read<span class="Apple-converted-space"> </span><a href="http://llvm.org/PR274" target="_blank">http://llvm.org/PR274</a>.</div><div>+ if (Name == "stat") return (void*)(intptr_t)&stat;</div><div>+ if (Name == "fstat") return (void*)(intptr_t)&fstat;</div><div>+ if (Name == "lstat") return (void*)(intptr_t)&lstat;</div><div>+ if (Name == "stat64") return (void*)(intptr_t)&stat64;</div><div>+ if (Name == "fstat64") return (void*)(intptr_t)&fstat64;</div><div>+ if (Name == "lstat64") return (void*)(intptr_t)&lstat64;</div><div>+ if (Name == "atexit") return (void*)(intptr_t)&atexit;</div><div>+ if (Name == "mknod") return (void*)(intptr_t)&mknod;</div><div>+#endif // __linux__</div><div>+</div><div>+ const char *NameStr = Name.c_str();</div><div>+ void *Ptr = sys::DynamicLibrary::SearchForAddressOfSymbol(NameStr);</div><div>+ if (Ptr) return Ptr;</div><div>+</div><div>+ // If it wasn't found and if it starts with an underscore ('_') character,</div><div>+ // try again without the underscore.</div><div>+ if (NameStr[0] == '_') {</div><div>+ Ptr = sys::DynamicLibrary::SearchForAddressOfSymbol(NameStr+1);</div><div>+ if (Ptr) return Ptr;</div><div>+ }</div><div>+</div><div>+ if (AbortOnFailure) {</div></blockquote><div><br></div><div>No need for enclosing compound statement braces.</div><br><blockquote type="cite">+ report_fatal_error("Program used external function '"+Name+</blockquote><br>Spaces around the "+" operators.</div><div><br><blockquote type="cite"><div>+ "' which could not be resolved!");</div><div>+ }</div><div>+ return 0;</div><div>+}</div><div>+</div><div>+LLIMCJITMemoryManager::~LLIMCJITMemoryManager() {</div><div>+ for (unsigned i = 0, e = AllocatedCodeMem.size(); i != e; ++i)</div><div>+ sys::Memory::ReleaseRWX(AllocatedCodeMem[i]);</div><div>+ for (unsigned i = 0, e = AllocatedDataMem.size(); i != e; ++i)</div><div>+ free(AllocatedDataMem[i].base());</div><div>+}</div><div>+</div><div> //===----------------------------------------------------------------------===//</div><div> // main Driver function</div><div> //</div><div>@@ -233,8 +394,11 @@</div><div> Mod->setTargetTriple(Triple::normalize(TargetTriple));</div><div> </div><div> // Enable MCJIT if desired.</div><div>+ LLIMCJITMemoryManager *JMM = 0;</div><div> if (UseMCJIT && !ForceInterpreter) {</div><div> builder.setUseMCJIT(true);</div><div>+ JMM = new LLIMCJITMemoryManager();</div><div>+ builder.setJITMemoryManager(JMM);</div><div> }</div><div> </div><div> CodeGenOpt::Level OLvl = CodeGenOpt::Default;</div><div>@@ -265,6 +429,9 @@</div><div> exit(1);</div><div> }</div></blockquote><blockquote type="cite"><div> </div><div>+ if (JMM)</div><div>+ JMM->invalidateInstructionCache();</div></blockquote><div><br></div><div>A comment explaining why we need to do this would be good.<br><blockquote type="cite"></blockquote></div><br><blockquote type="cite"><div>+</div><div> // The following functions have no effect if their respective profiling</div><div> // support wasn't enabled in the build configuration.</div><div> EE->RegisterJITEventListener(</div><div>Index: tools/llvm-rtdyld/llvm-rtdyld.cpp</div><div>===================================================================</div><div>--- tools/llvm-rtdyld/llvm-rtdyld.cpp<span class="Apple-tab-span" style="white-space: pre; ">
</span>(revision 156826)</div><div>+++ tools/llvm-rtdyld/llvm-rtdyld.cpp<span class="Apple-tab-span" style="white-space: pre; ">
</span>(working copy)</div><div>@@ -63,20 +63,37 @@</div><div> return 0;</div><div> }</div><div> </div><div>+ virtual void clearCache();</div></blockquote><div><br></div><div>A comment explaining why we need to do this would be good.<br><blockquote type="cite"></blockquote></div><br><blockquote type="cite"><div>+</div><div> };</div><div> </div><div> uint8_t *TrivialMemoryManager::allocateCodeSection(uintptr_t Size,</div><div> unsigned Alignment,</div><div> unsigned SectionID) {</div><div>- return (uint8_t*)sys::Memory::AllocateRWX(Size, 0, 0).base();</div><div>+ sys::MemoryBlock MB = sys::Memory::AllocateRWX(Size, 0, 0);</div><div>+ FunctionMemory.push_back(MB);</div><div>+ return (uint8_t*)MB.base();</div><div> }</div><div> </div><div> uint8_t *TrivialMemoryManager::allocateDataSection(uintptr_t Size,</div><div> unsigned Alignment,</div><div> unsigned SectionID) {</div><div>- return (uint8_t*)sys::Memory::AllocateRWX(Size, 0, 0).base();</div><div>+ sys::MemoryBlock MB = sys::Memory::AllocateRWX(Size, 0, 0);</div><div>+ DataMemory.push_back(MB);</div><div>+ return (uint8_t*)MB.base();</div><div> }</div><div> </div><div>+void TrivialMemoryManager::clearCache() {</div><div>+ for (int i = 0, e = FunctionMemory.size(); i != e; ++i) {</div><div>+ sys::Memory::InvalidateInstructionCache(FunctionMemory[i].base(),</div><div>+ FunctionMemory[i].size());</div><div>+ }</div><div>+ for (int i = 0, e = DataMemory.size(); i != e; ++i) {</div><div>+ sys::Memory::InvalidateInstructionCache(DataMemory[i].base(),</div><div>+ DataMemory[i].size());</div><div>+ }</div></blockquote><div>No need for enclosing compound statement braces here since the body is a single statement.</div><br><blockquote type="cite"><div>+}</div><div>+</div><div> static const char *ProgramName;</div><div> </div><div> static void Message(const char *Type, const Twine &Msg) {</div><div>@@ -113,6 +130,8 @@</div><div> </div><div> // Resolve all the relocations we can.</div><div> Dyld.resolveRelocations();</div><div>+ // Invalidate cache before execute.</div><div>+ MemMgr->clearCache();</div><div> </div><div> // FIXME: Error out if there are unresolved relocations.</div><div> </div></blockquote></div><div><br></div><div><br></div><div><br></div><div><br></div><br><div><div>On May 15, 2012, at 11:50 AM, Danil Malyshev <<a href="mailto:dmalyshev@accesssoftek.com">dmalyshev@accesssoftek.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="font-family: Tahoma; direction: ltr; font-size: x-small; "><div>Hi Jim,</div><div><font face="tahoma"></font> </div><div><font face="tahoma">I see, it's should be in the JITMemoryManager instead of the RTDyldMemoryManager.</font></div><div><font face="tahoma"></font> </div><div><font face="tahoma">Please review attached the patch. It's adds LLIMCJITMemoryManager to lli.</font></div><div><font face="tahoma">The another way is add the clear cache to the DefaultJITMemoryManager, but attached way is more<span class="Apple-converted-space"> </span><span id="result_box" lang="en" class="short_text"><span class="hps">flexible for MCJIT tasks</span></span>.</font></div><div><font face="tahoma"></font> </div><div><font face="tahoma"></font><font size="2" face="Tahoma"></font> </div><div><font face="tahoma">Regards,</font></div><div><font face="tahoma">Danil</font></div><div><font face="tahoma"></font> </div><div id="divRpF827210" style="direction: ltr; "><hr tabindex="-1"><font size="2" face="Tahoma"><b>From:</b><span class="Apple-converted-space"> </span>Jim Grosbach [<a href="mailto:grosbach@apple.com">grosbach@apple.com</a>]<br><b>Sent:</b><span class="Apple-converted-space"> </span>Monday, May 14, 2012 9:55 AM<br><b>To:</b><span class="Apple-converted-space"> </span>Danil Malyshev<br><b>Cc:</b><span class="Apple-converted-space"> </span><a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br><b>Subject:</b><span class="Apple-converted-space"> </span>Re: [llvm-commits] [llvm] [Patch] Add RuntimeDyld.invalidateEmittedSectionsCache()<br></font><br></div><div></div><div><div>Hi Danil,</div><div><br></div><div>I'm not sure what additional information you're looking for. The logic you're wanting to add belongs in the memory manager of the client application, not the MCJIT. For example, in the case of lli, it should be part of the TrivialMemoryManager there.</div><div><br></div><div>Note that the old JIT did this differently, as it assumed it wasn't ever going to deal with a remote target. It could, and did, make lots of assumptions about that. As such, be wary of using its code paths as a guide for how the MCJIT should work.</div><div><br></div><div>-Jim</div><div><br></div><br><div><div>On May 14, 2012, at 9:49 AM, Danil Malyshev <<a href="mailto:dmalyshev@accesssoftek.com">dmalyshev@accesssoftek.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="font-family: Tahoma; direction: ltr; font-size: x-small; "><div>Ping.</div><div><font face="tahoma"></font> </div><div><font face="tahoma"></font> </div><div><font face="tahoma">Regards,</font></div><div><font face="tahoma">Danil</font></div><div> </div><div dir="ltr"><font size="2" face="Tahoma"></font> </div><div id="divRpF115907" style="direction: ltr; "><hr tabindex="-1"><font size="2" face="Tahoma"><b>From:</b><span class="Apple-converted-space"> </span><a href="mailto:llvm-commits-bounces@cs.uiuc.edu">llvm-commits-bounces@cs.uiuc.edu</a><span class="Apple-converted-space"> </span>[<a href="mailto:llvm-commits-bounces@cs.uiuc.edu">llvm-commits-bounces@cs.uiuc.edu</a>] On Behalf Of Danil Malyshev [<a href="mailto:dmalyshev@accesssoftek.com">dmalyshev@accesssoftek.com</a>]<br><b>Sent:</b><span class="Apple-converted-space"> </span>Tuesday, May 08, 2012 5:50 PM<br><b>To:</b><span class="Apple-converted-space"> </span>Jim Grosbach<br><b>Cc:</b><span class="Apple-converted-space"> </span><a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br><b>Subject:</b><span class="Apple-converted-space"> </span>Re: [llvm-commits] [llvm] [Patch] Add RuntimeDyld.invalidateEmittedSectionsCache()<br></font><br></div><div></div><div><div style="font-family: Tahoma; direction: ltr; font-size: x-small; "><div>Hi Jim,</div><div><font face="tahoma"></font> </div><div>Yes, I agree that it's client application job. But the MCJIT hard linked with hosted platform. It loads hosted library, it executes code on the host machine and etc. JIT and MCJIT was hidden from appication by EngineBuilder, their memory managers hidden too. The JIT does it for own code, I believe the MCJIT should do it too.</div><div>The remote JIT will not be based by MCJIT, it's will be something new, with own memory manager inherited from RTDyldMemoryManager and in this case the remote client application will be cares about their cache.<br></div><div><font face="tahoma"></font> </div><div><font face="tahoma">Regards,</font></div><div><font face="tahoma">Danil</font></div><div dir="ltr"><font size="2" face="Tahoma"></font> </div><div id="divRpF163767" style="direction: ltr; "><hr tabindex="-1"><font size="2" face="Tahoma"><b>From:</b><span class="Apple-converted-space"> </span>Jim Grosbach [<a href="mailto:grosbach@apple.com">grosbach@apple.com</a>]<br><b>Sent:</b><span class="Apple-converted-space"> </span>Tuesday, May 08, 2012 4:24 PM<br><b>To:</b><span class="Apple-converted-space"> </span>Danil Malyshev<br><b>Cc:</b><span class="Apple-converted-space"> </span><a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br><b>Subject:</b><span class="Apple-converted-space"> </span>Re: [llvm-commits] [llvm] [Patch] Add RuntimeDyld.invalidateEmittedSectionsCache()<br></font><br></div><div></div><div>Hi Danil,<div><br></div><div>This is closer, but not quite. By the client's memory manager, I mean the application. This functionality shouldn't be in the core MC-JIT at all. For example, it belongs in the TrivialMemoryManager in llvm-rtdyld.cpp. That includes keeping the list of allocations and sections. Consider a remote client. The MemoryBlock map you're creating here will refer to the local copy, not the memory that's actually on the target where it'll be executed. The code that knows how to map between the two is the client's memory manager, so that's where this logic belongs as well.</div><div><br></div><div>-Jim</div><div><br><div><div>On May 8, 2012, at 4:09 PM, Danil Malyshev <<a href="mailto:dmalyshev@accesssoftek.com">dmalyshev@accesssoftek.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="font-family: Tahoma; direction: ltr; font-size: x-small; "><div><div>Hi,</div><div><font face="tahoma"></font> </div><div><font face="tahoma">Please review changed the patch.</font></div><div><font face="tahoma">This patch adds finalize() to RTDyldMemoryManager, and implements it for MCJITMemoryManager as invalidate instruction cache.</font></div><div><font face="tahoma"></font> </div><div> </div><div><font face="tahoma">Regards,</font></div><div><font face="tahoma">Danil</font></div><div><font face="tahoma"></font> </div></div><div dir="ltr"><font size="2" face="Tahoma"></font> </div><div id="divRpF625534" style="direction: ltr; "><hr tabindex="-1"><font size="2" face="Tahoma"><b>From:</b><span class="Apple-converted-space"> </span>Jim Grosbach [<a href="mailto:grosbach@apple.com">grosbach@apple.com</a>]<br><b>Sent:</b><span class="Apple-converted-space"> </span>Monday, May 07, 2012 4:16 PM<br><b>To:</b><span class="Apple-converted-space"> </span>Danil Malyshev<br><b>Cc:</b><span class="Apple-converted-space"> </span><a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br><b>Subject:</b><span class="Apple-converted-space"> </span>Re: [llvm-commits] [llvm] [Patch] Add RuntimeDyld.invalidateEmittedSectionsCache()<br></font><br></div><div></div><div><div>Hi Danil,</div><div><br></div>That's not the RuntimeDyld's job. That functionality belongs in elsewhere, probably in the client's memory manager implementation where it's hooked into copying the compiled code into the target's address space. For a hosted platform, something similar just w/o the copying.<div><br></div><div>-Jim</div><div><br><div><div><div>On May 7, 2012, at 2:09 PM, Danil Malyshev <<a href="mailto:dmalyshev@accesssoftek.com">dmalyshev@accesssoftek.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><div style="font-family: Tahoma; direction: ltr; font-size: x-small; "><div style="margin-top: 0px; margin-bottom: 0px; ">Hi everyone,</div><p style="margin-top: 0px; margin-bottom: 0px; "> </p><div style="margin-top: 0px; margin-bottom: 0px; ">Please review attached the patch.</div><div style="margin-top: 0px; margin-bottom: 0px; ">This patch adds invalidateEmmittedSectionsCache() to the RuntimeDyld and uses it in the MCJIT after resolve relocations.<br>The MCJIT works unstable on the ARM platforms without it.<br>This patch haven't any tests because I want to commit the common ExecutionEngine/MCJIT tests after attached the patch will be committed. These tests will cover it.<br></div><div></div><div dir="ltr"><font size="2" face="Tahoma">Regards,</font></div><div dir="ltr"><font face="tahoma">Danil</font></div></div><span><RuntimeDyld_invalidateEmittedSectionsCache-01.patch></span>_______________________________________________<br>llvm-commits mailing list<br><a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br><a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br></blockquote></div><br></div></div></div></div><span><RTDyldMemoryManager_finalize-01.patch></span></blockquote></div></div></div></div></div></div></blockquote></div><br></div></div><span><LLIMCJITMemoryManager.patch></span></blockquote></div><br></div></div><span><LLIMCJITMemoryManager-02.patch></span></div></blockquote></div><br></div></body></html>