diff options
author | Chris Lattner <sabre@nondot.org> | 2005-05-12 06:27:02 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2005-05-12 06:27:02 +0000 |
commit | 6980d8295f415caa752b45c745c25a9be0079a9a (patch) | |
tree | 850ecd3efccf972783ef7a68f8d9e4cf008bb9f8 /lib/CodeGen/SelectionDAG/SelectionDAG.cpp | |
parent | e131e5b81e5853f3c2a8c63651898ecd37eaf6f8 (diff) |
handle a common case generated by the uint64 -> FP code path better
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@21888 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/SelectionDAG/SelectionDAG.cpp')
-rw-r--r-- | lib/CodeGen/SelectionDAG/SelectionDAG.cpp | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp index dbb933eda9..1ca213b444 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAG.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAG.cpp @@ -1299,7 +1299,7 @@ SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT, N2.getOperand(0) == N3) return getNode(ISD::FABS, VT, N3); } - // select (setlt X, 0), A, 0 -> and (sra X, size(X)-1, A) + // select (setlt X, 0), A, 0 -> and (sra X, size(X)-1), A if (ConstantSDNode *CN = dyn_cast<ConstantSDNode>(SetCC->getOperand(1))) if (CN->getValue() == 0 && N3C && N3C->getValue() == 0) @@ -1307,6 +1307,22 @@ SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT, MVT::ValueType XType = SetCC->getOperand(0).getValueType(); MVT::ValueType AType = N2.getValueType(); if (XType >= AType) { + // and (sra X, size(X)-1, A) -> "and (srl X, C2), A" iff A is a + // single-bit constant. FIXME: remove once the dag combiner + // exists. + if (ConstantSDNode *AC = dyn_cast<ConstantSDNode>(N2)) + if ((AC->getValue() & (AC->getValue()-1)) == 0) { + unsigned ShCtV = ExactLog2(AC->getValue()); + ShCtV = MVT::getSizeInBits(XType)-ShCtV-1; + SDOperand ShCt = getConstant(ShCtV, TLI.getShiftAmountTy()); + SDOperand Shift = getNode(ISD::SRL, XType, + SetCC->getOperand(0), ShCt); + if (XType > AType) + Shift = getNode(ISD::TRUNCATE, AType, Shift); + return getNode(ISD::AND, AType, Shift, N2); + } + + SDOperand Shift = getNode(ISD::SRA, XType, SetCC->getOperand(0), getConstant(MVT::getSizeInBits(XType)-1, TLI.getShiftAmountTy())); |