|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 122628 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | perform initialization without static constructors AND without explicit initialization
by the client.  For the moment, passes are required to initialize both their
(potential) dependencies and any passes they preserve.  I hope to be able to relax
the latter requirement in the future.
llvm-svn: 116334 | 
| | 
| 
| 
| | llvm-svn: 115996 | 
| | 
| 
| 
| | llvm-svn: 109045 | 
| | 
| 
| 
| 
| 
| | TII::isMoveInstr is going tobe completely removed.
llvm-svn: 108507 | 
| | 
| 
| 
| 
| 
| | IMPLICIT_DEF (and subsequently eliminate them). This allows machine LICM to hoist IMPLICIT_DEF's. PR7620.
llvm-svn: 108304 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | EXTRACT_SUBREG no longer appears as a machine instruction. Use COPY instead.
Add isCopy() checks in many places using isMoveInstr() and isExtractSubreg().
The isMoveInstr hook will be removed later.
llvm-svn: 107879 | 
| | 
| 
| 
| 
| 
| 
| | Fix X86InstrInfo::convertToThreeAddressWithLEA to generate COPY instead of
INSERT_SUBREG.
llvm-svn: 107878 | 
| | 
| 
| 
| 
| 
| | Buildbot breakage.
llvm-svn: 107744 | 
| | 
| 
| 
| | llvm-svn: 107732 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | INSERT_SUBREG will now only appear in SSA machine instructions.
Fix the handling of partial redefs in ProcessImplicitDefs. This is now relevant
since partial redef COPY instructions appear.
llvm-svn: 107726 | 
| | 
| 
| 
| 
| 
| 
| | This code is transitional, it will soon be possible to eliminate
isExtractSubreg, isInsertSubreg, and isMoveInstr in most places.
llvm-svn: 107547 | 
| | 
| 
| 
| 
| 
| | indices.
llvm-svn: 103450 | 
| | 
| 
| 
| | llvm-svn: 103436 | 
| | 
| 
| 
| 
| 
| 
| | A virtual register can be used before it is defined in the same MBB if the MBB
is part of a loop. Teach the implicit-def pass about this case.
llvm-svn: 96279 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | 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 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | operand.
ProcessImplicitDefs would only mark one operand per instruction with <undef>.
This fixed PR6086.
llvm-svn: 95319 | 
| | 
| 
| 
| | llvm-svn: 92567 | 
| | 
| 
| 
| | llvm-svn: 89905 | 
| | 
| 
| 
| 
| 
| | implicit operands on copies.
llvm-svn: 89880 | 
| | 
| 
| 
| | llvm-svn: 88895 | 
| | 
| 
| 
| 
| 
| 
| | Make sure when ProcessImplicitDefs removes a copy which kills its source reg that it
removes the copy from said reg's Kills list.
llvm-svn: 88881 | 
|  | This introduces a new pass, SlotIndexes, which is responsible for numbering
instructions for register allocation (and other clients). SlotIndexes numbering
is designed to match the existing scheme, so this patch should not cause any
changes in the generated code.
For consistency, and to avoid naming confusion, LiveIndex has been renamed
SlotIndex.
The processImplicitDefs method of the LiveIntervals analysis has been moved
into its own pass so that it can be run prior to SlotIndexes. This was
necessary to match the existing numbering scheme.
llvm-svn: 85979 |