1 //===-- lib/MC/MCDisassembler.cpp - Disassembler interface ------*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 #include "llvm/MC/MCDisassembler.h"
11 #include "llvm/MC/MCExternalSymbolizer.h"
12 #include "llvm/Support/raw_ostream.h"
16 MCDisassembler::~MCDisassembler() {
20 MCDisassembler::setupForSymbolicDisassembly(
21 LLVMOpInfoCallback GetOpInfo,
22 LLVMSymbolLookupCallback SymbolLookUp,
25 OwningPtr<MCRelocationInfo> &RelInfo) {
26 this->GetOpInfo = GetOpInfo;
27 this->SymbolLookUp = SymbolLookUp;
28 this->DisInfo = DisInfo;
30 assert(Ctx != 0 && "No MCContext given for symbolic disassembly");
32 Symbolizer.reset(new MCExternalSymbolizer(*Ctx, RelInfo, GetOpInfo,
33 SymbolLookUp, DisInfo));
37 MCDisassembler::setupForSymbolicDisassembly(
38 LLVMOpInfoCallback GetOpInfo,
39 LLVMSymbolLookupCallback SymbolLookUp,
42 std::unique_ptr<MCRelocationInfo> &RelInfo) {
43 OwningPtr<MCRelocationInfo> MCRI;
44 setupForSymbolicDisassembly(GetOpInfo, SymbolLookUp, DisInfo, Ctx, MCRI);
45 RelInfo = MCRI.take_unique();
48 bool MCDisassembler::tryAddingSymbolicOperand(MCInst &Inst, int64_t Value,
49 uint64_t Address, bool IsBranch,
51 uint64_t InstSize) const {
52 raw_ostream &cStream = CommentStream ? *CommentStream : nulls();
54 return Symbolizer->tryAddingSymbolicOperand(Inst, cStream, Value, Address,
55 IsBranch, Offset, InstSize);
59 void MCDisassembler::tryAddingPcLoadReferenceComment(int64_t Value,
60 uint64_t Address) const {
61 raw_ostream &cStream = CommentStream ? *CommentStream : nulls();
63 Symbolizer->tryAddingPcLoadReferenceComment(cStream, Value, Address);
66 void MCDisassembler::setSymbolizer(OwningPtr<MCSymbolizer> &Symzer) {
67 Symbolizer.reset(Symzer.release());