2012-11-01 15:19:01 +00:00
|
|
|
// Copyright (C) 2003 Dolphin Project.
|
|
|
|
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
2012-11-04 22:01:49 +00:00
|
|
|
// the Free Software Foundation, version 2.0 or later versions.
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License 2.0 for more details.
|
|
|
|
|
|
|
|
// A copy of the GPL 2.0 should have been included with the program.
|
|
|
|
// If not, see http://www.gnu.org/licenses/
|
|
|
|
|
|
|
|
// Official SVN repository and contact information can be found at
|
|
|
|
// http://code.google.com/p/dolphin-emu/
|
|
|
|
|
2014-12-15 22:09:36 +00:00
|
|
|
#pragma once
|
2012-11-01 15:19:01 +00:00
|
|
|
|
|
|
|
#include "Common.h"
|
|
|
|
|
2019-02-12 09:58:20 +00:00
|
|
|
struct LSInstructionInfo
|
2012-11-01 15:19:01 +00:00
|
|
|
{
|
|
|
|
int operandSize; //8, 16, 32, 64
|
|
|
|
int instructionSize;
|
|
|
|
int regOperandReg;
|
|
|
|
int otherReg;
|
|
|
|
int scaledReg;
|
|
|
|
bool zeroExtend;
|
|
|
|
bool signExtend;
|
|
|
|
bool hasImmediate;
|
|
|
|
bool isMemoryWrite;
|
|
|
|
u64 immediate;
|
|
|
|
s32 displacement;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct ModRM
|
|
|
|
{
|
|
|
|
int mod, reg, rm;
|
|
|
|
ModRM(u8 modRM, u8 rex)
|
|
|
|
{
|
|
|
|
mod = modRM >> 6;
|
|
|
|
reg = ((modRM >> 3) & 7) | ((rex & 4)?8:0);
|
|
|
|
rm = modRM & 7;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2014-12-15 22:09:36 +00:00
|
|
|
enum {
|
2012-11-01 15:19:01 +00:00
|
|
|
MOVZX_BYTE = 0xB6, //movzx on byte
|
|
|
|
MOVZX_SHORT = 0xB7, //movzx on short
|
|
|
|
MOVSX_BYTE = 0xBE, //movsx on byte
|
|
|
|
MOVSX_SHORT = 0xBF, //movsx on short
|
|
|
|
MOVE_8BIT = 0xC6, //move 8-bit immediate
|
|
|
|
MOVE_16_32BIT = 0xC7, //move 16 or 32-bit immediate
|
|
|
|
MOVE_REG_TO_MEM = 0x89, //move reg to memory
|
2020-07-19 15:22:33 +00:00
|
|
|
MOVE_MEM_TO_REG = 0x8B, //move memory to reg
|
2012-11-01 15:19:01 +00:00
|
|
|
};
|
|
|
|
|
2014-12-15 22:09:36 +00:00
|
|
|
enum AccessType {
|
2012-11-01 15:19:01 +00:00
|
|
|
OP_ACCESS_READ = 0,
|
|
|
|
OP_ACCESS_WRITE = 1
|
|
|
|
};
|
|
|
|
|
2019-02-12 09:58:20 +00:00
|
|
|
bool X86AnalyzeMOV(const unsigned char *codePtr, LSInstructionInfo &info);
|