<div dir="ltr">Sorry, wrong version of patch...</div><div class="gmail_extra"><br><br><div class="gmail_quote">On Fri, Jul 25, 2014 at 1:41 PM, Tong Shen <span dir="ltr"><<a href="mailto:endlessroad@google.com" target="_blank">endlessroad@google.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">Hi Molenda, lldb-commits,<div><br></div><div>For now, x86 assembly profiler will stop after 10 "non-prologue" instructions. In practice it may not be sufficient. For example, we have a hand-written assembly function, which have hundreds of instruction before actual (stack-adjusting) prologue instructions.</div>

<div><br></div><div>One way is to change the limit to 1000; but there will always be functions that break the limit :-) I believe the right thing to do here is parsing all instructions before "ret"/"call" as prologue instructions.</div>

<div><br></div><div>Here's what I changed:</div><div>- For "push %rbx" and "mov %rbx, -8(%rbp)": only add first row for that register. They may appear multiple times in function body. But as long as one of them appears, first appearance should be in prologue(If it's not in prologue, this function will not use %rbx, so these 2 instructions should not appear at all).</div>

<div><div>- Also monitor "add %rsp 0x20".</div><div>- Remove non prologue instruction count.</div><div>- Add "call" instruction detection, and stop parsing after it.</div><div><br></div><div>Thanks.</div>
<span class="HOEnZb"><font color="#888888">
<div><br></div>-- <br><div dir="ltr">Best Regards, Tong Shen</div>
</font></span></div></div>
</blockquote></div><br><br clear="all"><div><br></div>-- <br><div dir="ltr">Best Regards, Tong Shen</div>
</div>