OSDN Git Service

Use Dan's supperior check
authorAndrew Lenharth <andrewl@lenharth.org>
Tue, 7 Oct 2008 18:27:23 +0000 (18:27 +0000)
committerAndrew Lenharth <andrewl@lenharth.org>
Tue, 7 Oct 2008 18:27:23 +0000 (18:27 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@57255 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/LegalizeDAG.cpp

index d4d13c3..8874eb8 100644 (file)
@@ -6441,22 +6441,18 @@ void SelectionDAGLegalize::ExpandOp(SDValue Op, SDValue &Lo, SDValue &Hi){
     LoOps[1] = RHSL;
     HiOps[0] = LHSH;
     HiOps[1] = RHSH;
+
     //cascaded check to see if any smaller size has a a carry flag.
     unsigned OpV = Node->getOpcode() == ISD::ADD ? ISD::ADDC : ISD::SUBC;
     bool hasCarry = false;
-    if (NVT == MVT::i64)
-      hasCarry = TLI.isOperationLegal(OpV, MVT::i64)
-        | TLI.isOperationLegal(OpV, MVT::i32)
-        | TLI.isOperationLegal(OpV, MVT::i16)
-        | TLI.isOperationLegal(OpV, MVT::i8);
-    if (NVT == MVT::i32)
-      hasCarry = TLI.isOperationLegal(OpV, MVT::i32)
-        | TLI.isOperationLegal(OpV, MVT::i16)
-        | TLI.isOperationLegal(OpV, MVT::i8);
-    if (NVT == MVT::i16)
-      hasCarry = TLI.isOperationLegal(OpV, MVT::i16)
-        | TLI.isOperationLegal(OpV, MVT::i8);
-      
+    for (unsigned BitSize = NVT.getSizeInBits(); BitSize != 0; BitSize /= 2) {
+      MVT AVT = MVT::getIntegerVT(BitSize);
+      if (TLI.isOperationLegal(OpV, AVT)) {
+        hasCarry = true;
+        break;
+      }
+    }
+
     if(hasCarry) {
       if (Node->getOpcode() == ISD::ADD) {
         Lo = DAG.getNode(ISD::ADDC, VTList, LoOps, 2);