Print physreg register nodes with target names (e.g. F1) instead of numbers
authorChris Lattner <sabre@nondot.org>
Fri, 19 Aug 2005 21:21:16 +0000 (21:21 +0000)
committerChris Lattner <sabre@nondot.org>
Fri, 19 Aug 2005 21:21:16 +0000 (21:21 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@22934 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/SelectionDAG.cpp
lib/CodeGen/SelectionDAG/SelectionDAGPrinter.cpp

index 8fb6070e94d1acd8dc5e054437b823ba6ea4053d..e083609cae634961720f120cd62a57c2e2b96aba 100644 (file)
@@ -2070,7 +2070,11 @@ void SDNode::dump(const SelectionDAG *G) const {
       std::cerr << LBB->getName() << " ";
     std::cerr << (const void*)BBDN->getBasicBlock() << ">";
   } else if (const RegisterSDNode *C2V = dyn_cast<RegisterSDNode>(this)) {
-    std::cerr << " #" << C2V->getReg();
+    if (G && MRegisterInfo::isPhysicalRegister(R->getReg())) {
+      std::cerr << " " <<G->getTarget().getRegisterInfo()->getName(R->getReg());
+    } else {
+      std::cerr << " #" << R->getReg();
+    }
   } else if (const ExternalSymbolSDNode *ES =
              dyn_cast<ExternalSymbolSDNode>(this)) {
     std::cerr << "'" << ES->getSymbol() << "'";
index 2a51d203fe1fd50d73d09754168ae9d13e1f1db2..060102c8fcaf0747fd65993659a880dab7f0a1bc 100644 (file)
@@ -13,6 +13,8 @@
 
 #include "llvm/CodeGen/SelectionDAG.h"
 #include "llvm/CodeGen/MachineFunction.h"
+#include "llvm/Target/MRegisterInfo.h"
+#include "llvm/Target/TargetMachine.h"
 #include "llvm/Function.h"
 #include "llvm/Support/GraphWriter.h"
 #include "llvm/ADT/StringExtras.h"
@@ -73,7 +75,11 @@ std::string DOTGraphTraits<SelectionDAG*>::getNodeLabel(const SDNode *Node,
       Op += LBB->getName();
     //Op += " " + (const void*)BBDN->getBasicBlock();
   } else if (const RegisterSDNode *R = dyn_cast<RegisterSDNode>(Node)) {
-    Op += " #" + utostr(R->getReg());
+    if (G && MRegisterInfo::isPhysicalRegister(R->getReg())) {
+      Op = Op + " " + G->getTarget().getRegisterInfo()->getName(R->getReg());
+    } else {
+      Op += " #" + utostr(R->getReg());
+    }
   } else if (const ExternalSymbolSDNode *ES =
              dyn_cast<ExternalSymbolSDNode>(Node)) {
     Op += "'" + std::string(ES->getSymbol()) + "'";