<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On Thu, Nov 12, 2015 at 9:37 AM, Quentin Colombet <span dir="ltr"><<a href="mailto:qcolombet@apple.com" target="_blank">qcolombet@apple.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi Joseph,<br>
<br>
Thanks for the detail explanation.<br>
<br>
Based on the description, it seems to me the MachineFunction representation is, at least partly, not properly modeling the constraints of the EH code.<br>
Indeed, in the funclets, there is nothing that uses of modify CSRs registers, so it looks like we do not need any prologue and epilogue in that case. I thought that what we were missing is something that expand CATCHRET into "lea BLOCKADER, rax”, i.e., just a pseudo expansion, but not a full prologue and epilogue.<br>
<br>
But anyway, let me ask a couple more questions:<br>
- When you said the funclet needs their own prologue and epilogue my impression is that right now this prologue and epilogue are needlessly identical to the function prologue and epilogue. Is this true or they actually different and this is just an artefact or the test case?<br></blockquote><div><br></div><div>Ideally, funclets would have their own CSR sets. That was difficult to implement in the current framework, so I made them all use the same CSR sets.</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
- Is it worth adding the support for funclet in shrink-wrapping? My impression was that the constraints on EH prologue and epilogue are too tight to have it kicking in.</blockquote><div><br></div><div>I think it's definitely not worth trying to shrink-wrap funclets. It might be worth shrink-wrapping the parent function that happens to use funclets. However, we would have to overcome the Win64 epilogue constraints, and we've decided not to do that now.</div></div></div></div>