The first patch of X86 support for read cycle counter
authorAndrew Lenharth <andrewl@lenharth.org>
Sun, 20 Nov 2005 21:32:07 +0000 (21:32 +0000)
committerAndrew Lenharth <andrewl@lenharth.org>
Sun, 20 Nov 2005 21:32:07 +0000 (21:32 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@24429 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/LegalizeDAG.cpp

index 31b0e0815d3a18b8b1c75cd91c233ec789ac9e0d..429abf3be2acbc19a6b29525a28707cecbb167bc 100644 (file)
@@ -1168,6 +1168,7 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
     if (Tmp1 != Node->getOperand(0))
       Result = DAG.getNode(ISD::READCYCLECOUNTER, MVT::i64, Tmp1);
     break;
+
   case ISD::TRUNCSTORE:
     Tmp1 = LegalizeOp(Node->getOperand(0));  // Legalize the chain.
     Tmp3 = LegalizeOp(Node->getOperand(2));  // Legalize the pointer.
@@ -3336,6 +3337,17 @@ void SelectionDAGLegalize::ExpandOp(SDOperand Op, SDOperand &Lo, SDOperand &Hi){
     Hi = DAG.getConstant(0, NVT);
     break;
   }
+
+  case ISD::READCYCLECOUNTER:
+    if (TLI.getOperationAction(ISD::READCYCLECOUNTER, VT) == TargetLowering::Custom) {
+      SDOperand Chain = LegalizeOp(Node->getOperand(0));
+      AddLegalizedOperand(SDOperand(Node, 1), Chain);
+      SDOperand t = TLI.LowerOperation(Op, DAG);
+      ExpandOp(t, Lo, Hi);
+    } else
+      assert(0 && "Must custom expand ReadCycleCounter");
+    break;
+
     // These operators cannot be expanded directly, emit them as calls to
     // library functions.
   case ISD::FP_TO_SINT: