|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| | happy.
llvm-svn: 123389 | 
| | 
| 
| 
| 
| 
| 
| | It will still return an iterator that points to the first terminator or end(),
but there may be DBG_VALUE instructions following the first terminator.
llvm-svn: 123384 | 
| | 
| 
| 
| | llvm-svn: 123351 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | without a TRI instance.
Print virtual registers numbered from 0 instead of the arbitrary
FirstVirtualRegister. The first virtual register is printed as %vreg0.
TRI::NoRegister is printed as %noreg.
llvm-svn: 123107 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | BB#1: derived from LLVM BB %bb.nph28
    Live Ins: %AL
    Predecessors according to CFG: BB#0
	TEST8rr %reg16384<kill>, %reg16384, %EFLAGS<imp-def>; GR8:%reg16384
	JNE_4 <BB#2>, %EFLAGS<imp-use,kill>
	JMP_4 <BB#2>
    Successors according to CFG: BB#2 BB#2
These double CFG edges only ever occur in bugpoint-generated code, so there is
no need to attempt something clever.
llvm-svn: 117992 | 
| | 
| 
| 
| 
| 
| | elsewhere.
llvm-svn: 117763 | 
| | 
| 
| 
| 
| 
| | SlotIndexes when available.
llvm-svn: 117392 | 
| | 
| 
| 
| | llvm-svn: 111574 | 
| | 
| 
| 
| 
| 
| | clients. Also fixed an erroneous check. An edge is only a back edge when the from and to blocks are in the same loop.
llvm-svn: 111256 | 
| | 
| 
| 
| | llvm-svn: 111250 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | code placement issues. rdar://8263994
good:
LBB0_2:
  mov     r2, r0
  . . .
  mov     r1, r2
  bne     LBB0_2
bad:
LBB0_2:
  mov     r2, r0
  . . .
@ BB#3:
  mov     r1, r2
  b       LBB0_2
llvm-svn: 111221 | 
| | 
| 
| 
| | llvm-svn: 107778 | 
| | 
| 
| 
| 
| 
| 
| | the block before calling the expansion hook. And don't
put EFLAGS in a mbb's live-in list twice.
llvm-svn: 107691 | 
| | 
| 
| 
| | llvm-svn: 107668 | 
| | 
| 
| 
| 
| 
| | the pseudo instruction is not at the end of the block.
llvm-svn: 107655 | 
| | 
| 
| 
| 
| 
| 
| | into a utility routine, teach it how to update MachineLoopInfo, and
make use of it in MachineLICM to split critical edges on demand.
llvm-svn: 106555 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | addresses a longstanding deficiency noted in many FIXMEs scattered
across all the targets.
This effectively moves the problem up one level, replacing eleven
FIXMEs in the targets with eight FIXMEs in CodeGen, plus one path
through FastISel where we actually supply a DebugLoc, fixing Radar
7421831.
llvm-svn: 106243 | 
| | 
| 
| 
| 
| 
| 
| 
| | MachineBasicBlock::livein_iterator a const_iterator, because
clients shouldn't ever be using the iterator interface to
mutate the livein set.
llvm-svn: 101147 | 
| | 
| 
| 
| | llvm-svn: 100065 | 
| | 
| 
| 
| | llvm-svn: 100062 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | * Set the "DestA" and "DestB" according to how they're understood by the
  method. I.e., if one or both of them should point to the "fall through" block,
  then point to the fall through block.
* Improve the loop that removes superfluous edges to be more understandable.
llvm-svn: 100056 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | create symbols.  It is extremely error prone and a source of a lot
of the remaining integrated assembler bugs on x86-64.
This fixes rdar://7807601.
llvm-svn: 99902 | 
| | 
| 
| 
| | llvm-svn: 98451 | 
| | 
| 
| 
| | llvm-svn: 98124 | 
| | 
| 
| 
| 
| 
| 
| | and add a sparc implementation that knows about delay slots.  Patch by
Nathan Keynes!
llvm-svn: 96492 | 
| | 
| 
| 
| | llvm-svn: 95730 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | into TargetOpcodes.h.  #include the new TargetOpcodes.h
into MachineInstr.  Add new inline accessors (like isPHI())
to MachineInstr, and start using them throughout the 
codebase.
llvm-svn: 95687 | 
| | 
| 
| 
| 
| 
| | the AsmPrinter::GetMBBSymbol.
llvm-svn: 94515 | 
| | 
| 
| 
| | llvm-svn: 94032 | 
| | 
| 
| 
| 
| 
| 
| | more cases where debug declarations affect
debug line info.
llvm-svn: 93953 | 
| | 
| 
| 
| 
| 
| 
| | This fixes the regression for -pre-regalloc-taildup in
MultiSource/Applications/lambda-0.1.3.
llvm-svn: 93541 | 
| | 
| 
| 
| | llvm-svn: 92542 | 
| | 
| 
| 
| | llvm-svn: 91479 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | $ svn merge -c -91161 https://llvm.org/svn/llvm-project/llvm/trunk
--- Reverse-merging r91161 into '.':
U    lib/CodeGen/BranchFolding.cpp
U    lib/CodeGen/MachineBasicBlock.cpp
$ svn merge -c -91113 https://llvm.org/svn/llvm-project/llvm/trunk
--- Reverse-merging r91113 into '.':
G    lib/CodeGen/MachineBasicBlock.cpp
$ svn merge -c -91101 https://llvm.org/svn/llvm-project/llvm/trunk
--- Reverse-merging r91101 into '.':
U    include/llvm/CodeGen/MachineBasicBlock.h
G    lib/CodeGen/MachineBasicBlock.cpp
$ svn merge -c -91092 https://llvm.org/svn/llvm-project/llvm/trunk
--- Reverse-merging r91092 into '.':
G    include/llvm/CodeGen/MachineBasicBlock.h
G    lib/CodeGen/MachineBasicBlock.cpp
llvm-svn: 91376 | 
| | 
| 
| 
| | llvm-svn: 91274 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | branches only to a landing pad. Without this check, the compiler would go into
an infinite loop because the branch to a landing pad is an "abnormal" edge which
wasn't being taken into account.
This is the meat of that fix:
  if (!PrevBB.canFallThrough() && !MBB->BranchesToLandingPad(MBB)) {
The other stuff is simplification of the "branches to a landing pad" code.
llvm-svn: 91161 | 
| | 
| 
| 
| 
| 
| | build bots.
llvm-svn: 91113 | 
| | 
| 
| 
| 
| 
| 
| 
| | - Loosen the restrictions when checking of it branches to a landing pad.
- Make the loop more efficient by checking the '.insert' return value.
- Do cheaper checks first.
llvm-svn: 91101 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | more than one successor. Normally, these extra successors are dead. However,
some of them may branch to exception handling landing pads. If we remove those
successors, then the landing pads could go away if all predecessors to it are
removed. Before, it was checking if the direct successor was the landing
pad. But it could be the result of jumping through multiple basic blocks to get
to it. If we were to only check for the existence of an EH_LABEL in the basic
block and not remove successors if it's in there, then it could stop actually
dead basic blocks from being removed.
llvm-svn: 91092 | 
| | 
| 
| 
| | llvm-svn: 90633 | 
| | 
| 
| 
| 
| 
| | Patch by Howard Hinnant!
llvm-svn: 90365 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | running tail duplication when doing branch folding for if-conversion, and
we also want to be able to run tail duplication earlier to fix some
reg alloc problems.  Move the CanFallThrough function from BranchFolding
to MachineBasicBlock so that it can be shared by TailDuplication.
llvm-svn: 89904 | 
| | 
| 
| 
| 
| 
| 
| 
| | TII->ReverseBranchCondition(Cond) call.
This fixes the MallocBench/cfrac test case regression.
llvm-svn: 89608 | 
| | 
| 
| 
| 
| 
| | Fix debug code that assumes getBasicBlock never returns NULL.
llvm-svn: 89428 | 
| | 
| 
| 
| | llvm-svn: 89130 | 
| | 
| 
| 
| 
| 
| | MachineBasicBlock so other passes can utilize it.
llvm-svn: 86947 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | tail merging support to handle more cases.
 - Recognize several cases where tail merging is beneficial even when
   the tail size is smaller than the generic threshold.
 - Make use of MachineInstrDesc::isBarrier to help detect
   non-fallthrough blocks.
 - Check for and avoid disrupting fall-through edges in more cases.
llvm-svn: 86871 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Be consistent when referring to MachineBasicBlocks: BB#0.
 - Be consistent when referring to virtual registers: %reg1024.
 - Be consistent when referring to unknown physical registers: %physreg10.
 - Be consistent when referring to known physical registers: %RAX
 - Be consistent when referring to register 0: %reg0
 - Be consistent when printing alignments: align=16
 - Print jump table contents.
 - Don't print host addresses, in general.
 - and various other cleanups.
llvm-svn: 85682 | 
| | 
| 
| 
| | llvm-svn: 85571 | 
| | 
| 
| 
| | llvm-svn: 85556 |