2013-04-17 23:09:55 -04:00
|
|
|
// Copyright 2013 Dolphin Emulator Project
|
2015-05-18 01:08:10 +02:00
|
|
|
// Licensed under GPLv2+
|
2013-04-17 23:09:55 -04:00
|
|
|
// Refer to the license.txt file included.
|
2009-03-28 08:57:34 +00:00
|
|
|
|
2014-02-10 13:54:46 -05:00
|
|
|
#pragma once
|
2008-12-08 04:46:09 +00:00
|
|
|
|
2014-02-17 05:18:15 -05:00
|
|
|
#include "Common/CommonTypes.h"
|
2008-12-08 04:46:09 +00:00
|
|
|
|
|
|
|
struct InstructionInfo
|
|
|
|
{
|
|
|
|
int operandSize; //8, 16, 32, 64
|
|
|
|
int instructionSize;
|
|
|
|
int regOperandReg;
|
|
|
|
int otherReg;
|
|
|
|
int scaledReg;
|
|
|
|
bool zeroExtend;
|
|
|
|
bool signExtend;
|
|
|
|
bool hasImmediate;
|
|
|
|
bool isMemoryWrite;
|
2014-04-23 15:05:40 +02:00
|
|
|
bool byteSwap;
|
2008-12-08 04:46:09 +00:00
|
|
|
u64 immediate;
|
|
|
|
s32 displacement;
|
2014-10-04 11:04:46 +10:00
|
|
|
|
|
|
|
bool operator==(const InstructionInfo &other) const;
|
2008-12-08 04:46:09 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
struct ModRM
|
|
|
|
{
|
|
|
|
int mod, reg, rm;
|
|
|
|
ModRM(u8 modRM, u8 rex)
|
|
|
|
{
|
|
|
|
mod = modRM >> 6;
|
2015-02-15 14:43:31 -05:00
|
|
|
reg = ((modRM >> 3) & 7) | ((rex & 4) ? 8 : 0);
|
2008-12-08 04:46:09 +00:00
|
|
|
rm = modRM & 7;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2013-09-02 16:37:04 -04:00
|
|
|
enum AccessType
|
|
|
|
{
|
2008-12-08 04:46:09 +00:00
|
|
|
OP_ACCESS_READ = 0,
|
|
|
|
OP_ACCESS_WRITE = 1
|
|
|
|
};
|
|
|
|
|
2013-09-02 16:37:04 -04:00
|
|
|
bool DisassembleMov(const unsigned char *codePtr, InstructionInfo *info);
|