LLVM  9.0.0svn
AArch64Disassembler.h
Go to the documentation of this file.
1 //===- AArch64Disassembler.h - Disassembler 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 //
10 //===----------------------------------------------------------------------===//
11 
12 #ifndef LLVM_LIB_TARGET_AARCH64_DISASSEMBLER_AARCH64DISASSEMBLER_H
13 #define LLVM_LIB_TARGET_AARCH64_DISASSEMBLER_AARCH64DISASSEMBLER_H
14 
16 
17 namespace llvm {
18 
20 public:
22  : MCDisassembler(STI, Ctx) {}
23 
24  ~AArch64Disassembler() override = default;
25 
27  getInstruction(MCInst &Instr, uint64_t &Size, ArrayRef<uint8_t> Bytes,
28  uint64_t Address, raw_ostream &VStream,
29  raw_ostream &CStream) const override;
30 };
31 
32 } // end namespace llvm
33 
34 #endif // LLVM_LIB_TARGET_AARCH64_DISASSEMBLER_AARCH64DISASSEMBLER_H
This class represents lattice values for constants.
Definition: AllocatorList.h:23
DecodeStatus
Ternary decode status.
Superclass for all disassemblers.
Context object for machine code objects.
Definition: MCContext.h:62
const MCSubtargetInfo & STI
Instances of this class represent a single low-level machine instruction.
Definition: MCInst.h:158
MCDisassembler::DecodeStatus getInstruction(MCInst &Instr, uint64_t &Size, ArrayRef< uint8_t > Bytes, uint64_t Address, raw_ostream &VStream, raw_ostream &CStream) const override
Returns the disassembly of a single instruction.
AArch64Disassembler(const MCSubtargetInfo &STI, MCContext &Ctx)
~AArch64Disassembler() override=default
Generic base class for all target subtargets.
uint32_t Size
Definition: Profile.cpp:46
This class implements an extremely fast bulk output stream that can only output to a stream...
Definition: raw_ostream.h:45