diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2014-07-23 22:26:07 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2014-07-23 22:26:07 +0000 |
commit | 5addace56d25523af6ce9ecf5406a17c93d72134 (patch) | |
tree | 71ecf5a4ef183f70b8bee90e90b26aaebde2bc91 /llvm/lib/MC/MCDisassembler/MCDisassembler.cpp | |
parent | fa154f03d1e2f356f862e2f6960f4dca3ea4bf87 (diff) | |
download | llvm-5addace56d25523af6ce9ecf5406a17c93d72134.zip llvm-5addace56d25523af6ce9ecf5406a17c93d72134.tar.gz llvm-5addace56d25523af6ce9ecf5406a17c93d72134.tar.bz2 |
Finish inverting the MC -> Object dependency.
There were still some disassembler bits in lib/MC, but their use of Object
was only visible in the includes they used, not in the symbols.
llvm-svn: 213808
Diffstat (limited to 'llvm/lib/MC/MCDisassembler/MCDisassembler.cpp')
-rw-r--r-- | llvm/lib/MC/MCDisassembler/MCDisassembler.cpp | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/llvm/lib/MC/MCDisassembler/MCDisassembler.cpp b/llvm/lib/MC/MCDisassembler/MCDisassembler.cpp new file mode 100644 index 0000000..1084e5e --- /dev/null +++ b/llvm/lib/MC/MCDisassembler/MCDisassembler.cpp @@ -0,0 +1,39 @@ +//===-- MCDisassembler.cpp - Disassembler interface -----------------------===// +// +// The LLVM Compiler Infrastructure +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#include "llvm/MC/MCDisassembler.h" +#include "llvm/MC/MCExternalSymbolizer.h" +#include "llvm/Support/raw_ostream.h" + +using namespace llvm; + +MCDisassembler::~MCDisassembler() { +} + +bool MCDisassembler::tryAddingSymbolicOperand(MCInst &Inst, int64_t Value, + uint64_t Address, bool IsBranch, + uint64_t Offset, + uint64_t InstSize) const { + raw_ostream &cStream = CommentStream ? *CommentStream : nulls(); + if (Symbolizer) + return Symbolizer->tryAddingSymbolicOperand(Inst, cStream, Value, Address, + IsBranch, Offset, InstSize); + return false; +} + +void MCDisassembler::tryAddingPcLoadReferenceComment(int64_t Value, + uint64_t Address) const { + raw_ostream &cStream = CommentStream ? *CommentStream : nulls(); + if (Symbolizer) + Symbolizer->tryAddingPcLoadReferenceComment(cStream, Value, Address); +} + +void MCDisassembler::setSymbolizer(std::unique_ptr<MCSymbolizer> Symzer) { + Symbolizer = std::move(Symzer); +} |