|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 137642 | 
| | 
| 
| 
| | llvm-svn: 136722 | 
| | 
| 
| 
| 
| 
| | it's used and not included where it isn't.
llvm-svn: 135628 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | nodes.
Original message:
Let simplify cfg simplify bb with only debug and lifetime intrinsics.
llvm-svn: 134182 | 
| | 
| 
| 
| 
| 
| | lifetime intrinsics" due to buildbot failures.
llvm-svn: 134071 | 
| | 
| 
| 
| | llvm-svn: 134057 | 
| | 
| 
| 
| | llvm-svn: 133990 | 
| | 
| 
| 
| 
| 
| | -Wshorten-64-to-32 warning in Instructions.h.
llvm-svn: 133708 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | "Reinstate r133435 and r133449 (reverted in r133499) now that the clang
self-hosted build failure has been fixed (r133512)."
Due to some additional warnings.
llvm-svn: 133700 | 
| | 
| 
| 
| 
| 
| | self-hosted build failure has been fixed (r133512).
llvm-svn: 133513 | 
| | 
| 
| 
| | llvm-svn: 133499 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Change PHINodes to store simple pointers to their incoming basic blocks,
instead of full-blown Uses.
Note that this loses an optimization in SplitCriticalEdge(), because we
can no longer walk the use list of a BasicBlock to find phi nodes. See
the comment I removed starting "However, the foreach loop is slow for
blocks with lots of predecessors".
Extend replaceAllUsesWith() on a BasicBlock to also update any phi
nodes in the block's successors. This mimics what would have happened
when PHINodes were proper Users of their incoming blocks. (Note that
this only works if OldBB->replaceAllUsesWith(NewBB) is called when
OldBB still has a terminator instruction, so it still has some
successors.)
llvm-svn: 133435 | 
| | 
| 
| 
| | llvm-svn: 133086 | 
| | 
| 
| 
| 
| 
| | promoting allocas to SSA variables. Fixes <rdar://problem/9479036>.
llvm-svn: 131953 | 
| | 
| 
| 
| 
| 
| 
| 
| | to also clean up the condition of any conditional terminator it folds to be unconditional, if that turns the condition into dead code. This just means it calls RecursivelyDeleteTriviallyDeadInstructions() in strategic spots. It defaults to the old behavior.
I also changed -simplifycfg, -jump-threading and -codegenprepare to use this to produce slightly better code without any extra cleanup passes (AFAICT this was the only place in -simplifycfg where now-dead conditions of replaced terminators weren't being cleaned up). The only other user of this function is -sccp, but I didn't read that thoroughly enough to figure out whether it might be holding pointers to instructions that could be deleted by this.
llvm-svn: 131855 | 
| | 
| 
| 
| | llvm-svn: 131543 | 
| | 
| 
| 
| | llvm-svn: 131541 | 
| | 
| 
| 
| 
| 
| | Radar 9422775.
llvm-svn: 131422 | 
| | 
| 
| 
| | llvm-svn: 130431 | 
| | 
| 
| 
| | llvm-svn: 129759 | 
| | 
| 
| 
| | llvm-svn: 129271 | 
| | 
| 
| 
| 
| 
| 
| | llvm-commits.  (Not sure why it only breaks on Windows; maybe it has
something to do with the iterator representation...)
llvm-svn: 128802 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | after the given instruction; make sure to handle that case correctly.
(It's difficult to trigger; the included testcase involves a dead 
block, but I don't think that's a requirement.) 
While I'm here, get rid of the unnecessary warning about
SimplifyInstructionsInBlock, since it should work correctly as far as I know.
llvm-svn: 128782 | 
| | 
| 
| 
| | llvm-svn: 128030 | 
| | 
| 
| 
| 
| 
| | LoadInst should also get a corresponding llvm.dbg.value intrinsic.
llvm-svn: 127924 | 
| | 
| 
| 
| | llvm-svn: 127923 | 
| | 
| 
| 
| | llvm-svn: 127922 | 
| | 
| 
| 
| 
| 
| 
| | This is done by lowering dbg.declare intrinsic into dbg.value intrinsic.
Radar 9143931.
llvm-svn: 127834 | 
| | 
| 
| 
| | llvm-svn: 127832 | 
| | 
| 
| 
| 
| 
| 
| | Avoid colliding with the sentinels, hopefully unbreaking
llvm-gcc-x86_64-linux-selfhost.
llvm-svn: 126982 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | itself without going via a phi node then we could return false here in
spite of making a change.  Also, tweak the comment because this method
can (and always could) return true without deleting the original phi node.
For example, if the phi node was used by a read-only invoke instruction
which is used by another phi node phi2 which is only used by and only uses
the invoke, then phi2 would be deleted but not the invoke instruction and
not the original phi node.
llvm-svn: 126129 | 
| | 
| 
| 
| 
| 
| 
| 
| | should be that if the phi is used by a side-effect free instruction with
no uses then the phi and the instruction now get zapped (checked by the
unittest).
llvm-svn: 126124 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | test for that. With this change, test/CodeGen/X86/codegen-dce.ll no longer finds
any instructions to DCE, so delete the test.
Also renamed J and JP to I and IP in RecursivelyDeleteDeadPHINode.
llvm-svn: 126088 | 
| | 
| 
| 
| 
| 
| | by Andrew Clinton!
llvm-svn: 126077 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | they all ready do). This removes two dominator recomputations prior to isel,
which is a 1% improvement in total llc time for 403.gcc.
The only potentially suspect thing is making GCStrategy recompute dominators if
it used a custom lowering strategy.
llvm-svn: 123064 | 
| | 
| 
| 
| | llvm-svn: 123025 | 
| | 
| 
| 
| | llvm-svn: 122642 | 
| | 
| 
| 
| | llvm-svn: 122556 | 
| | 
| 
| 
| | llvm-svn: 122554 | 
| | 
| 
| 
| 
| 
| 
| | is trivially dead, since these have side effects.  This makes the
(misnamed) MemoryUseIntrinsic class dead, so remove it.
llvm-svn: 120382 | 
| | 
| 
| 
| 
| 
| | rather than hasConstantValue.
llvm-svn: 119457 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Eliminate redundant successors.
 - Convert an indirectbr with one successor into a direct branch.
Also, generalize SimplifyCFG to be able to be run on a function entry block.
It knows quite a few simplifications which are applicable to the entry
block, and it only needs a few checks to avoid trouble with the entry block.
llvm-svn: 111060 | 
| | 
| 
| 
| 
| 
| 
| 
| | it *changing* the things it replaces, not just causing them
to drop to null.  There is no functionality change yet, but 
this is required for a subsequent patch.
llvm-svn: 108414 | 
| | 
| 
| 
| | llvm-svn: 108132 | 
| | 
| 
| 
| 
| 
| 
| | lib/Transforms/Utils and into lib/Analysis so that Analysis passes
can use them.
llvm-svn: 104949 | 
| | 
| 
| 
| 
| 
| 
| | and T->isPointerTy().  Convert most instances of the first form to the second form.
Requested by Chris.
llvm-svn: 96344 | 
| | 
| 
| 
| 
| 
| | called by jump threading.
llvm-svn: 96263 | 
| | 
| 
| 
| 
| 
| 
| | The testcase from pr6198 does not crash for me -- I don't know what's up with
that -- so I'm not adding it to the tests.
llvm-svn: 94984 | 
| | 
| 
| 
| 
| 
| 
| | unconditionally.  Besides checking the offset, also check that the underlying
object is aligned as much as the load itself.
llvm-svn: 94875 | 
| | 
| 
| 
| | llvm-svn: 94835 |