diff options
author | Dan Gohman <gohman@apple.com> | 2008-02-25 21:57:04 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2008-02-25 21:57:04 +0000 |
commit | 2ff975e749dfe746d702f71f8ca924dcc44912ff (patch) | |
tree | 2199410a3a06b30697c1b6706b973b3fbffa6227 /llvm/lib/Target/X86/X86ISelDAGToDAG.cpp | |
parent | 432e4a67427fc91d2d498921ae088b3ccd310398 (diff) | |
download | bcm5719-llvm-2ff975e749dfe746d702f71f8ca924dcc44912ff.tar.gz bcm5719-llvm-2ff975e749dfe746d702f71f8ca924dcc44912ff.zip |
Remove the hack that turned an {S,U}MUL_LOHI with an unused high
result into a MUL late in the X86 codegen process. ISD::MUL is
once again Legal on X86, so this is no longer needed. And, the
hack was suboptimal; see PR1874 for details.
llvm-svn: 47567
Diffstat (limited to 'llvm/lib/Target/X86/X86ISelDAGToDAG.cpp')
-rw-r--r-- | llvm/lib/Target/X86/X86ISelDAGToDAG.cpp | 9 |
1 files changed, 0 insertions, 9 deletions
diff --git a/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp b/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp index c8b341406ca..75e9faecb29 100644 --- a/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp +++ b/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp @@ -1224,15 +1224,6 @@ SDNode *X86DAGToDAGISel::Select(SDOperand N) { SDOperand N0 = Node->getOperand(0); SDOperand N1 = Node->getOperand(1); - // There are several forms of IMUL that just return the low part and - // don't have fixed-register operands. If we don't need the high part, - // use these instead. They can be selected with the generated ISel code. - if (NVT != MVT::i8 && - N.getValue(1).use_empty()) { - N = CurDAG->getNode(ISD::MUL, NVT, N0, N1); - break; - } - bool isSigned = Opcode == ISD::SMUL_LOHI; if (!isSigned) switch (NVT) { |