diff options
author | Chris Lattner <sabre@nondot.org> | 2007-04-29 08:12:22 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2007-04-29 08:12:22 +0000 |
commit | 45e0f890f82ad2daee99f17e99ff7de932326a2f (patch) | |
tree | 371fd8ea78ce058fddaab6180610a9a95eeb8101 | |
parent | 107d80956d1a7017b132e508defdb5f90e74de5f (diff) | |
download | external_llvm-45e0f890f82ad2daee99f17e99ff7de932326a2f.zip external_llvm-45e0f890f82ad2daee99f17e99ff7de932326a2f.tar.gz external_llvm-45e0f890f82ad2daee99f17e99ff7de932326a2f.tar.bz2 |
very early support for analyzing a bitstream. This opens the file, starts
reading the stream, and detects whether it is LLVM IR or not.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36556 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | tools/llvm-bcanalyzer/llvm-bcanalyzer.cpp | 74 |
1 files changed, 67 insertions, 7 deletions
diff --git a/tools/llvm-bcanalyzer/llvm-bcanalyzer.cpp b/tools/llvm-bcanalyzer/llvm-bcanalyzer.cpp index 46440d9..ad13063 100644 --- a/tools/llvm-bcanalyzer/llvm-bcanalyzer.cpp +++ b/tools/llvm-bcanalyzer/llvm-bcanalyzer.cpp @@ -31,14 +31,15 @@ //===----------------------------------------------------------------------===// #include "llvm/Analysis/Verifier.h" +#include "llvm/Bitcode/BitstreamReader.h" #include "llvm/Bytecode/Analyzer.h" #include "llvm/Support/CommandLine.h" #include "llvm/Support/Compressor.h" #include "llvm/Support/ManagedStatic.h" +#include "llvm/Support/MemoryBuffer.h" #include "llvm/System/Signals.h" #include <fstream> #include <iostream> - using namespace llvm; static cl::opt<std::string> @@ -50,15 +51,74 @@ static cl::opt<std::string> static cl::opt<bool> NoDetails("nodetails", cl::desc("Skip detailed output")); static cl::opt<bool> Dump("dump", cl::desc("Dump low level bytecode trace")); static cl::opt<bool> Verify("verify", cl::desc("Progressively verify module")); +static cl::opt<bool> Bitcode("bitcode", cl::desc("Read a bitcode file")); + +/// CurStreamType - If we can sniff the flavor of this stream, we can produce +/// better dump info. +static enum { + UnknownBitstream, + LLVMIRBitstream +} CurStreamType; + +/// AnalyzeBitcode - Analyze the bitcode file specified by InputFilename. +static int AnalyzeBitcode() { + // Read the input file. + MemoryBuffer *Buffer; + if (InputFilename == "-") + Buffer = MemoryBuffer::getSTDIN(); + else + Buffer = MemoryBuffer::getFile(&InputFilename[0], InputFilename.size()); + + if (Buffer == 0) { + std::cerr << "Error reading '" << InputFilename << "'.\n"; + return 1; + } + + if (Buffer->getBufferSize() & 3) { + std::cerr << "Bitcode stream should be a multiple of 4 bytes in length\n"; + return 1; + } + + unsigned char *BufPtr = (unsigned char *)Buffer->getBufferStart(); + BitstreamReader Stream(BufPtr, BufPtr+Buffer->getBufferSize()); + + + // Read the stream signature. + char Signature[6]; + Signature[0] = Stream.Read(8); + Signature[1] = Stream.Read(8); + Signature[2] = Stream.Read(4); + Signature[3] = Stream.Read(4); + Signature[4] = Stream.Read(4); + Signature[5] = Stream.Read(4); + + CurStreamType = UnknownBitstream; + if (Signature[0] == 'B' && Signature[1] == 'C' && + Signature[2] == 0x0 && Signature[3] == 0xC && + Signature[4] == 0xE && Signature[5] == 0xD) + CurStreamType = LLVMIRBitstream; + + std::cerr << "Summary of " << InputFilename << ":\n"; + std::cerr << " Stream type: "; + switch (CurStreamType) { + default: assert(0 && "Unknown bitstream type"); + case UnknownBitstream: std::cerr << "unknown\n"; break; + case LLVMIRBitstream: std::cerr << "LLVM IR\n"; break; + } + + return 0; +} int main(int argc, char **argv) { llvm_shutdown_obj X; // Call llvm_shutdown() on exit. + cl::ParseCommandLineOptions(argc, argv, " llvm-bcanalyzer file analyzer\n"); + + sys::PrintStackTraceOnErrorSignal(); + + if (Bitcode) + return AnalyzeBitcode(); + try { - cl::ParseCommandLineOptions(argc, argv, - " llvm-bcanalyzer Analysis of ByteCode Dumper\n"); - - sys::PrintStackTraceOnErrorSignal(); - std::ostream *Out = &std::cout; // Default to printing to stdout... std::string ErrorMessage; BytecodeAnalysis bca; @@ -75,7 +135,7 @@ int main(int argc, char **argv) { // All that bcanalyzer does is write the gathered statistics to the output PrintBytecodeAnalysis(bca,*Out); - if ( M && Verify ) { + if (M && Verify) { std::string verificationMsg; if (verifyModule(*M, ReturnStatusAction, &verificationMsg)) std::cerr << "Final Verification Message: " << verificationMsg << "\n"; |