<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;">Ping?<div><br><div apple-content-edited="true">
<div style="color: rgb(0, 0, 0); font-family: Helvetica; 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; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space; ">-Quentin</div>
</div>
<br><div style=""><div>On Sep 3, 2013, at 2:16 PM, Quentin Colombet <<a href="mailto:qcolombet@apple.com">qcolombet@apple.com</a>> wrote:</div><br class="Apple-interchange-newline"><blockquote type="cite"><meta http-equiv="Content-Type" content="text/html charset=us-ascii"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">Hi,<div><br></div><div>The proposed patch fixes PR16882: <a href="http://llvm.org/bugs/show_bug.cgi?id=16882">http://llvm.org/bugs/show_bug.cgi?id=16882</a>.</div><div>PR16882 reports a poor code generation issue where we were saving the link register before a call to a noreturn function, whereas it is not needed.</div><div><br></div><div>Thanks for your reviews.</div><div><br></div><div>** Details **</div><div><br></div><div>PEI inserts a save/restore sequence for the link register, according to the information it gets from the MachineRegisterInfo.</div><div>MachineRegisterInfo is populated by the VirtRegMap pass.</div><div>This pass was not aware of noreturn calls and was registering the definitions of these calls the same way as regular operations.</div><div><br></div><div><br></div><div>** Proposed Solution **</div><div><br></div><div>Modify VirtRegPass so that it does not set the isPhysRegUsed information for registers only defined by noreturn calls.</div><div>The rational is that a noreturn call is the "last instruction" of the program (if it returns the behavior is undefined), so everything that is defined by it cannot be used and will not interfere with anything else. Therefore, it is pointless to account for then.</div><div><br></div><div><br></div><div>** Experiments **</div><div><br></div><div><div>I have made functional tests on x86_64 with O3 -fomit-frame-pointer on the llvm test-suite + SPEC.</div><div>I did the same for ARMv7s.</div><div><br></div><div>I have attached the performance numbers for ARMv7s (lower is better). These numbers only reports benches where the patch kicks in and the test runs for more than 1s (to avoid noise).</div></div><div>The Reference column is LLVM r189613 and Test column is LLVM r189613 + the proposed patch.</div><div><br></div><div>Cheers,<br><div apple-content-edited="true">
<div style="font-family: Helvetica; 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-stroke-width: 0px; word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;">-Quentin</div>
</div>
</div></div><span><virtreg.svndiff></span><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><meta http-equiv="Content-Type" content="text/html charset=us-ascii"><div></div></div>
<span><noreturn_perf.txt></span><meta http-equiv="Content-Type" content="text/html charset=us-ascii"><div style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div></div></div>
_______________________________________________<br>llvm-commits mailing list<br><a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br>http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits<br></blockquote></div><br></div></body></html>