|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| | llvm-svn: 25515 | 
| | 
| 
| 
| 
| 
| 
| | code.  PrologEpilogInserter hasn't been updated yet though, so targets cannot
use this info.
llvm-svn: 23536 | 
| | 
| 
| 
| | llvm-svn: 21439 | 
| | 
| 
| 
| | llvm-svn: 21420 | 
| | 
| 
| 
| | llvm-svn: 19793 | 
| | 
| 
| 
| 
| 
| 
| 
| | Move include/Config and include/Support into include/llvm/Config,
include/llvm/ADT and include/llvm/Support. From here on out, all LLVM
public header files must be under include/llvm/.
llvm-svn: 16137 | 
| | 
| 
| 
| | llvm-svn: 15775 | 
| | 
| 
| 
| | llvm-svn: 15774 | 
| | 
| 
| 
| 
| 
| | "Support/Debug.h".
llvm-svn: 15089 | 
| | 
| 
| 
| 
| 
| | MachineBasicBlock that is not yet attached to a MachineFunction. This change includes changing the third operand (TargetMachine) to a pointer for the MachineInstr::print function.
llvm-svn: 14389 | 
| | 
| 
| 
| | llvm-svn: 13956 | 
| | 
| 
| 
| | llvm-svn: 12425 | 
| | 
| 
| 
| 
| 
| | by reference now that MachineInstr* are in an ilist
llvm-svn: 11732 | 
| | 
| 
| 
| | llvm-svn: 11619 | 
| | 
| 
| 
| 
| 
| | Remove one of the operands of a two operand instruction
llvm-svn: 11478 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | MRegisterInfo::getNumRegs() instead of
MRegisterInfo::FirstVirtualRegister.
Also use MRegisterInfo::is{Physical,Virtual}Register where
appropriate.
llvm-svn: 11477 | 
| | 
| 
| 
| | llvm-svn: 11393 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | ilist of MachineInstr objects. This allows constant time removal and
insertion of MachineInstr instances from anywhere in each
MachineBasicBlock. It also allows for constant time splicing of
MachineInstrs into or out of MachineBasicBlocks.
llvm-svn: 11340 | 
| | 
| 
| 
| | llvm-svn: 11283 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | a) remove opIsUse(), opIsDefOnly(), opIsDefAndUse()
    b) add isUse(), isDef()
    c) rename opHiBits32() to isHiBits32(),
              opLoBits32() to isLoBits32(),
              opHiBits64() to isHiBits64(),
              opLoBits64() to isLoBits64().
This results to much more readable code, for example compare
"op.opIsDef() || op.opIsDefAndUse()" to "op.isDef()" a pattern used
very often in the code.
llvm-svn: 10461 | 
| | 
| 
| 
| | llvm-svn: 9903 | 
| | 
| 
| 
| 
| 
| | Header files will be on the way.
llvm-svn: 9298 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | and TargetInstrDescriptor::ImplicitUses to always point to a null
terminated array and never be null. So there is no need to check for
pointer validity when iterating over those sets. Code that looked
like:
if (const unsigned* AS = TID.ImplicitDefs) {
  for (int i = 0; AS[i]; ++i) {
    // use AS[i]
  }
}
was changed to:
for (const unsigned* AS = TID.ImplicitDefs; *AS; ++AS) {
  // use *AS
}
llvm-svn: 8960 | 
| | 
| 
| 
| | llvm-svn: 7944 | 
| | 
| 
| 
| | llvm-svn: 7823 | 
| | 
| 
| 
| | llvm-svn: 7533 | 
| | 
| 
| 
| | llvm-svn: 7497 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Fixed spilling of %fcc[0-3] which are part of %fsr.
(2) Moved some machine-independent reg-class code to class TargetRegInfo
    from SparcReg{Class,}Info.
(3) Renamed MachienOperand::opIsDef to MachineOperand::opIsDefOnly()
    and related functions and flags.  Fixed several bugs where only
    "isDef" was being checked, not "isDefAndUse".
llvm-svn: 6341 | 
| | 
| 
| 
| | llvm-svn: 5272 | 
| | 
| 
| 
| | llvm-svn: 5220 | 
| | 
| 
| 
| | llvm-svn: 5200 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | * Use new FunctionFrameInfo object to manage stack slots instead of doing
  it directly
* Adjust to new MRegisterInfo API
* Don't take a TM as a ctor argument
* Don't keep track of which callee saved registers are modified
* Don't emit prolog/epilog code or spill/restore code for callee saved regs
* Use new allocation_order_begin/end iterators to simplify dramatically the
  logic for picking registers to allocate
* Machine PHI nodes can no longer contain constant arguments
* Use a bitvector to keep track of registers used instead of a set
* Fix problem where explicitly referenced registers would be added to
  regsused set and never removed
llvm-svn: 5196 | 
| | 
| 
| 
| | llvm-svn: 5144 | 
| | 
| 
| 
| | llvm-svn: 5113 | 
| | 
| 
| 
| | llvm-svn: 5103 | 
| | 
| 
| 
| | llvm-svn: 5099 | 
| | 
| 
| 
| | llvm-svn: 5081 | 
| | 
| 
| 
| 
| 
| | Remvoe some dead code
llvm-svn: 5070 | 
| | 
| 
| 
| | llvm-svn: 5067 | 
| | 
| 
| 
| 
| 
| | register allocation
llvm-svn: 5066 | 
| | 
| 
| 
| 
| 
| | the dependence on PhysRegClassMap
llvm-svn: 5064 | 
| | 
| 
| 
| | llvm-svn: 5061 | 
| | 
| 
| 
| | llvm-svn: 5060 | 
| | 
| 
| 
| | llvm-svn: 5058 | 
| | 
| 
| 
| | llvm-svn: 5057 | 
| | 
| 
| 
| 
| 
| | predecessor
llvm-svn: 5055 | 
| | 
| 
| 
| 
| 
| | spills and reloads emitted
llvm-svn: 5054 | 
| | 
| 
| 
| | llvm-svn: 5052 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | seperate
  function from normal regalloc code
* Make the regalloc for a block a function instead of part of runOnMachineBB, which
  makes it easier to see what's going on in runOnMBB.
llvm-svn: 5051 | 
| | 
| 
| 
| 
| 
| | * Make allocateStackSpaceFor only allocate the right amount of space
llvm-svn: 5048 |