//===- LTOBugPoint.h - Top-Level LTO BugPoint class -------------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This class contains all of the shared state and information that is used by // the LTO BugPoint tool to track down bit code files that cause errors. // //===----------------------------------------------------------------------===// #include "llvm/ADT/SmallVector.h" #include "llvm/ADT/BitVector.h" #include "llvm/Module.h" #include "llvm/System/Path.h" #include #include class LTOBugPoint { public: LTOBugPoint(std::istream &args, std::istream &ins); ~LTOBugPoint(); /// findTroubleMakers - Find minimum set of input files that causes error /// identified by the script. bool findTroubleMakers(llvm::SmallVector &TroubleMakers, std::string &Script); /// getNativeObjectFile - Generate native object file based from llvm /// bitcode file. Return false in case of an error. Generated native /// object file is inserted in to the NativeInputFiles list. bool getNativeObjectFile(std::string &FileName); std::string &getErrMsg() { return ErrMsg; } private: /// LinkerInputFiles - This is a list of linker input files. Once populated /// this list is not modified. llvm::SmallVector LinkerInputFiles; /// LinkerOptions - List of linker command line options. llvm::SmallVector LinkerOptions; /// NativeInputFiles - This is a list of input files that are not llvm /// bitcode files. The order in this list is important. The a file /// in LinkerInputFiles at index 4 is a llvm bitcode file then the file /// at index 4 in NativeInputFiles is corresponding native object file. llvm::SmallVector NativeInputFiles; /// BCFiles - This bit vector tracks input bitcode files. llvm::BitVector BCFiles; /// ConfirmedClean - This bit vector tracks input files that are confirmed /// to be clean. llvm::BitVector ConfirmedClean; /// ConfirmedGuilty - This bit vector tracks input files that are confirmed /// to contribute to the bug being investigated. llvm::BitVector ConfirmedGuilty; std::string getFeatureString(const char *TargetTriple); std::string ErrMsg; llvm::sys::Path TempDir; /// findLinkingFailure - If true, investigate link failure bugs when /// one or more linker input files are llvm bitcode files. If false, /// investigate optimization or code generation bugs in LTO mode. bool findLinkingFailure; private: /// assembleBitcode - Generate assembly code from the module. Return false /// in case of an error. bool assembleBitcode(llvm::Module *M, const char *AsmFileName); /// relinkProgram - Relink program. Return false if linking fails. bool relinkProgram(llvm::SmallVector &InputFiles); /// reproduceProgramError - Validate program using user provided script. bool reproduceProgramError(std::string &Script); /// identifyTroubleMakers - Identify set of inputs from the given /// bitvector that are causing the bug under investigation. void identifyTroubleMakers(llvm::BitVector &In); };