2001-10-03 17:10:38 +04:00
|
|
|
/////////////////////////////////////////////////////////////////////////
|
2002-10-25 15:44:41 +04:00
|
|
|
// $Id: disasm.h,v 1.8 2002-10-25 11:44:35 bdenney Exp $
|
2001-10-03 17:10:38 +04:00
|
|
|
/////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
2001-04-10 06:20:02 +04:00
|
|
|
// Copyright (C) 2001 MandrakeSoft S.A.
|
2001-04-10 05:04:59 +04:00
|
|
|
//
|
|
|
|
// MandrakeSoft S.A.
|
|
|
|
// 43, rue d'Aboukir
|
|
|
|
// 75002 Paris - France
|
|
|
|
// http://www.linux-mandrake.com/
|
|
|
|
// http://www.mandrakesoft.com/
|
|
|
|
//
|
|
|
|
// This library 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 2 of the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This library 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 this library; if not, write to the Free Software
|
|
|
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
|
|
|
|
|
|
#define BX_SEGMENT_REG 10
|
|
|
|
#define BX_GENERAL_8BIT_REG 11
|
|
|
|
#define BX_GENERAL_16BIT_REG 12
|
|
|
|
#define BX_GENERAL_32BIT_REG 13
|
|
|
|
#define BX_NO_REG_TYPE 14
|
|
|
|
|
|
|
|
#define BX_DECODE_MODRM(mod_rm_byte, mod, opcode, rm) { \
|
|
|
|
mod = (mod_rm_byte >> 6) & 0x03; \
|
|
|
|
opcode = (mod_rm_byte >> 3) & 0x07; \
|
|
|
|
rm = mod_rm_byte & 0x07; \
|
|
|
|
}
|
|
|
|
|
|
|
|
|
merge in BRANCH-io-cleanup.
To see the commit logs for this use either cvsweb or
cvs update -r BRANCH-io-cleanup and then 'cvs log' the various files.
In general this provides a generic interface for logging.
logfunctions:: is a class that is inherited by some classes, and also
. allocated as a standalone global called 'genlog'. All logging uses
. one of the ::info(), ::error(), ::ldebug(), ::panic() methods of this
. class through 'BX_INFO(), BX_ERROR(), BX_DEBUG(), BX_PANIC()' macros
. respectively.
.
. An example usage:
. BX_INFO(("Hello, World!\n"));
iofunctions:: is a class that is allocated once by default, and assigned
as the iofunction of each logfunctions instance. It is this class that
maintains the file descriptor and other output related code, at this
point using vfprintf(). At some future point, someone may choose to
write a gui 'console' for bochs to which messages would be redirected
simply by assigning a different iofunction class to the various logfunctions
objects.
More cleanup is coming, but this works for now. If you want to see alot
of debugging output, in main.cc, change onoff[LOGLEV_DEBUG]=0 to =1.
Comments, bugs, flames, to me: todd@fries.net
2001-05-15 18:49:57 +04:00
|
|
|
class bx_disassemble_c : public logfunctions {
|
2001-04-10 05:04:59 +04:00
|
|
|
public:
|
|
|
|
bx_disassemble_c(void);
|
2002-10-25 15:44:41 +04:00
|
|
|
unsigned disasm(bx_bool is_32, Bit32u ip, Bit8u *instr, char *disbuf);
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
private:
|
2002-10-25 15:44:41 +04:00
|
|
|
bx_bool db_32bit_opsize;
|
|
|
|
bx_bool db_32bit_addrsize;
|
|
|
|
bx_bool db_rep_prefix;
|
|
|
|
bx_bool db_repne_prefix;
|
2002-09-28 10:29:55 +04:00
|
|
|
Bit32u db_eip;
|
2001-04-10 05:04:59 +04:00
|
|
|
Bit8u *instruction_begin; // keep track of where instruction starts
|
|
|
|
Bit8u *instruction; // for fetching of next byte of instruction
|
|
|
|
|
|
|
|
char *seg_override;
|
|
|
|
|
|
|
|
char *disbufptr;
|
|
|
|
|
|
|
|
char *sreg_mod01_rm32[8];
|
|
|
|
char *sreg_mod10_rm32[8];
|
|
|
|
|
|
|
|
char *sreg_mod00_base32[8];
|
|
|
|
char *sreg_mod01_base32[8];
|
|
|
|
char *sreg_mod10_base32[8];
|
|
|
|
|
|
|
|
char *sreg_mod00_rm16[8];
|
|
|
|
char *sreg_mod01_rm16[8];
|
|
|
|
char *sreg_mod10_rm16[8];
|
|
|
|
|
|
|
|
char *segment_name[8];
|
|
|
|
char *general_8bit_reg_name[8];
|
|
|
|
char *general_16bit_reg_name[8];
|
|
|
|
char *general_32bit_reg_name[8];
|
|
|
|
char *base_name16[8];
|
|
|
|
char *index_name16[8];
|
|
|
|
char *index_name32[8];
|
|
|
|
|
2001-04-10 06:10:09 +04:00
|
|
|
BX_CPP_INLINE Bit8u fetch_byte(void) {
|
2002-09-28 10:29:55 +04:00
|
|
|
db_eip++;
|
2001-04-10 05:04:59 +04:00
|
|
|
return(*instruction++);
|
|
|
|
};
|
2001-04-10 06:10:09 +04:00
|
|
|
BX_CPP_INLINE Bit8u peek_byte(void) {
|
2001-04-10 05:04:59 +04:00
|
|
|
return(*instruction);
|
|
|
|
};
|
|
|
|
|
2001-04-10 06:10:09 +04:00
|
|
|
BX_CPP_INLINE Bit16u fetch_word(void) {
|
2001-04-10 05:04:59 +04:00
|
|
|
Bit16u ret16;
|
|
|
|
Bit8u b1, b0;
|
|
|
|
|
|
|
|
b0 = * (Bit8u *) instruction++;
|
|
|
|
b1 = * (Bit8u *) instruction++;
|
|
|
|
ret16 = (b1<<8) | b0;
|
2002-09-28 10:29:55 +04:00
|
|
|
db_eip += 2;
|
2001-04-10 05:04:59 +04:00
|
|
|
return(ret16);
|
|
|
|
};
|
|
|
|
|
2001-04-10 06:10:09 +04:00
|
|
|
BX_CPP_INLINE Bit32u fetch_dword(void) {
|
2001-04-10 05:04:59 +04:00
|
|
|
Bit32u ret32;
|
|
|
|
Bit8u b3, b2, b1, b0;
|
|
|
|
|
|
|
|
b0 = * (Bit8u *) instruction++;
|
|
|
|
b1 = * (Bit8u *) instruction++;
|
|
|
|
b2 = * (Bit8u *) instruction++;
|
|
|
|
b3 = * (Bit8u *) instruction++;
|
|
|
|
ret32 = (b3<<24) | (b2<<16) | (b1<<8) | b0;
|
2002-09-28 10:29:55 +04:00
|
|
|
db_eip += 4;
|
2001-04-10 05:04:59 +04:00
|
|
|
return(ret32);
|
|
|
|
};
|
|
|
|
|
|
|
|
void invalid_opcode(void);
|
|
|
|
void dis_sprintf(char *fmt, ...);
|
|
|
|
void decode_exgx(unsigned modrm_reg_type, unsigned reg_type);
|
|
|
|
void decode_gxex(unsigned reg_type, unsigned modrm_reg_type);
|
|
|
|
void decode_ex(Bit8u modrm, unsigned modrm_reg_type);
|
|
|
|
void out_reg_name(int reg, int reg_type);
|
|
|
|
void out_16bit_base(int base);
|
|
|
|
void out_16bit_index(int index);
|
|
|
|
|
|
|
|
void EbGb(void);
|
|
|
|
void EvGv(void);
|
|
|
|
void GbEb(void);
|
|
|
|
void GvEv(void);
|
|
|
|
void Ew(void);
|
|
|
|
void Ms(void);
|
|
|
|
void GvEw(void);
|
|
|
|
void RdCd(void);
|
|
|
|
void RdDd(void);
|
|
|
|
void CdRd(void);
|
|
|
|
void DdRd(void);
|
|
|
|
void RdTd(void);
|
|
|
|
void TdRd(void);
|
|
|
|
void Jv(void);
|
|
|
|
void Eb(void);
|
|
|
|
void XBTS(void);
|
|
|
|
void IBTS(void);
|
|
|
|
void Mp(void);
|
|
|
|
void EvIb(void);
|
|
|
|
void GvEb(void);
|
|
|
|
void GvMa(void);
|
|
|
|
void EwRw(void);
|
|
|
|
void Iv(void);
|
|
|
|
void Ib(void);
|
|
|
|
void Jb(void);
|
|
|
|
void EbIb(void);
|
|
|
|
void EvIv(void);
|
|
|
|
void EwSw(void);
|
|
|
|
void GvM(void);
|
|
|
|
void SwEw(void);
|
|
|
|
void Ev(void);
|
|
|
|
|
|
|
|
void eAX(void);
|
|
|
|
void eCX(void);
|
|
|
|
void eDX(void);
|
|
|
|
void eBX(void);
|
|
|
|
void eSP(void);
|
|
|
|
void eBP(void);
|
|
|
|
void eSI(void);
|
|
|
|
void eDI(void);
|
|
|
|
|
|
|
|
void Ap(void);
|
|
|
|
void ALOb(void);
|
|
|
|
void eAXOv(void);
|
|
|
|
void ObAL(void);
|
|
|
|
void OveAX(void);
|
|
|
|
void XbYb(void);
|
|
|
|
void XvYv(void);
|
|
|
|
void YbAL(void);
|
|
|
|
void YveAX(void);
|
|
|
|
void ALXb(void);
|
|
|
|
void eAXXv(void);
|
|
|
|
|
|
|
|
void eSPIv(void);
|
|
|
|
void eBPIv(void);
|
|
|
|
void Iw(void);
|
|
|
|
void GvMp(void);
|
|
|
|
void Eb1(void);
|
|
|
|
void Ev1(void);
|
|
|
|
void Es(void);
|
|
|
|
void ST_STi(void);
|
|
|
|
void Ea(void);
|
|
|
|
void STi(void);
|
|
|
|
void Et(void);
|
|
|
|
void Ed(void);
|
|
|
|
void El(void);
|
|
|
|
void STi_ST(void);
|
|
|
|
void Eq(void);
|
|
|
|
void Av(void);
|
|
|
|
void eAXEv(void);
|
|
|
|
void Ep(void);
|
|
|
|
};
|
|
|
|
|
|
|
|
extern bx_disassemble_c bx_disassemble;
|