<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;">On Apr 27, 2013, at 11:28 AM, Evan Cheng <<a href="mailto:evan.cheng@apple.com">evan.cheng@apple.com</a>> wrote:<br><div>On Apr 27, 2013, at 8:10 AM, Chandler Carruth <<a href="mailto:chandlerc@google.com">chandlerc@google.com</a>> wrote:<br><blockquote type="cite"><div style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><br class="Apple-interchange-newline"><blockquote type="cite"><div dir="ltr">On Fri, Apr 26, 2013 at 11:33 PM, Dan Gohman<span class="Apple-converted-space"> </span><span dir="ltr"><<a href="mailto:dan433584@gmail.com" target="_blank" class="cremed">dan433584@gmail.com</a>></span><span class="Apple-converted-space"> </span>wrote:<br><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin: 0px 0px 0px 0.8ex; border-left-width: 1px; border-left-color: rgb(204, 204, 204); border-left-style: solid; padding-left: 1ex;"><div dir="ltr">To all, I'm moving on and accepting what appears to be the consensus of the list, for now.<br></div></blockquote><div><br></div><div>I want to point out something about this direction that hasn't really come up, but I think deserves some better discussion. I don't think it should be the basis of a decision one way or the other, its more a consequence of the decision.</div><div><br></div><div>At the IR level, we have some great infrastructure that doesn't exist at the MI level:</div><div><br></div><div>- The pass management tools.</div><div>- A verifier that can be run before and after any pass to check the basic invariants.</div><div>- The ability to serialize and deserialize to/from a human understandable (and authorable) form.</div><div><br></div><div>I think before we invest in *significantly* more complexity and logic in the MI layer of the optimizer, we will need it to have these three things. Without them, the work will be considerably harder, and we will continue to be unable to do fine grained testing during the development of new features. We might not need all of the capabilities we have in the IR, but I think we'll need at least those used to orchestrate fine grained testing and validation.</div></div></div></div></blockquote><div><br></div>MI does have a verifier which can be extended if anything is lacking. I'm not seeing how improving MI passes is critical for the an instruction selector. But perhaps I am missing some important details.</div><div style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><br></div><div style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; line-height: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">I agree having the ability to serialize and deserialize the IR is an important missing feature for MI. We had an intern working on this before but it wasn't successful. My vague plan is this area involves instruction selecting directly to a "generic" (and configurable) target. But it's by no means a concrete proposal.</div></blockquote><div><div><br></div><div>...but MI serialization did not fail because of any fundamental problem AFAIK. There simply was an out-of-tree dependency that prevented checkin at the time.</div><div><br></div><div>Command-line driven pass management would be nice for testing. But, the situation for MI passes is already much better than for SD sub-passes.</div><div><br></div><div>A few important things were not made very clear in all the high-level discussion:</div><div><br></div><div>MI can be very easily extended to represent ISD operations. MachineOperand already handles various heterogenous kinds of operands. Adding EVT/MVT would be straightforward.</div><div><br></div><div>MI data-structures (like SD) are ammenable to incremental lowering. Target-specific transforms can easily flip opcodes and add operands. Imagine how efficient operation lowering will be in MI--just an en-masse opcode flip.</div><div><br></div><div>Chris mentioned that we need to be able to mix register class contraints on target instructions with type constraints on ISDs. I believe this can be done in MI without inserting special bitcasts throughout.</div><div><br></div><div>As Krysztof mentioned, we already need a way to express MI->MI patterns. We currently have pass ordering problems between target specific DAG Combine, ISEL, and machine optimizations. Performing simple lowering in one pass and deferring or replaying more complex patterns, like operand folding, would solve the problem. It would be nice to use the same infrastructure for both.</div><div><br></div><div>-Andy</div></div></div></body></html>