<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class="">Hi James,<div class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Nov 18, 2015, at 11:53 AM, James Molloy <<a href="mailto:james@jamesmolloy.co.uk" class="">james@jamesmolloy.co.uk</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: normal; font-weight: normal; letter-spacing: 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;" class="">Hi Quentin,<div class=""><br class=""></div><div class="">I'm really excited to see this happening!</div><div class=""><br class=""></div><div class="">My major question is over the testing story for this. How are we going to write unit tests for GIR?</div></div></div></blockquote><div><br class=""></div><div>Thanks for bringing that up!</div><div>That is a very good question and also one that will require a lot of work to address properly.</div><div><br class=""></div><div>Ultimately, I’d like we are able to write unit tests directly in the MachineInstr representation. Part of the goal of making the IR self contained, i.e., with no back links to LLVM IR, is to make the testing easier.</div><div><br class=""></div><div>Now, to answer the question on how we do that, I have a pragmatic answer, though I am not proud of it:</div><div>We are going to write unit tests with LLVM IR as input and check the MI output of the pass, e.g.,with print-after=IRTranslator.</div><div><br class=""></div><div>That’s not great, but at least we can test now!</div><div><br class=""></div><blockquote type="cite" class=""><div class=""><div dir="ltr" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: 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;" class=""><div class=""> Are you intending to leverage the LIR lowering that noone is using yet?</div></div></div></blockquote><div><br class=""></div><div>That’s a tricky question because I do not intend to work on this in the prototype timeframe and I am not fond of the way this testing works.</div><div>However, yes, I believe that we need to redevelop or leverage the LIR lowering for this purpose. Actually, I was looking for volunteers to work on that during the prototype timeframe, so that we have everything we need when we productize the new framework.</div><div><br class=""></div><div>Interested? :P</div><div><br class=""></div><div>Note: My main concern is that is uses a YAML format, i.e., we cannot dump the output of a machine function and feed into it.</div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: 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;" class=""><div class=""> Will you be using unit/LIT tests right from the start, or adding them in later?</div></div></div></blockquote><div><br class=""></div><div>Definitely right from the start, with the “output” method I mentioned.</div><div>The hope is that a "LIR lowering" like mechanism will be developed along the way and we can migrate tests to the new format when it is ready. If we carefully design this "LIR lowering” format, we may just have to change the RUN line :).</div><div><br class=""></div>Thanks,</div><div>-Quentin<br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: 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;" class=""><div class=""><br class=""></div><div class="">Cheers,</div><div class=""><br class=""></div><div class="">James</div></div><br style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: 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;" class=""><div class="gmail_quote" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: 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;"><div dir="ltr" class="">On Wed, 18 Nov 2015 at 19:27 Quentin Colombet via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:<br class=""></div><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 style="word-wrap: break-word;" class=""><div class="">Hi,<br class=""><font color="#12c00e" class=""><br class=""></font>With this email, I would like to kick-off the development for the next instruction selector that I described during the last LLVM Dev’ Meeting.<br class="">For the motivations, see Jakob’s proposal (<a href="http://lists.cs.uiuc.edu/pipermail/llvmdev/2013-August/064727.html" target="_blank" class="">http://lists.cs.uiuc.edu/pipermail/llvmdev/2013-August/064727.html</a>) and for the proposal, see the slides (Keynote: <a href="http://llvm.org/viewvc/llvm-project/www/trunk/devmtg/2015-10/slides/Colombet-GlobalInstructionSelection.key?view=co" target="_blank" class="">http://llvm.org/viewvc/llvm-project/www/trunk/devmtg/2015-10/slides/Colombet-GlobalInstructionSelection.key?view=co</a> or PDF: <a href="http://llvm.org/viewvc/llvm-project/www/trunk/devmtg/2015-10/slides/Colombet-GlobalInstructionSelection.pdf?revision=252430&view=co" target="_blank" class="">http://llvm.org/viewvc/llvm-project/www/trunk/devmtg/2015-10/slides/Colombet-GlobalInstructionSelection.pdf?revision=252430&view=co</a>) or the talk (<a href="https://www.youtube.com/watch?v=F6GGbYtae3g&list=PL_R5A0lGi1AA4Lv2bBFSwhgDaHvvpVU21&index=2" target="_blank" class="">https://www.youtube.com/watch?v=F6GGbYtae3g&list=PL_R5A0lGi1AA4Lv2bBFSwhgDaHvvpVU21&index=2</a>).</div><div class=""><font class=""><br class="">TL;DR This is happening now, feedbacks invited!<br class=""><br class=""></font>*** Context ***<br class=""><font color="#12c00e" class=""><br class=""></font>During the last LLVM Dev’ Meeting, I have presented a proposal for the next instruction selector, GlobalISel. The proposal is basically summarized in "High Level Prototype Design” and “Roadmap”. (If you want further details, feel free to reach me.)<br class=""><font color="#00afcd" class=""><br class=""></font>The first step of the development plan is to prototype the new framework on open source. The idea is to <b class="">start prototyping now(!)</b> and have the discussion ongoing in parallel. The reason of such approach is to have code that can be used to inform those discussions, e.g., by collecting data and trying different designs approaches. Regarding the discussion, I have listed a few points where your feedbacks would be particularly appreciated (see Feedback Invite).</div><div class=""><font color="#00afcd" class=""><br class=""></font>Also, as I have mentioned in my talk, some issues are controversial but I expect them to be resolved during prototype development. Specifically theses concern aspects of legalization (should parts of it be done at the LLVM IR level or all at the MI level?) and code re-use for instruction combiner. Please feel free to bring up your specific concern as I move along with the development plan.<br class=""><font color="#00afcd" class=""><br class=""></font>I expect the design to evolve with our experimental findings and your feedbacks and contributions.<br class="">Nonetheless, we expect to nail down some design decisions once and for all as the prototype progresses. I have highlighted them with the following pattern <b class="">[final]</b>.<br class=""><font color="#12c00e" class=""><br class=""><br class=""><br class=""></font>*** Feedback Invite ***<br class=""><font color="#00afcd" class=""><br class=""></font>If you follow and support this work you need to be aware of three things and I am eager to hear your feedback and thoughts about them: the overall goals of Global ISel, the goals of the prototype, and the impact of the prototype work on backend design. <br class=""><font color="#00afcd" class=""><br class=""></font>In the section “Goals", I defined (repeated for people that saw the talk) the goals for the Global ISel design.<br class="">- Do you see anything missing?<br class="">- Do you see something that should not be there? <br class=""><font color="#00afcd" class=""><br class=""></font>The prototype will answer critical design questions (see “Design Questions the Prototype Addresses at the End of M1" for examples) before the actual design of Gobal ISel is finalized, but it cannot cover everything.<br class="">Specifically we will <b class="">*not*</b> look into improving TableGen or reuse InstCombine (see “ Proposed Approach” for the rational). Please let me know if you see any issue with that.<br class=""><font color="#00afcd" class=""><br class=""></font>There is also basic ground work needed to prepare for Global ISel and I need to extend the core MachineInstr-level APIs as explained during the talk. For this, I prepared sketches of patches to illustrate them and describe the details in the “Implications” section below. Please have a look at the patches to have a better idea of the expected impact.<br class=""><font color="#00afcd" class=""><br class=""></font>If there is anything else you want to discuss related to Global ISel feel free to reach me. In particular, several people expressed their interests during the LLVM Dev Meeting in contributing to the project. Let me know what is your area of interest, so that we can coordinate our efforts.<br class="">Anyhow, please add [GlobalISel] in the subject line to help categorizing the emails.<br class=""><font color="#00afcd" class=""><br class=""><br class=""><br class=""></font>*** Goals ***<br class=""><font color="#12c00e" class=""><br class=""></font>The high level goals of the new instruction selector are:<br class="">- Global instruction selector.<br class="">- Fast instruction selector.<br class="">- Shared code path for fast and good instruction selection.<br class="">- IR that represents ISA concepts better.<br class="">- More flexible instruction selector.<br class="">- Easier to maintain/understand framework, in particular legalization.<br class="">- Self contained machine representation, no back links to LLVM IR.<br class="">- No change to LLVM IR.<br class=""><font color="#5856d6" class=""><br class=""></font>Note: The goals are common to all targets. In particular, we do not intend to work on target specific feature for the prototype.<br class="">The bottom line is please make sure those goals are compatible with what you want to achieve for your target, even if your requirement does not get listed here.<br class=""><br class=""><font color="#12c00e" class=""><br class=""><br class=""></font>*** Proposed Approach ***<br class=""><font color="#12c00e" class=""><br class=""></font>In this section, I describe the approach I plan to pursue in the prototype and the roadmap to get there. The final design will flow out of it.<br class=""><font color="#12c00e" class=""><br class=""></font>For this prototype, we purposely exclude any work to improve or use TableGen or InstCombine <b class="">[final].</b> We will keep in mind however, that some of the C++ code we write will be table-generated at some point.<br class="">The rational is that we do not want to lay down a new TableGen/InstCombine infrastructure before being able to work on the ISel framework itself.<br class=""><font color="#12c00e" class=""><br class=""></font>The prototype vehicle will be <b class="">AArch64</b>. None of the changes for GlobalISel will negatively impact the existing ISel.<br class=""><font color="#12c00e" class=""><br class=""><br class=""></font>** High Level Prototype Design **<br class=""><font color="#12c00e" class=""><br class=""></font>As shown in the talk, the expected pipeline for the prototype is:<br class=""><b class="">LLVM IR </b>-> IRTranslator -> <b class="">Generic (G) MachineInstr</b> -> Legalizer -> RegBankSelect -> Select -> <b class="">MachineInstr</b><br class=""><font color="#12c00e" class=""><br class=""></font>Where:<br class="">- Terms in <b class="">bold</b> are intermediate representations.<br class="">- Generic MachineInstrs are machine instructions with a generic opcode, e.g., ADD, COPY.</div><div class="">- IRTranslator: Translate LLVM IR to (G) MachineInstr.<br class="">- Legalizer: Legalize illegal (G) MachineInstr to legal (G) MachineInstr.<br class="">- RegBankSelect: Assign virtual register with size to virtual register with Register Bank.<br class="">- Select: Translate the remaining (G) MachineInstr to MachineIntr.<br class=""><br class=""><font color="#00afcd" class=""><br class=""><br class=""></font>** Implications **<br class=""><font color="#00afcd" class=""><br class=""></font>As part of the bring-up of the prototype, we need to extend some of the core MachineInstr-level APIs:<br class=""> <span class="Apple-converted-space"> </span>- Need to remember FastMath flags for each MachineInstr.<br class=""> <span class="Apple-converted-space"> </span>- Need to know the type of each MachineInstr. We don’t want ADD8, ADD16, etc.<br class=""> <span class="Apple-converted-space"> </span>- Extend the MachineRegisterInfo to support size as well as register classes for virtual registers.<br class=""><font color="#00afcd" class=""><br class=""></font>I have sketched the changes in the attached patches to help picturing how the changes would impact the existing APIs.</div><div class=""><br class=""></div><div class="">Note: I do not intend to commit those changes as they are. They will go the usual review process in due time.</div><div class=""><br class="">The patches contain “// ***”-like comment that give a rough explanation on why those changes are needed w.r.t. the goals.<br class="">The order of the patches could be modified since the dependencies between those are not sequential. Anyhow, here are the patches:<br class="">1. Introduce (some of) the generic opcode.<br class="">2. Make MachineFunction more independent of LLVM IR to eventually be able to delete the LLVM IR instance from the memory.<br class="">3. Extend MachineInstr to represent additional information attached to generic opcode.<br class="">4. Teach MachineRegisterInfo about size for virtual registers.<br class="">5. Introduce a helper class to build MachineInstr related objects.<br class="">6. Add new target hooks to lower the ABI directly to MachineInstr.<br class="">7. Introduce the IRTranslator pass.<br class=""><br class=""><font color="#12c00e" class=""><br class=""></font>** Roadmap for the Prototype **<br class=""><font color="#00afcd" class=""><br class=""></font>We plan to split the prototype in three main milestones:<br class="">1. Translation: LLVM IR to (G) MachineInstr translation.<br class="">2. Basic selector: Legal LLVM IR to target specific MachineInstr.<br class="">3. Simple legalization: Support scalar type legalization and some vector instructions.<br class=""><font color="#00afcd" class=""><br class=""></font>Notes:<br class="">- For #1, we will not support any fancy instructions like landing pad or switch.<br class="">- Each milestone should take about 3-4 months.</div><div class="">- At the end of #2, we would have a FastISel like selector.<br class=""><font color="#00afcd" class=""><br class=""></font>Each milestone will be detailed right before starting it. The rational is that we want to accommodate what we discovered with the prototype for the next milestone. In other words, in this email, <b class="">I only describe the first milestone</b> in detail and I will give more details on the next milestone shortly before we start it and so on. For your information, here is the remaining of the intended roadmap for the <b class="">full</b> project:<br class="">4. Productization: Clean up implementation, stabilize the APIs.<br class="">5. Complex legalization: Extend legalization support to everything missing.<br class="">6. Completeness: Fill the blanks, e.g., landing pad.<br class="">7. Clean-up and performance: Add the necessary bits to be at parity or beat SelectionDAG generated code.<br class="">8. Transition: Document how to switch, provide tools to help.<br class=""><font color="#00afcd" class=""><br class=""><br class=""></font>** Milestone 1 **<br class=""><font color="#12c00e" class=""><br class=""></font>The first phase is focused on the IRTranslator pass.<br class=""><font color="#12c00e" class=""><br class=""></font>The IRTranslator is responsible for translating the LLVM IR into Generic MachineInstr. The IRTranslator pass uses some target hooks to perform the ABI lowering. We can either define a new API for them, e.g., ABILoweringInfo, or extend the existing TargetLowering.<br class="">Moreover, the prototype will focus on simple instruction, i.e., we will not support switch or landing pad for this iteration.<br class=""><font color="#12c00e" class=""><br class=""></font>At the end of M1, the prototype will not be able to produce code, since we would only have the beginning of the Global ISel pipeline. Instead, we will test the IRTranslator on the generic output that is produced from the tested IR.<br class=""><font color="#12c00e" class=""><br class=""></font>* Design Decisions *<br class=""><font color="#12c00e" class=""><br class=""></font>- The IRTranslator is a final class. Its purpose is to move away from LLVM IR to MachineInstr world <b class="">[final]</b>.<br class="">- Lower the ABI as part of the translation process <b class="">[final]</b>.<br class=""><font color="#12c00e" class=""><br class=""></font>* Design Questions the Prototype Addresses at the End of M1 *<br class=""><font color="#12c00e" class=""><br class=""></font>- Handling of aggregate types during the translation.<br class="">- Lowering of switches.<br class="">- What about Module pass for Machine pass?<br class="">- Introduce new APIs to have a clearer separation between:<br class=""> <span class="Apple-converted-space"> </span>- Legalization (setOperationAction, etc.)<br class=""> <span class="Apple-converted-space"> </span>- Cost/Combine related (isXXXFree, etc.)<br class=""> <span class="Apple-converted-space"> </span>- Lowering related (LowerFormal, etc.)<br class="">- What is the contract with the backends? Is it still “should be able to select any valid LLVM IR”?<br class=""><font color="#00afcd" class=""><br class=""></font>Thanks,<br class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class="">-Quentin</div><div class=""></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div><div style="word-wrap: break-word;" class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div><div style="word-wrap: break-word;" class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div><div style="word-wrap: break-word;" class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div><div style="word-wrap: break-word;" class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div><div style="word-wrap: break-word;" class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div><div style="word-wrap: break-word;" class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""><div style="word-wrap: break-word;" class=""><div class=""><div class=""><div class=""><div class=""></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div></div><div style="word-wrap: break-word;" class=""></div>_______________________________________________<br class="">LLVM Developers mailing list<br class=""><a href="mailto:llvm-dev@lists.llvm.org" target="_blank" class="">llvm-dev@lists.llvm.org</a><br class=""><a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank" class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a></blockquote></div></div></blockquote></div><br class=""></div></body></html>