Skip to content
  1. Mar 28, 2011
  2. Mar 20, 2011
  3. Mar 16, 2011
  4. Mar 13, 2011
  5. Mar 10, 2011
  6. Mar 09, 2011
  7. Mar 07, 2011
  8. Mar 05, 2011
  9. Mar 04, 2011
  10. Mar 03, 2011
  11. Mar 02, 2011
  12. Mar 01, 2011
    • Jakob Stoklund Olesen's avatar
      Keep track of which stage produced a live range, and bypass earlier stages when revisiting. · 5f9f081d
      Jakob Stoklund Olesen authored
      This effectively disables the 'turbo' functionality of the greedy register
      allocator where all new live ranges created by splitting would be reconsidered
      as if they were originals.
      
      There are two reasons for doing this, 1. It guarantees that the algorithm
      terminates. Early versions were prone to infinite looping in certain corner
      cases. 2. It is a 2x speedup. We can skip a lot of unnecessary interference
      checks that won't lead to good splitting anyway.
      
      The problem is that region splitting only gets one shot, so it should probably
      be changed to target multiple physical registers at once.
      
      Local live range splitting is still 'turbo' enabled. It only accounts for a
      small fraction of compile time, so it is probably not necessary to do anything
      about that.
      
      llvm-svn: 126781
      5f9f081d
  13. Feb 25, 2011
  14. Feb 23, 2011
  15. Feb 22, 2011
  16. Feb 19, 2011
  17. Feb 18, 2011
  18. Feb 17, 2011
  19. Feb 10, 2011
  20. Feb 09, 2011
  21. Feb 08, 2011
Loading