<div dir="ltr">Cool, thanks for the help!<div><br></div><div>-Dilan</div></div><br><div class="gmail_quote"><div dir="ltr">On Mon, Jul 31, 2017 at 3:39 PM Matthias Braun <<a href="mailto:mbraun@apple.com">mbraun@apple.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div style="word-wrap:break-word"><div>Yes looking at the MachineScheduler.cpp and the `SchedMachienModel`s in the targets along with -debug-only=machine-scheduler / -print-machineinstrs  is the way to understand scheduling.</div></div><div style="word-wrap:break-word"><div><br></div><div>- Matthias</div></div><div style="word-wrap:break-word"><br><div><blockquote type="cite"><div>On Jul 31, 2017, at 3:36 PM, Dilan Manatunga <<a href="mailto:manatunga@gmail.com" target="_blank">manatunga@gmail.com</a>> wrote:</div><br class="m_4182200011385145151Apple-interchange-newline"><div><div dir="ltr">Thanks that clears things up. So if I want to mess around with how schedules are generated, looking at the MachineScheduler pass is the best place now?<div><br></div><div>-Dilan</div><div><br><div class="gmail_quote"><div dir="ltr">On Mon, Jul 31, 2017 at 3:24 PM Matthias Braun <<a href="mailto:mbraun@apple.com" target="_blank">mbraun@apple.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><br>
> On Jul 31, 2017, at 2:51 PM, Dilan Manatunga via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org" target="_blank">llvm-dev@lists.llvm.org</a>> wrote:<br>
><br>
> Hi,<br>
><br>
> I was looking into how SelectionDAG scheduling is done in LLVM for different backends, and I noticed that for the X86 backend, even though it sets scheduling preferences of ILP or RegisterPressure depending on architecture, in the end, it ends up using source scheduling. I realized this is because it overrides enableMachineScheduler to return true. Is there any specific reasons why it was done this way, and also, what happens to be class mainly responsible for the X86 scheduling then?<br>
<br>
The MachineScheduler is consider the standard scheduler and does a better job at tracking among other things register pressure and machine state/latencies, features a more modular design etc.<br>
<br>
The SelectionDAG schedulers are still here because:<br>
- We need to bring the selection graph back into a linear order for the MI representation. While we would like the SelectionDAG scheduler to be as simple as an RPO walk, it also does:<br>
- Duplicating/Rematerializing of flag producing nodes in order to avoid unnecessary spilling/restoring of flag registers (which is an expensive operation on most architectures).<br>
<br>
Scheduling for any other goals in the selection dag scheduler and using something else than the source/fast scheduler is considered deprecated.<br>
That said for some targets the machine scheduler tuning efforts were never finished (or maybe just never verified?) so that they still use the other selection dag scheduler.<br>
<br>
- Matthias<br>
</blockquote></div></div></div>
</div></blockquote></div><br></div></blockquote></div>