<html>
<head>
<style><!--
.hmmessage P
{
margin:0px;
padding:0px
}
body.hmmessage
{
font-size: 10pt;
font-family:Tahoma
}
--></style>
</head>
<body class='hmmessage'>
Hi,<br><br>thank you for your explanations.<br><br>In order to get a pre-RA scheduling, I would need something like:<br><pre>- LiveVars<br>- PhiElim<br>- TwoAddr<br>- LiveIntervals<br>- Coalescing<br>- Scheduler (new)<br>- SlotIndexing<br>- LiveIntervals2 (new)<br>- RegAlloc</pre>My qeustion then is, is it really so difficult to create the live intervals information, with modifications to the original algorithm, or even from scratch? Normally, it should not have to be difficult to do a non-SSA live analysis pass. The format of the LiveInterval ought to serve well for any Live analysis, or? What are the pitfalls relating to the LLVM classes?<br><br>One thing that is somewhat unclear to me is why phys-regs are only considered live to end of block? Is this because the RA later ignores these registers? How come<br>this information is not needed?<br><br>Jonas<br><br><br>> Subject: Re: [LLVMdev] Need advice on writing scheduling pass<br>> From: stoklund@2pi.dk<br>> Date: Tue, 24 May 2011 09:59:26 -0700<br>> CC: llvmdev@cs.uiuc.edu<br>> To: jnspaulsson@hotmail.com<br>> <br>> <br>> On May 24, 2011, at 8:22 AM, Jonas Paulsson wrote:<br>> <br>> > Hi (Jakob),<br>> > <br>> > in reference to the prior message below, I have the following follow-up questions, as I also need a scheduling pass <br>> > prior to regalloc. I need to do this in order to set VLIW-flags, so that the RA is aware of several MI's<br>> > per cycle with a redefined LiveRange::overlap-function. On a multiple-issue cycle, a register that gets killed<br>> > can be reused by another MI - these live ranges do not then overlap.<br>> <br>> Redefining overlap() won't work for that. There is other code assuming that overlap means overlap, for example the LiveIntervalUnion used by the new register allocators.<br>> <br>> For VLIW, you probably want to number your packets instead of individual instructions. We don't have any VLIW support, so nobody has thought about how best to do it.<br>> <br>> > Well, I would like to schedule the VLIW code after SimpleRegisterCoalescer, so that I get more or less the <br>> > final code to work with. As the instructions are rearrange, I suppose I must run the SlotIndexes and <br>> > LiveIntervals again. LiveVariables should also be refreshed as a register might get killed with a different<br>> > MI if two users change place, etc, I suppose.<br>> > <br>> > I would like to just rerun these passes, but you said below that LiveIntervals do not work after SSA form is<br>> > abandoned.<br>> > <br>> > I wonder how you mean to update the live intervals after scheduling -- the slot indexes must surely be useless<br>> > with a changed order of MI's?<br>> > <br>> > Do you know of a scheme to rewrite these passes so that they can be rerun as needed? Is all but LiveIntervals<br>> > ok with this as of now?<br>> <br>> So the good news is that we are slowly moving towards a similar design. The bad news is that we are *slowly* moving...<br>> <br>> Currently, the register allocator super-pass contains these passes:<br>> <br>> - LiveVars<br>> - PhiElim<br>> - TwoAddr<br>> - LiveIntervals<br>> - Coalescing<br>> - RegAlloc<br>> <br>> Currently, LiveVars requires SSA form, and LiveIntervals only works with simple multi-defs as produced by PhiElim and TwoAddr. That means the pass order is fixed.<br>> <br>> The plan is to teach PhiELim and TwoAddr how to update LiveIntervals so it can run earlier:<br>> <br>> - LiveVars<br>> - LiveIntervals<br>> - PhiElim<br>> - TwoAddr<br>> - Coalescing<br>> - RegAlloc<br>> <br>> Then we can eliminate LiveVars completely:<br>> <br>> - LiveIntervals<br>> - PhiElim<br>> - TwoAddr<br>> - Coalescing<br>> - RegAlloc<br>> <br>> This version of LiveIntervals will compute liveness autonomously, but it is very likely to also require SSA form because of the possible speedups.<br>> <br>> The next step is to merge PhiElim and TwoAddr into a SuperCoalescer pass:<br>> <br>> - LiveIntervals<br>> - SuperCoalescing<br>> - RegAlloc<br>> <br>> Finally, Andy also wants to schedule after coalescing:<br>> <br>> - LiveIntervals<br>> - SuperCoalescing<br>> - Schedule<br>> - RegAlloc<br>> <br>> We don't have any concrete plans for how that scheduler would look. It would likely benefit from the existing LiveIntervals, at least the embedded SSA form is essential.<br>> <br>> It is not clear if such a scheduler should preserve live intervals or if everything should be recomputed. There are also phase ordering issues; the scheduler would be severely constrained by our very aggressive coalescing, and it would expose further coalescing opportunities that RegAlloc probably wouldn't be able to exploit fully.<br>> <br>> <br>> But if you want to add a VLIW scheduler tomorrow, I don't know what to tell you. It's a big project.<br>> <br>> /jakob<br>> <br> </body>
</html>