/* Copyright 2006-2009, BeatriX * File coded by BeatriX * * This file is part of BeaEngine. * * BeaEngine is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * BeaEngine 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with BeaEngine. If not, see . */ /* ==================================================================== * 0c0h * ==================================================================== */ void __bea_callspec__ G2_EbIb(PDISASM pMyDisasm) { GV.REGOPCODE = ((*((UInt8*)(UIntPtr) (GV.EIP_+1))) >> 3) & 0x7; EbIb(pMyDisasm); if (GV.REGOPCODE == 0) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rol "); #endif FillFlags(pMyDisasm, 88); } else if (GV.REGOPCODE == 1) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "ror "); #endif FillFlags(pMyDisasm, 88); } else if (GV.REGOPCODE == 2) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcl "); #endif FillFlags(pMyDisasm, 81); } else if (GV.REGOPCODE == 3) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcr "); #endif FillFlags(pMyDisasm, 81); } else if (GV.REGOPCODE == 4) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shl "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 5) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shr "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 6) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sal "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 7) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sar "); #endif FillFlags(pMyDisasm, 92); } } /* ==================================================================== * 0c1h * ==================================================================== */ void __bea_callspec__ G2_EvIb(PDISASM pMyDisasm) { GV.REGOPCODE = ((*((UInt8*)(UIntPtr) (GV.EIP_+1))) >> 3) & 0x7; EvIb(pMyDisasm); if (GV.REGOPCODE == 0) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rol "); #endif FillFlags(pMyDisasm, 88); } else if (GV.REGOPCODE == 1) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "ror "); #endif FillFlags(pMyDisasm, 88); } else if (GV.REGOPCODE == 2) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcl "); #endif FillFlags(pMyDisasm, 81); } else if (GV.REGOPCODE == 3) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcr "); #endif FillFlags(pMyDisasm, 81); } else if (GV.REGOPCODE == 4) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shl "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 5) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shr "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 6) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sal "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 7) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sar "); #endif FillFlags(pMyDisasm, 92); } } /* ==================================================================== * 0d0h * ==================================================================== */ void __bea_callspec__ G2_Eb1(PDISASM pMyDisasm) { GV.REGOPCODE = ((*((UInt8*)(UIntPtr) (GV.EIP_+1))) >> 3) & 0x7; GV.MemDecoration = Arg1byte; GV.OperandSize = 8; MOD_RM(&(*pMyDisasm).Argument1, pMyDisasm); GV.OperandSize = 32; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Argument2.ArgMnemonic, "1 "); #endif (*pMyDisasm).Argument2.ArgType = CONSTANT_TYPE+ABSOLUTE_; (*pMyDisasm).Argument2.ArgSize = 8; (*pMyDisasm).Instruction.Immediat = 1; if (GV.REGOPCODE == 0) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rol "); #endif FillFlags(pMyDisasm, 87); } else if (GV.REGOPCODE == 1) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "ror "); #endif FillFlags(pMyDisasm, 87); } else if (GV.REGOPCODE == 2) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcl "); #endif FillFlags(pMyDisasm, 80); } else if (GV.REGOPCODE == 3) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcr "); #endif FillFlags(pMyDisasm, 80); } else if (GV.REGOPCODE == 4) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shl "); #endif FillFlags(pMyDisasm, 91); } else if (GV.REGOPCODE == 5) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shr "); #endif FillFlags(pMyDisasm, 91); } else if (GV.REGOPCODE == 6) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sal "); #endif FillFlags(pMyDisasm, 91); } else if (GV.REGOPCODE == 7) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sar "); #endif FillFlags(pMyDisasm, 91); } GV.EIP_ += GV.DECALAGE_EIP+2; } /* ==================================================================== * 0d1h * ==================================================================== */ void __bea_callspec__ G2_Ev1(PDISASM pMyDisasm) { GV.REGOPCODE = ((*((UInt8*)(UIntPtr) (GV.EIP_+1))) >> 3) & 0x7; if (GV.OperandSize == 64) { GV.MemDecoration = Arg1qword; } else if (GV.OperandSize == 32) { GV.MemDecoration = Arg1dword; } else { GV.MemDecoration = Arg1word; } MOD_RM(&(*pMyDisasm).Argument1, pMyDisasm); #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Argument2.ArgMnemonic, "1 "); #endif (*pMyDisasm).Argument2.ArgType = CONSTANT_TYPE+ABSOLUTE_; (*pMyDisasm).Argument2.ArgSize = 8; (*pMyDisasm).Instruction.Immediat = 1; if (GV.REGOPCODE == 0) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rol "); #endif FillFlags(pMyDisasm, 87); } else if (GV.REGOPCODE == 1) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "ror "); #endif FillFlags(pMyDisasm, 87); } else if (GV.REGOPCODE == 2) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcl "); #endif FillFlags(pMyDisasm, 80); } else if (GV.REGOPCODE == 3) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcr "); #endif FillFlags(pMyDisasm, 80); } else if (GV.REGOPCODE == 4) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shl "); #endif FillFlags(pMyDisasm, 91); } else if (GV.REGOPCODE == 5) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shr "); #endif FillFlags(pMyDisasm, 91); } else if (GV.REGOPCODE == 6) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sal "); #endif FillFlags(pMyDisasm, 91); } else if (GV.REGOPCODE == 7) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sar "); #endif FillFlags(pMyDisasm, 91); } GV.EIP_ += GV.DECALAGE_EIP+2; } /* ==================================================================== * 0d2h * ==================================================================== */ void __bea_callspec__ G2_EbCL(PDISASM pMyDisasm) { GV.REGOPCODE = ((*((UInt8*)(UIntPtr) (GV.EIP_+1))) >> 3) & 0x7; GV.MemDecoration = Arg1byte; GV.OperandSize = 8; MOD_RM(&(*pMyDisasm).Argument1, pMyDisasm); GV.OperandSize = 32; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Argument2.ArgMnemonic, Registers8Bits[1]); #endif (*pMyDisasm).Argument2.ArgType = REGISTER_TYPE+GENERAL_REG+REG1; (*pMyDisasm).Argument2.ArgSize = 8; if (GV.REGOPCODE == 0) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rol "); #endif FillFlags(pMyDisasm, 88); } else if (GV.REGOPCODE == 1) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "ror "); #endif FillFlags(pMyDisasm, 88); } else if (GV.REGOPCODE == 2) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcl "); #endif FillFlags(pMyDisasm, 81); } else if (GV.REGOPCODE == 3) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcr "); #endif FillFlags(pMyDisasm, 81); } else if (GV.REGOPCODE == 4) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shl "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 5) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shr "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 6) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sal "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 7) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sar "); #endif FillFlags(pMyDisasm, 92); } GV.EIP_ += GV.DECALAGE_EIP+2; } /* ==================================================================== * 0d3h * ==================================================================== */ void __bea_callspec__ G2_EvCL(PDISASM pMyDisasm) { GV.REGOPCODE = ((*((UInt8*)(UIntPtr) (GV.EIP_+1))) >> 3) & 0x7; if (GV.OperandSize == 64) { GV.MemDecoration = Arg1qword; } else if (GV.OperandSize == 32) { GV.MemDecoration = Arg1dword; } else { GV.MemDecoration = Arg1word; } MOD_RM(&(*pMyDisasm).Argument1, pMyDisasm); #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Argument2.ArgMnemonic, Registers8Bits[1]); #endif (*pMyDisasm).Argument2.ArgType = REGISTER_TYPE+GENERAL_REG+REG1; (*pMyDisasm).Argument2.ArgSize = 8; if (GV.REGOPCODE == 0) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rol "); #endif FillFlags(pMyDisasm, 88); } else if (GV.REGOPCODE == 1) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "ror "); #endif FillFlags(pMyDisasm, 88); } else if (GV.REGOPCODE == 2) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcl "); #endif FillFlags(pMyDisasm, 81); } else if (GV.REGOPCODE == 3) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "rcr "); #endif FillFlags(pMyDisasm, 81); } else if (GV.REGOPCODE == 4) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shl "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 5) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "shr "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 6) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sal "); #endif FillFlags(pMyDisasm, 92); } else if (GV.REGOPCODE == 7) { (*pMyDisasm).Instruction.Category = GENERAL_PURPOSE_INSTRUCTION+SHIFT_ROTATE; #ifndef BEA_LIGHT_DISASSEMBLY (void) strcpy ((*pMyDisasm).Instruction.Mnemonic, "sar "); #endif FillFlags(pMyDisasm, 92); } GV.EIP_ += GV.DECALAGE_EIP+2; }