<div dir="ltr">Dear Community, <div><br></div><div>This week I got my patch reviewed by mentors and based on that I have done changes. Also we have identified a problem with callee-saved registers being marked as clobbered registers so we fixed that bug. I have described other minor changes in following section.</div><div><br></div><div>It was expected to get the patch committed by end of this week but due to unexpected mistake I was not able to complete writing test cases. Sorry for that.</div><div><span style="font-size:13px">I had build llvm with ipra enable by default and that build files were on my path ! Due to that next time I tried to build llvm it was terribly slow  (almost 1 hour for 10% build ). I spend to much time on fixing this by playing around with environment variables, cmake options etc.</span></div><div style="font-size:13px">But I think this is a serious concern, we need to think verify this time complexity other wise building a large software with IPRA enable would be very time consuming.</div><div style="font-size:13px"><br></div><div style="font-size:13px">The toughest part for this week was to get lit and FileCheck work as you expect them to work, specially when analysis pass prints info on stdio and there is also a output file generated by llc or opt command. <br></div><div style="font-size:13px"><br></div><div style="font-size:13px">So here is brief summary :</div><div style="font-size:13px"><br></div><div style="font-size:13px">Implementation:</div><div style="font-size:13px">============</div><div><p style="margin:0px;line-height:normal;font-family:Helvetica"></p>RegUsageInfoCollector is now Calling Convention aware so that RegMask does not mark callee saved register as clobbered register. Due to this register allocator can use callee saved register for caller. <br>PhysicalRegisterUsageInfo.cpp renamed to RegisterUsageInfo.cpp.<br>StringMap used in RegisterUsageInfo.cpp is replaced by DenseMap of GlobalVariable * to RegMask.<br>DummyCGSCCPass moved from TargetPassConfig.cpp to CallGraphSCCPass.h.<br>Minor correction in comments, changes to adhere coding standards of LLVM.<br><p></p>



</div><div>Testing:</div><div>=====</div><div><p style="margin:0px;line-height:normal;font-family:Helvetica">The above mentioned changes has been tested with SNU-Realtime benchmarks.</p>
<p style="margin:0px;line-height:normal;font-family:Helvetica">Studied lit and FileCheck tool and written simple test to verify functionality of coding. </p><p style="margin:0px;line-height:normal;font-family:Helvetica"><br></p><p style="margin:0px;line-height:normal;font-family:Helvetica">Study and other:</p><p style="margin:0px;line-height:normal;font-family:Helvetica">============</p><p style="margin:0px;line-height:normal;font-family:Helvetica">Studied some examples of lit compatible llvm IR with comments to RUN test cases, FileCheck tool syntax and how to use it with in lit infrastructure. </p><p style="margin:0px;line-height:normal;font-family:Helvetica">I also understand X86 calling convention in more details. </p><p style="margin:0px;line-height:normal;font-family:Helvetica">I also studied basic concepts in llvm IR language while reading .ll files written for lit.</p><p style="margin:0px;line-height:normal;font-family:Helvetica">


</p><p style="margin:0px;line-height:normal;font-family:Helvetica">I learned about rvalue references and move semantics introduced in C++11.</p><p style="margin:0px;line-height:normal;font-family:Helvetica"><br></p><p style="margin:0px;line-height:normal;font-family:Helvetica">Plan for next week:</p><p style="margin:0px;line-height:normal;font-family:Helvetica">1) Get the patch committed along with proper tets cases.</p><p style="margin:0px;line-height:normal;font-family:Helvetica">2) Analyse time complexity of the approach.</p><p style="margin:0px;line-height:normal;font-family:Helvetica">3) Make target specific pass to CodeGen as it seems it is not required to be target specific.</p><p style="margin:0px;line-height:normal;font-family:Helvetica">4) If possible build a large application with ipra enable and analyze the impact.</p><p style="margin:0px;line-height:normal;font-family:Helvetica"><br></p><p style="margin:0px;line-height:normal;font-family:Helvetica">Sincerely,</p><p style="margin:0px;line-height:normal;font-family:Helvetica">Vivek</p></div><div><br></div></div><div class="gmail_extra"><br><div class="gmail_quote">On Sat, May 28, 2016 at 7:31 PM, vivek pandya <span dir="ltr"><<a href="mailto:vivekvpandya@gmail.com" target="_blank">vivekvpandya@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">Dear community,<div><br></div><div>This is to brief you the progress of Interprocedural Register Allocation, for those who are interested to see the progress in terms of code please consider <a href="http://reviews.llvm.org/D20769" target="_blank">http://reviews.llvm.org/D20769</a> </div><div>This patch contains simple infrastructure to propagate register usage information of callee to caller in call graph. The code generation order is changed to follow bottom up order on call graph , Thanks to Mehdi Amini for the patch for the same !  I will write a blog on this very soon. </div><div><br></div><div>So during this week as per the schedule proposed it should be study related infrastructure in LLVM and finalizing an approach for IPRA, but instead I am able to implement a working (may not be fully correct) prototype because I have used community bonding period to discuss and learn related stuffs from the mentors and also due to patch for CodeGen reordering was provided by dear mentor Mehdi Amini.</div><div><br></div><div>So I conclude the work done during this week as follows:</div><div><div>Implementation :</div><div>============</div><div>Following passes have been implemented during this week:
An immutable pass to store competed RegMask, a  machine function pass that iterates through each registers and check if it is used or not and based on that details create a RegMask and a target specific machine function pass that uses the RegMask created by second pass and propagates information by updating call instructions RegMask. To update the RegMask of MI , setRegMask() function has been added to MachineOperand, a command line option -enable-ipra and debug type -debug-only=“ipra" has been added to control the optimization through llc.</div><div><br></div><div>Testing: </div><div>=====</div><div>The above mentioned implementation has been tested over SNU-Real-Time benchmark suit (<a href="http://www.cprover.org/goto-cc/examples/snu.html" target="_blank">http://www.cprover.org/goto-cc/examples/snu.html</a>) and some simple programs that uses library function ( for a library function register allocation is not done by LLVM so this optimization will simply skip them)<span style="white-space:pre-wrap">    </span></div><div><br></div><div>Study and Other:</div><div>=============</div><div>I have learned following things in LLVM, how it stores reg clobbering information? how it is used by Reg allocators through LivePhysRegs, LiveRegMatrix and other related passes? How to schedule a pass using TargetPassConfig and TargetMachine? What are called callee saved registers? What is an Immutable Pass? 
Apart from that I have also learned how to use phabricator to send review request. 
I have also read some related literatures.<span style="white-space:pre-wrap">    </span></div></div><div><br></div><div>During this week though task was to schedule the passes in proper order so that dependencies of related passes are satisfied.</div><div><br></div><div>Plan for next week:</div><div>1) Perform more testing and debug any known issue</div><div>2) Fine ture the implementation so as to eliminate any unnecessary work</div><div>3) During the testing from the stats I have observed that IPRA does not always improve the work of IntraProcedural register allocators and it is also observer that the amount of benefit (in terms of spilled live ranges ) is not deterministic. So I would like to find reasons for this behavior.</div><div>4) Start implementing target specific pass for other targets if review passes properly with no major bugs.</div><div><br></div><div>Please provide any feedback/suggestion including for format of this email. </div><div><br></div><div>I would also like to thanks my mentors Mehdi Amini , Hal Finkel, <span style="font-size:13px">Quentin Colombet, </span><span style="font-size:13px">Matthias Braun</span><span style="font-size:13px"> and other community members for providing quick help every time when I asked ( I have got replies even after 8 PM ( PDT) ! ) .</span></div><div><span style="font-size:13px"> </span></div><div>Sincerely,</div><div>Vivek</div></div>
</blockquote></div><br></div>