<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40"><head><meta http-equiv=Content-Type content="text/html; charset=utf-8"><meta name=Generator content="Microsoft Word 12 (filtered medium)"><style><!--
/* Font Definitions */
@font-face
        {font-family:"Cambria Math";
        panose-1:2 4 5 3 5 4 6 3 2 4;}
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:Tahoma;
        panose-1:2 11 6 4 3 5 4 4 2 4;}
@font-face
        {font-family:Consolas;
        panose-1:2 11 6 9 2 2 4 3 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        font-size:12.0pt;
        font-family:"Times New Roman","serif";
        color:black;}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
span.hoenzb
        {mso-style-name:hoenzb;}
span.EmailStyle18
        {mso-style-type:personal-reply;
        font-family:"Calibri","sans-serif";
        color:#1F497D;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.0in 1.0in 1.0in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]--></head><body bgcolor=white lang=EN-US link=blue vlink=purple><div class=WordSection1><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>I should probably voice our point of view as well… Hexagon is another VLIW target with “non standard” demands for bundling.<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>  I think Jacob has summarized current view of bundles as “black box” rather precise, but I should say that our view of bundles is way more fluid and open than that.<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>To avoid going into lengthy discussion, let me just say – bundling for us is not a single occurrence, but rather a multi step process, with individual instructions moved between bundles (and potentially between blocks) multiple times. Current infrastructure does not support this kind of freedom – seemingly more out of philosophy rather than from engineering point of view.<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>  Taking on Ivan’s question about remat, I would probably prefer affected bundles generically “disassembled” (if possible) with liveness correctly updated, with a following (machine specific pass) being able to re-bundle.  This of cause not always possible since some parallel semantics are not being expressible in serial code, but those rare “swap” like cases could be left intact (bundled). As far as I understand remat should never come “inside” such circular dependency without breaking it, so it should work just fine.<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>Generally as far as I concern, there is no way “generic” (platform independent) code can add instructions to bundles optimally. In the given example it is a job for Post RA scheduler… but before this could happen, a lot of infrastructural changes should be put in place.<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p> </o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'>Sergei <o:p></o:p></span></p><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p> </o:p></span></p><div><p class=MsoNormal><span style='font-size:10.5pt;font-family:Consolas;color:#1F497D'>--<o:p></o:p></span></p><p class=MsoNormal><span style='font-size:10.5pt;font-family:Consolas;color:#1F497D'>Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum.<o:p></o:p></span></p></div><p class=MsoNormal><span style='font-size:11.0pt;font-family:"Calibri","sans-serif";color:#1F497D'><o:p> </o:p></span></p><div style='border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt'><div><div style='border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in'><p class=MsoNormal><b><span style='font-size:10.0pt;font-family:"Tahoma","sans-serif";color:windowtext'>From:</span></b><span style='font-size:10.0pt;font-family:"Tahoma","sans-serif";color:windowtext'> llvmdev-bounces@cs.uiuc.edu [mailto:llvmdev-bounces@cs.uiuc.edu] <b>On Behalf Of </b>Ivan Llopard<br><b>Sent:</b> Thursday, June 07, 2012 3:26 AM<br><b>To:</b> Jakob Stoklund Olesen<br><b>Cc:</b> LLVM Developers Mailing List<br><b>Subject:</b> Re: [LLVMdev] Instruction bundles before RA: Rematerialization<o:p></o:p></span></p></div></div><p class=MsoNormal><o:p> </o:p></p><p class=MsoNormal style='margin-bottom:12.0pt'>Hi Jakob,<o:p></o:p></p><div><p class=MsoNormal>2012/6/6 Jakob Stoklund Olesen <<a href="mailto:stoklund@2pi.dk" target="_blank">stoklund@2pi.dk</a>><o:p></o:p></p><div><p class=MsoNormal style='margin-bottom:12.0pt'><br>On Jun 6, 2012, at 2:53 AM, Ivan Llopard <<a href="mailto:ivanllopard@gmail.com">ivanllopard@gmail.com</a>> wrote:<br><br>> We have a new BE for a VLIW-like processor and I'm currently working on<br>> instruction bundles. Ideally, I'd like to have bundles *before* RA to<br>> model certain constraints, e.g. the exposed one by Tzu-Chien a while ago<br>> in his thread<br>> <a href="http://lists.cs.uiuc.edu/pipermail/llvmdev/2005-September/004798.html" target="_blank">http://lists.cs.uiuc.edu/pipermail/llvmdev/2005-September/004798.html</a><o:p></o:p></p></div><p class=MsoNormal>The bundle support in the tree should handle constraints like that. The register allocator basically sees bundles as single instructions when computing interference.<o:p></o:p></p><div><p class=MsoNormal style='margin-bottom:12.0pt'><br>> In order to build bundles, we have added a new bottom-up MIScheduler,<br>> right after reg coalescing, which behaves much like ScheduleDAGVLIW but<br>> without hazard recognizing. Due to some tricky instructions, we cannot<br>> schedule on the DAG. Bundles are built at exitRegion() in the scheduling<br>> process and the live interval information is updated correctly. After<br>> this, the RA is aware of bundles, at least from a LiveInterval point of<br>> view, and I had some problems regarding the rematerialization.<br>><br>> AFAIK, the RA cannot remat if the target instruction is not the bundle's<br>> header.<br>> For this, I rather need a light bundle representation, or no bundle at<br>> all, so it can remat the right instruction with one condition: the<br>> remated location should preserve bundles. Nevertheless, for many other<br>> actions like LI splitting, the current representation works very well.<br>><br>> In general, I want the RA to preserve bundles as well as to be able to<br>> model the constraint presented above in the thread.<br>> Should I fix the rematerialization code to look for the right<br>> instruction into the current bundle ?<br>> What's the direction you are following about instruction bundling ?<o:p></o:p></p></div><p class=MsoNormal>Remat is a problem because it breaks the abstraction of treating whole bundles as instructions. There are two issues:<br><br>- Should we rematerialize the full bundle defining a value, or should we try to dig out the 'real' def inside the bundle?<o:p></o:p></p><div><p class=MsoNormal style='margin-bottom:12.0pt'><br>The second option is the preferred one for us. The remated instruction should create a new bundle which may be merged with other bundles later by custom passes. The same condition applies for copy insertions.<o:p></o:p></p></div><blockquote style='border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in'><p class=MsoNormal><br>- After remat, we run dead code elimination in case the original def has no more uses. Again, should DCE erase a single instruction from inside a bundle, or should we erase the full bundle once all its defs are dead?<o:p></o:p></p></blockquote><div><p class=MsoNormal><br>In our particular case, the RA can freely remove instructions from a bundle without any special constraint. We don't need to wait till all defs inside a bundle are dead, which in some situations it may never happen.<br> <o:p></o:p></p></div><blockquote style='border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in'><p class=MsoNormal><br>Ideally, I would like to treat the inside of a bundle like a black box that only the target understands. I am not too happy about erasing instructions inside bundles without some help from the target.<br><br>How do you need remat to work?<o:p></o:p></p></blockquote><div><p class=MsoNormal><br>As described above.<br><br>I understand your concern, other architectures may have stronger constraints or use bundles for other purposes (ARM?) which makes the task non-trivial.<br>We have a very particular VLIW architecture with complex operators but fewer constraints regarding the packet building and mangling. We need remat to work because spill is forbidden for a certain reg class.<br><br>Do you plan to add more hooks in TargetLowering to remat?<br><br> <o:p></o:p></p></div><blockquote style='border:none;border-left:solid #CCCCCC 1.0pt;padding:0in 0in 0in 6.0pt;margin-left:4.8pt;margin-right:0in'><p class=MsoNormal style='margin-bottom:12.0pt'><span style='color:#888888'><br><span class=hoenzb>/jakob</span></span><o:p></o:p></p></blockquote></div><p class=MsoNormal style='margin-bottom:12.0pt'><o:p> </o:p></p></div></div></body></html>