Skip to content
  1. May 19, 2009
    • Dan Gohman's avatar
      Trim unneeded #includes. · adc70d68
      Dan Gohman authored
      llvm-svn: 72130
      adc70d68
    • Dan Gohman's avatar
      Teach SCEVExpander to expand arithmetic involving pointers into GEP · 2649491f
      Dan Gohman authored
      instructions. It attempts to create high-level multi-operand GEPs,
      though in cases where this isn't possible it falls back to casting
      the pointer to i8* and emitting a GEP with that. Using GEP instructions
      instead of ptrtoint+arithmetic+inttoptr helps pointer analyses that
      don't use ScalarEvolution, such as BasicAliasAnalysis.
      
      Also, make the AddrModeMatcher more aggressive in handling GEPs.
      Previously it assumed that operand 0 of a GEP would require a register
      in almost all cases. It now does extra checking and can do more
      matching if operand 0 of the GEP is foldable. This fixes a problem
      that was exposed by SCEVExpander using GEPs.
      
      llvm-svn: 72093
      2649491f
  2. May 18, 2009
  3. May 13, 2009
    • Dale Johannesen's avatar
      Add an int64_t variant of abs, for host environments · 536de01b
      Dale Johannesen authored
      without one.  Use it where we were using abs on
      int64_t objects.
      (I strongly suspect the casts to unsigned in the
      fragments in LoopStrengthReduce are not doing whatever
      the original intent was, but the obvious change to
      uint64_t doesn't work.  Maybe later.)
      
      llvm-svn: 71612
      536de01b
  4. May 12, 2009
    • Dan Gohman's avatar
      Factor the code for collecting IV users out of LSR into an IVUsers class, · d76d71a2
      Dan Gohman authored
      and generalize it so that it can be used by IndVarSimplify. Implement the
      base IndVarSimplify transformation code using IVUsers. This removes
      TestOrigIVForWrap and associated code, as ScalarEvolution now has enough
      builtin overflow detection and folding logic to handle all the same cases,
      and more. Run "opt -iv-users -analyze -disable-output" on your favorite
      loop for an example of what IVUsers does.
      
      This lets IndVarSimplify eliminate IV casts and compute trip counts in
      more cases. Also, this happens to finally fix the remaining testcases
      in PR1301.
      
      Now that IndVarSimplify is being more aggressive, it occasionally runs
      into the problem where ScalarEvolutionExpander's code for avoiding
      duplicate expansions makes it difficult to ensure that all expanded
      instructions dominate all the instructions that will use them. As a
      temporary measure, IndVarSimplify now uses a FixUsesBeforeDefs function
      to fix up instructions inserted by SCEVExpander. Fortunately, this code
      is contained, and can be easily removed once a more comprehensive
      solution is available.
      
      llvm-svn: 71535
      d76d71a2
    • Evan Cheng's avatar
      Teach LSR to optimize more loop exit compares, i.e. change them to use postinc... · 78a4eb84
      Evan Cheng authored
      Teach LSR to optimize more loop exit compares, i.e. change them to use postinc iv value. Previously LSR would only optimize those which are in the loop latch block. However, if LSR can prove it is safe (and profitable), it's now possible to change those not in the latch blocks to use postinc values.
      
      Also, if the compare is the only use, LSR would place the iv increment instruction before the compare instead in the latch.
      
      llvm-svn: 71485
      78a4eb84
  5. May 11, 2009
  6. May 09, 2009
  7. May 06, 2009
  8. May 05, 2009
    • Bill Wendling's avatar
      Temporarily reverting r71008. It was causing this failure: · 5e2ac0cd
      Bill Wendling authored
      Running /Volumes/Sandbox/Buildbot/llvm/full-llvm/build/llvm.src/test/
      CodeGen/X86/dg.exp ...
      FAIL: /Volumes/Sandbox/Buildbot/llvm/full-llvm/build/llvm.src/test/
      CodeGen/X86/change-compare-stride-1.ll
      Failed with exit(1) at line 2
      while running: grep {cmpq       $-478,} change-compare-stride-1.ll.tmp
      child process exited abnormally
      
      llvm-svn: 71013
      5e2ac0cd
    • David Greene's avatar
      · 246a3dfb
      David Greene authored
      Handle overflow of 64-bit loop conditions.
      
      llvm-svn: 71008
      246a3dfb
    • Dan Gohman's avatar
      Re-apply 70645, converting ScalarEvolution to use · 48f82222
      Dan Gohman authored
      CallbackVH, with fixes. allUsesReplacedWith need to
      walk the def-use chains and invalidate all users of a
      value that is replaced. SCEVs of users need to be
      recalcualted even if the new value is equivalent. Also,
      make forgetLoopPHIs walk def-use chains, since any
      SCEV that depends on a PHI should be recalculated when
      more information about that PHI becomes available.
      
      llvm-svn: 70927
      48f82222
    • Dan Gohman's avatar
      Constify a bunch of SCEV-using code. · a30370bc
      Dan Gohman authored
      llvm-svn: 70919
      a30370bc
  9. May 03, 2009
  10. May 02, 2009
    • Dan Gohman's avatar
      Convert ScalarEvolution to use CallbackVH for its internal map. This · e9a38d16
      Dan Gohman authored
      makes ScalarEvolution::deleteValueFromRecords, and it's code that
      subtly needed to be called before ReplaceAllUsesWith, unnecessary.
      
      It also makes ValueDeletionListener unnecessary.
      
      llvm-svn: 70645
      e9a38d16
    • Dan Gohman's avatar
      Previously, RecursivelyDeleteDeadInstructions provided an option · ff089955
      Dan Gohman authored
      of returning a list of pointers to Values that are deleted. This was
      unsafe, because the pointers in the list are, by nature of what
      RecursivelyDeleteDeadInstructions does, always dangling. Replace this
      with a simple callback mechanism. This may eventually be removed if
      all clients can reasonably be expected to use CallbackVH.
      
      Use this to factor out the dead-phi-cycle-elimination code from LSR
      utility function, and generalize it to use the
      RecursivelyDeleteTriviallyDeadInstructions utility function.
      
      This makes LSR more aggressive about eliminating dead PHI cycles;
      adjust tests to either be less trivial or to simply expect fewer
      instructions.
      
      llvm-svn: 70636
      ff089955
    • Dan Gohman's avatar
      Don't split critical edges during the AddUsersIfInteresting phase · 6409e7d4
      Dan Gohman authored
      of LSR. This makes the AddUsersIfInteresting phase of LSR a pure
      analysis instead of a phase that potentially does CFG modifications.
      
      The conditions where this code would actually perform a split are
      rare, and in the cases where it actually would do a split the split
      is usually undone by CodeGenPrepare, and in cases where splits
      actually survive into codegen, they appear to hurt more often than
      they help.
      
      llvm-svn: 70625
      6409e7d4
  11. May 01, 2009
  12. Apr 30, 2009
  13. Apr 27, 2009
  14. Apr 21, 2009
  15. Apr 18, 2009
  16. Apr 17, 2009
  17. Apr 16, 2009
  18. Mar 18, 2009
  19. Mar 09, 2009
Loading