|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| | adding <map> to many files that actually do need it.
llvm-svn: 48667 | 
| | 
| 
| 
| | llvm-svn: 46930 | 
| | 
| 
| 
| 
| 
| 
| | Make MachineInstr::getDesc return a reference instead
of a pointer, since it can never be null.
llvm-svn: 45695 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | that it is cheap and efficient to get.
Move a variety of predicates from TargetInstrInfo into 
TargetInstrDescriptor, which makes it much easier to query a predicate
when you don't have TII around.  Now you can use MI->getDesc()->isBranch()
instead of going through TII, and this is much more efficient anyway. Not
all of the predicates have been moved over yet.
Update old code that used MI->getInstrDescriptor()->Flags to use the
new predicates in many places.
llvm-svn: 45674 | 
| | 
| 
| 
| | llvm-svn: 45484 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | that "machine" classes are used to represent the current state of
the code being compiled.  Given this expanded name, we can start 
moving other stuff into it.  For now, move the UsedPhysRegs and
LiveIn/LoveOuts vectors from MachineFunction into it.
Update all the clients to match.
This also reduces some needless #includes, such as MachineModuleInfo
from MachineFunction.
llvm-svn: 45467 | 
| | 
| 
| 
| | llvm-svn: 45418 | 
| | 
| 
| 
| 
| 
| | the stored register is killed.
llvm-svn: 44600 | 
| | 
| 
| 
| | llvm-svn: 36662 | 
| | 
| 
| 
| 
| 
| 
| | Due to darwin gcc bug, one version of darwin linker coalesces
static const int, which defauts PassID based pass identification.
llvm-svn: 36652 | 
| | 
| 
| 
| | llvm-svn: 36632 | 
| | 
| 
| 
| | llvm-svn: 36452 | 
| | 
| 
| 
| | llvm-svn: 32698 | 
| | 
| 
| 
| | llvm-svn: 32366 | 
| | 
| 
| 
| | llvm-svn: 32353 | 
| | 
| 
| 
| | llvm-svn: 32321 | 
| | 
| 
| 
| 
| 
| | is 'unsigned'.
llvm-svn: 32279 | 
| | 
| 
| 
| | llvm-svn: 31985 | 
| | 
| 
| 
| | llvm-svn: 31364 | 
| | 
| 
| 
| 
| 
| | dest / src operands can be tied together.
llvm-svn: 31363 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | actually *removes* one of the operands, instead of just assigning both operands
the same register.  This make reasoning about instructions unnecessarily complex,
because you need to know if you are before or after register allocation to match
up operand #'s with the target description file.
Changing this also gets rid of a bunch of hacky code in various places.
This patch also includes changes to fold loads into cmp/test instructions in
the X86 backend, along with a significant simplification to the X86 spill
folding code.
llvm-svn: 30108 | 
| | 
| 
| 
| | llvm-svn: 29911 | 
| | 
| 
| 
| | llvm-svn: 29471 | 
| | 
| 
| 
| | llvm-svn: 29434 | 
| | 
| 
| 
| | llvm-svn: 29250 | 
| | 
| 
| 
| | llvm-svn: 29220 | 
| | 
| 
| 
| | llvm-svn: 28973 | 
| | 
| 
| 
| | llvm-svn: 28102 | 
| | 
| 
| 
| | 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 |