<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;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Sep 12, 2016, at 8:51 AM, vivek pandya via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div dir="ltr" class=""><div class=""><br class=""></div><div class="">1 ) As LLVM MI is already in SSA form before reg allocation so for LLVM I think it does not require to build SSA graph and converting it back after optimization completed as mentioned in [1]</div><div class=""><br class=""></div><div class="">2 ) We would like to add a pass similar to SCCP.cpp (Sparse Conditional Constant</div><div class="">Propagation based on Wegman and Zadeck's work <a href="http://dl.acm.org/citation.cfm?id=103136" class="">http://dl.acm.org/citation.cfm?id=103136</a>) as desribed in [1]. This pass will be scheduled to run before register allocation.</div><div class=""><br class=""></div><div class="">3 ) Output of the pass added in Step 2 will be a Map of def to instructions pointers (instructions which can be used to remat the given live range). The map will contain live ranges which is due to single instruction and multiple instructions.</div></div></div></blockquote><div><br class=""></div>LiveIntervals maintains a quasi-SSA form via VNInfo. It does not allow efficient def-use queries, but use-def is there, which is all that you should need.</div><div><br class=""></div><div>It would be great to have better remat during regalloc, but please try to avoid building additional state that needs to be maintained.</div><div><br class=""></div><div>-Andy</div><div><br class=""><blockquote type="cite" class=""><div class=""><div dir="ltr" class=""><div class=""><br class=""></div><div class="">4 ) The remat APIs defined in LiveRangeEdit.cpp will use analysis from the Map</div><div class="">when a spill is required for RA.</div><div class=""><br class=""></div><div class="">5 ) The remat transformation APIs like rematerializeAt() will be teached to remat</div><div class="">live ranges with multiple instructions too.</div><div class=""><br class=""></div><div class="">6 ) A cost analysis will be require to decide between remat and spill. This should be based on at least two factors register pressure and spill cost</div><div class=""><br class=""></div><div class="">Few points:</div><div class="">--------------</div><div class="">* The analysis pass to be addes as per (2) will use target specific information</div><div class="">from TargetInstrInfo.cpp as the current remat infrastructure uses.</div><div class=""><br class=""></div><div class="">* This approach will not be on demand as the current approach is (i.e remat specific</div><div class="">code will be executed only if there is a spill) so the pass in (2) can be an</div><div class="">overhead so we may want it to enable only for higher level of optimization.</div><div class=""><br class=""></div><div class="">* Will it be possible to use existing SCCP.cpp code with few modification to lattice</div><div class="">and related mathematical operation so that it can serve both purpose?</div><div class=""><br class=""></div><div class="">* No changes in current register allocators or spill framework will be required</div><div class="">because remat entry point will be LiveRangeEdit.</div><div class=""><br class=""></div><div class="">Any other way with less overhead is always welcomed.</div><div class="">Please help us developing a plan to implement this.</div><div class=""><br class=""></div><div class="">Hoping for comments!</div><div class=""><br class=""></div><div class="">Sincerely,</div><div class="">Vivek</div><div class=""><br class=""></div></div>
_______________________________________________<br class="">LLVM Developers mailing list<br class=""><a href="mailto:llvm-dev@lists.llvm.org" class="">llvm-dev@lists.llvm.org</a><br class="">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev<br class=""></div></blockquote></div><br class=""></body></html>