<html><head><meta http-equiv="Content-Type" content="text/html charset=us-ascii"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Apr 26, 2017, at 12:33 PM, David Blaikie <<a href="mailto:dblaikie@gmail.com" class="">dblaikie@gmail.com</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class=""><br class=""><br class=""><div class="gmail_quote"><div dir="ltr" class="">On Wed, Apr 26, 2017 at 11:43 AM Eric Christopher <<a href="mailto:echristo@gmail.com" class="">echristo@gmail.com</a>> wrote:<br class=""></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;"><div dir="ltr" class="">Adding Quentin here...<br class=""><br class=""><div class="gmail_quote"></div></div><div dir="ltr" class=""><div class="gmail_quote"><div dir="ltr" class="">On Wed, Apr 26, 2017 at 11:31 AM Carlo Kok <<a href="mailto:ck@remobjects.com" target="_blank" class="">ck@remobjects.com</a>> wrote:<br class=""></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;"><br class=""><br class="">On 2017-04-26 19:56, Eric Christopher wrote:<br class="">> That's really weird. I'm quite surprised that the entry block was moved<br class="">> so much later in the function but haven't had a chance to look more at<br class="">> it. Probably want to take a look and find out where that's happening and<br class="">> why.<br class=""><br class=""> From irc, thegameg helped me find the -enable-shrink-wrap=false, which<br class="">"fixes" this, although this option doesn't seem to have a switch from<br class="">code, only from the llc command line.<br class=""><br class=""></blockquote><div class=""><br class=""></div></div></div><div dir="ltr" class=""><div class="gmail_quote"><div class="">This is a good point. I've not overly thought about how shrink wrapping is going to correlate with entry/exit blocks and prologues. That said, the whole point of shrink wrapping is that the stack adjustments are hidden.</div><div class=""><br class=""></div><div class="">I'd have to page in that code to make more than a hand wavy "here's how you'll fix this" though. More thoughts right below though...</div></div></div><div dir="ltr" class=""><div class="gmail_quote"><div class=""> <br class=""></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;">Unless I'm missing something obvious, this will always screw up debug<br class="">info on Windows 32bits.<br class=""><br class=""></blockquote><div class=""><br class=""></div></div></div><div dir="ltr" class=""><div class="gmail_quote"><div class="">It's pretty much everywhere and just means that the debugger will have some weird state until you actually hit that point. in the code. The problem is that you probably want the debugger to stop at the "beginning" of the function, but with shrink wrapping you won't have stack adjustments at all for that code and if you wait and put the prologue end at the end of the "stack adjustments" then you likely won't stop at all in the function.</div><div class=""><br class=""></div><div class="">Tricky.</div><div class=""><br class=""></div><div class="">At the moment I'm inclined to believe that this is "correct", but that we really need a better way of distinguishing these entry points.</div><div class=""><br class=""></div><div class="">Adrian/Dave: Any other ideas here?</div></div></div></blockquote><div class=""><br class="">My guess (& this is more a "if someone wants to write patches for this, this is the direction I'd suggest" - since it's not a priority for me to do this work) would be that once the prologue is sunk beneath instructions with other debugloc lines (I think the current theory is that prologue locations have no debugloc at all - so basically as soon as you hit any debugloc) - it's no longer really the prologue. At that point emit the DWARF prologue - describe the value of parameters based on where they are at that point (registers, stack offsets, etc) and if you later reach a prologue that stuffs the values into stack, etc - emit a new location for the variables at that point.<br class=""></div></div></div></div></blockquote><div><br class=""></div><div>I agree.</div><div>I also think the too early prologue_end is mostly a concern for the unwinder in the debugger (if it looks at the prologue_end at all), since variable locations in optimized code are rarely frame-relative and if they are they are typically of the DEBUG_VALUE kind and generate a location list whose first address will be after the "real" function prologue.</div><div><br class=""></div>-- adrian<br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class=""><div class="gmail_quote"><div class=""><br class="">- Dave<br class=""> </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;"><div dir="ltr" class=""><div class="gmail_quote"><div class=""><br class=""></div><div class="">-eric</div></div></div><div dir="ltr" class=""><div class="gmail_quote"><div class=""> </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;">The check in code to enable this calls:<br class=""><br class=""><br class=""> bool usesWindowsCFI() const {<br class=""> return ExceptionsType == ExceptionHandling::WinEH &&<br class=""> <span class="Apple-converted-space"> </span>(WinEHEncodingType != WinEH::EncodingType::Invalid &&<br class=""> WinEHEncodingType != WinEH::EncodingType::X86);<br class=""> }<br class=""><br class="">Where EncodingType::X86: //Windows x86, uses no CFI, just EH tables<br class=""><br class="">The comment seems to imply there are EH tables for i386 Windows, however<br class="">I can't find them.<br class=""><br class="">--<br class="">Carlo Kok<br class="">RemObjects Software</blockquote></div></div></blockquote></div></div></div></blockquote></div><br class=""></body></html>