<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 Aug 23, 2016, at 6:58 AM, Tyler Kenney 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 class="socmaildefaultfont" dir="ltr" style="font-family:Arial;font-size:10.5pt"><div class="socmaildefaultfont" dir="ltr" style="font-family:Arial;font-size:10.5pt"><div dir="ltr" class=""> </div>
<div dir="ltr" class="">Hi all,</div>
<div dir="ltr" class=""> </div>
<div dir="ltr" class=""> </div>
<div dir="ltr" class="">The documentation at the top of LiveVariables.cpp states the following:<br class=""><br class=""> "It ... assumes that physical registers are only live within a single basic block (allowing it to do a single local analysis to resolve physical register lifetimes in each basic block). If a physical register is not register allocatable, it is not tracked. "</div></div></div></div></blockquote><blockquote type="cite" class=""><div class=""><div class="socmaildefaultfont" dir="ltr" style="font-family:Arial;font-size:10.5pt"><div class="socmaildefaultfont" dir="ltr" style="font-family:Arial;font-size:10.5pt"><div dir="ltr" class=""> </div>
<div dir="ltr" class="">This is consistent with the behaviour I'm witnessing, but I don't understand why it's designed this way. I am developing an out-of-tree backend and I have the following scenario:</div>
<div dir="ltr" class=""> </div>
<div dir="ltr" class=""> -physreg X marked as a live-in for a successor MBB (A.K.A., a live-out of the current block)<br class=""> -physreg X is a member of an allocatable reg-class<br class=""> -the only reference to physreg X in the current block is a<strong class="">: %physregX<def> = COPY %vreg43<kill></strong></div>
<div dir="ltr" class=""> </div>
<div dir="ltr" class="">That is the IR immediately before the Live Variables pass. The problem is that LiveVariables is marking physregX as dead, meaning that after LiveVariables, the IR above becomes:</div>
<div dir="ltr" class=""> </div>
<div dir="ltr" class=""> </div>
<div dir="ltr" class=""> <strong class="">%physregX<def,dead> = COPY %vreg43<kill></strong></div>
<div dir="ltr" class=""> </div>
<div dir="ltr" class=""> </div>
<div dir="ltr" class="">...and this eventually causes the COPY to be eliminated rather than lowered to machine instructions. Why does LiveVariables assume physical registers are only live within a single basic block? I have confirmed that if I remove the allocatable check in runOnBlock() [if (!TRI->isInAllocatableClass(LI.PhysReg))] and instead add all successor live-ins to LiveOuts regardless of regclass allocatability, my copy is not marked dead and not subsequently eliminated. This seems consistent with the aforementioned comment, so I don't think it's a bug but I really don't understand the intention here. If anyone could shed some light on why allocatable live-in's are pretty much ignored here, that'd be really helpful.</div></div></div></div></blockquote><div><br class=""></div><div>The long term plan is to get rid of LiveVariables and use LiveIntervalAnalysis for everything. However the TwoAddressInstructionPass has never been converted properly (some code was added to that pass to deal with LiveIntervals but the work was never completed so this is currently broken). If someone could get this working we could finally get rid of LiveVariables...</div><div><br class=""></div><div>However apart from the LiveVariables situation I would expect the assumption that physregs are only live within a basic block to be a valid one. What stops you to immediate copy the physregs from/to a virtual register for each use/def? That also gives the register allocator more freedom. If on the other hand a value must be in a register even though there are no apparent def/use operand then you probably have something on your hand that should be marked as non-allocatable or better reserved.</div><div><br class=""></div><div>- Matthias</div><div><br class=""></div></div></body></html>