blob: 18f0f2f0b2bcfd16ad575c99bd3cc24f1fe86d1d [file] [log] [blame]
Sean Callanan1358fb72009-09-09 22:49:13 +00001//===-- lib/MC/MCDisassembler.cpp - Disassembler interface ------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#include "llvm/MC/MCDisassembler.h"
Ahmed Bougachaad1084d2013-05-24 00:39:57 +000011#include "llvm/MC/MCExternalSymbolizer.h"
12#include "llvm/Support/raw_ostream.h"
13
Chris Lattnerd747a9f2009-09-09 23:46:42 +000014using namespace llvm;
Sean Callanan1358fb72009-09-09 22:49:13 +000015
Chris Lattnerd747a9f2009-09-09 23:46:42 +000016MCDisassembler::~MCDisassembler() {
Edward O'Callaghan50d75a62009-10-05 18:43:19 +000017}
Ahmed Bougachaad1084d2013-05-24 00:39:57 +000018
Ahmed Charles56440fd2014-03-06 05:51:42 +000019void MCDisassembler::setupForSymbolicDisassembly(
20 LLVMOpInfoCallback GetOpInfo, LLVMSymbolLookupCallback SymbolLookUp,
21 void *DisInfo, MCContext *Ctx, std::unique_ptr<MCRelocationInfo> &RelInfo) {
Quentin Colombetf4828052013-05-24 22:51:52 +000022 this->GetOpInfo = GetOpInfo;
23 this->SymbolLookUp = SymbolLookUp;
24 this->DisInfo = DisInfo;
25 this->Ctx = Ctx;
Ahmed Bougachaad1084d2013-05-24 00:39:57 +000026 assert(Ctx != 0 && "No MCContext given for symbolic disassembly");
Quentin Colombetf4828052013-05-24 22:51:52 +000027 if (!Symbolizer)
28 Symbolizer.reset(new MCExternalSymbolizer(*Ctx, RelInfo, GetOpInfo,
29 SymbolLookUp, DisInfo));
Ahmed Bougachaad1084d2013-05-24 00:39:57 +000030}
31
Ahmed Charles56440fd2014-03-06 05:51:42 +000032void MCDisassembler::setupForSymbolicDisassembly(
33 LLVMOpInfoCallback GetOpInfo, LLVMSymbolLookupCallback SymbolLookUp,
34 void *DisInfo, MCContext *Ctx, OwningPtr<MCRelocationInfo> &RelInfo) {
35 std::unique_ptr<MCRelocationInfo> MCRI;
Ahmed Charlesfba06642014-03-05 10:27:34 +000036 setupForSymbolicDisassembly(GetOpInfo, SymbolLookUp, DisInfo, Ctx, MCRI);
Ahmed Charles56440fd2014-03-06 05:51:42 +000037 RelInfo = std::move(MCRI);
Ahmed Charlesfba06642014-03-05 10:27:34 +000038}
39
Ahmed Bougachaad1084d2013-05-24 00:39:57 +000040bool MCDisassembler::tryAddingSymbolicOperand(MCInst &Inst, int64_t Value,
41 uint64_t Address, bool IsBranch,
42 uint64_t Offset,
43 uint64_t InstSize) const {
44 raw_ostream &cStream = CommentStream ? *CommentStream : nulls();
45 if (Symbolizer)
46 return Symbolizer->tryAddingSymbolicOperand(Inst, cStream, Value, Address,
47 IsBranch, Offset, InstSize);
48 return false;
49}
50
51void MCDisassembler::tryAddingPcLoadReferenceComment(int64_t Value,
52 uint64_t Address) const {
53 raw_ostream &cStream = CommentStream ? *CommentStream : nulls();
54 if (Symbolizer)
55 Symbolizer->tryAddingPcLoadReferenceComment(cStream, Value, Address);
56}
57
Ahmed Charlesdf17c832014-03-07 09:38:02 +000058void MCDisassembler::setSymbolizer(std::unique_ptr<MCSymbolizer> Symzer) {
59 Symbolizer = std::move(Symzer);
Ahmed Bougachaad1084d2013-05-24 00:39:57 +000060}