1 //===- AArch64ExternalSymbolizer.h - Symbolizer for AArch64 -----*- C++ -*-===// 2 // 3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4 // See https://llvm.org/LICENSE.txt for license information. 5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6 // 7 //===----------------------------------------------------------------------===// 8 // 9 // Symbolize AArch64 assembly code during disassembly using callbacks. 10 // 11 //===----------------------------------------------------------------------===// 12 13 #ifndef LLVM_LIB_TARGET_AARCH64_DISASSEMBLER_AARCH64EXTERNALSYMBOLIZER_H 14 #define LLVM_LIB_TARGET_AARCH64_DISASSEMBLER_AARCH64EXTERNALSYMBOLIZER_H 15 16 #include "llvm/MC/MCDisassembler/MCExternalSymbolizer.h" 17 18 namespace llvm { 19 20 class AArch64ExternalSymbolizer : public MCExternalSymbolizer { 21 public: AArch64ExternalSymbolizer(MCContext & Ctx,std::unique_ptr<MCRelocationInfo> RelInfo,LLVMOpInfoCallback GetOpInfo,LLVMSymbolLookupCallback SymbolLookUp,void * DisInfo)22 AArch64ExternalSymbolizer(MCContext &Ctx, 23 std::unique_ptr<MCRelocationInfo> RelInfo, 24 LLVMOpInfoCallback GetOpInfo, 25 LLVMSymbolLookupCallback SymbolLookUp, 26 void *DisInfo) 27 : MCExternalSymbolizer(Ctx, std::move(RelInfo), GetOpInfo, SymbolLookUp, 28 DisInfo) {} 29 30 bool tryAddingSymbolicOperand(MCInst &MI, raw_ostream &CommentStream, 31 int64_t Value, uint64_t Address, bool IsBranch, 32 uint64_t Offset, uint64_t OpSize, 33 uint64_t InstSize) override; 34 }; 35 36 } // namespace llvm 37 38 #endif 39