<html><head><meta http-equiv="Content-Type" content="text/html; charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; line-break: after-white-space;" class=""><br class=""><div><br class=""><blockquote type="cite" class=""><div class="">On Apr 10, 2018, at 2:30 PM, Leonard Mosescu <<a href="mailto:mosescu@google.com" class="">mosescu@google.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class="">Thanks Greg! It makes sense and looking at the code it's already implemented along those lines: Target::GetSharedModule() defaults to Platform::GetSharedModule() if the initial attempt to get the module fails.<div class=""><br class=""></div><div class="">The part I'd like to understand is if there's a precedence for modules which don't have any accessible file image (local or remote). Is everything expected to work if we create placeholder Module & ModuleSpecs?</div></div></div></blockquote><div><br class=""></div>No, it is up to the platform to be able to track down files that don't exist locally. Most platforms do nothing and will return an empty module shared pointer. We need a file to use or we will just not have any info.</div><div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class="">(it seems that the current implementation assumes that we have a file somewhere. Ex. even creating a Module from a ModuleSpec will still try to map the source ModuleSpec to some files).</div></div></div></blockquote><div><br class=""></div>Yes. Right now with only the path, we will load the file if it exists on disk since no UUID was specified in the ModuleSpec which is really bad and can lead to incorrect info being displayed.</div><div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class=""><br class=""></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span style="color:rgb(34,34,34);font-family:arial,sans-serif;font-size:12.8px;font-style:normal;font-variant-ligatures:normal;font-variant-caps:normal;font-weight:400;letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline" class="">At Apple, we call "dsymForUUID <UUID>" which, if global defaults were set to point at Apple's build servers, would go out and download the correct file for us and store it locally in a cache for future use.</span></blockquote><div class=""><br class=""></div><div class="">Just curious, what happens if the download fails? Is the corresponding module skipped? (is this strictly about the dSYMs or the same mechanism works for the Mach-O binaries?)</div></div></div></blockquote><div><br class=""></div>It will block until the module is downloaded, and it can and often does fail and returns an error that can be displayed. When we need to download large debug info files, it creates delays with no user interaction and often leads to people wondering what is going on. Not optimal, but it does work if you wait for it.</div><div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class=""><div class=""><br class=""></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><span style="color:rgb(34,34,34);font-family:arial,sans-serif;font-size:12.8px;font-style:normal;font-variant-ligatures:normal;font-variant-caps:normal;font-weight:400;letter-spacing:normal;text-align:start;text-indent:0px;text-transform:none;white-space:normal;word-spacing:0px;background-color:rgb(255,255,255);text-decoration-style:initial;text-decoration-color:initial;float:none;display:inline" class="">That way if you create a target that is a minidump on a different system (macOS, linux, etc), the platform would be remote-windows. </span><br class=""></blockquote><div class=""><br class=""></div><div class="">Not sure if I understand this one, core & minidumps are currently not using any of the the remote debugging machinery, right? Are you suggesting changing that?</div></div></div></div></blockquote><div><br class=""></div><div>No. Each binary knows how to tell LLDB what target triple it is. PECOFF files will always map to the host windows platform or remote-windows when not on a Windows host computer. If you say "file a.out" and give it a PECOFF file, just do "target list" and see the platform was selected for you. Since the Minidump is specific to Windows, it should select the right platform for you. If it doesn't we will need to fix that.</div><div><br class=""></div><div>Does the mini dump format have the UUID or some sort of checksum of the file in it?</div><div><br class=""></div><blockquote type="cite" class=""><div class=""><div class="gmail_extra"><br class=""><div class="gmail_quote">On Tue, Apr 10, 2018 at 11:56 AM, Greg Clayton <span dir="ltr" class=""><<a href="mailto:clayborg@gmail.com" target="_blank" class="">clayborg@gmail.com</a>></span> wrote:<br class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word;line-break:after-white-space" class=""><br class=""><div class=""><span class=""><br class=""><blockquote type="cite" class=""><div class="">On Apr 10, 2018, at 11:32 AM, Leonard Mosescu via lldb-dev <<a href="mailto:lldb-dev@lists.llvm.org" target="_blank" class="">lldb-dev@lists.llvm.org</a>> wrote:</div><br class="m_5255565185019921136Apple-interchange-newline"><div class=""><div dir="ltr" class="">I'm looking at how the LLDB minidump reader creates the list of modules:<div class=""><br class=""></div><blockquote style="margin:0 0 0 40px;border:none;padding:0px" class=""><font face="monospace, monospace" class=""><span style="white-space:pre-wrap;color:rgb(0,0,255)" class="">void</span><span style="white-space:pre-wrap" class=""> </span><span style="white-space:pre-wrap;color:rgb(121,94,38)" class="">ProcessMinidump::<wbr class="">ReadModuleList</span><span style="white-space:pre-wrap" class="">() {</span></font><blockquote style="margin:0 0 0 40px;border:none;padding:0px" class=""><div style="background-color:rgb(255,255,255);font-weight:normal;line-height:18px;white-space:pre-wrap" class=""><div class=""><font face="monospace, monospace" class="">...</font></div></div></blockquote><div class=""><div style="background-color:rgb(255,255,255);font-weight:normal;line-height:18px;white-space:pre-wrap" class=""><div class=""><font face="monospace, monospace" class=""><span class=""> </span><span style="color:rgb(0,0,255)" class="">const</span><span class=""> </span><span style="color:rgb(0,0,255)" class="">auto</span><span class=""> file_spec </span><span class="">=</span><span class=""> </span><span style="color:rgb(121,94,38)" class="">FileSpec</span><span class="">(name.</span><span style="color:rgb(121,94,38)" class="">getValue</span><span class="">(), </span><span style="color:rgb(0,0,255)" class="">true</span><span class="">);</span></font></div></div></div><div class=""><div style="background-color:rgb(255,255,255);font-weight:normal;line-height:18px;white-space:pre-wrap" class=""><div class=""><font face="monospace, monospace" class=""><span class=""> ModuleSpec module_spec </span><span class="">=</span><span class=""> file_spec;</span></font></div></div></div><div class=""><div style="background-color:rgb(255,255,255);font-weight:normal;line-height:18px;white-space:pre-wrap" class=""><div class=""><span class=""><font face="monospace, monospace" class=""> Status error;</font></span></div></div></div><div class=""><div style="font-weight:normal;line-height:18px;white-space:pre-wrap" class=""><div class=""><font face="monospace, monospace" class=""><span class=""><span style="background-color:rgb(255,255,255)" class=""> </span><span style="background-color:rgb(255,242,204)" class="">lldb::ModuleSP module_sp </span></span><span style="background-color:rgb(255,242,204)" class=""><span class="">=</span><span class=""> </span><span style="color:rgb(121,94,38)" class="">GetTarget</span><span class="">().</span><span style="color:rgb(121,94,38)" class="">GetSharedModule</span><span class="">(<wbr class="">module_spec, </span><span class="">&</span><span class="">error);</span></span></font></div></div></div><div class=""><div style="background-color:rgb(255,255,255);font-weight:normal;line-height:18px;white-space:pre-wrap" class=""><div class=""><font face="monospace, monospace" class=""><span class=""> </span><span style="color:rgb(175,0,219)" class="">if</span><span class=""> (</span><span class="">!</span><span class="">module_sp </span><span class="">||</span><span class=""> error.</span><span style="color:rgb(121,94,38)" class="">Fail</span><span class="">()) {</span></font></div></div></div><div class=""><div style="background-color:rgb(255,255,255);font-weight:normal;line-height:18px;white-space:pre-wrap" class=""><div class=""><font face="monospace, monospace" class=""><span class=""> </span><span style="color:rgb(175,0,219)" class="">continue</span><span class="">;</span></font></div></div></div><div class=""><div style="background-color:rgb(255,255,255);font-weight:normal;line-height:18px;white-space:pre-wrap" class=""><div class=""><span class=""><font face="monospace, monospace" class=""> }</font></span></div></div></div><blockquote style="margin:0 0 0 40px;border:none;padding:0px" class=""><div class=""><div style="background-color:rgb(255,255,255);font-weight:normal;line-height:18px;white-space:pre-wrap" class=""><div class=""><span class=""><font face="monospace, monospace" class="">...</font></span></div></div></div></blockquote><div class=""><div style="background-color:rgb(255,255,255);font-weight:normal;line-height:18px;white-space:pre-wrap" class=""><div class=""><font face="monospace, monospace" class="">}</font></div></div></div></blockquote><div class=""><div style="background-color:rgb(255,255,255);font-family:"Droid Sans Mono",monospace,monospace,"Droid Sans Fallback";font-weight:normal;font-size:13px;line-height:18px;white-space:pre-wrap" class=""><div class=""></div></div></div><div class=""><br class=""></div><div class="">LLDB currently will insist on finding a local image for the module, which is usually not the case for postmortem debugging on machines different than the the the one where the minidump was created.</div><div class=""><br class=""></div><div class="">I don't see an obvious way to model modules which have no local image (which is still different than the remote scenario where there is a remote module image), am I missing anything?<br class=""></div></div></div></blockquote><div class=""><br class=""></div></span>The lldb_private::Platform is responsible for digging up any binaries for a given target, so this code should be grabbing the platform from the target and using that to get the shared module. That way if you create a target that is a minidump on a different system (macOS, linux, etc), the platform would be remote-windows. </div><div class=""><br class=""></div><div class="">That being said "ModuleSpec" should be filled in with more than just the path. It should specify the UUID info from the mini dump that specifies exactly which version the file that you want. That way if the file on the current system exists, it won't return it unless the path matches. I assume the mini dump has each module's UUID information? If so, set it. If not the file format assumes you will be running the dumping the same machine and it should be updated to include this information. The platform code can then use this UUID info to possible go and fetch the right version from a UUID database, or how ever the platform wants to provide access to certain binaries. At Apple, we call "dsymForUUID <UUID>" which, if global defaults were set to point at Apple's build servers, would go out and download the correct file for us and store it locally in a cache for future use.</div><div class=""><br class=""></div><div class="">So fill in the UUID in ModuleSpec and modify the Platform::GetSharedModule() for your platform to do the right thing is the correct way to go. ProcessMinidump should switch over to using the Platform::GetSharedModule() instead of the target one, or use it after the target one if the target returns an invalid module.</div><div class=""><br class=""></div><div class="">Let me know if you have any more questions,</div><div class=""><br class=""></div><div class="">Greg</div><div class=""><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class=""><br class=""></div><div class="">Thanks!</div><div class="">Lemo.</div><div class=""><br class=""></div><div class=""><br class=""></div><div class=""><br class=""></div></div>
______________________________<wbr class="">_________________<br class="">lldb-dev mailing list<br class=""><a href="mailto:lldb-dev@lists.llvm.org" target="_blank" class="">lldb-dev@lists.llvm.org</a><br class=""><a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/lldb-dev" target="_blank" class="">http://lists.llvm.org/cgi-bin/<wbr class="">mailman/listinfo/lldb-dev</a><br class=""></div></blockquote></div><br class=""></div></blockquote></div><br class=""></div>
</div></blockquote></div><br class=""></body></html>