|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 72030 | 
| | 
| 
| 
| | llvm-svn: 71057 | 
| | 
| 
| 
| 
| 
| | This fixes a very subtle bug. vr defined by an implicit_def is allowed overlap with any register since it doesn't actually modify anything. However, if it's used as a two-address use, its live range can be extended and it can be spilled. The spiller must take care not to emit a reload for the vn number that's defined by the implicit_def. This is both a correctness and performance issue.
llvm-svn: 69743 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | register is available and when it's profitable.
e.g.
     xorq  %r12<kill>, %r13
     addq  %rax, -184(%rbp)
     addq  %r13, -184(%rbp)
==>
     xorq  %r12<kill>, %r13
     movq  -184(%rbp), %r12
     addq  %rax, %r12
     addq  %r13, %r12
     movq  %r12, -184(%rbp)
Two more instructions, but fewer memory accesses. It can also open up
opportunities for more optimizations.
llvm-svn: 69341 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | the subreg field to 0, since the subreg field is only used
for virtual register subregs. This doesn't change
current functionality; it just eliminates bogus noise from
debug output.
llvm-svn: 68955 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | register destinations that are tied to source operands.  The
TargetInstrDescr::findTiedToSrcOperand method silently fails for inline
assembly.  The existing MachineInstr::isRegReDefinedByTwoAddr was very
close to doing what is needed, so this revision makes a few changes to
that method and also renames it to isRegTiedToUseOperand (for consistency
with the very similar isRegTiedToDefOperand and because it handles both
two-address instructions and inline assembly with tied registers).
llvm-svn: 68714 | 
| | 
| 
| 
| | llvm-svn: 68099 | 
| | 
| 
| 
| | llvm-svn: 68092 | 
| | 
| 
| 
| | llvm-svn: 68059 | 
| | 
| 
| 
| | llvm-svn: 67372 | 
| | 
| 
| 
| | llvm-svn: 67335 | 
| | 
| 
| 
| 
| 
| | the would be loaded value is available in a register. It needs to check if it's legal to clobber the register. Also, the register can contain values of multiple spill slots, make sure to check all instead of just the one being unfolded.
llvm-svn: 67068 | 
| | 
| 
| 
| | llvm-svn: 67000 | 
| | 
| 
| 
| | llvm-svn: 66780 | 
|  | No (intended) functionality change.
llvm-svn: 66720 |