forked from OSchip/llvm-project
- Enable x86 isel preprocessing by default unless -fast is specified.
- Also disable isel load folding if -fast. llvm-svn: 29956
This commit is contained in:
parent
9b675bd769
commit
358b9ed98a
|
@ -28,7 +28,7 @@ class MachineCodeEmitter;
|
|||
/// createX86ISelDag - This pass converts a legalized DAG into a
|
||||
/// X86-specific DAG, ready for instruction scheduling.
|
||||
///
|
||||
FunctionPass *createX86ISelDag(X86TargetMachine &TM);
|
||||
FunctionPass *createX86ISelDag(X86TargetMachine &TM, bool Fast);
|
||||
|
||||
/// createX86FloatingPointStackifierPass - This function returns a pass which
|
||||
/// converts floating point register references and pseudo instructions into
|
||||
|
|
|
@ -92,6 +92,10 @@ namespace {
|
|||
/// register should set this to true.
|
||||
bool ContainsFPCode;
|
||||
|
||||
/// FastISel - Enable fast(er) instruction selection.
|
||||
///
|
||||
bool FastISel;
|
||||
|
||||
/// X86Lowering - This object fully describes how to lower LLVM code to an
|
||||
/// X86-specific SelectionDAG.
|
||||
X86TargetLowering X86Lowering;
|
||||
|
@ -103,8 +107,9 @@ namespace {
|
|||
unsigned GlobalBaseReg;
|
||||
|
||||
public:
|
||||
X86DAGToDAGISel(X86TargetMachine &TM)
|
||||
X86DAGToDAGISel(X86TargetMachine &TM, bool fast)
|
||||
: SelectionDAGISel(X86Lowering),
|
||||
ContainsFPCode(false), FastISel(fast),
|
||||
X86Lowering(*TM.getTargetLowering()),
|
||||
Subtarget(&TM.getSubtarget<X86Subtarget>()) {}
|
||||
|
||||
|
@ -237,7 +242,7 @@ bool X86DAGToDAGISel::CanBeFoldedBy(SDNode *N, SDNode *U) {
|
|||
// / [X]
|
||||
// | ^
|
||||
// [U]--------|
|
||||
return !isNonImmUse(U, N);
|
||||
return !FastISel && !isNonImmUse(U, N);
|
||||
}
|
||||
|
||||
/// MoveBelowTokenFactor - Replace TokenFactor operand with load's chain operand
|
||||
|
@ -370,7 +375,7 @@ void X86DAGToDAGISel::InstructionSelectBasicBlock(SelectionDAG &DAG) {
|
|||
DEBUG(BB->dump());
|
||||
MachineFunction::iterator FirstMBB = BB;
|
||||
|
||||
if (X86ISelPreproc)
|
||||
if (!FastISel)
|
||||
InstructionSelectPreprocess(DAG);
|
||||
|
||||
// Codegen the basic block.
|
||||
|
@ -1071,6 +1076,6 @@ SelectInlineAsmMemoryOperand(const SDOperand &Op, char ConstraintCode,
|
|||
/// createX86ISelDag - This pass converts a legalized DAG into a
|
||||
/// X86-specific DAG, ready for instruction scheduling.
|
||||
///
|
||||
FunctionPass *llvm::createX86ISelDag(X86TargetMachine &TM) {
|
||||
return new X86DAGToDAGISel(TM);
|
||||
FunctionPass *llvm::createX86ISelDag(X86TargetMachine &TM, bool Fast) {
|
||||
return new X86DAGToDAGISel(TM, Fast);
|
||||
}
|
||||
|
|
|
@ -103,7 +103,7 @@ bool X86TargetMachine::addPassesToEmitFile(PassManager &PM, std::ostream &Out,
|
|||
PM.add(createUnreachableBlockEliminationPass());
|
||||
|
||||
// Install an instruction selector.
|
||||
PM.add(createX86ISelDag(*this));
|
||||
PM.add(createX86ISelDag(*this, Fast));
|
||||
|
||||
// Print the instruction selected machine code...
|
||||
if (PrintMachineCode)
|
||||
|
@ -168,7 +168,7 @@ void X86JITInfo::addPassesToJITCompile(FunctionPassManager &PM) {
|
|||
PM.add(createUnreachableBlockEliminationPass());
|
||||
|
||||
// Install an instruction selector.
|
||||
PM.add(createX86ISelDag(TM));
|
||||
PM.add(createX86ISelDag(TM, false));
|
||||
|
||||
// Print the instruction selected machine code...
|
||||
if (PrintMachineCode)
|
||||
|
|
Loading…
Reference in New Issue