ModuleDebugInfoPrinter.cpp revision 081c34b725980f995be9080eaec24cd3dfaaf065
1f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)//===-- ModuleDebugInfoPrinter.cpp - Prints module debug info metadata ----===// 2f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// 3f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// The LLVM Compiler Infrastructure 4f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// 5f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// This file is distributed under the University of Illinois Open Source 6f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// License. See LICENSE.TXT for details. 7f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// 8f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)//===----------------------------------------------------------------------===// 9f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// 10f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// This pass decodes the debug info metadata in a module and prints in a 11f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// (sufficiently-prepared-) human-readable form. 12f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// 1303b57e008b61dfcb1fbad3aea950ae0e001748b0Torne (Richard Coles)// For example, run this pass from opt along with the -analyze option, and 14f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// it'll print to standard output. 15f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)// 1603b57e008b61dfcb1fbad3aea950ae0e001748b0Torne (Richard Coles)//===----------------------------------------------------------------------===// 17f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 18f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)#include "llvm/Analysis/Passes.h" 19f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)#include "llvm/Analysis/DebugInfo.h" 20f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)#include "llvm/Assembly/Writer.h" 21f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)#include "llvm/Pass.h" 22f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)#include "llvm/Function.h" 23f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)#include "llvm/Support/ErrorHandling.h" 24f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)#include "llvm/Support/raw_ostream.h" 25f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)#include "llvm/ADT/Statistic.h" 26f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)using namespace llvm; 27f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 28f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)namespace { 29f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) class ModuleDebugInfoPrinter : public ModulePass { 30f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) DebugInfoFinder Finder; 31f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) public: 32f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) static char ID; // Pass identification, replacement for typeid 33f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) ModuleDebugInfoPrinter() : ModulePass(ID) { 34 initializeModuleDebugInfoPrinterPass(*PassRegistry::getPassRegistry()); 35 } 36 37 virtual bool runOnModule(Module &M); 38 39 virtual void getAnalysisUsage(AnalysisUsage &AU) const { 40 AU.setPreservesAll(); 41 } 42 virtual void print(raw_ostream &O, const Module *M) const; 43 }; 44} 45 46char ModuleDebugInfoPrinter::ID = 0; 47INITIALIZE_PASS(ModuleDebugInfoPrinter, "module-debuginfo", 48 "Decodes module-level debug info", false, true) 49 50ModulePass *llvm::createModuleDebugInfoPrinterPass() { 51 return new ModuleDebugInfoPrinter(); 52} 53 54bool ModuleDebugInfoPrinter::runOnModule(Module &M) { 55 Finder.processModule(M); 56 return false; 57} 58 59void ModuleDebugInfoPrinter::print(raw_ostream &O, const Module *M) const { 60 for (DebugInfoFinder::iterator I = Finder.compile_unit_begin(), 61 E = Finder.compile_unit_end(); I != E; ++I) { 62 O << "Compile Unit: "; 63 DICompileUnit(*I).print(O); 64 O << '\n'; 65 } 66 67 for (DebugInfoFinder::iterator I = Finder.subprogram_begin(), 68 E = Finder.subprogram_end(); I != E; ++I) { 69 O << "Subprogram: "; 70 DISubprogram(*I).print(O); 71 O << '\n'; 72 } 73 74 for (DebugInfoFinder::iterator I = Finder.global_variable_begin(), 75 E = Finder.global_variable_end(); I != E; ++I) { 76 O << "GlobalVariable: "; 77 DIGlobalVariable(*I).print(O); 78 O << '\n'; 79 } 80 81 for (DebugInfoFinder::iterator I = Finder.type_begin(), 82 E = Finder.type_end(); I != E; ++I) { 83 O << "Type: "; 84 DIType(*I).print(O); 85 O << '\n'; 86 } 87} 88