diff options
author | Chris Lattner <sabre@nondot.org> | 2007-11-27 22:36:16 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2007-11-27 22:36:16 +0000 |
commit | f3f4ad9dd6124555f58b5dae1b6dd46cd8f42ed0 (patch) | |
tree | e06e7a62d99c4faaaa916444b8827d16197c8b7d /llvm/lib/Target/ARM/ARMISelLowering.cpp | |
parent | 79ae9895f60ccfb98225419f0e32600d5af623ae (diff) | |
download | bcm5719-llvm-f3f4ad9dd6124555f58b5dae1b6dd46cd8f42ed0.tar.gz bcm5719-llvm-f3f4ad9dd6124555f58b5dae1b6dd46cd8f42ed0.zip |
implement a trivial readme entry.
llvm-svn: 44380
Diffstat (limited to 'llvm/lib/Target/ARM/ARMISelLowering.cpp')
-rw-r--r-- | llvm/lib/Target/ARM/ARMISelLowering.cpp | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/llvm/lib/Target/ARM/ARMISelLowering.cpp b/llvm/lib/Target/ARM/ARMISelLowering.cpp index 608cc4c15de..8cf545287bd 100644 --- a/llvm/lib/Target/ARM/ARMISelLowering.cpp +++ b/llvm/lib/Target/ARM/ARMISelLowering.cpp @@ -262,6 +262,9 @@ ARMTargetLowering::ARMTargetLowering(TargetMachine &TM) setOperationAction(ISD::FP_TO_UINT, MVT::i32, Custom); setOperationAction(ISD::FP_TO_SINT, MVT::i32, Custom); + // We have target-specific dag combine patterns for the following nodes: + // ARMISD::FMRRD - No need to call setTargetDAGCombine + setStackPointerRegisterToSaveRestore(ARM::SP); setSchedulingPreference(SchedulingForRegPressure); setIfCvtBlockSizeLimit(Subtarget->isThumb() ? 0 : 10); @@ -1510,6 +1513,27 @@ ARMTargetLowering::InsertAtEndOfBasicBlock(MachineInstr *MI, // ARM Optimization Hooks //===----------------------------------------------------------------------===// +/// PerformFMRRDCombine - Target-specific dag combine xforms for ARMISD::FMRRD. +static SDOperand PerformFMRRDCombine(SDNode *N, + TargetLowering::DAGCombinerInfo &DCI) { + // fmrrd(fmdrr x, y) -> x,y + SDOperand InDouble = N->getOperand(0); + if (InDouble.getOpcode() == ARMISD::FMDRR) + return DCI.CombineTo(N, InDouble.getOperand(0), InDouble.getOperand(1)); + return SDOperand(); +} + +SDOperand ARMTargetLowering::PerformDAGCombine(SDNode *N, + DAGCombinerInfo &DCI) const { + switch (N->getOpcode()) { + default: break; + case ARMISD::FMRRD: return PerformFMRRDCombine(N, DCI); + } + + return SDOperand(); +} + + /// isLegalAddressImmediate - Return true if the integer value can be used /// as the offset of the target addressing mode for load / store of the /// given type. |