diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2011-05-02 19:34:44 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2011-05-02 19:34:44 +0000 | 
| commit | 6b943ff3a3f8617113ecbf611cf0f8957e4e19d2 (patch) | |
| tree | fc5f365fb9035b2d0c622bbf06c9bbe8627d7279 /tools/llvm-objdump/llvm-objdump.cpp | |
| parent | d0e4e96dc17a6c1c6de3340842c80f0e187ba349 (diff) | |
Notes
Diffstat (limited to 'tools/llvm-objdump/llvm-objdump.cpp')
| -rw-r--r-- | tools/llvm-objdump/llvm-objdump.cpp | 16 | 
1 files changed, 14 insertions, 2 deletions
| diff --git a/tools/llvm-objdump/llvm-objdump.cpp b/tools/llvm-objdump/llvm-objdump.cpp index 1fef8b6e2496f..a17624aa3dcf8 100644 --- a/tools/llvm-objdump/llvm-objdump.cpp +++ b/tools/llvm-objdump/llvm-objdump.cpp @@ -38,13 +38,13 @@  #include "llvm/Support/SourceMgr.h"  #include "llvm/Support/raw_ostream.h"  #include "llvm/Support/system_error.h" +#include "llvm/Target/TargetMachine.h"  #include "llvm/Target/TargetRegistry.h"  #include "llvm/Target/TargetSelect.h"  #include <algorithm>  #include <cctype>  #include <cerrno>  #include <cstring> -#include <vector>  using namespace llvm;  using namespace object; @@ -182,9 +182,21 @@ static void DisassembleInput(const StringRef &Filename) {        return;      } +    // FIXME: We shouldn't need to do this (and link in codegen). +    //        When we split this out, we should do it in a way that makes +    //        it straightforward to switch subtargets on the fly (.e.g, +    //        the .cpu and .code16 directives). +    std::string FeaturesStr; +    OwningPtr<TargetMachine> TM(TheTarget->createTargetMachine(TripleName, +                                                               FeaturesStr)); +    if (!TM) { +      errs() << "error: could not create target for triple " << TripleName << "\n"; +      return; +    } +      int AsmPrinterVariant = AsmInfo->getAssemblerDialect();      OwningPtr<MCInstPrinter> IP(TheTarget->createMCInstPrinter( -                                  AsmPrinterVariant, *AsmInfo)); +                                  *TM, AsmPrinterVariant, *AsmInfo));      if (!IP) {        errs() << "error: no instruction printer for target " << TripleName << '\n';        return; | 
