mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-19 03:24:09 +00:00
Pass an ArrayRef to MCDisassembler::getInstruction.
With this patch MCDisassembler::getInstruction takes an ArrayRef<uint8_t> instead of a MemoryObject. Even on X86 there is a maximum size an instruction can have. Given that, it seems way simpler and more efficient to just pass an ArrayRef to the disassembler instead of a MemoryObject and have it do a virtual call every time it wants some extra bytes. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@221751 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -38,8 +38,7 @@ static bool PrintInsts(const MCDisassembler &DisAsm,
|
||||
MCStreamer &Streamer, bool InAtomicBlock,
|
||||
const MCSubtargetInfo &STI) {
|
||||
// Wrap the vector in a MemoryObject.
|
||||
StringRef Data((const char*)Bytes.first.data(), Bytes.first.size());
|
||||
StringRefMemoryObject memoryObject(Data);
|
||||
ArrayRef<uint8_t> Data(Bytes.first.data(), Bytes.first.size());
|
||||
|
||||
// Disassemble it to strings.
|
||||
uint64_t Size;
|
||||
@ -49,7 +48,7 @@ static bool PrintInsts(const MCDisassembler &DisAsm,
|
||||
MCInst Inst;
|
||||
|
||||
MCDisassembler::DecodeStatus S;
|
||||
S = DisAsm.getInstruction(Inst, Size, memoryObject, Index,
|
||||
S = DisAsm.getInstruction(Inst, Size, Data.slice(Index), Index,
|
||||
/*REMOVE*/ nulls(), nulls());
|
||||
switch (S) {
|
||||
case MCDisassembler::Fail:
|
||||
|
Reference in New Issue
Block a user