Skip to content
  1. Aug 23, 2009
  2. Aug 22, 2009
  3. Jul 25, 2009
    • Daniel Dunbar's avatar
      More migration to raw_ostream, the water has dried up around the iostream hole. · 0dd5e1ed
      Daniel Dunbar authored
       - Some clients which used DOUT have moved to DEBUG. We are deprecating the
         "magic" DOUT behavior which avoided calling printing functions when the
         statement was disabled. In addition to being unnecessary magic, it had the
         downside of leaving code in -Asserts builds, and of hiding potentially
         unnecessary computations.
      
      llvm-svn: 77019
      0dd5e1ed
  4. Jul 14, 2009
  5. Jul 12, 2009
  6. Jul 11, 2009
  7. Jun 25, 2009
  8. Jun 15, 2009
  9. May 14, 2009
  10. May 05, 2009
  11. Nov 04, 2008
  12. Oct 21, 2008
    • Dan Gohman's avatar
      Optimized FCMP_OEQ and FCMP_UNE for x86. · 97d95d6d
      Dan Gohman authored
      Where previously LLVM might emit code like this:
      
              ucomisd %xmm1, %xmm0
              setne   %al
              setp    %cl
              orb     %al, %cl
              jne     .LBB4_2
      
      it now emits this:
      
              ucomisd %xmm1, %xmm0
              jne     .LBB4_2
              jp      .LBB4_2
      
      It has fewer instructions and uses fewer registers, but it does
      have more branches. And in the case that this code is followed by
      a non-fallthrough edge, it may be followed by a jmp instruction,
      resulting in three branch instructions in sequence. Some effort
      is made to avoid this situation.
      
      To achieve this, X86ISelLowering.cpp now recognizes FCMP_OEQ and
      FCMP_UNE in lowered form, and replace them with code that emits
      two branches, except in the case where it would require converting
      a fall-through edge to an explicit branch.
      
      Also, X86InstrInfo.cpp's branch analysis and transform code now
      knows now to handle blocks with multiple conditional branches. It
      uses loops instead of having fixed checks for up to two
      instructions. It can now analyze and transform code generated
      from FCMP_OEQ and FCMP_UNE.
      
      llvm-svn: 57873
      97d95d6d
  13. Sep 04, 2008
  14. Aug 22, 2008
  15. Aug 15, 2008
  16. Jul 08, 2008
    • Dan Gohman's avatar
      Pool-allocation for MachineInstrs, MachineBasicBlocks, and · 3b460303
      Dan Gohman authored
      MachineMemOperands. The pools are owned by MachineFunctions.
      
      This drastically reduces the number of calls to malloc/free made
      during the "Emit" phase of scheduling, as well as later phases
      in CodeGen. Combined with other changes, this speeds up the
      "instruction selection" phase of CodeGen by 10% in some cases.
      
      llvm-svn: 53212
      3b460303
  17. Jun 04, 2008
  18. Feb 28, 2008
  19. Feb 20, 2008
  20. Jan 29, 2008
  21. Jan 07, 2008
  22. Dec 29, 2007
  23. Jul 10, 2007
  24. Jul 07, 2007
  25. Jun 19, 2007
  26. Jun 18, 2007
  27. Jun 16, 2007
    • Evan Cheng's avatar
      Really turn if-converter loose: · 3a51c854
      Evan Cheng authored
      1. Consider all possible ifcvt cases at once. No longer restricted to bottom
         up iterative approach.
      2. Sort all possible cases based on a cost function. Perform the most profitable
         ones first invalidate others that target the same blocks.
      3. Fixed a number of bugs related to block duplication.
      
      llvm-svn: 37613
      3a51c854
  28. Jun 15, 2007
Loading