Skip to content
  1. Mar 20, 2012
  2. Mar 19, 2012
  3. Mar 18, 2012
  4. Mar 17, 2012
  5. Mar 16, 2012
    • Jim Grosbach's avatar
      ARM fix silly typo in optional operand alias. · c40b0f72
      Jim Grosbach authored
      rdar://11065671
      
      llvm-svn: 152954
      c40b0f72
    • Jim Grosbach's avatar
      ARM divided syntax fmrx/fmxr mnemonics. · db7db7d3
      Jim Grosbach authored
      llvm-svn: 152946
      db7db7d3
    • Jim Grosbach's avatar
      ARM ldm/stm register lists can be out of order. · 905686a8
      Jim Grosbach authored
      It's not a good style idea, as the registers will be laid down in memory in
      numerical order, not the order they're in the list, but it's legal. vldm/vstm
      are stricter.
      
      rdar://11064740
      
      llvm-svn: 152943
      905686a8
    • Bill Wendling's avatar
      Revert r152907. · 55b6b2b6
      Bill Wendling authored
      llvm-svn: 152935
      55b6b2b6
    • Benjamin Kramer's avatar
      ScheduleDAGInstrs: When adding uses we add them into a set that's empty at the... · 411d5a20
      Benjamin Kramer authored
      ScheduleDAGInstrs: When adding uses we add them into a set that's empty at the beginning, no need to maintain another set for the added regs.
      
      llvm-svn: 152934
      411d5a20
    • Benjamin Kramer's avatar
      Limit the number of memory operands in MachineInstr to 2^16 and store the number in padding. · d03878bd
      Benjamin Kramer authored
      Saves one machine word on MachineInstr (88->80 bytes on x86_64, 48->44 on i386).
      
      llvm-svn: 152930
      d03878bd
    • Benjamin Kramer's avatar
      CriticalAntiDepBreaker: BasicBlock::size is an expensive operation, reuse the cached value. · 8e5af375
      Benjamin Kramer authored
      No functionality change.
      
      llvm-svn: 152927
      8e5af375
    • Bill Wendling's avatar
      The alignment of the pointer part of the store instruction may have an · a2a26b54
      Bill Wendling authored
      alignment. If that's the case, then we want to make sure that we don't increase
      the alignment of the store instruction. Because if we increase it to be "more
      aligned" than the pointer, code-gen may use instructions which require a greater
      alignment than the pointer guarantees.
      <rdar://problem/11043589>
      
      llvm-svn: 152907
      a2a26b54
    • Chandler Carruth's avatar
      Rip out support for 'llvm.noinline'. This thing has a strange history... · b37fc13a
      Chandler Carruth authored
      It was added in 2007 as the first cut at supporting no-inline
      attributes, but we didn't have function attributes of any form at the
      time. However, it was added without any mention in the LangRef or other
      documentation.
      
      Later on, in 2008, Devang added function notes for 'inline=never' and
      then turned them into proper function attributes. From that point
      onward, as far as I can tell, the world moved on, and no one has touched
      'llvm.noinline' in any meaningful way since.
      
      It's time has now come. We have had better mechanisms for doing this for
      a long time, all the frontends I'm aware of use them, and this is just
      holding back progress. Given that it was never a documented feature of
      the IR, I've provided no auto-upgrade support. If people know of real,
      in-the-wild bitcode that relies on this, yell at me and I'll add it, but
      I *seriously* doubt anyone cares.
      
      llvm-svn: 152904
      b37fc13a
    • Chandler Carruth's avatar
      Start removing the use of an ad-hoc 'never inline' set and instead · d7a5f2ad
      Chandler Carruth authored
      directly query the function information which this set was representing.
      This simplifies the interface of the inline cost analysis, and makes the
      always-inline pass significantly more efficient.
      
      Previously, always-inline would first make a single set of every
      function in the module *except* those marked with the always-inline
      attribute. It would then query this set at every call site to see if the
      function was a member of the set, and if so, refuse to inline it. This
      is quite wasteful. Instead, simply check the function attribute directly
      when looking at the callsite.
      
      The normal inliner also had similar redundancy. It added every function
      in the module with the noinline attribute to its set to ignore, even
      though inside the cost analysis function we *already tested* the
      noinline attribute and produced the same result.
      
      The only tricky part of removing this is that we have to be able to
      correctly remove only the functions inlined by the always-inline pass
      when finalizing, which requires a bit of a hack. Still, much less of
      a hack than the set of all non-always-inline functions was. While I was
      touching this function, I switched a heavy-weight set to a vector with
      sort+unique. The algorithm already had a two-phase insert and removal
      pattern, we were just needlessly paying the uniquing cost on every
      insert.
      
      This probably speeds up some compiles by a small amount (-O0 compiles
      with lots of always-inline, so potentially heavy libc++ users), but I've
      not tried to measure it.
      
      I believe there is no functional change here, but yell if you spot one.
      None are intended.
      
      Finally, the direction this is going in is to greatly simplify the
      inline cost query interface so that we can replace its implementation
      with a much more clever one. Along the way, all the APIs get simplified,
      so it seems incrementally good.
      
      llvm-svn: 152903
      d7a5f2ad
Loading