Skip to content
  1. Oct 14, 2011
  2. Oct 13, 2011
  3. Oct 12, 2011
  4. Oct 11, 2011
  5. Oct 08, 2011
  6. Oct 07, 2011
  7. Oct 06, 2011
    • Eli Friedman's avatar
      PR11061: Make simplifylibcalls fold strcmp("", x) correctly. · 3e3aecbc
      Eli Friedman authored
      While I'm here, fix the related issue with strncmp, add some actual tests for strcmp and strncmp, and start using StringRef::compare for constant folding instead of using strcmp/strncmp so that the optimized IR isn't dependent on the host's implementation of strcmp.
      
      llvm-svn: 141227
      3e3aecbc
  8. Oct 05, 2011
    • Jim Grosbach's avatar
      Re-commit 141203, but much more conservative. · e7abae04
      Jim Grosbach authored
      Just pull the instruction name, but don't change the order of anything
      else. That keeps --debug happy and non-crashing, but doesn't change
      how the worklist gets built.
      
      llvm-svn: 141210
      e7abae04
    • Jim Grosbach's avatar
      Revert 141203. InstCombine is looping on unit tests. · 8f9acfac
      Jim Grosbach authored
      llvm-svn: 141209
      8f9acfac
    • Jim Grosbach's avatar
      Update InstCombine worklist after instruction transform is complete. · e37e0301
      Jim Grosbach authored
      When updating the worklist for InstCombine, the Add/AddUsersToWorklist
      functions may access the instruction(s) being added, for debug output for
      example. If the instructions aren't yet added to the basic block, this
      can result in a crash. Finish the instruction transformation before
      adjusting the worklist instead.
      
      rdar://10238555
      
      llvm-svn: 141203
      e37e0301
    • Duncan Sands's avatar
      GVN does simple propagation of conditions: when it sees a conditional · f4f47ccd
      Duncan Sands authored
      branch "br i1 %x, label %if_true, label %if_false" then it replaces
      "%x" with "true" in places only reachable via the %if_true arm, and
      with "false" in places only reachable via the %if_false arm.  Except
      that actually it doesn't: if value numbering shows that %y is equal
      to %x then, yes, %y will be turned into true/false in this way, but
      any occurrences of %x itself are not transformed.  Fix this.  What's
      more, it's often the case that %x is an equality comparison such as
      "%x = icmp eq %A, 0", in which case every occurrence of %A that is
      only reachable via the %if_true arm can be replaced with 0.  Implement
      this and a few other variations on this theme.  This reduces the number
      of lines of LLVM IR in "GCC as one big file" by 0.2%.  It has a bigger
      impact on Ada code, typically reducing the number of lines of bitcode
      by around 0.4% by removing repeated compiler generated checks.  Passes
      the LLVM nightly testsuite and the Ada ACATS testsuite.
      
      llvm-svn: 141177
      f4f47ccd
    • Duncan Sands's avatar
      Generalize GVN's conditional propagation logic slightly: · e90dd058
      Duncan Sands authored
      it's OK for the false/true destination to have multiple
      predecessors as long as the extra ones are dominated by
      the branch destination.
      
      llvm-svn: 141176
      e90dd058
  9. Oct 04, 2011
  10. Oct 02, 2011
  11. Oct 01, 2011
    • Andrew Trick's avatar
      Inlining and unrolling heuristics should be aware of free truncs. · f7656015
      Andrew Trick authored
      We want heuristics to be based on accurate data, but more importantly
      we don't want llvm to behave randomly. A benign trunc inserted by an
      upstream pass should not cause a wild swings in optimization
      level. See PR11034. It's a general problem with threshold-based
      heuristics, but we can make it less bad.
      
      llvm-svn: 140919
      f7656015
    • Andrew Trick's avatar
      whitespace · caa500bf
      Andrew Trick authored
      llvm-svn: 140916
      caa500bf
  12. Sep 30, 2011
  13. Sep 29, 2011
  14. Sep 28, 2011
  15. Sep 27, 2011
Loading