Skip to content
  1. Dec 16, 2010
  2. Dec 15, 2010
  3. Dec 14, 2010
  4. Dec 11, 2010
  5. Dec 10, 2010
  6. Dec 09, 2010
  7. Dec 08, 2010
    • Jakob Stoklund Olesen's avatar
      Implement very primitive hinting support in RegAllocGreedy. · eaa650a9
      Jakob Stoklund Olesen authored
      The hint is simply tried first and then forgotten if it couldn't be allocated
      immediately.
      
      llvm-svn: 121306
      eaa650a9
    • Jakob Stoklund Olesen's avatar
      Store (priority,regnum) pairs in the priority queue instead of providing an · e0df786c
      Jakob Stoklund Olesen authored
      abstract priority queue interface in subclasses that want to override the
      priority calculations.
      
      Subclasses must provide a getPriority() implementation instead.
      
      This approach requires less code as long as priorities are expressable as simple
      floats, and it avoids the dangers of defining potentially expensive priority
      comparison functions.
      
      It also should speed up priority_queue operations since they no longer have to
      chase pointers when comparing registers. This is not measurable, though.
      
      Preferably, we shouldn't use floats to guide code generation. The use of floats
      here is derived from the use of floats for spill weights. Spill weights have a
      dynamic range that doesn't lend itself easily to a fixpoint implementation.
      
      When someone invents a stable spill weight representation, it can be reused for
      allocation priorities.
      
      llvm-svn: 121294
      e0df786c
    • Jakob Stoklund Olesen's avatar
      Trim includes. · 310916a2
      Jakob Stoklund Olesen authored
      llvm-svn: 121283
      310916a2
    • Jakob Stoklund Olesen's avatar
      Stub out RegAllocGreedy. · b8812a1c
      Jakob Stoklund Olesen authored
      This new register allocator is initially identical to RegAllocBasic, but it will
      receive all of the tricks that RegAllocBasic won't get.
      
      RegAllocGreedy will eventually replace linear scan.
      
      llvm-svn: 121234
      b8812a1c
Loading