|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This only affects targets like Mips where branch instructions may kill virtual
registers. Most other targets branch on flag values, so virtual registers are
not involved.
The problem is that MachineBasicBlock::updateTerminator deletes branches and
inserts new ones while LiveVariables keeps a list of pointers to instructions
that kill virtual registers. That list wasn't properly updated in
MBB::SplitCriticalEdge.
llvm-svn: 132298 | 
| | 
| 
| 
| | llvm-svn: 129720 | 
| | 
| 
| 
| 
| 
| 
| 
| | A live range cannot be split everywhere in a basic block. A split must go before
the first terminator, and if the variable is live into a landing pad, the split
must happen before the call that can throw.
llvm-svn: 124894 | 
| | 
| 
| 
| 
| 
| | This time let's rephrase to trick gcc-4.3 into not miscompiling.
llvm-svn: 123432 | 
| | 
| 
| 
| | llvm-svn: 123423 | 
| | 
| 
| 
| 
| 
| | Fix some callers to better deal with debug values.
llvm-svn: 123419 | 
| | 
| 
| 
| | llvm-svn: 123399 | 
| | 
| 
| 
| 
| 
| | 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 |