Print modref information in a useful way.
authorChris Lattner <sabre@nondot.org>
Sat, 17 Jul 2004 06:43:20 +0000 (06:43 +0000)
committerChris Lattner <sabre@nondot.org>
Sat, 17 Jul 2004 06:43:20 +0000 (06:43 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@14907 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/AliasAnalysisEvaluator.cpp

index f30ea43096d242974dd5505885b88be359b2ebed..f3b4ebae9c5fa5cb6478f1773607f7e85b0cb532 100644 (file)
@@ -81,6 +81,16 @@ static inline void PrintResults(const char *Msg, bool P, Value *V1, Value *V2,
   }
 }
 
+static inline void 
+PrintModRefResults(const char *Msg, bool P, Instruction *I, Value *Ptr,
+                   Module *M) {
+  if (P) {
+    std::cerr << "  " << Msg << ":  Ptr: ";
+    WriteAsOperand(std::cerr, Ptr, true, true, M);
+    std::cerr << "\t<->" << *I;
+  }
+}
+
 bool AAEval::runOnFunction(Function &F) {
   AliasAnalysis &AA = getAnalysis<AliasAnalysis>();
   
@@ -133,16 +143,16 @@ bool AAEval::runOnFunction(Function &F) {
       Instruction *I = C->getInstruction();
       switch (AA.getModRefInfo(*C, *V, (*V)->getType()->getPrimitiveSize())) {
       case AliasAnalysis::NoModRef:
-        PrintResults("NoModRef", PrintNoModRef, I, *V, F.getParent());
+        PrintModRefResults("NoModRef", PrintNoModRef, I, *V, F.getParent());
         ++NoModRef; break;
       case AliasAnalysis::Mod:
-        PrintResults("Mod", PrintMod, I, *V, F.getParent());
+        PrintModRefResults("     Mod", PrintMod, I, *V, F.getParent());
         ++Mod; break;
       case AliasAnalysis::Ref:
-        PrintResults("Ref", PrintRef, I, *V, F.getParent());
+        PrintModRefResults("     Ref", PrintRef, I, *V, F.getParent());
         ++Ref; break;
       case AliasAnalysis::ModRef:
-        PrintResults("ModRef", PrintModRef, I, *V, F.getParent());
+        PrintModRefResults("  ModRef", PrintModRef, I, *V, F.getParent());
         ++ModRef; break;
       default:
         std::cerr << "Unknown alias query result!\n";