2001-10-03 17:10:38 +04:00
|
|
|
/////////////////////////////////////////////////////////////////////////
|
2007-11-16 11:30:22 +03:00
|
|
|
// $Id: cpu.h,v 1.357 2007-11-16 08:30:21 sshwarts 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
|
2005-02-27 20:41:45 +03:00
|
|
|
/////////////////////////////////////////////////////////////////////////
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
|
|
|
|
#ifndef BX_CPU_H
|
|
|
|
# define BX_CPU_H 1
|
|
|
|
|
|
|
|
#include <setjmp.h>
|
|
|
|
|
|
|
|
#include "cpu/lazy_flags.h"
|
|
|
|
|
2006-03-07 01:32:03 +03:00
|
|
|
#if BX_DISASM
|
|
|
|
# include "disasm/disasm.h"
|
|
|
|
#endif
|
|
|
|
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-DEFINES-DECODE-START>
|
2001-04-10 05:04:59 +04:00
|
|
|
// segment register encoding
|
|
|
|
#define BX_SEG_REG_ES 0
|
|
|
|
#define BX_SEG_REG_CS 1
|
|
|
|
#define BX_SEG_REG_SS 2
|
|
|
|
#define BX_SEG_REG_DS 3
|
|
|
|
#define BX_SEG_REG_FS 4
|
|
|
|
#define BX_SEG_REG_GS 5
|
2002-09-18 09:36:48 +04:00
|
|
|
// NULL now has to fit in 3 bits.
|
|
|
|
#define BX_SEG_REG_NULL 7
|
|
|
|
#define BX_NULL_SEG_REG(seg) ((seg) == BX_SEG_REG_NULL)
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-DEFINES-DECODE-END>
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
#ifdef BX_LITTLE_ENDIAN
|
|
|
|
#define BX_REG8L_OFFSET 0
|
|
|
|
#define BX_REG8H_OFFSET 1
|
|
|
|
#define BX_REG16_OFFSET 0
|
|
|
|
#else // BX_BIG_ENDIAN
|
|
|
|
#define BX_REG8L_OFFSET 3
|
|
|
|
#define BX_REG8H_OFFSET 2
|
|
|
|
#define BX_REG16_OFFSET 2
|
|
|
|
#endif // ifdef BX_LITTLE_ENDIAN
|
|
|
|
|
|
|
|
#define BX_16BIT_REG_AX 0
|
|
|
|
#define BX_16BIT_REG_CX 1
|
|
|
|
#define BX_16BIT_REG_DX 2
|
|
|
|
#define BX_16BIT_REG_BX 3
|
|
|
|
#define BX_16BIT_REG_SP 4
|
|
|
|
#define BX_16BIT_REG_BP 5
|
|
|
|
#define BX_16BIT_REG_SI 6
|
|
|
|
#define BX_16BIT_REG_DI 7
|
|
|
|
|
|
|
|
#define BX_32BIT_REG_EAX 0
|
|
|
|
#define BX_32BIT_REG_ECX 1
|
|
|
|
#define BX_32BIT_REG_EDX 2
|
|
|
|
#define BX_32BIT_REG_EBX 3
|
|
|
|
#define BX_32BIT_REG_ESP 4
|
|
|
|
#define BX_32BIT_REG_EBP 5
|
|
|
|
#define BX_32BIT_REG_ESI 6
|
|
|
|
#define BX_32BIT_REG_EDI 7
|
|
|
|
|
2004-09-14 00:48:11 +04:00
|
|
|
#define BX_64BIT_REG_RAX 0
|
|
|
|
#define BX_64BIT_REG_RCX 1
|
|
|
|
#define BX_64BIT_REG_RDX 2
|
|
|
|
#define BX_64BIT_REG_RBX 3
|
|
|
|
#define BX_64BIT_REG_RSP 4
|
|
|
|
#define BX_64BIT_REG_RBP 5
|
|
|
|
#define BX_64BIT_REG_RSI 6
|
|
|
|
#define BX_64BIT_REG_RDI 7
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2006-10-22 02:06:39 +04:00
|
|
|
#define BX_64BIT_REG_R8 8
|
|
|
|
#define BX_64BIT_REG_R9 9
|
|
|
|
#define BX_64BIT_REG_R10 10
|
|
|
|
#define BX_64BIT_REG_R11 11
|
|
|
|
#define BX_64BIT_REG_R12 12
|
|
|
|
#define BX_64BIT_REG_R13 13
|
|
|
|
#define BX_64BIT_REG_R14 14
|
|
|
|
#define BX_64BIT_REG_R15 15
|
|
|
|
|
2001-05-24 22:46:34 +04:00
|
|
|
#if defined(NEED_CPU_REG_SHORTCUTS)
|
|
|
|
|
|
|
|
/* WARNING:
|
|
|
|
Only BX_CPU_C member functions can use these shortcuts safely!
|
|
|
|
Functions that use the shortcuts outside of BX_CPU_C might work
|
|
|
|
when BX_USE_CPU_SMF=1 but will fail when BX_USE_CPU_SMF=0
|
|
|
|
(for example in SMP mode).
|
|
|
|
*/
|
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
// access to 8 bit general registers
|
|
|
|
#define AL (BX_CPU_THIS_PTR gen_reg[0].word.byte.rl)
|
|
|
|
#define CL (BX_CPU_THIS_PTR gen_reg[1].word.byte.rl)
|
|
|
|
#define DL (BX_CPU_THIS_PTR gen_reg[2].word.byte.rl)
|
|
|
|
#define BL (BX_CPU_THIS_PTR gen_reg[3].word.byte.rl)
|
|
|
|
#define AH (BX_CPU_THIS_PTR gen_reg[0].word.byte.rh)
|
|
|
|
#define CH (BX_CPU_THIS_PTR gen_reg[1].word.byte.rh)
|
|
|
|
#define DH (BX_CPU_THIS_PTR gen_reg[2].word.byte.rh)
|
|
|
|
#define BH (BX_CPU_THIS_PTR gen_reg[3].word.byte.rh)
|
|
|
|
|
|
|
|
// access to 16 bit general registers
|
|
|
|
#define AX (BX_CPU_THIS_PTR gen_reg[0].word.rx)
|
|
|
|
#define CX (BX_CPU_THIS_PTR gen_reg[1].word.rx)
|
|
|
|
#define DX (BX_CPU_THIS_PTR gen_reg[2].word.rx)
|
|
|
|
#define BX (BX_CPU_THIS_PTR gen_reg[3].word.rx)
|
|
|
|
#define SP (BX_CPU_THIS_PTR gen_reg[4].word.rx)
|
|
|
|
#define BP (BX_CPU_THIS_PTR gen_reg[5].word.rx)
|
|
|
|
#define SI (BX_CPU_THIS_PTR gen_reg[6].word.rx)
|
|
|
|
#define DI (BX_CPU_THIS_PTR gen_reg[7].word.rx)
|
|
|
|
|
|
|
|
// access to 16 bit instruction pointer
|
2007-10-19 02:44:39 +04:00
|
|
|
#define IP BX_CPU_THIS_PTR eip_reg.word.ip
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
// accesss to 32 bit general registers
|
2002-09-13 04:15:23 +04:00
|
|
|
#define EAX BX_CPU_THIS_PTR gen_reg[0].dword.erx
|
|
|
|
#define ECX BX_CPU_THIS_PTR gen_reg[1].dword.erx
|
|
|
|
#define EDX BX_CPU_THIS_PTR gen_reg[2].dword.erx
|
|
|
|
#define EBX BX_CPU_THIS_PTR gen_reg[3].dword.erx
|
|
|
|
#define ESP BX_CPU_THIS_PTR gen_reg[4].dword.erx
|
|
|
|
#define EBP BX_CPU_THIS_PTR gen_reg[5].dword.erx
|
|
|
|
#define ESI BX_CPU_THIS_PTR gen_reg[6].dword.erx
|
|
|
|
#define EDI BX_CPU_THIS_PTR gen_reg[7].dword.erx
|
|
|
|
|
2006-01-31 22:45:34 +03:00
|
|
|
// access to 32 bit instruction pointer
|
2007-10-19 02:44:39 +04:00
|
|
|
#define EIP BX_CPU_THIS_PTR eip_reg.dword.eip
|
2006-01-31 22:45:34 +03:00
|
|
|
|
2002-09-13 04:15:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
// accesss to 64 bit general registers
|
|
|
|
#define RAX BX_CPU_THIS_PTR gen_reg[0].rrx
|
|
|
|
#define RCX BX_CPU_THIS_PTR gen_reg[1].rrx
|
|
|
|
#define RDX BX_CPU_THIS_PTR gen_reg[2].rrx
|
|
|
|
#define RBX BX_CPU_THIS_PTR gen_reg[3].rrx
|
|
|
|
#define RSP BX_CPU_THIS_PTR gen_reg[4].rrx
|
|
|
|
#define RBP BX_CPU_THIS_PTR gen_reg[5].rrx
|
|
|
|
#define RSI BX_CPU_THIS_PTR gen_reg[6].rrx
|
|
|
|
#define RDI BX_CPU_THIS_PTR gen_reg[7].rrx
|
|
|
|
#define R8 BX_CPU_THIS_PTR gen_reg[8].rrx
|
|
|
|
#define R9 BX_CPU_THIS_PTR gen_reg[9].rrx
|
|
|
|
#define R10 BX_CPU_THIS_PTR gen_reg[10].rrx
|
|
|
|
#define R11 BX_CPU_THIS_PTR gen_reg[11].rrx
|
|
|
|
#define R12 BX_CPU_THIS_PTR gen_reg[12].rrx
|
|
|
|
#define R13 BX_CPU_THIS_PTR gen_reg[13].rrx
|
|
|
|
#define R14 BX_CPU_THIS_PTR gen_reg[14].rrx
|
|
|
|
#define R15 BX_CPU_THIS_PTR gen_reg[15].rrx
|
|
|
|
|
|
|
|
// access to 64 bit instruction pointer
|
2007-10-19 02:44:39 +04:00
|
|
|
#define RIP BX_CPU_THIS_PTR eip_reg.rip
|
2002-09-25 16:54:41 +04:00
|
|
|
|
|
|
|
// access to 64 bit MSR registers
|
2002-09-25 18:09:08 +04:00
|
|
|
#define MSR_FSBASE (BX_CPU_THIS_PTR sregs[BX_SEG_REG_FS].cache.u.segment.base)
|
|
|
|
#define MSR_GSBASE (BX_CPU_THIS_PTR sregs[BX_SEG_REG_GS].cache.u.segment.base)
|
2002-09-25 16:54:41 +04:00
|
|
|
#define MSR_STAR (BX_CPU_THIS_PTR msr.star)
|
|
|
|
#define MSR_LSTAR (BX_CPU_THIS_PTR msr.lstar)
|
|
|
|
#define MSR_CSTAR (BX_CPU_THIS_PTR msr.cstar)
|
|
|
|
#define MSR_FMASK (BX_CPU_THIS_PTR msr.fmask)
|
2002-09-25 18:09:08 +04:00
|
|
|
#define MSR_KERNELGSBASE (BX_CPU_THIS_PTR msr.kernelgsbase)
|
2005-08-05 16:47:33 +04:00
|
|
|
#define MSR_TSC_AUX (BX_CPU_THIS_PTR msr.tsc_aux)
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if BX_SUPPORT_X86_64
|
2002-09-13 21:04:14 +04:00
|
|
|
#define BX_READ_8BIT_REGx(index,extended) ((((index) < 4) || (extended)) ? \
|
2002-09-13 04:15:23 +04:00
|
|
|
(BX_CPU_THIS_PTR gen_reg[index].word.byte.rl) : \
|
|
|
|
(BX_CPU_THIS_PTR gen_reg[(index)-4].word.byte.rh))
|
|
|
|
#define BX_READ_64BIT_REG(index) (BX_CPU_THIS_PTR gen_reg[index].rrx)
|
|
|
|
#else
|
2001-04-10 05:04:59 +04:00
|
|
|
#define BX_READ_8BIT_REG(index) (((index) < 4) ? \
|
|
|
|
(BX_CPU_THIS_PTR gen_reg[index].word.byte.rl) : \
|
|
|
|
(BX_CPU_THIS_PTR gen_reg[(index)-4].word.byte.rh))
|
2002-09-13 21:04:14 +04:00
|
|
|
#define BX_READ_8BIT_REGx(index,ext) BX_READ_8BIT_REG(index)
|
2003-08-30 01:20:52 +04:00
|
|
|
#endif
|
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
#define BX_READ_16BIT_REG(index) (BX_CPU_THIS_PTR gen_reg[index].word.rx)
|
2002-09-13 04:15:23 +04:00
|
|
|
#define BX_READ_32BIT_REG(index) (BX_CPU_THIS_PTR gen_reg[index].dword.erx)
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-09-07 00:22:39 +04:00
|
|
|
#define BX_WRITE_16BIT_REG(index, val) {\
|
|
|
|
BX_CPU_THIS_PTR gen_reg[index].word.rx = val; \
|
2005-08-08 23:56:11 +04:00
|
|
|
}
|
2004-09-07 00:22:39 +04:00
|
|
|
|
2007-01-27 01:16:59 +03:00
|
|
|
/*
|
2004-09-07 00:22:39 +04:00
|
|
|
#define BX_WRITE_32BIT_REG(index, val) {\
|
|
|
|
BX_CPU_THIS_PTR gen_reg[index].dword.erx = val; \
|
2005-08-08 23:56:11 +04:00
|
|
|
}
|
2007-01-27 01:16:59 +03:00
|
|
|
*/
|
2004-09-07 00:22:39 +04:00
|
|
|
|
2002-09-13 04:15:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2003-08-30 01:20:52 +04:00
|
|
|
|
2002-09-13 21:04:14 +04:00
|
|
|
#define BX_WRITE_8BIT_REGx(index, extended, val) {\
|
2002-09-13 04:15:23 +04:00
|
|
|
if (((index) < 4) || (extended)) \
|
|
|
|
BX_CPU_THIS_PTR gen_reg[index].word.byte.rl = val; \
|
|
|
|
else \
|
|
|
|
BX_CPU_THIS_PTR gen_reg[(index)-4].word.byte.rh = val; \
|
2005-08-08 23:56:11 +04:00
|
|
|
}
|
2004-09-07 00:22:39 +04:00
|
|
|
|
2002-09-13 04:15:23 +04:00
|
|
|
#define BX_WRITE_32BIT_REGZ(index, val) {\
|
|
|
|
BX_CPU_THIS_PTR gen_reg[index].rrx = (Bit32u) val; \
|
2005-08-08 23:56:11 +04:00
|
|
|
}
|
2002-09-13 04:15:23 +04:00
|
|
|
|
|
|
|
#define BX_WRITE_64BIT_REG(index, val) {\
|
|
|
|
BX_CPU_THIS_PTR gen_reg[index].rrx = val; \
|
2005-08-08 23:56:11 +04:00
|
|
|
}
|
2004-02-26 22:17:40 +03:00
|
|
|
#define BX_CLEAR_64BIT_HIGH(index) {\
|
|
|
|
BX_CPU_THIS_PTR gen_reg[index].dword.hrx = 0; \
|
2005-08-08 23:56:11 +04:00
|
|
|
}
|
2002-09-13 04:15:23 +04:00
|
|
|
|
|
|
|
#else
|
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
#define BX_WRITE_8BIT_REG(index, val) {\
|
|
|
|
if ((index) < 4) \
|
|
|
|
BX_CPU_THIS_PTR gen_reg[index].word.byte.rl = val; \
|
|
|
|
else \
|
|
|
|
BX_CPU_THIS_PTR gen_reg[(index)-4].word.byte.rh = val; \
|
2005-08-08 23:56:11 +04:00
|
|
|
}
|
2002-09-13 21:04:14 +04:00
|
|
|
#define BX_WRITE_8BIT_REGx(index, ext, val) BX_WRITE_8BIT_REG(index, val)
|
2003-11-07 23:53:27 +03:00
|
|
|
|
2002-09-13 21:04:14 +04:00
|
|
|
// For x86-32, I just pretend this one is like the macro above,
|
|
|
|
// so common code can be used.
|
|
|
|
#define BX_WRITE_32BIT_REGZ(index, val) {\
|
|
|
|
BX_CPU_THIS_PTR gen_reg[index].dword.erx = (Bit32u) val; \
|
2005-08-08 23:56:11 +04:00
|
|
|
}
|
2003-08-30 01:20:52 +04:00
|
|
|
|
2004-02-26 22:17:40 +03:00
|
|
|
#define BX_CLEAR_64BIT_HIGH(index)
|
|
|
|
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
#define CPL (BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].selector.rpl)
|
|
|
|
|
2006-01-18 21:35:38 +03:00
|
|
|
#if BX_SUPPORT_SMP
|
2003-02-13 18:51:22 +03:00
|
|
|
#define BX_CPU_ID (BX_CPU_THIS_PTR bx_cpuid)
|
2006-01-18 21:35:38 +03:00
|
|
|
#else
|
|
|
|
#define BX_CPU_ID (0)
|
2003-02-13 18:51:22 +03:00
|
|
|
#endif
|
|
|
|
|
2001-05-24 22:46:34 +04:00
|
|
|
#endif // defined(NEED_CPU_REG_SHORTCUTS)
|
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
#define BX_DE_EXCEPTION 0 // Divide Error (fault)
|
|
|
|
#define BX_DB_EXCEPTION 1 // Debug (fault/trap)
|
|
|
|
#define BX_BP_EXCEPTION 3 // Breakpoint (trap)
|
|
|
|
#define BX_OF_EXCEPTION 4 // Overflow (trap)
|
|
|
|
#define BX_BR_EXCEPTION 5 // BOUND (fault)
|
|
|
|
#define BX_UD_EXCEPTION 6
|
|
|
|
#define BX_NM_EXCEPTION 7
|
|
|
|
#define BX_DF_EXCEPTION 8
|
|
|
|
#define BX_TS_EXCEPTION 10
|
|
|
|
#define BX_NP_EXCEPTION 11
|
|
|
|
#define BX_SS_EXCEPTION 12
|
|
|
|
#define BX_GP_EXCEPTION 13
|
|
|
|
#define BX_PF_EXCEPTION 14
|
|
|
|
#define BX_MF_EXCEPTION 16
|
|
|
|
#define BX_AC_EXCEPTION 17
|
2002-09-17 18:36:39 +04:00
|
|
|
#define BX_MC_EXCEPTION 18
|
2003-05-15 20:41:17 +04:00
|
|
|
#define BX_XM_EXCEPTION 19
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2002-03-27 19:04:05 +03:00
|
|
|
/* MSR registers */
|
2002-10-04 21:04:33 +04:00
|
|
|
#define BX_MSR_P5_MC_ADDR 0x0000
|
|
|
|
#define BX_MSR_MC_TYPE 0x0001
|
|
|
|
#define BX_MSR_TSC 0x0010
|
|
|
|
#define BX_MSR_CESR 0x0011
|
|
|
|
#define BX_MSR_CTR0 0x0012
|
|
|
|
#define BX_MSR_CTR1 0x0013
|
|
|
|
#define BX_MSR_APICBASE 0x001b
|
2007-09-20 21:33:35 +04:00
|
|
|
|
2003-01-20 23:10:31 +03:00
|
|
|
#if BX_SUPPORT_SEP
|
|
|
|
# define BX_MSR_SYSENTER_CS 0x0174
|
|
|
|
# define BX_MSR_SYSENTER_ESP 0x0175
|
|
|
|
# define BX_MSR_SYSENTER_EIP 0x0176
|
|
|
|
#endif
|
2007-09-20 21:33:35 +04:00
|
|
|
|
2002-10-04 21:04:33 +04:00
|
|
|
#define BX_MSR_DEBUGCTLMSR 0x01d9
|
|
|
|
#define BX_MSR_LASTBRANCHFROMIP 0x01db
|
|
|
|
#define BX_MSR_LASTBRANCHTOIP 0x01dc
|
|
|
|
#define BX_MSR_LASTINTOIP 0x01dd
|
2007-09-20 21:33:35 +04:00
|
|
|
|
|
|
|
#if BX_SUPPORT_MTRR
|
|
|
|
#define BX_MSR_MTRRCAP 0x00fe
|
|
|
|
#define BX_MSR_MTRRPHYSBASE0 0x0200
|
|
|
|
#define BX_MSR_MTRRPHYSMASK0 0x0201
|
|
|
|
#define BX_MSR_MTRRPHYSBASE1 0x0202
|
|
|
|
#define BX_MSR_MTRRPHYSMASK1 0x0203
|
|
|
|
#define BX_MSR_MTRRPHYSBASE2 0x0204
|
|
|
|
#define BX_MSR_MTRRPHYSMASK2 0x0205
|
|
|
|
#define BX_MSR_MTRRPHYSBASE3 0x0206
|
|
|
|
#define BX_MSR_MTRRPHYSMASK3 0x0207
|
|
|
|
#define BX_MSR_MTRRPHYSBASE4 0x0208
|
|
|
|
#define BX_MSR_MTRRPHYSMASK4 0x0209
|
|
|
|
#define BX_MSR_MTRRPHYSBASE5 0x020a
|
|
|
|
#define BX_MSR_MTRRPHYSMASK5 0x020b
|
|
|
|
#define BX_MSR_MTRRPHYSBASE6 0x020c
|
|
|
|
#define BX_MSR_MTRRPHYSMASK6 0x020d
|
|
|
|
#define BX_MSR_MTRRPHYSBASE7 0x020e
|
|
|
|
#define BX_MSR_MTRRPHYSMASK7 0x020f
|
|
|
|
#define BX_MSR_MTRRFIX64K_00000 0x0250
|
|
|
|
#define BX_MSR_MTRRFIX16K_80000 0x0258
|
|
|
|
#define BX_MSR_MTRRFIX16K_A0000 0x0259
|
|
|
|
#define BX_MSR_MTRRFIX4K_C0000 0x0268
|
|
|
|
#define BX_MSR_MTRRFIX4K_C8000 0x0269
|
|
|
|
#define BX_MSR_MTRRFIX4K_D0000 0x026a
|
|
|
|
#define BX_MSR_MTRRFIX4K_D8000 0x026b
|
|
|
|
#define BX_MSR_MTRRFIX4K_E0000 0x026c
|
|
|
|
#define BX_MSR_MTRRFIX4K_E8000 0x026d
|
|
|
|
#define BX_MSR_MTRRFIX4K_F0000 0x026e
|
|
|
|
#define BX_MSR_MTRRFIX4K_F8000 0x026f
|
|
|
|
#define BX_MSR_PAT 0x0277
|
|
|
|
#define BX_MSR_MTRR_DEFTYPE 0x02ff
|
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2002-09-13 04:15:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
#define BX_MSR_EFER 0xc0000080
|
|
|
|
#define BX_MSR_STAR 0xc0000081
|
|
|
|
#define BX_MSR_LSTAR 0xc0000082
|
|
|
|
#define BX_MSR_CSTAR 0xc0000083
|
|
|
|
#define BX_MSR_FMASK 0xc0000084
|
|
|
|
#define BX_MSR_FSBASE 0xc0000100
|
|
|
|
#define BX_MSR_GSBASE 0xc0000101
|
|
|
|
#define BX_MSR_KERNELGSBASE 0xc0000102
|
2005-08-05 16:47:33 +04:00
|
|
|
#define BX_MSR_TSC_AUX 0xc0000103
|
2002-09-14 01:08:54 +04:00
|
|
|
#endif
|
2002-09-13 04:15:23 +04:00
|
|
|
|
2005-07-29 10:29:57 +04:00
|
|
|
#define BX_MODE_IA32_REAL 0x0 // CR0.PE=0 |
|
2006-02-14 23:03:14 +03:00
|
|
|
#define BX_MODE_IA32_V8086 0x1 // CR0.PE=1, EFLAGS.VM=1 | EFER.LMA=0
|
|
|
|
#define BX_MODE_IA32_PROTECTED 0x2 // CR0.PE=1, EFLAGS.VM=0 |
|
|
|
|
#define BX_MODE_LONG_COMPAT 0x3 // EFER.LMA = 1, CR0.PE=1, CS.L=0
|
|
|
|
#define BX_MODE_LONG_64 0x4 // EFER.LMA = 1, CR0.PE=1, CS.L=1
|
2002-09-13 04:15:23 +04:00
|
|
|
|
2007-10-11 22:12:00 +04:00
|
|
|
extern const char* cpu_mode_string(unsigned cpu_mode);
|
2007-11-08 21:21:37 +03:00
|
|
|
extern const char* cpu_state_string(Bit32u debug_trap);
|
2006-01-24 22:03:55 +03:00
|
|
|
|
2004-11-26 22:53:04 +03:00
|
|
|
#if BX_SUPPORT_X86_64
|
2007-04-14 14:05:30 +04:00
|
|
|
#define IsCanonical(offset) ((Bit64u)((((Bit64s)(offset)) >> (BX_LIN_ADDRESS_WIDTH-1)) + 1) < 2)
|
2004-11-26 22:53:04 +03:00
|
|
|
#else
|
2005-07-31 21:57:27 +04:00
|
|
|
#define IsCanonical(offset) (0)
|
2004-11-26 22:53:04 +03:00
|
|
|
#endif
|
|
|
|
|
2005-04-17 22:54:54 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2005-10-13 23:28:10 +04:00
|
|
|
#define Is64BitMode() (BX_CPU_THIS_PTR cpu_mode == BX_MODE_LONG_64)
|
2005-04-17 22:54:54 +04:00
|
|
|
#else
|
2005-10-13 23:28:10 +04:00
|
|
|
#define Is64BitMode() (0)
|
2005-04-17 22:54:54 +04:00
|
|
|
#endif
|
|
|
|
|
2007-09-20 21:33:35 +04:00
|
|
|
#define StackAddrSize64() Is64BitMode()
|
|
|
|
|
2002-10-05 14:25:31 +04:00
|
|
|
#if BX_SUPPORT_APIC
|
2004-11-26 22:53:04 +03:00
|
|
|
#define BX_CPU_INTR (BX_CPU_THIS_PTR INTR || BX_CPU_THIS_PTR local_apic.INTR)
|
2002-10-05 14:25:31 +04:00
|
|
|
#else
|
2005-04-10 23:42:48 +04:00
|
|
|
#define BX_CPU_INTR (BX_CPU_THIS_PTR INTR)
|
2002-10-05 14:25:31 +04:00
|
|
|
#endif
|
|
|
|
|
2007-11-01 21:03:48 +03:00
|
|
|
#define CACHE_LINE_SIZE 64
|
|
|
|
|
2002-09-12 21:06:40 +04:00
|
|
|
class BX_CPU_C;
|
2006-03-07 01:03:16 +03:00
|
|
|
class BX_MEM_C;
|
2002-09-12 21:06:40 +04:00
|
|
|
|
2002-09-12 22:10:46 +04:00
|
|
|
#if BX_USE_CPU_SMF == 0
|
|
|
|
// normal member functions. This can ONLY be used within BX_CPU_C classes.
|
2002-10-05 14:25:31 +04:00
|
|
|
// Anyone on the outside should use the BX_CPU macro (defined in bochs.h)
|
2002-09-12 22:10:46 +04:00
|
|
|
// instead.
|
|
|
|
# define BX_CPU_THIS_PTR this->
|
2002-09-19 23:17:20 +04:00
|
|
|
# define BX_CPU_THIS this
|
2002-09-12 22:10:46 +04:00
|
|
|
# define BX_SMF
|
|
|
|
# define BX_CPU_C_PREFIX BX_CPU_C::
|
|
|
|
// with normal member functions, calling a member fn pointer looks like
|
|
|
|
// object->*(fnptr)(arg, ...);
|
|
|
|
// Since this is different from when SMF=1, encapsulate it in a macro.
|
|
|
|
# define BX_CPU_CALL_METHOD(func, args) \
|
2002-09-28 04:54:05 +04:00
|
|
|
(this->*((BxExecutePtr_t) (func))) args
|
2003-03-17 03:41:01 +03:00
|
|
|
# define BX_CPU_CALL_METHODR(func, args) \
|
|
|
|
(this->*((BxExecutePtr_tR) (func))) args
|
2002-09-12 22:10:46 +04:00
|
|
|
#else
|
|
|
|
// static member functions. With SMF, there is only one CPU by definition.
|
|
|
|
# define BX_CPU_THIS_PTR BX_CPU(0)->
|
2002-09-19 23:17:20 +04:00
|
|
|
# define BX_CPU_THIS BX_CPU(0)
|
2002-09-12 22:10:46 +04:00
|
|
|
# define BX_SMF static
|
|
|
|
# define BX_CPU_C_PREFIX
|
2002-09-28 04:54:05 +04:00
|
|
|
# define BX_CPU_CALL_METHOD(func, args) \
|
|
|
|
((BxExecutePtr_t) (func)) args
|
2003-03-17 03:41:01 +03:00
|
|
|
# define BX_CPU_CALL_METHODR(func, args) \
|
|
|
|
((BxExecutePtr_tR) (func)) args
|
2002-09-12 22:10:46 +04:00
|
|
|
#endif
|
|
|
|
|
2006-01-18 21:35:38 +03:00
|
|
|
#if BX_SUPPORT_SMP
|
2002-09-12 22:10:46 +04:00
|
|
|
// multiprocessor simulation, we need an array of cpus and memories
|
2006-01-18 21:35:38 +03:00
|
|
|
BOCHSAPI extern BX_CPU_C **bx_cpu_array;
|
|
|
|
#else
|
|
|
|
// single processor simulation, so there's one of everything
|
|
|
|
BOCHSAPI extern BX_CPU_C bx_cpu;
|
2002-09-12 22:10:46 +04:00
|
|
|
#endif
|
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
typedef struct {
|
2005-10-17 17:06:09 +04:00
|
|
|
/* 31|30|29|28| 27|26|25|24| 23|22|21|20| 19|18|17|16
|
|
|
|
* ==|==|=====| ==|==|==|==| ==|==|==|==| ==|==|==|==
|
|
|
|
* 0| 0| 0| 0| 0| 0| 0| 0| 0| 0|ID|VP| VF|AC|VM|RF
|
2001-04-10 05:04:59 +04:00
|
|
|
*
|
2005-10-17 17:06:09 +04:00
|
|
|
* 15|14|13|12| 11|10| 9| 8| 7| 6| 5| 4| 3| 2| 1| 0
|
|
|
|
* ==|==|=====| ==|==|==|==| ==|==|==|==| ==|==|==|==
|
|
|
|
* 0|NT| IOPL| OF|DF|IF|TF| SF|ZF| 0|AF| 0|PF| 1|CF
|
2001-04-10 05:04:59 +04:00
|
|
|
*/
|
2002-09-08 08:08:14 +04:00
|
|
|
Bit32u val32; // Raw 32-bit value in x86 bit position. Used to store
|
|
|
|
// some eflags which are not cached in separate fields.
|
2002-09-22 22:22:24 +04:00
|
|
|
Bit32u VM_cached;
|
|
|
|
|
2002-09-12 22:10:46 +04:00
|
|
|
// accessors for all eflags in bx_flags_reg_t
|
2007-10-22 02:07:33 +04:00
|
|
|
// The macro is used once for each flag bit
|
|
|
|
// Do not use for arithmetic flags !
|
2005-09-29 21:32:32 +04:00
|
|
|
#define DECLARE_EFLAG_ACCESSOR(name,bitnum) \
|
|
|
|
BX_CPP_INLINE void assert_##name (); \
|
|
|
|
BX_CPP_INLINE void clear_##name (); \
|
|
|
|
BX_CPP_INLINE Bit32u get_##name (); \
|
|
|
|
BX_CPP_INLINE bx_bool getB_##name (); \
|
2007-10-22 02:07:33 +04:00
|
|
|
BX_CPP_INLINE void set_##name (Bit8u val); \
|
|
|
|
BX_CPP_INLINE void setB_##name (Bit8u val);
|
2002-09-12 22:10:46 +04:00
|
|
|
|
2005-09-29 21:32:32 +04:00
|
|
|
#define IMPLEMENT_EFLAG_ACCESSOR(name,bitnum) \
|
|
|
|
BX_CPP_INLINE void BX_CPU_C::assert_##name () { \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 |= (1<<bitnum); \
|
|
|
|
} \
|
|
|
|
BX_CPP_INLINE void BX_CPU_C::clear_##name () { \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 &= ~(1<<bitnum); \
|
|
|
|
} \
|
|
|
|
BX_CPP_INLINE bx_bool BX_CPU_C::getB_##name () { \
|
|
|
|
return 1 & (BX_CPU_THIS_PTR eflags.val32 >> bitnum); \
|
|
|
|
} \
|
|
|
|
BX_CPP_INLINE Bit32u BX_CPU_C::get_##name () { \
|
|
|
|
return BX_CPU_THIS_PTR eflags.val32 & (1 << bitnum); \
|
|
|
|
} \
|
|
|
|
BX_CPP_INLINE void BX_CPU_C::set_##name (Bit8u val) { \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 = \
|
|
|
|
(BX_CPU_THIS_PTR eflags.val32&~(1<<bitnum))|((!!val)<<bitnum); \
|
2007-10-22 02:07:33 +04:00
|
|
|
} \
|
|
|
|
BX_CPP_INLINE void BX_CPU_C::setB_##name (Bit8u val) { \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 = \
|
|
|
|
(BX_CPU_THIS_PTR eflags.val32&~(1<<bitnum))|((val)<<bitnum); \
|
2002-09-12 22:10:46 +04:00
|
|
|
}
|
2002-09-22 22:22:24 +04:00
|
|
|
|
2007-08-01 00:25:52 +04:00
|
|
|
#if BX_SUPPORT_ALIGNMENT_CHECK
|
|
|
|
|
|
|
|
#define DECLARE_EFLAG_ACCESSOR_AC(bitnum) \
|
|
|
|
BX_CPP_INLINE void clear_AC (); \
|
|
|
|
BX_CPP_INLINE Bit32u get_AC(); \
|
|
|
|
BX_CPP_INLINE bx_bool getB_AC(); \
|
|
|
|
|
|
|
|
#define IMPLEMENT_EFLAG_ACCESSOR_AC(bitnum) \
|
|
|
|
BX_CPP_INLINE void BX_CPU_C::clear_AC () { \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 &= ~(1<<bitnum); \
|
|
|
|
BX_CPU_THIS_PTR alignment_check = 0; \
|
|
|
|
} \
|
|
|
|
BX_CPP_INLINE Bit32u BX_CPU_C::get_AC() { \
|
|
|
|
return BX_CPU_THIS_PTR eflags.val32 & (1 << bitnum); \
|
|
|
|
} \
|
|
|
|
BX_CPP_INLINE Bit32u BX_CPU_C::getB_AC() { \
|
|
|
|
return 1 & (BX_CPU_THIS_PTR eflags.val32 >> bitnum); \
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2005-09-29 21:32:32 +04:00
|
|
|
#define DECLARE_EFLAG_ACCESSOR_VM(bitnum) \
|
|
|
|
BX_CPP_INLINE void assert_VM(); \
|
|
|
|
BX_CPP_INLINE void clear_VM(); \
|
|
|
|
BX_CPP_INLINE Bit32u get_VM(); \
|
|
|
|
BX_CPP_INLINE bx_bool getB_VM(); \
|
2002-09-22 22:22:24 +04:00
|
|
|
BX_CPP_INLINE void set_VM(Bit32u val);
|
|
|
|
|
2005-09-29 21:32:32 +04:00
|
|
|
#define IMPLEMENT_EFLAG_ACCESSOR_VM(bitnum) \
|
|
|
|
BX_CPP_INLINE Bit32u BX_CPU_C::get_VM() { \
|
|
|
|
return BX_CPU_THIS_PTR eflags.VM_cached; \
|
|
|
|
} \
|
|
|
|
BX_CPP_INLINE Bit32u BX_CPU_C::getB_VM() { \
|
|
|
|
return BX_CPU_THIS_PTR eflags.VM_cached > 0; \
|
|
|
|
} \
|
|
|
|
BX_CPP_INLINE void BX_CPU_C::assert_VM() { \
|
|
|
|
set_VM(1); \
|
|
|
|
} \
|
|
|
|
BX_CPP_INLINE void BX_CPU_C::clear_VM() { \
|
|
|
|
set_VM(0); \
|
|
|
|
} \
|
|
|
|
BX_CPP_INLINE void BX_CPU_C::set_VM(Bit32u val) { \
|
2007-07-09 19:16:14 +04:00
|
|
|
if (long_mode()) return; \
|
2005-09-29 21:32:32 +04:00
|
|
|
if (val) { \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 |= (1<<bitnum); \
|
|
|
|
BX_CPU_THIS_PTR eflags.VM_cached = 1; \
|
2007-07-09 19:16:14 +04:00
|
|
|
if (BX_CPU_THIS_PTR cr0.get_PE()) \
|
2005-09-29 21:32:32 +04:00
|
|
|
BX_CPU_THIS_PTR cpu_mode = BX_MODE_IA32_V8086; \
|
|
|
|
} else { \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 &= ~(1<<bitnum); \
|
|
|
|
BX_CPU_THIS_PTR eflags.VM_cached = 0; \
|
2007-07-09 19:16:14 +04:00
|
|
|
if (BX_CPU_THIS_PTR cr0.get_PE()) \
|
2005-09-29 21:32:32 +04:00
|
|
|
BX_CPU_THIS_PTR cpu_mode = BX_MODE_IA32_PROTECTED; \
|
|
|
|
} \
|
2005-02-04 01:08:34 +03:00
|
|
|
}
|
2002-09-22 22:22:24 +04:00
|
|
|
|
2005-09-29 21:32:32 +04:00
|
|
|
#define DECLARE_EFLAG_ACCESSOR_IOPL(bitnum) \
|
|
|
|
BX_CPP_INLINE void set_IOPL(Bit32u val); \
|
2002-10-05 02:25:22 +04:00
|
|
|
BX_CPP_INLINE Bit32u get_IOPL(void);
|
2002-09-22 22:22:24 +04:00
|
|
|
|
2005-09-29 21:32:32 +04:00
|
|
|
#define IMPLEMENT_EFLAG_ACCESSOR_IOPL(bitnum) \
|
|
|
|
BX_CPP_INLINE void BX_CPU_C::set_IOPL(Bit32u val) { \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 &= ~(3<<12); \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 |= ((3&val) << 12); \
|
|
|
|
} \
|
|
|
|
BX_CPP_INLINE Bit32u BX_CPU_C::get_IOPL() { \
|
|
|
|
return 3 & (BX_CPU_THIS_PTR eflags.val32 >> 12); \
|
2005-02-04 01:08:34 +03:00
|
|
|
}
|
2002-09-22 22:22:24 +04:00
|
|
|
|
2005-08-08 23:56:11 +04:00
|
|
|
#define EFlagsCFMask (1 << 0)
|
|
|
|
#define EFlagsPFMask (1 << 2)
|
|
|
|
#define EFlagsAFMask (1 << 4)
|
|
|
|
#define EFlagsZFMask (1 << 6)
|
|
|
|
#define EFlagsSFMask (1 << 7)
|
|
|
|
#define EFlagsTFMask (1 << 8)
|
|
|
|
#define EFlagsIFMask (1 << 9)
|
|
|
|
#define EFlagsDFMask (1 << 10)
|
|
|
|
#define EFlagsOFMask (1 << 11)
|
|
|
|
#define EFlagsIOPLMask (3 << 12)
|
|
|
|
#define EFlagsNTMask (1 << 14)
|
|
|
|
#define EFlagsRFMask (1 << 16)
|
|
|
|
#define EFlagsVMMask (1 << 17)
|
|
|
|
#define EFlagsACMask (1 << 18)
|
2007-09-20 21:33:35 +04:00
|
|
|
#define EFlagsVIFMask (1 << 19)
|
|
|
|
#define EFlagsVIPMask (1 << 20)
|
2005-08-08 23:56:11 +04:00
|
|
|
#define EFlagsIDMask (1 << 21)
|
2003-05-15 20:41:17 +04:00
|
|
|
|
|
|
|
#define EFlagsOSZAPCMask \
|
|
|
|
(EFlagsCFMask | EFlagsPFMask | EFlagsAFMask | EFlagsZFMask | EFlagsSFMask | EFlagsOFMask)
|
|
|
|
|
|
|
|
#define EFlagsOSZAPMask \
|
|
|
|
(EFlagsPFMask | EFlagsAFMask | EFlagsZFMask | EFlagsSFMask | EFlagsOFMask)
|
2002-09-23 02:22:16 +04:00
|
|
|
|
2005-10-17 17:06:09 +04:00
|
|
|
#define EFlagsValidMask 0x003f7fd5 // only supported bits for EFLAGS
|
|
|
|
|
2005-08-08 23:56:11 +04:00
|
|
|
} bx_flags_reg_t;
|
2002-09-22 22:22:24 +04:00
|
|
|
|
2002-03-27 19:04:05 +03:00
|
|
|
#if BX_CPU_LEVEL >= 5
|
2006-03-15 20:57:11 +03:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
#if BX_SUPPORT_APIC
|
2006-03-02 01:32:24 +03:00
|
|
|
bx_phy_address apicbase;
|
2006-03-15 20:57:11 +03:00
|
|
|
#endif
|
2002-09-13 04:15:23 +04:00
|
|
|
|
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
Bit64u star;
|
|
|
|
Bit64u lstar;
|
|
|
|
Bit64u cstar;
|
|
|
|
Bit64u fmask;
|
|
|
|
Bit64u kernelgsbase;
|
2005-08-05 16:47:33 +04:00
|
|
|
Bit32u tsc_aux;
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif
|
|
|
|
|
2006-01-21 15:06:03 +03:00
|
|
|
// TSC: Time Stamp Counter
|
|
|
|
// Instead of storing a counter and incrementing it every instruction, we
|
|
|
|
// remember the time in ticks that it was reset to zero. With a little
|
|
|
|
// algebra, we can also support setting it to something other than zero.
|
|
|
|
// Don't read this directly; use get_TSC and set_TSC to access the TSC.
|
|
|
|
Bit64u tsc_last_reset;
|
|
|
|
|
2006-02-28 22:50:08 +03:00
|
|
|
// SYSENTER/SYSEXIT instruction msr's
|
|
|
|
#if BX_SUPPORT_SEP
|
|
|
|
Bit32u sysenter_cs_msr;
|
|
|
|
Bit32u sysenter_esp_msr;
|
|
|
|
Bit32u sysenter_eip_msr;
|
|
|
|
#endif
|
|
|
|
|
2007-09-20 21:33:35 +04:00
|
|
|
#if BX_SUPPORT_MTRR
|
|
|
|
Bit64u mtrrphys[16];
|
|
|
|
Bit64u mtrrfix64k_00000;
|
|
|
|
Bit64u mtrrfix16k_80000;
|
|
|
|
Bit64u mtrrfix16k_a0000;
|
|
|
|
Bit64u mtrrfix4k[8];
|
|
|
|
Bit16u mtrr_deftype;
|
|
|
|
Bit64u pat;
|
|
|
|
#endif
|
|
|
|
|
2002-03-27 19:04:05 +03:00
|
|
|
/* TODO finish of the others */
|
2005-02-27 20:41:45 +03:00
|
|
|
} bx_regs_msr_t;
|
2001-04-10 05:04:59 +04:00
|
|
|
#endif
|
|
|
|
|
2007-10-12 23:30:51 +04:00
|
|
|
#define MAX_STD_CPUID_FUNCTION 8
|
|
|
|
#define MAX_EXT_CPUID_FUNCTION 8
|
|
|
|
|
|
|
|
struct cpuid_function_t {
|
|
|
|
Bit32u eax;
|
|
|
|
Bit32u ebx;
|
|
|
|
Bit32u ecx;
|
|
|
|
Bit32u edx;
|
|
|
|
};
|
|
|
|
|
2007-09-10 20:00:15 +04:00
|
|
|
#include "crregs.h"
|
2005-02-27 20:41:45 +03:00
|
|
|
#include "descriptor.h"
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-CLASS-INSTRUCTION-START>
|
2002-09-18 02:50:53 +04:00
|
|
|
class bxInstruction_c {
|
|
|
|
public:
|
2002-09-18 09:36:48 +04:00
|
|
|
// Function pointers; a function to resolve the modRM address
|
|
|
|
// given the current state of the CPU and the instruction data,
|
|
|
|
// and a function to execute the instruction after resolving
|
|
|
|
// the memory address (if any).
|
|
|
|
#if BX_USE_CPU_SMF
|
2006-05-08 00:45:42 +04:00
|
|
|
void (BX_CPP_AttrRegparmN(1) *ResolveModrm)(bxInstruction_c *);
|
2002-09-18 09:36:48 +04:00
|
|
|
void (*execute)(bxInstruction_c *);
|
|
|
|
#else
|
2003-03-17 03:41:01 +03:00
|
|
|
void (BX_CPU_C::*ResolveModrm)(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
2002-09-18 09:36:48 +04:00
|
|
|
void (BX_CPU_C::*execute)(bxInstruction_c *);
|
|
|
|
#endif
|
|
|
|
|
2007-11-12 00:14:24 +03:00
|
|
|
// 31..28 (unused)
|
|
|
|
// 27..19 b1 (9bits of opcode; 1byte-op=0..255, 2byte-op=256..511
|
|
|
|
// (leave this one on top so no mask is needed)
|
|
|
|
// 18..18 mod==c0 (modrm)
|
|
|
|
// 17..16 repUsed (0=none, 2=0xF2, 3=0xF3).
|
|
|
|
Bit16u metaInfo3;
|
|
|
|
|
|
|
|
// 15..12 (unused)
|
|
|
|
// 11...8 ilen (0..15)
|
|
|
|
Bit8u metaInfo2;
|
|
|
|
|
|
|
|
// 7...7 extend8bit
|
|
|
|
// 6...6 as64
|
|
|
|
// 5...5 os64
|
|
|
|
// 4...4 as32
|
|
|
|
// 3...3 os32
|
2002-09-18 09:36:48 +04:00
|
|
|
// 2...0 seg
|
2007-11-12 00:14:24 +03:00
|
|
|
Bit8u metaInfo1;
|
2002-09-18 09:36:48 +04:00
|
|
|
|
2002-09-17 08:20:42 +04:00
|
|
|
union {
|
2002-09-21 03:17:51 +04:00
|
|
|
// Form (longest case): [opcode+modrm+sib/displacement32/immediate32]
|
2002-09-18 02:50:53 +04:00
|
|
|
struct {
|
2007-11-08 21:21:37 +03:00
|
|
|
|
|
|
|
// 31..28 (unused)
|
|
|
|
// 27..24 nnn (modrm)
|
|
|
|
Bit8u modRMData4;
|
|
|
|
|
|
|
|
// 23..20 (unused)
|
2007-11-13 20:30:54 +03:00
|
|
|
// 19..16 base (sib)
|
2007-11-08 21:21:37 +03:00
|
|
|
Bit8u modRMData3;
|
2007-11-07 13:40:40 +03:00
|
|
|
|
2007-11-08 21:21:37 +03:00
|
|
|
// 15..14 mod (modrm)
|
|
|
|
// 13..12 scale (sib)
|
2007-11-13 20:30:54 +03:00
|
|
|
// 11...8 index (sib)
|
2007-11-08 21:21:37 +03:00
|
|
|
Bit8u modRMData2;
|
|
|
|
|
|
|
|
// 7...4 (unused)
|
2002-09-18 02:50:53 +04:00
|
|
|
// 3...0 rm (modrm)
|
2007-11-08 21:21:37 +03:00
|
|
|
Bit8u modRMData1;
|
2002-09-18 02:50:53 +04:00
|
|
|
|
|
|
|
union {
|
2002-09-21 03:17:51 +04:00
|
|
|
Bit32u Id;
|
|
|
|
Bit16u Iw;
|
|
|
|
Bit8u Ib;
|
2005-02-27 20:41:45 +03:00
|
|
|
};
|
2002-09-18 09:36:48 +04:00
|
|
|
|
2002-09-21 03:17:51 +04:00
|
|
|
union {
|
|
|
|
Bit16u displ16u; // for 16-bit modrm forms
|
|
|
|
Bit32u displ32u; // for 32-bit modrm forms
|
2005-02-27 20:41:45 +03:00
|
|
|
};
|
|
|
|
} modRMForm;
|
2002-09-21 03:17:51 +04:00
|
|
|
|
|
|
|
struct {
|
|
|
|
Bit32u dummy;
|
2002-09-18 02:50:53 +04:00
|
|
|
union {
|
|
|
|
Bit32u Id;
|
|
|
|
Bit16u Iw;
|
|
|
|
Bit8u Ib;
|
2005-02-27 20:41:45 +03:00
|
|
|
};
|
2002-09-21 03:17:51 +04:00
|
|
|
union {
|
|
|
|
Bit32u Id2; // Not used (for alignment)
|
|
|
|
Bit16u Iw2;
|
|
|
|
Bit8u Ib2;
|
2005-02-27 20:41:45 +03:00
|
|
|
};
|
|
|
|
} IxIxForm;
|
2002-09-21 03:17:51 +04:00
|
|
|
|
|
|
|
struct {
|
|
|
|
// For opcodes which don't use modRM, but which encode the
|
|
|
|
// register in the low 3 bits of the opcode, extended by the
|
|
|
|
// REX.B bit on x86-64, the register value is cached in opcodeReg.
|
|
|
|
Bit32u opcodeReg;
|
|
|
|
union {
|
|
|
|
Bit32u Id;
|
|
|
|
Bit16u Iw;
|
|
|
|
Bit8u Ib;
|
2005-02-27 20:41:45 +03:00
|
|
|
};
|
2002-09-21 03:17:51 +04:00
|
|
|
Bit32u dummy;
|
2005-02-27 20:41:45 +03:00
|
|
|
} IxForm;
|
2002-09-18 02:50:53 +04:00
|
|
|
|
2002-09-13 04:15:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2002-09-18 09:36:48 +04:00
|
|
|
// Form: [opcode/Iq]. These opcode never use a modrm sequence.
|
2002-09-18 02:50:53 +04:00
|
|
|
struct {
|
2002-09-21 03:17:51 +04:00
|
|
|
Bit32u opcodeReg;
|
2002-09-18 02:50:53 +04:00
|
|
|
Bit64u Iq; // for MOV Rx,imm64
|
2005-02-27 20:41:45 +03:00
|
|
|
} IqForm;
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif
|
2005-02-27 20:41:45 +03:00
|
|
|
};
|
2002-09-17 08:20:42 +04:00
|
|
|
|
2002-09-21 03:17:51 +04:00
|
|
|
BX_CPP_INLINE unsigned opcodeReg() {
|
|
|
|
// The opcodeReg form (low 3 bits of the opcode byte (extended
|
|
|
|
// by REX.B on x86-64) can be accessed by IxForm or IqForm. They
|
|
|
|
// are aligned in the same place, so it doesn't matter.
|
|
|
|
return IxForm.opcodeReg;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2007-11-08 21:21:37 +03:00
|
|
|
// used in FPU only
|
|
|
|
BX_CPP_INLINE unsigned modrm() {
|
2007-11-11 23:44:07 +03:00
|
|
|
#if BX_SUPPORT_X86_64
|
2007-11-08 21:21:37 +03:00
|
|
|
return mod() | (rm() & 7) | ((nnn() & 7) << 3);
|
2007-11-11 23:44:07 +03:00
|
|
|
#else
|
|
|
|
return mod() | rm() | (nnn() << 3);
|
|
|
|
#endif
|
2007-11-08 21:21:37 +03:00
|
|
|
}
|
|
|
|
BX_CPP_INLINE unsigned mod() { return modRMForm.modRMData2 & 0xc0; }
|
2002-09-20 07:52:59 +04:00
|
|
|
BX_CPP_INLINE unsigned modC0()
|
2005-02-27 20:41:45 +03:00
|
|
|
{
|
2002-09-20 07:52:59 +04:00
|
|
|
// This is a cheaper way to test for modRM instructions where
|
|
|
|
// the mod field is 0xc0. FetchDecode flags this condition since
|
|
|
|
// it is quite common to be tested for.
|
2007-11-12 00:14:24 +03:00
|
|
|
return metaInfo3 & (1<<2);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2007-11-07 13:40:40 +03:00
|
|
|
BX_CPP_INLINE unsigned assertModC0()
|
|
|
|
{
|
2007-11-12 00:14:24 +03:00
|
|
|
return metaInfo3 |= (1<<2);
|
2007-11-07 13:40:40 +03:00
|
|
|
}
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_CPP_INLINE unsigned nnn() {
|
2007-11-08 21:21:37 +03:00
|
|
|
return modRMForm.modRMData4;
|
|
|
|
}
|
|
|
|
BX_CPP_INLINE unsigned rm() {
|
|
|
|
return modRMForm.modRMData1;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_CPP_INLINE unsigned sibScale() {
|
2007-11-08 21:21:37 +03:00
|
|
|
return (modRMForm.modRMData2 >> 4) & 0x3;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_CPP_INLINE unsigned sibIndex() {
|
2007-11-13 20:30:54 +03:00
|
|
|
return (modRMForm.modRMData2) & 0xf;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_CPP_INLINE unsigned sibBase() {
|
2007-11-13 20:30:54 +03:00
|
|
|
return modRMForm.modRMData3;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_CPP_INLINE Bit32u displ32u() { return modRMForm.displ32u; }
|
|
|
|
BX_CPP_INLINE Bit16u displ16u() { return modRMForm.displ16u; }
|
|
|
|
BX_CPP_INLINE Bit32u Id() { return modRMForm.Id; }
|
|
|
|
BX_CPP_INLINE Bit16u Iw() { return modRMForm.Iw; }
|
|
|
|
BX_CPP_INLINE Bit8u Ib() { return modRMForm.Ib; }
|
2002-09-21 03:17:51 +04:00
|
|
|
BX_CPP_INLINE Bit16u Iw2() { return IxIxForm.Iw2; } // Legacy
|
|
|
|
BX_CPP_INLINE Bit8u Ib2() { return IxIxForm.Ib2; } // Legacy
|
2002-09-18 02:50:53 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
BX_CPP_INLINE Bit64u Iq() { return IqForm.Iq; }
|
2001-05-23 12:16:07 +04:00
|
|
|
#endif
|
2002-09-18 09:36:48 +04:00
|
|
|
|
|
|
|
// Info in the metaInfo field.
|
|
|
|
// Note: the 'L' at the end of certain flags, means the value returned
|
|
|
|
// is for Logical comparisons, eg if (i->os32L() && i->as32L()). If you
|
2002-10-25 15:44:41 +04:00
|
|
|
// want a bx_bool value, use os32B() etc. This makes for smaller
|
2002-09-18 09:36:48 +04:00
|
|
|
// code, when a strict 0 or 1 is not necessary.
|
2007-11-11 23:56:22 +03:00
|
|
|
BX_CPP_INLINE void initMetaInfo(unsigned os32, unsigned as32,
|
2005-03-02 00:44:01 +03:00
|
|
|
unsigned os64, unsigned as64)
|
|
|
|
{
|
2007-11-12 00:14:24 +03:00
|
|
|
metaInfo1 = BX_SEG_REG_NULL | (os32<<3) | (as32<<4) | (os64<<5) | (as64<<6);
|
|
|
|
metaInfo2 = metaInfo3 = 0;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE unsigned seg(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
return metaInfo1 & 7;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE void setSeg(unsigned val) {
|
2007-11-12 00:14:24 +03:00
|
|
|
metaInfo1 = (metaInfo1 & ~7) | val;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
|
|
|
|
BX_CPP_INLINE unsigned os32L(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
return metaInfo1 & (1<<3);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE unsigned os32B(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
return (metaInfo1 >> 3) & 1;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE void setOs32B(unsigned bit) {
|
2007-11-12 00:14:24 +03:00
|
|
|
metaInfo1 = (metaInfo1 & ~(1<<3)) | (bit<<3);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE void assertOs32(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
metaInfo1 |= (1<<3);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
|
|
|
|
BX_CPP_INLINE unsigned as32L(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
return metaInfo1 & (1<<4);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE unsigned as32B(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
return (metaInfo1 >> 4) & 1;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE void setAs32B(unsigned bit) {
|
2007-11-12 00:14:24 +03:00
|
|
|
metaInfo1 = (metaInfo1 & ~(1<<4)) | (bit<<4);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
|
2002-09-20 07:52:59 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE unsigned os64L(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
return metaInfo1 & (1<<5);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE void assertOs64(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
metaInfo1 |= (1<<5);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-20 07:52:59 +04:00
|
|
|
#else
|
|
|
|
BX_CPP_INLINE unsigned os64L(void) { return 0; }
|
|
|
|
#endif
|
2002-09-18 09:36:48 +04:00
|
|
|
|
2002-09-20 07:52:59 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE unsigned as64L(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
return metaInfo1 & (1<<6);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE void setAs64B(unsigned bit) {
|
2007-11-12 00:14:24 +03:00
|
|
|
metaInfo1 = (metaInfo1 & ~(1<<6)) | (bit<<6);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-20 07:52:59 +04:00
|
|
|
#else
|
|
|
|
BX_CPP_INLINE unsigned as64L(void) { return 0; }
|
|
|
|
#endif
|
2002-09-18 09:36:48 +04:00
|
|
|
|
2002-09-20 07:52:59 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE unsigned extend8bitL(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
return metaInfo1 & (1<<7);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 09:36:48 +04:00
|
|
|
BX_CPP_INLINE void assertExtend8bit(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
metaInfo1 |= (1<<7);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-20 07:52:59 +04:00
|
|
|
#endif
|
2002-09-18 12:00:43 +04:00
|
|
|
|
2007-11-12 00:14:24 +03:00
|
|
|
BX_CPP_INLINE unsigned ilen(void) {
|
|
|
|
return metaInfo2;
|
|
|
|
}
|
|
|
|
BX_CPP_INLINE void setILen(unsigned ilen) {
|
|
|
|
metaInfo2 = ilen;
|
|
|
|
}
|
|
|
|
|
2002-09-18 12:00:43 +04:00
|
|
|
BX_CPP_INLINE unsigned repUsedL(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
return metaInfo3 & 3;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 12:00:43 +04:00
|
|
|
BX_CPP_INLINE unsigned repUsedValue(void) {
|
2007-11-12 00:14:24 +03:00
|
|
|
return metaInfo3 & 3;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 12:00:43 +04:00
|
|
|
BX_CPP_INLINE void setRepUsed(unsigned value) {
|
2007-11-12 00:14:24 +03:00
|
|
|
metaInfo3 = (metaInfo3 & ~3) | (value);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2002-09-18 12:00:43 +04:00
|
|
|
|
|
|
|
// Note this is the highest field, and thus needs no masking.
|
|
|
|
// DON'T PUT ANY FIELDS HIGHER THAN THIS ONE WITHOUT ADDING A MASK.
|
2007-11-12 00:14:24 +03:00
|
|
|
BX_CPP_INLINE unsigned b1(void) {
|
|
|
|
return metaInfo3 >> 3;
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
2007-11-12 00:14:24 +03:00
|
|
|
BX_CPP_INLINE void setB1(unsigned b1) {
|
|
|
|
metaInfo3 = (metaInfo3 & ~(0x1ff << 3)) | ((b1 & 0x1ff) << 3);
|
2005-02-27 20:41:45 +03:00
|
|
|
}
|
|
|
|
};
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-CLASS-INSTRUCTION-END>
|
2001-05-23 12:16:07 +04:00
|
|
|
|
|
|
|
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-TYPE-EXECUTEPTR-START>
|
2002-09-18 02:50:53 +04:00
|
|
|
#if BX_USE_CPU_SMF
|
|
|
|
typedef void (*BxExecutePtr_t)(bxInstruction_c *);
|
2004-02-12 02:47:55 +03:00
|
|
|
typedef void (BX_CPP_AttrRegparmN(1) *BxExecutePtr_tR)(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
#else
|
|
|
|
typedef void (BX_CPU_C::*BxExecutePtr_t)(bxInstruction_c *);
|
2003-03-17 03:41:01 +03:00
|
|
|
typedef void (BX_CPU_C::*BxExecutePtr_tR)(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
2001-04-10 05:04:59 +04:00
|
|
|
#endif
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-TYPE-EXECUTEPTR-END>
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
|
2002-09-19 23:17:20 +04:00
|
|
|
// ========== iCache =============================================
|
2004-07-30 00:15:19 +04:00
|
|
|
#if BX_SUPPORT_ICACHE
|
2004-11-14 22:29:34 +03:00
|
|
|
#include "icache.h"
|
2002-09-19 23:17:20 +04:00
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
#if BX_USE_TLB
|
2003-02-28 05:37:18 +03:00
|
|
|
typedef bx_ptr_equiv_t bx_hostpageaddr_t;
|
|
|
|
|
2005-06-15 00:55:57 +04:00
|
|
|
typedef struct {
|
2006-04-05 21:31:35 +04:00
|
|
|
bx_address lpf; // linear page frame
|
|
|
|
bx_phy_address ppf; // physical page frame
|
|
|
|
Bit32u accessBits; // Page Table Address for updating A & D bits
|
2005-06-15 00:55:57 +04:00
|
|
|
bx_hostpageaddr_t hostPageAddr;
|
|
|
|
} bx_TLB_entry;
|
2007-10-19 02:44:39 +04:00
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2007-10-19 02:44:39 +04:00
|
|
|
// general purpose register
|
2002-09-13 04:15:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
|
|
|
|
#ifdef BX_BIG_ENDIAN
|
2005-06-15 00:55:57 +04:00
|
|
|
typedef struct {
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
Bit32u dword_filler;
|
2006-01-21 15:06:03 +03:00
|
|
|
Bit16u word_filler;
|
2005-06-15 00:55:57 +04:00
|
|
|
union {
|
|
|
|
Bit16u rx;
|
|
|
|
struct {
|
|
|
|
Bit8u rh;
|
|
|
|
Bit8u rl;
|
|
|
|
} byte;
|
|
|
|
};
|
|
|
|
} word;
|
|
|
|
Bit64u rrx;
|
|
|
|
struct {
|
|
|
|
Bit32u hrx; // hi 32 bits
|
2006-01-21 15:06:03 +03:00
|
|
|
Bit32u erx; // lo 32 bits
|
2005-06-15 00:55:57 +04:00
|
|
|
} dword;
|
|
|
|
};
|
|
|
|
} bx_gen_reg_t;
|
2002-09-13 04:15:23 +04:00
|
|
|
#else
|
2005-06-15 00:55:57 +04:00
|
|
|
typedef struct {
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
union {
|
|
|
|
Bit16u rx;
|
|
|
|
struct {
|
|
|
|
Bit8u rl;
|
|
|
|
Bit8u rh;
|
|
|
|
} byte;
|
|
|
|
};
|
2006-01-21 15:06:03 +03:00
|
|
|
Bit16u word_filler;
|
2005-06-15 00:55:57 +04:00
|
|
|
Bit32u dword_filler;
|
|
|
|
} word;
|
|
|
|
Bit64u rrx;
|
|
|
|
struct {
|
2006-01-21 15:06:03 +03:00
|
|
|
Bit32u erx; // lo 32 bits
|
2005-06-15 00:55:57 +04:00
|
|
|
Bit32u hrx; // hi 32 bits
|
|
|
|
} dword;
|
|
|
|
};
|
|
|
|
} bx_gen_reg_t;
|
2002-09-13 04:15:23 +04:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#else // #if BX_SUPPORT_X86_64
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
#ifdef BX_BIG_ENDIAN
|
|
|
|
typedef struct {
|
|
|
|
union {
|
2002-09-13 04:15:23 +04:00
|
|
|
struct {
|
|
|
|
Bit32u erx;
|
2005-06-15 00:55:57 +04:00
|
|
|
} dword;
|
2001-04-10 05:04:59 +04:00
|
|
|
struct {
|
|
|
|
Bit16u word_filler;
|
|
|
|
union {
|
|
|
|
Bit16u rx;
|
|
|
|
struct {
|
|
|
|
Bit8u rh;
|
|
|
|
Bit8u rl;
|
2005-06-15 00:55:57 +04:00
|
|
|
} byte;
|
|
|
|
};
|
|
|
|
} word;
|
|
|
|
};
|
|
|
|
} bx_gen_reg_t;
|
2001-04-10 05:04:59 +04:00
|
|
|
#else
|
|
|
|
typedef struct {
|
|
|
|
union {
|
2002-09-13 04:15:23 +04:00
|
|
|
struct {
|
|
|
|
Bit32u erx;
|
2005-06-15 00:55:57 +04:00
|
|
|
} dword;
|
2001-04-10 05:04:59 +04:00
|
|
|
struct {
|
|
|
|
union {
|
|
|
|
Bit16u rx;
|
|
|
|
struct {
|
|
|
|
Bit8u rl;
|
|
|
|
Bit8u rh;
|
2005-06-15 00:55:57 +04:00
|
|
|
} byte;
|
|
|
|
};
|
2001-04-10 05:04:59 +04:00
|
|
|
Bit16u word_filler;
|
2005-06-15 00:55:57 +04:00
|
|
|
} word;
|
|
|
|
};
|
|
|
|
} bx_gen_reg_t;
|
2001-04-10 05:04:59 +04:00
|
|
|
#endif
|
|
|
|
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif // #if BX_SUPPORT_X86_64
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2007-10-19 02:44:39 +04:00
|
|
|
// instruction pointer register
|
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
|
|
|
|
#ifdef BX_BIG_ENDIAN
|
|
|
|
typedef struct {
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
Bit32u rip_upper;
|
|
|
|
Bit16u word_filler;
|
|
|
|
Bit16u ip;
|
|
|
|
} word;
|
|
|
|
Bit64u rip;
|
|
|
|
struct {
|
|
|
|
Bit32u rip_upper; // hi 32 bits
|
|
|
|
Bit32u eip; // lo 32 bits
|
|
|
|
} dword;
|
|
|
|
};
|
|
|
|
} bx_eip_reg_t;
|
|
|
|
#else
|
|
|
|
typedef struct {
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
Bit16u ip;
|
|
|
|
Bit16u word_filler;
|
|
|
|
Bit32u rip_upper;
|
|
|
|
} word;
|
|
|
|
Bit64u rip;
|
|
|
|
struct {
|
|
|
|
Bit32u eip; // lo 32 bits
|
|
|
|
Bit32u rip_upper; // hi 32 bits
|
|
|
|
} dword;
|
|
|
|
};
|
|
|
|
} bx_eip_reg_t;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#else // #if BX_SUPPORT_X86_64
|
|
|
|
|
|
|
|
#ifdef BX_BIG_ENDIAN
|
|
|
|
typedef struct {
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
Bit32u eip;
|
|
|
|
} dword;
|
|
|
|
struct {
|
|
|
|
Bit16u word_filler;
|
|
|
|
Bit16u ip;
|
|
|
|
} word;
|
|
|
|
};
|
|
|
|
} bx_eip_reg_t;
|
|
|
|
#else
|
|
|
|
typedef struct {
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
Bit32u eip;
|
|
|
|
} dword;
|
|
|
|
struct {
|
|
|
|
Bit16u ip;
|
|
|
|
Bit16u word_filler;
|
|
|
|
} word;
|
|
|
|
};
|
|
|
|
} bx_eip_reg_t;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif // #if BX_SUPPORT_X86_64
|
|
|
|
|
2006-03-07 01:03:16 +03:00
|
|
|
#if BX_SUPPORT_APIC
|
|
|
|
#define BX_INCLUDE_LOCAL_APIC 1
|
|
|
|
#include "apic.h"
|
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2001-05-23 12:16:07 +04:00
|
|
|
class BX_MEM_C;
|
|
|
|
|
2004-09-15 00:19:54 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
# define BX_GENERAL_REGISTERS 16
|
|
|
|
#else
|
|
|
|
# define BX_GENERAL_REGISTERS 8
|
2003-04-23 00:21:34 +04:00
|
|
|
#endif
|
2002-09-09 20:11:25 +04:00
|
|
|
|
2004-09-15 00:19:54 +04:00
|
|
|
#if BX_SUPPORT_FPU
|
|
|
|
#include "cpu/i387.h"
|
2002-10-16 21:37:35 +04:00
|
|
|
#include "cpu/xmm.h"
|
2004-09-15 00:19:54 +04:00
|
|
|
#endif
|
2002-10-16 21:37:35 +04:00
|
|
|
|
2007-11-01 21:03:48 +03:00
|
|
|
#if BX_SUPPORT_MONITOR_MWAIT
|
|
|
|
struct monitor_addr_t {
|
|
|
|
bx_phy_address monitor_begin;
|
|
|
|
bx_phy_address monitor_end;
|
|
|
|
|
|
|
|
// avoid false trigger when MONITOR was not set up properly
|
|
|
|
monitor_addr_t():
|
|
|
|
monitor_begin(0xffffffff), monitor_end(0xffffffff) {}
|
|
|
|
monitor_addr_t(bx_phy_address addr, unsigned len):
|
|
|
|
monitor_begin(addr), monitor_end(addr+len) {}
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2002-10-25 01:07:56 +04:00
|
|
|
class BOCHSAPI BX_CPU_C : public logfunctions {
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
public: // for now...
|
|
|
|
|
2001-05-23 12:16:07 +04:00
|
|
|
char name[64];
|
|
|
|
|
2003-02-13 18:51:22 +03:00
|
|
|
unsigned bx_cpuid;
|
|
|
|
|
2007-10-12 23:30:51 +04:00
|
|
|
// cpuid
|
|
|
|
cpuid_function_t cpuid_std_function[MAX_STD_CPUID_FUNCTION];
|
|
|
|
cpuid_function_t cpuid_ext_function[MAX_EXT_CPUID_FUNCTION];
|
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
// General register set
|
|
|
|
// eax: accumulator
|
|
|
|
// ebx: base
|
|
|
|
// ecx: count
|
|
|
|
// edx: data
|
|
|
|
// ebp: base pointer
|
|
|
|
// esi: source index
|
|
|
|
// edi: destination index
|
|
|
|
// esp: stack pointer
|
2006-01-21 15:06:03 +03:00
|
|
|
bx_gen_reg_t gen_reg[BX_GENERAL_REGISTERS];
|
2002-09-13 04:15:23 +04:00
|
|
|
|
2004-09-15 00:19:54 +04:00
|
|
|
// instruction pointer
|
2007-10-19 02:44:39 +04:00
|
|
|
bx_eip_reg_t eip_reg;
|
2002-09-13 04:15:23 +04:00
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
// status and control flags register set
|
2003-08-28 23:25:23 +04:00
|
|
|
Bit32u lf_flags_status;
|
2001-04-10 05:04:59 +04:00
|
|
|
bx_flags_reg_t eflags;
|
|
|
|
|
|
|
|
bx_lf_flags_entry oszapc;
|
|
|
|
bx_lf_flags_entry oszap;
|
|
|
|
|
2005-06-15 00:55:57 +04:00
|
|
|
// so that we can back up when handling faults, exceptions, etc.
|
|
|
|
// we need to store the value of the instruction pointer, before
|
|
|
|
// each fetch/execute cycle.
|
|
|
|
bx_address prev_eip;
|
|
|
|
bx_address prev_esp;
|
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
#define BX_INHIBIT_INTERRUPTS 0x01
|
|
|
|
#define BX_INHIBIT_DEBUG 0x02
|
|
|
|
// What events to inhibit at any given time. Certain instructions
|
|
|
|
// inhibit interrupts, some debug exceptions and single-step traps.
|
|
|
|
unsigned inhibit_mask;
|
|
|
|
|
|
|
|
/* user segment register set */
|
|
|
|
bx_segment_reg_t sregs[6];
|
|
|
|
|
|
|
|
/* system segment registers */
|
|
|
|
#if BX_CPU_LEVEL >= 2
|
|
|
|
bx_global_segment_reg_t gdtr; /* global descriptor table register */
|
|
|
|
bx_global_segment_reg_t idtr; /* interrupt descriptor table register */
|
|
|
|
#endif
|
2003-06-08 13:55:50 +04:00
|
|
|
bx_segment_reg_t ldtr; /* local descriptor table register */
|
2001-04-10 05:04:59 +04:00
|
|
|
bx_segment_reg_t tr; /* task register */
|
|
|
|
|
2006-05-13 16:49:45 +04:00
|
|
|
/* debug registers DR0-DR7 */
|
2001-04-10 05:04:59 +04:00
|
|
|
#if BX_CPU_LEVEL >= 3
|
2006-05-13 16:49:45 +04:00
|
|
|
bx_address dr0;
|
|
|
|
bx_address dr1;
|
|
|
|
bx_address dr2;
|
|
|
|
bx_address dr3;
|
|
|
|
Bit32u dr6;
|
|
|
|
Bit32u dr7;
|
2001-04-10 05:04:59 +04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* TR3 - TR7 (Test Register 3-7), unimplemented */
|
|
|
|
|
|
|
|
/* Control registers */
|
|
|
|
#if BX_CPU_LEVEL >= 2
|
2006-04-05 21:31:35 +04:00
|
|
|
bx_cr0_t cr0;
|
|
|
|
Bit32u cr1;
|
|
|
|
bx_address cr2;
|
2006-05-13 16:49:45 +04:00
|
|
|
bx_phy_address cr3, cr3_masked;
|
2001-04-10 05:04:59 +04:00
|
|
|
#if BX_CPU_LEVEL >= 4
|
2006-05-13 16:49:45 +04:00
|
|
|
bx_cr4_t cr4;
|
|
|
|
#endif
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2007-09-11 00:47:08 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
bx_efer_t efer;
|
|
|
|
#endif
|
|
|
|
|
2006-03-07 01:32:03 +03:00
|
|
|
/* SMM base register */
|
|
|
|
Bit32u smbase;
|
|
|
|
|
2002-03-27 19:04:05 +03:00
|
|
|
#if BX_CPU_LEVEL >= 5
|
2002-10-04 21:04:33 +04:00
|
|
|
bx_regs_msr_t msr;
|
2002-03-27 19:04:05 +03:00
|
|
|
#endif
|
|
|
|
|
2003-08-01 13:32:33 +04:00
|
|
|
#if BX_SUPPORT_FPU || BX_SUPPORT_MMX
|
2002-09-09 20:11:25 +04:00
|
|
|
i387_t the_i387;
|
2003-04-23 00:21:34 +04:00
|
|
|
#endif
|
2002-09-09 20:11:25 +04:00
|
|
|
|
2002-12-22 23:13:00 +03:00
|
|
|
#if BX_SUPPORT_SSE
|
2002-10-16 21:37:35 +04:00
|
|
|
bx_xmm_reg_t xmm[BX_XMM_REGISTERS];
|
|
|
|
bx_mxcsr_t mxcsr;
|
|
|
|
#endif
|
|
|
|
|
2007-11-01 21:03:48 +03:00
|
|
|
#if BX_SUPPORT_MONITOR_MWAIT
|
|
|
|
monitor_addr_t monitor;
|
|
|
|
#endif
|
|
|
|
|
2001-05-23 12:16:07 +04:00
|
|
|
// pointer to the address space that this processor uses.
|
|
|
|
BX_MEM_C *mem;
|
|
|
|
|
2006-01-21 15:06:03 +03:00
|
|
|
#if BX_SUPPORT_APIC
|
|
|
|
bx_local_apic_c local_apic;
|
|
|
|
#endif
|
|
|
|
|
2002-10-25 15:44:41 +04:00
|
|
|
bx_bool EXT; /* 1 if processing external interrupt or exception
|
2001-04-10 05:04:59 +04:00
|
|
|
* or if not related to current instruction,
|
|
|
|
* 0 if current CS:IP caused exception */
|
|
|
|
unsigned errorno; /* signal exception during instruction emulation */
|
|
|
|
|
2007-11-01 21:03:48 +03:00
|
|
|
#define BX_DEBUG_TRAP_HALT (0x80000000)
|
|
|
|
#define BX_DEBUG_TRAP_SHUTDOWN (0x40000000)
|
|
|
|
#define BX_DEBUG_TRAP_WAIT_FOR_SIPI (0x20000000)
|
|
|
|
#define BX_DEBUG_TRAP_MWAIT (0x10000000)
|
|
|
|
#define BX_DEBUG_TRAP_MWAIT_IF (0x18000000)
|
|
|
|
// combine all possible states
|
|
|
|
#define BX_DEBUG_TRAP_SPECIAL (0xf8000000)
|
|
|
|
|
|
|
|
Bit32u debug_trap; // holds DR6 value (16bit) to be set as well
|
2002-10-25 15:44:41 +04:00
|
|
|
volatile bx_bool async_event;
|
|
|
|
volatile bx_bool INTR;
|
2006-02-14 22:00:08 +03:00
|
|
|
volatile bx_bool smi_pending;
|
|
|
|
volatile bx_bool nmi_pending;
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-CLASS-CPU-START>
|
2001-04-10 05:04:59 +04:00
|
|
|
// for decoding instructions; accessing seg reg's by index
|
|
|
|
unsigned sreg_mod00_rm16[8];
|
2004-12-11 23:51:13 +03:00
|
|
|
unsigned sreg_mod01or10_rm16[8];
|
2002-09-13 04:15:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2004-12-11 23:51:13 +03:00
|
|
|
unsigned sreg_mod01or10_rm32[16];
|
2002-09-13 04:15:23 +04:00
|
|
|
unsigned sreg_mod0_base32[16];
|
|
|
|
unsigned sreg_mod1or2_base32[16];
|
|
|
|
#else
|
2004-12-11 23:51:13 +03:00
|
|
|
unsigned sreg_mod01or10_rm32[8];
|
2001-04-10 05:04:59 +04:00
|
|
|
unsigned sreg_mod0_base32[8];
|
|
|
|
unsigned sreg_mod1or2_base32[8];
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-CLASS-CPU-END>
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
// for exceptions
|
|
|
|
jmp_buf jmp_buf_env;
|
|
|
|
Bit8u curr_exception[2];
|
|
|
|
|
|
|
|
bx_segment_reg_t save_cs;
|
|
|
|
bx_segment_reg_t save_ss;
|
2005-10-17 17:06:09 +04:00
|
|
|
bx_address save_eip;
|
|
|
|
bx_address save_esp;
|
2002-09-02 22:44:35 +04:00
|
|
|
|
|
|
|
// Boundaries of current page, based on EIP
|
2002-09-13 04:15:23 +04:00
|
|
|
bx_address eipPageBias;
|
|
|
|
bx_address eipPageWindowSize;
|
2002-09-19 23:17:20 +04:00
|
|
|
Bit8u *eipFetchPtr;
|
2006-02-23 21:23:31 +03:00
|
|
|
bx_phy_address pAddrA20Page; // Guest physical address of current instruction
|
|
|
|
// page with A20() already applied.
|
2005-08-13 18:10:22 +04:00
|
|
|
#if BX_SUPPORT_ICACHE
|
2005-08-10 22:18:57 +04:00
|
|
|
const Bit32u *currPageWriteStampPtr;
|
2005-08-13 18:10:22 +04:00
|
|
|
#endif
|
2007-11-01 21:03:48 +03:00
|
|
|
unsigned cpu_mode;
|
2006-02-14 23:03:14 +03:00
|
|
|
bx_bool in_smm;
|
2006-03-16 23:24:09 +03:00
|
|
|
bx_bool nmi_disable;
|
2007-08-01 00:25:52 +04:00
|
|
|
#if BX_CPU_LEVEL >= 4 && BX_SUPPORT_ALIGNMENT_CHECK
|
|
|
|
bx_bool alignment_check;
|
|
|
|
#endif
|
2002-09-13 04:15:23 +04:00
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
#if BX_DEBUGGER
|
2007-10-09 23:49:23 +04:00
|
|
|
bx_phy_address watchpoint;
|
2001-04-10 05:04:59 +04:00
|
|
|
Bit8u break_point;
|
2004-01-29 20:49:03 +03:00
|
|
|
#if BX_MAGIC_BREAKPOINT
|
2001-04-10 05:04:59 +04:00
|
|
|
Bit8u magic_break;
|
|
|
|
#endif
|
|
|
|
Bit8u stop_reason;
|
2001-10-03 23:53:48 +04:00
|
|
|
Bit8u trace_reg;
|
2006-01-24 22:03:55 +03:00
|
|
|
Bit8u mode_break;
|
2006-02-12 23:21:36 +03:00
|
|
|
bx_bool dbg_cpu_mode; /* contains current mode */
|
|
|
|
unsigned show_flag;
|
2001-05-23 12:16:07 +04:00
|
|
|
bx_guard_found_t guard_found;
|
2001-04-10 05:04:59 +04:00
|
|
|
#endif
|
2005-12-12 22:44:06 +03:00
|
|
|
Bit8u trace;
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
// for paging
|
|
|
|
#if BX_USE_TLB
|
2007-10-31 01:15:42 +03:00
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
struct {
|
2002-09-19 23:17:20 +04:00
|
|
|
bx_TLB_entry entry[BX_TLB_SIZE] BX_CPP_AlignN(16);
|
2005-03-15 22:00:04 +03:00
|
|
|
} TLB;
|
2007-10-31 01:15:42 +03:00
|
|
|
|
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
#define LPFOf(laddr) ((laddr) & BX_CONST64(0xfffffffffffff000))
|
|
|
|
#else
|
|
|
|
#define LPFOf(laddr) ((laddr) & 0xfffff000)
|
|
|
|
#endif
|
|
|
|
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif // #if BX_USE_TLB
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2002-09-19 23:17:20 +04:00
|
|
|
// An instruction cache. Each entry should be exactly 32 bytes, and
|
|
|
|
// this structure should be aligned on a 32-byte boundary to be friendly
|
|
|
|
// with the host cache lines.
|
2004-07-30 00:15:19 +04:00
|
|
|
#if BX_SUPPORT_ICACHE
|
2006-02-28 20:47:33 +03:00
|
|
|
bxICache_c iCache BX_CPP_AlignN(32);
|
|
|
|
Bit32u fetchModeMask;
|
2006-04-05 21:31:35 +04:00
|
|
|
void updateFetchModeMask(void);
|
2002-09-19 23:17:20 +04:00
|
|
|
#endif
|
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
struct {
|
2007-11-08 21:21:37 +03:00
|
|
|
bx_address rm_addr; // The address offset after resolution.
|
|
|
|
bx_phy_address paddress1; // physical address after translation of 1st len1 bytes of data
|
|
|
|
bx_phy_address paddress2; // physical address after translation of 2nd len2 bytes of data
|
|
|
|
Bit32u len1; // Number of bytes in page 1
|
|
|
|
Bit32u len2; // Number of bytes in page 2
|
2003-02-28 05:37:18 +03:00
|
|
|
bx_ptr_equiv_t pages; // Number of pages access spans (1 or 2). Also used
|
2002-09-07 01:54:58 +04:00
|
|
|
// for the case when a native host pointer is
|
|
|
|
// available for the R-M-W instructions. The host
|
|
|
|
// pointer is stuffed here. Since this field has
|
|
|
|
// to be checked anyways (and thus cached), if it
|
|
|
|
// is greated than 2 (the maximum possible for
|
|
|
|
// normal cases) it is a native pointer and is used
|
|
|
|
// for a direct write access.
|
2005-08-08 23:56:11 +04:00
|
|
|
} address_xlation;
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2002-11-04 08:27:26 +03:00
|
|
|
#if BX_EXTERNAL_DEBUGGER
|
2006-06-26 01:44:46 +04:00
|
|
|
virtual void ask(int level, const char *prefix, const char *fmt, va_list ap);
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif
|
|
|
|
|
2006-04-05 21:31:35 +04:00
|
|
|
BX_SMF void setEFlags(Bit32u val) BX_CPP_AttrRegparmN(1);
|
2005-09-29 21:32:32 +04:00
|
|
|
|
|
|
|
#define lfMaskCF 0x0000000f
|
|
|
|
#define lfMaskPF 0x000000f0
|
|
|
|
#define lfMaskAF 0x00000f00
|
|
|
|
#define lfMaskZF 0x0000f000
|
|
|
|
#define lfMaskSF 0x000f0000
|
|
|
|
#define lfMaskOF 0x00f00000
|
|
|
|
|
|
|
|
#define ArithmeticalFlag(flag, lfMask, eflagsBitShift) \
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF bx_bool get_##flag##Lazy(void); \
|
|
|
|
BX_SMF bx_bool getB_##flag(void) { \
|
2005-09-29 21:32:32 +04:00
|
|
|
if ( (BX_CPU_THIS_PTR lf_flags_status & (lfMask)) == 0) \
|
2002-09-22 05:52:21 +04:00
|
|
|
return (BX_CPU_THIS_PTR eflags.val32 >> eflagsBitShift) & 1; \
|
|
|
|
else \
|
|
|
|
return get_##flag##Lazy(); \
|
2002-09-22 22:22:24 +04:00
|
|
|
} \
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF bx_bool get_##flag(void) { \
|
2005-09-29 21:32:32 +04:00
|
|
|
if ( (BX_CPU_THIS_PTR lf_flags_status & (lfMask)) == 0) \
|
2002-09-22 22:22:24 +04:00
|
|
|
return BX_CPU_THIS_PTR eflags.val32 & (1<<eflagsBitShift); \
|
|
|
|
else \
|
|
|
|
return get_##flag##Lazy(); \
|
2005-09-29 21:32:32 +04:00
|
|
|
} \
|
|
|
|
BX_SMF void set_##flag(bx_bool val) { \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status &= ~(lfMask); \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 &= ~(1<<eflagsBitShift); \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 |= ((!!val)<<eflagsBitShift); \
|
|
|
|
} \
|
2007-10-22 02:07:33 +04:00
|
|
|
BX_SMF void setB_##flag(bx_bool val) { \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status &= ~(lfMask); \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 &= ~(1<<eflagsBitShift); \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 |= ((val)<<eflagsBitShift); \
|
|
|
|
} \
|
2005-09-29 21:32:32 +04:00
|
|
|
BX_SMF void clear_##flag(void) { \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status &= ~(lfMask); \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 &= ~(1<<eflagsBitShift); \
|
|
|
|
} \
|
|
|
|
BX_SMF void assert_##flag(void) { \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status &= ~(lfMask); \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 |= (1<<eflagsBitShift); \
|
|
|
|
}
|
2002-09-22 05:52:21 +04:00
|
|
|
|
2005-09-29 21:32:32 +04:00
|
|
|
ArithmeticalFlag(OF, lfMaskOF, 11);
|
|
|
|
ArithmeticalFlag(SF, lfMaskSF, 7);
|
|
|
|
ArithmeticalFlag(ZF, lfMaskZF, 6);
|
|
|
|
ArithmeticalFlag(AF, lfMaskAF, 4);
|
|
|
|
ArithmeticalFlag(PF, lfMaskPF, 2);
|
|
|
|
ArithmeticalFlag(CF, lfMaskCF, 0);
|
|
|
|
|
|
|
|
BX_SMF BX_CPP_INLINE void set_PF_base(Bit8u val);
|
2002-09-22 05:52:21 +04:00
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
// constructors & destructors...
|
2005-11-27 00:36:51 +03:00
|
|
|
BX_CPU_C(unsigned id = 0);
|
2004-10-30 01:15:48 +04:00
|
|
|
#if BX_EXTERNAL_DEBUGGER
|
|
|
|
virtual ~BX_CPU_C();
|
|
|
|
#else
|
|
|
|
~BX_CPU_C();
|
|
|
|
#endif
|
2005-11-27 00:36:51 +03:00
|
|
|
void initialize(BX_MEM_C *addrspace);
|
2006-05-28 21:07:57 +04:00
|
|
|
void after_restore_state(void);
|
2007-10-14 23:04:51 +04:00
|
|
|
void register_state(void);
|
|
|
|
#if BX_WITH_WX
|
|
|
|
void register_wx_state(void);
|
|
|
|
#endif
|
2006-05-27 19:54:49 +04:00
|
|
|
static Bit64s param_save_handler(void *devptr, bx_param_c *param, Bit64s val);
|
|
|
|
static Bit64s param_restore_handler(void *devptr, bx_param_c *param, Bit64s val);
|
|
|
|
#if !BX_USE_CPU_SMF
|
|
|
|
Bit64s param_save(bx_param_c *param, Bit64s val);
|
|
|
|
Bit64s param_restore(bx_param_c *param, Bit64s val);
|
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-CLASS-CPU-START>
|
2001-04-10 05:04:59 +04:00
|
|
|
// prototypes for CPU instructions...
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void ADD_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void ADD_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void ADD_GbEb(bxInstruction_c *);
|
2002-09-29 23:21:38 +04:00
|
|
|
|
2007-11-16 11:30:22 +03:00
|
|
|
BX_SMF void ADD_GdEdM(bxInstruction_c *);
|
|
|
|
BX_SMF void ADD_GdEdR(bxInstruction_c *);
|
2002-09-29 23:21:38 +04:00
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void ADD_ALIb(bxInstruction_c *);
|
|
|
|
BX_SMF void ADD_EAXId(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_GbEb(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_GdEd(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_GwEw(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_ALIb(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_EAXId(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_AXIw(bxInstruction_c *);
|
|
|
|
|
2005-07-31 21:57:27 +04:00
|
|
|
BX_SMF void PUSH16_CS(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH16_DS(bxInstruction_c *);
|
|
|
|
BX_SMF void POP16_DS(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH16_ES(bxInstruction_c *);
|
|
|
|
BX_SMF void POP16_ES(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH16_FS(bxInstruction_c *);
|
|
|
|
BX_SMF void POP16_FS(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH16_GS(bxInstruction_c *);
|
|
|
|
BX_SMF void POP16_GS(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH16_SS(bxInstruction_c *);
|
|
|
|
BX_SMF void POP16_SS(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void PUSH32_CS(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH32_DS(bxInstruction_c *);
|
|
|
|
BX_SMF void POP32_DS(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH32_ES(bxInstruction_c *);
|
|
|
|
BX_SMF void POP32_ES(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH32_FS(bxInstruction_c *);
|
|
|
|
BX_SMF void POP32_FS(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH32_GS(bxInstruction_c *);
|
|
|
|
BX_SMF void POP32_GS(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH32_SS(bxInstruction_c *);
|
|
|
|
BX_SMF void POP32_SS(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
|
|
|
BX_SMF void ADC_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_GbEb(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_GdEd(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_ALIb(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_EAXId(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_GbEb(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_GdEd(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_ALIb(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_EAXId(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void AND_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_GbEb(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_GdEd(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_GwEw(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_ALIb(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_EAXId(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_AXIw(bxInstruction_c *);
|
|
|
|
BX_SMF void DAA(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_GbEb(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_GdEd(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_ALIb(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_EAXId(bxInstruction_c *);
|
|
|
|
BX_SMF void DAS(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void XOR_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_GbEb(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_GdEd(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_GwEw(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_ALIb(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_EAXId(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_AXIw(bxInstruction_c *);
|
|
|
|
BX_SMF void AAA(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_GbEb(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_GdEd(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_ALIb(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_EAXId(bxInstruction_c *);
|
|
|
|
BX_SMF void AAS(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void PUSHAD32(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSHAD16(bxInstruction_c *);
|
|
|
|
BX_SMF void POPAD32(bxInstruction_c *);
|
|
|
|
BX_SMF void POPAD16(bxInstruction_c *);
|
|
|
|
BX_SMF void ARPL_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH_Id(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH_Iw(bxInstruction_c *);
|
2007-01-05 16:40:47 +03:00
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void INSB_YbDX(bxInstruction_c *);
|
2006-05-07 22:27:36 +04:00
|
|
|
BX_SMF void INSW_YwDX(bxInstruction_c *);
|
2006-06-10 02:29:07 +04:00
|
|
|
BX_SMF void INSD_YdDX(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void OUTSB_DXXb(bxInstruction_c *);
|
2006-05-07 22:27:36 +04:00
|
|
|
BX_SMF void OUTSW_DXXw(bxInstruction_c *);
|
2006-06-10 02:29:07 +04:00
|
|
|
BX_SMF void OUTSD_DXXd(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
2007-01-05 16:40:47 +03:00
|
|
|
BX_SMF void REP_INSB_YbDX(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_INSW_YwDX(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_INSD_YdDX(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_OUTSB_DXXb(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_OUTSW_DXXw(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_OUTSD_DXXd(bxInstruction_c *);
|
|
|
|
|
2005-01-28 23:50:48 +03:00
|
|
|
BX_SMF void BOUND_GwMa(bxInstruction_c *);
|
|
|
|
BX_SMF void BOUND_GdMa(bxInstruction_c *);
|
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void TEST_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void TEST_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void TEST_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void XCHG_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void XCHG_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void XCHG_EwGw(bxInstruction_c *);
|
2002-09-28 09:38:11 +04:00
|
|
|
|
2007-11-16 11:30:22 +03:00
|
|
|
BX_SMF void MOV_EbGbM(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_EbGbR(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_EdGdM(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_EdGdR(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_EwGwM(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_EwGwR(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_GbEbM(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_GbEbR(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_GdEdM(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_GdEdR(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_GwEwM(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_GwEwR(bxInstruction_c *);
|
2002-09-28 09:38:11 +04:00
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void MOV_EwSw(bxInstruction_c *);
|
|
|
|
BX_SMF void LEA_GdM(bxInstruction_c *);
|
|
|
|
BX_SMF void LEA_GwM(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_SwEw(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void CBW(bxInstruction_c *);
|
|
|
|
BX_SMF void CWD(bxInstruction_c *);
|
|
|
|
BX_SMF void CALL32_Ap(bxInstruction_c *);
|
|
|
|
BX_SMF void CALL16_Ap(bxInstruction_c *);
|
2005-08-08 23:56:11 +04:00
|
|
|
BX_SMF void PUSHF_Fw(bxInstruction_c *);
|
|
|
|
BX_SMF void POPF_Fw(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSHF_Fd(bxInstruction_c *);
|
|
|
|
BX_SMF void POPF_Fd(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void SAHF(bxInstruction_c *);
|
|
|
|
BX_SMF void LAHF(bxInstruction_c *);
|
|
|
|
|
2007-01-13 01:47:21 +03:00
|
|
|
BX_SMF void MOV_ALOd(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void MOV_EAXOd(bxInstruction_c *);
|
2007-01-13 01:47:21 +03:00
|
|
|
BX_SMF void MOV_AXOd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_OdAL(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void MOV_OdEAX(bxInstruction_c *);
|
2007-01-13 01:47:21 +03:00
|
|
|
BX_SMF void MOV_OdAX(bxInstruction_c *);
|
2004-11-19 02:16:36 +03:00
|
|
|
BX_SMF void TEST_ALIb(bxInstruction_c *);
|
|
|
|
BX_SMF void TEST_EAXId(bxInstruction_c *);
|
|
|
|
BX_SMF void TEST_AXIw(bxInstruction_c *);
|
|
|
|
|
|
|
|
// repeatable instructions
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void MOVSB_XbYb(bxInstruction_c *);
|
2004-11-21 02:26:32 +03:00
|
|
|
BX_SMF void MOVSW_XwYw(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVSD_XdYd(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void CMPSB_XbYb(bxInstruction_c *);
|
2004-11-21 02:26:32 +03:00
|
|
|
BX_SMF void CMPSW_XwYw(bxInstruction_c *);
|
|
|
|
BX_SMF void CMPSD_XdYd(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void STOSB_YbAL(bxInstruction_c *);
|
|
|
|
BX_SMF void LODSB_ALXb(bxInstruction_c *);
|
|
|
|
BX_SMF void SCASB_ALXb(bxInstruction_c *);
|
2004-11-21 02:26:32 +03:00
|
|
|
BX_SMF void STOSW_YwAX(bxInstruction_c *);
|
|
|
|
BX_SMF void LODSW_AXXw(bxInstruction_c *);
|
|
|
|
BX_SMF void SCASW_AXXw(bxInstruction_c *);
|
|
|
|
BX_SMF void STOSD_YdEAX(bxInstruction_c *);
|
|
|
|
BX_SMF void LODSD_EAXXd(bxInstruction_c *);
|
|
|
|
BX_SMF void SCASD_EAXXd(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
2007-01-05 16:40:47 +03:00
|
|
|
BX_SMF void REP_MOVSB_XbYb(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_MOVSW_XwYw(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_MOVSD_XdYd(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_CMPSB_XbYb(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_CMPSW_XwYw(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_CMPSD_XdYd(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_STOSB_YbAL(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_LODSB_ALXb(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_SCASB_ALXb(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_STOSW_YwAX(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_LODSW_AXXw(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_SCASW_AXXw(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_STOSD_YdEAX(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_LODSD_EAXXd(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_SCASD_EAXXd(bxInstruction_c *);
|
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void RETnear32(bxInstruction_c *);
|
|
|
|
BX_SMF void RETnear16(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_EbIb(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_EdId(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_EwIw(bxInstruction_c *);
|
|
|
|
BX_SMF void ENTER_IwIb(bxInstruction_c *);
|
|
|
|
BX_SMF void LEAVE(bxInstruction_c *);
|
|
|
|
BX_SMF void RETfar32(bxInstruction_c *);
|
|
|
|
BX_SMF void RETfar16(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void INT1(bxInstruction_c *);
|
|
|
|
BX_SMF void INT3(bxInstruction_c *);
|
|
|
|
BX_SMF void INT_Ib(bxInstruction_c *);
|
|
|
|
BX_SMF void INTO(bxInstruction_c *);
|
|
|
|
BX_SMF void IRET32(bxInstruction_c *);
|
|
|
|
BX_SMF void IRET16(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void AAM(bxInstruction_c *);
|
|
|
|
BX_SMF void AAD(bxInstruction_c *);
|
|
|
|
BX_SMF void SALC(bxInstruction_c *);
|
|
|
|
BX_SMF void XLAT(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void LOOPNE_Jb(bxInstruction_c *);
|
|
|
|
BX_SMF void LOOPE_Jb(bxInstruction_c *);
|
|
|
|
BX_SMF void LOOP_Jb(bxInstruction_c *);
|
|
|
|
BX_SMF void JCXZ_Jb(bxInstruction_c *);
|
|
|
|
BX_SMF void IN_ALIb(bxInstruction_c *);
|
2006-05-07 22:27:36 +04:00
|
|
|
BX_SMF void IN_AXIb(bxInstruction_c *);
|
|
|
|
BX_SMF void IN_EAXIb(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void OUT_IbAL(bxInstruction_c *);
|
2006-05-07 22:27:36 +04:00
|
|
|
BX_SMF void OUT_IbAX(bxInstruction_c *);
|
|
|
|
BX_SMF void OUT_IbEAX(bxInstruction_c *);
|
2007-10-22 21:41:41 +04:00
|
|
|
BX_SMF void CALL_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void CALL_Jd(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void JMP_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JMP_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JMP_Ap(bxInstruction_c *);
|
|
|
|
BX_SMF void IN_ALDX(bxInstruction_c *);
|
2006-05-07 22:27:36 +04:00
|
|
|
BX_SMF void IN_AXDX(bxInstruction_c *);
|
|
|
|
BX_SMF void IN_EAXDX(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void OUT_DXAL(bxInstruction_c *);
|
2006-05-07 22:27:36 +04:00
|
|
|
BX_SMF void OUT_DXAX(bxInstruction_c *);
|
|
|
|
BX_SMF void OUT_DXEAX(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
|
|
|
BX_SMF void HLT(bxInstruction_c *);
|
|
|
|
BX_SMF void CMC(bxInstruction_c *);
|
|
|
|
BX_SMF void CLC(bxInstruction_c *);
|
|
|
|
BX_SMF void STC(bxInstruction_c *);
|
|
|
|
BX_SMF void CLI(bxInstruction_c *);
|
|
|
|
BX_SMF void STI(bxInstruction_c *);
|
|
|
|
BX_SMF void CLD(bxInstruction_c *);
|
|
|
|
BX_SMF void STD(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void LAR_GvEw(bxInstruction_c *);
|
|
|
|
BX_SMF void LSL_GvEw(bxInstruction_c *);
|
|
|
|
BX_SMF void CLTS(bxInstruction_c *);
|
|
|
|
BX_SMF void INVD(bxInstruction_c *);
|
|
|
|
BX_SMF void WBINVD(bxInstruction_c *);
|
2007-01-29 00:27:31 +03:00
|
|
|
BX_SMF void CLFLUSH(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
|
|
|
BX_SMF void MOV_CdRd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_DdRd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_RdCd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_RdDd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_TdRd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_RdTd(bxInstruction_c *);
|
|
|
|
|
2007-11-12 21:20:15 +03:00
|
|
|
BX_SMF void JO_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JNO_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JB_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JNB_Jw(bxInstruction_c *);
|
2002-09-22 05:52:21 +04:00
|
|
|
BX_SMF void JZ_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JNZ_Jw(bxInstruction_c *);
|
2007-11-12 21:20:15 +03:00
|
|
|
BX_SMF void JBE_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JNBE_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JS_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JNS_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JP_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JNP_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JL_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JNL_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JLE_Jw(bxInstruction_c *);
|
|
|
|
BX_SMF void JNLE_Jw(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void JO_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JNO_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JB_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JNB_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JZ_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JNZ_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JBE_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JNBE_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JS_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JNS_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JP_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JNP_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JL_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JNL_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JLE_Jd(bxInstruction_c *);
|
|
|
|
BX_SMF void JNLE_Jd(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
|
|
|
BX_SMF void SETO_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETNO_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETB_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETNB_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETZ_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETNZ_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETBE_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETNBE_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETS_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETNS_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETP_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETNP_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETL_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETNL_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETLE_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SETNLE_Eb(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void CPUID(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void SHRD_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void SHRD_EdGd(bxInstruction_c *);
|
2004-09-18 00:47:19 +04:00
|
|
|
BX_SMF void SHLD_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void SHLD_EwGw(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
2004-09-18 00:47:19 +04:00
|
|
|
BX_SMF void BSF_GwEw(bxInstruction_c *);
|
|
|
|
BX_SMF void BSF_GdEd(bxInstruction_c *);
|
|
|
|
BX_SMF void BSR_GwEw(bxInstruction_c *);
|
|
|
|
BX_SMF void BSR_GdEd(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void BT_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void BT_EdGd(bxInstruction_c *);
|
2005-07-25 08:18:20 +04:00
|
|
|
BX_SMF void BT_EwIb(bxInstruction_c *);
|
|
|
|
BX_SMF void BT_EdIb(bxInstruction_c *);
|
|
|
|
|
2004-09-18 00:47:19 +04:00
|
|
|
BX_SMF void BTS_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void BTS_EdGd(bxInstruction_c *);
|
2005-07-25 08:18:20 +04:00
|
|
|
BX_SMF void BTS_EwIb(bxInstruction_c *);
|
|
|
|
BX_SMF void BTS_EdIb(bxInstruction_c *);
|
2004-09-18 00:47:19 +04:00
|
|
|
BX_SMF void BTR_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void BTR_EdGd(bxInstruction_c *);
|
2005-07-25 08:18:20 +04:00
|
|
|
BX_SMF void BTR_EwIb(bxInstruction_c *);
|
|
|
|
BX_SMF void BTR_EdIb(bxInstruction_c *);
|
2004-09-18 00:47:19 +04:00
|
|
|
BX_SMF void BTC_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void BTC_EdGd(bxInstruction_c *);
|
2005-07-25 08:18:20 +04:00
|
|
|
BX_SMF void BTC_EwIb(bxInstruction_c *);
|
|
|
|
BX_SMF void BTC_EdIb(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
2007-04-10 00:28:15 +04:00
|
|
|
BX_SMF void LES_GwMp(bxInstruction_c *);
|
|
|
|
BX_SMF void LDS_GwMp(bxInstruction_c *);
|
|
|
|
BX_SMF void LSS_GwMp(bxInstruction_c *);
|
|
|
|
BX_SMF void LFS_GwMp(bxInstruction_c *);
|
|
|
|
BX_SMF void LGS_GwMp(bxInstruction_c *);
|
|
|
|
BX_SMF void LES_GdMp(bxInstruction_c *);
|
|
|
|
BX_SMF void LDS_GdMp(bxInstruction_c *);
|
|
|
|
BX_SMF void LSS_GdMp(bxInstruction_c *);
|
|
|
|
BX_SMF void LFS_GdMp(bxInstruction_c *);
|
|
|
|
BX_SMF void LGS_GdMp(bxInstruction_c *);
|
2005-01-28 23:50:48 +03:00
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void MOVZX_GdEb(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVZX_GwEb(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVZX_GdEw(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVSX_GdEb(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVSX_GwEb(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVSX_GdEw(bxInstruction_c *);
|
|
|
|
|
2006-05-07 22:58:47 +04:00
|
|
|
BX_SMF void BSWAP_ERX(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
|
|
|
BX_SMF void ADD_EbIb(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_EbIb(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_EbIb(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_EbIb(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_EbIb(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_EbIb(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_EbIb(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_EbIb(bxInstruction_c *);
|
2007-11-16 11:30:22 +03:00
|
|
|
BX_SMF void ADD_EdIdR(bxInstruction_c *);
|
|
|
|
BX_SMF void ADD_EdIdM(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void OR_EdId(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_EwIw(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_EdId(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_EdId(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_EdId(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_EwIw(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_EdId(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_EdId(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_EwIw(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_EdId(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void ROL_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void ROR_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void RCL_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void RCR_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SHL_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SHR_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void SAR_Eb(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void ROL_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void ROL_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void ROR_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void ROR_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void RCL_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void RCL_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void RCR_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void RCR_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void SHL_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void SHL_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void SHR_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void SHR_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void SAR_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void SAR_Ew(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void TEST_EbIb(bxInstruction_c *);
|
|
|
|
BX_SMF void NOT_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void NEG_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void MUL_ALEb(bxInstruction_c *);
|
2004-09-18 00:47:19 +04:00
|
|
|
BX_SMF void IMUL_GdEd(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void IMUL_ALEb(bxInstruction_c *);
|
2004-09-18 00:47:19 +04:00
|
|
|
BX_SMF void IMUL_GdEdId(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void DIV_ALEb(bxInstruction_c *);
|
|
|
|
BX_SMF void IDIV_ALEb(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void TEST_EdId(bxInstruction_c *);
|
|
|
|
BX_SMF void TEST_EwIw(bxInstruction_c *);
|
|
|
|
BX_SMF void NOT_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void NOT_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void NEG_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void MUL_EAXEd(bxInstruction_c *);
|
|
|
|
BX_SMF void IMUL_EAXEd(bxInstruction_c *);
|
|
|
|
BX_SMF void DIV_EAXEd(bxInstruction_c *);
|
|
|
|
BX_SMF void IDIV_EAXEd(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void INC_Eb(bxInstruction_c *);
|
|
|
|
BX_SMF void DEC_Eb(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void INC_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void DEC_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void CALL_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void CALL_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void CALL32_Ep(bxInstruction_c *);
|
|
|
|
BX_SMF void CALL16_Ep(bxInstruction_c *);
|
|
|
|
BX_SMF void JMP_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void JMP_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void JMP32_Ep(bxInstruction_c *);
|
|
|
|
BX_SMF void JMP16_Ep(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH_Ew(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void SLDT_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void STR_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void LLDT_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void LTR_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void VERR_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void VERW_Ew(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void SGDT_Ms(bxInstruction_c *);
|
|
|
|
BX_SMF void SIDT_Ms(bxInstruction_c *);
|
|
|
|
BX_SMF void LGDT_Ms(bxInstruction_c *);
|
|
|
|
BX_SMF void LIDT_Ms(bxInstruction_c *);
|
|
|
|
BX_SMF void SMSW_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void LMSW_Ew(bxInstruction_c *);
|
|
|
|
|
2004-04-09 19:34:59 +04:00
|
|
|
#if BX_SUPPORT_FPU == 0 // if FPU is disabled
|
|
|
|
BX_SMF void FPU_ESC(bxInstruction_c *);
|
|
|
|
#endif
|
|
|
|
|
2003-12-27 16:50:06 +03:00
|
|
|
BX_SMF void FWAIT(bxInstruction_c *);
|
|
|
|
|
2004-04-09 19:34:59 +04:00
|
|
|
#if BX_SUPPORT_FPU
|
2004-06-18 18:11:11 +04:00
|
|
|
// load/store
|
2003-12-27 16:50:06 +03:00
|
|
|
BX_SMF void FLD_STi(bxInstruction_c *);
|
|
|
|
BX_SMF void FLD_SINGLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FLD_DOUBLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FLD_EXTENDED_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FILD_WORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FILD_DWORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FILD_QWORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FBLD_PACKED_BCD(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void FST_STi(bxInstruction_c *);
|
|
|
|
BX_SMF void FST_SINGLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FST_DOUBLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FSTP_EXTENDED_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FIST_WORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FIST_DWORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FISTP_QWORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FBSTP_PACKED_BCD(bxInstruction_c *);
|
|
|
|
|
2006-04-06 22:30:05 +04:00
|
|
|
BX_SMF void FISTTP16(bxInstruction_c *); // SSE3
|
2003-12-27 16:50:06 +03:00
|
|
|
BX_SMF void FISTTP32(bxInstruction_c *);
|
|
|
|
BX_SMF void FISTTP64(bxInstruction_c *);
|
|
|
|
|
2004-06-18 18:11:11 +04:00
|
|
|
// control
|
|
|
|
BX_SMF void FNINIT(bxInstruction_c *);
|
|
|
|
BX_SMF void FNCLEX(bxInstruction_c *);
|
|
|
|
|
2003-12-27 16:50:06 +03:00
|
|
|
BX_SMF void FRSTOR(bxInstruction_c *);
|
2003-12-28 21:58:15 +03:00
|
|
|
BX_SMF void FNSAVE(bxInstruction_c *);
|
2004-06-18 18:11:11 +04:00
|
|
|
BX_SMF void FLDENV(bxInstruction_c *);
|
|
|
|
BX_SMF void FNSTENV(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void FLDCW(bxInstruction_c *);
|
|
|
|
BX_SMF void FNSTCW(bxInstruction_c *);
|
|
|
|
BX_SMF void FNSTSW(bxInstruction_c *);
|
|
|
|
BX_SMF void FNSTSW_AX(bxInstruction_c *);
|
|
|
|
|
|
|
|
// const
|
|
|
|
BX_SMF void FLD1(bxInstruction_c *);
|
|
|
|
BX_SMF void FLDL2T(bxInstruction_c *);
|
|
|
|
BX_SMF void FLDL2E(bxInstruction_c *);
|
|
|
|
BX_SMF void FLDPI(bxInstruction_c *);
|
|
|
|
BX_SMF void FLDLG2(bxInstruction_c *);
|
|
|
|
BX_SMF void FLDLN2(bxInstruction_c *);
|
|
|
|
BX_SMF void FLDZ(bxInstruction_c *);
|
2003-12-27 16:50:06 +03:00
|
|
|
|
|
|
|
// add
|
|
|
|
BX_SMF void FADD_ST0_STj(bxInstruction_c *);
|
|
|
|
BX_SMF void FADD_STi_ST0(bxInstruction_c *);
|
|
|
|
BX_SMF void FADD_SINGLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FADD_DOUBLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FIADD_WORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FIADD_DWORD_INTEGER(bxInstruction_c *);
|
|
|
|
|
|
|
|
// mul
|
|
|
|
BX_SMF void FMUL_ST0_STj(bxInstruction_c *);
|
|
|
|
BX_SMF void FMUL_STi_ST0(bxInstruction_c *);
|
|
|
|
BX_SMF void FMUL_SINGLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FMUL_DOUBLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FIMUL_WORD_INTEGER (bxInstruction_c *);
|
|
|
|
BX_SMF void FIMUL_DWORD_INTEGER(bxInstruction_c *);
|
|
|
|
|
|
|
|
// sub
|
|
|
|
BX_SMF void FSUB_ST0_STj(bxInstruction_c *);
|
|
|
|
BX_SMF void FSUBR_ST0_STj(bxInstruction_c *);
|
|
|
|
BX_SMF void FSUB_STi_ST0(bxInstruction_c *);
|
|
|
|
BX_SMF void FSUBR_STi_ST0(bxInstruction_c *);
|
|
|
|
BX_SMF void FSUB_SINGLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FSUBR_SINGLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FSUB_DOUBLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FSUBR_DOUBLE_REAL(bxInstruction_c *);
|
2004-06-18 18:11:11 +04:00
|
|
|
|
2003-12-27 16:50:06 +03:00
|
|
|
BX_SMF void FISUB_WORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FISUBR_WORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FISUB_DWORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FISUBR_DWORD_INTEGER(bxInstruction_c *);
|
|
|
|
|
|
|
|
// div
|
|
|
|
BX_SMF void FDIV_ST0_STj(bxInstruction_c *);
|
|
|
|
BX_SMF void FDIVR_ST0_STj(bxInstruction_c *);
|
|
|
|
BX_SMF void FDIV_STi_ST0(bxInstruction_c *);
|
|
|
|
BX_SMF void FDIVR_STi_ST0(bxInstruction_c *);
|
|
|
|
BX_SMF void FDIV_SINGLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FDIVR_SINGLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FDIV_DOUBLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FDIVR_DOUBLE_REAL(bxInstruction_c *);
|
2004-06-18 18:11:11 +04:00
|
|
|
|
2003-12-27 16:50:06 +03:00
|
|
|
BX_SMF void FIDIV_WORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FIDIVR_WORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FIDIV_DWORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FIDIVR_DWORD_INTEGER(bxInstruction_c *);
|
|
|
|
|
|
|
|
// compare
|
|
|
|
BX_SMF void FCOM_STi(bxInstruction_c *);
|
2004-06-18 18:11:11 +04:00
|
|
|
BX_SMF void FUCOM_STi(bxInstruction_c *);
|
2003-12-27 16:50:06 +03:00
|
|
|
BX_SMF void FCOMI_ST0_STj(bxInstruction_c *);
|
|
|
|
BX_SMF void FUCOMI_ST0_STj(bxInstruction_c *);
|
|
|
|
BX_SMF void FCOM_SINGLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FCOM_DOUBLE_REAL(bxInstruction_c *);
|
|
|
|
BX_SMF void FICOM_WORD_INTEGER(bxInstruction_c *);
|
|
|
|
BX_SMF void FICOM_DWORD_INTEGER(bxInstruction_c *);
|
2004-06-18 18:11:11 +04:00
|
|
|
BX_SMF void FCMOV_ST0_STj(bxInstruction_c *);
|
2003-12-27 16:50:06 +03:00
|
|
|
|
|
|
|
BX_SMF void FCOMPP(bxInstruction_c *);
|
|
|
|
BX_SMF void FUCOMPP(bxInstruction_c *);
|
|
|
|
|
|
|
|
// misc
|
|
|
|
BX_SMF void FXCH_STi(bxInstruction_c *);
|
|
|
|
BX_SMF void FNOP(bxInstruction_c *);
|
2004-06-18 18:11:11 +04:00
|
|
|
BX_SMF void FPLEGACY(bxInstruction_c *);
|
2003-12-27 16:50:06 +03:00
|
|
|
BX_SMF void FCHS(bxInstruction_c *);
|
|
|
|
BX_SMF void FABS(bxInstruction_c *);
|
|
|
|
BX_SMF void FTST(bxInstruction_c *);
|
|
|
|
BX_SMF void FXAM(bxInstruction_c *);
|
2004-06-18 18:11:11 +04:00
|
|
|
BX_SMF void FDECSTP(bxInstruction_c *);
|
|
|
|
BX_SMF void FINCSTP(bxInstruction_c *);
|
|
|
|
BX_SMF void FFREE_STi(bxInstruction_c *);
|
2004-07-15 23:45:33 +04:00
|
|
|
BX_SMF void FFREEP_STi(bxInstruction_c *);
|
2003-12-27 16:50:06 +03:00
|
|
|
|
|
|
|
BX_SMF void F2XM1(bxInstruction_c *);
|
|
|
|
BX_SMF void FYL2X(bxInstruction_c *);
|
|
|
|
BX_SMF void FPTAN(bxInstruction_c *);
|
|
|
|
BX_SMF void FPATAN(bxInstruction_c *);
|
|
|
|
BX_SMF void FXTRACT(bxInstruction_c *);
|
|
|
|
BX_SMF void FPREM1(bxInstruction_c *);
|
|
|
|
BX_SMF void FPREM(bxInstruction_c *);
|
|
|
|
BX_SMF void FYL2XP1(bxInstruction_c *);
|
|
|
|
BX_SMF void FSQRT(bxInstruction_c *);
|
|
|
|
BX_SMF void FSINCOS(bxInstruction_c *);
|
|
|
|
BX_SMF void FRNDINT(bxInstruction_c *);
|
2003-12-30 00:24:35 +03:00
|
|
|
#undef FSCALE // <sys/param.h> is #included on Mac OS X from bochs.h
|
2003-12-27 16:50:06 +03:00
|
|
|
BX_SMF void FSCALE(bxInstruction_c *);
|
|
|
|
BX_SMF void FSIN(bxInstruction_c *);
|
|
|
|
BX_SMF void FCOS(bxInstruction_c *);
|
2004-04-09 19:34:59 +04:00
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2002-09-09 20:11:25 +04:00
|
|
|
/* MMX */
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void PUNPCKLBW_PqQd(bxInstruction_c *i);
|
|
|
|
BX_SMF void PUNPCKLWD_PqQd(bxInstruction_c *i);
|
|
|
|
BX_SMF void PUNPCKLDQ_PqQd(bxInstruction_c *i);
|
|
|
|
BX_SMF void PACKSSWB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPGTB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPGTW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPGTD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PACKUSWB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PUNPCKHBW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PUNPCKHWD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PUNPCKHDQ_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PACKSSDW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVD_PqEd(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVQ_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPEQB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPEQW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPEQD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void EMMS(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVD_EdPd(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVQ_QqPq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLQ_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULLW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBUSB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBUSW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PAND_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDUSB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDUSW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PANDN_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRAW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRAD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULHW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBSB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBSW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void POR_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDSB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDSW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PXOR_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLQ_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMADDWD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLW_PqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRAW_PqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLW_PqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLD_PqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRAD_PqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLD_PqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLQ_PqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLQ_PqIb(bxInstruction_c *i);
|
2002-09-09 20:11:25 +04:00
|
|
|
/* MMX */
|
|
|
|
|
2003-05-15 20:41:17 +04:00
|
|
|
#if BX_SUPPORT_3DNOW
|
|
|
|
BX_SMF void PFPNACC_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PI2FW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PI2FD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PF2IW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PF2ID_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFNACC_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFCMPGE_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFMIN_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFRCP_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFRSQRT_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFSUB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFADD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFCMPGT_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFMAX_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFRCPIT1_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFRSQIT1_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFSUBR_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFACC_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFCMPEQ_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFMUL_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PFRCPIT2_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULHRW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSWAPD_PqQq(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* SSE */
|
|
|
|
BX_SMF void FXSAVE(bxInstruction_c *i);
|
|
|
|
BX_SMF void FXRSTOR(bxInstruction_c *i);
|
|
|
|
BX_SMF void LDMXCSR(bxInstruction_c *i);
|
|
|
|
BX_SMF void STMXCSR(bxInstruction_c *i);
|
|
|
|
BX_SMF void PREFETCH(bxInstruction_c *i);
|
|
|
|
/* SSE */
|
|
|
|
|
|
|
|
/* SSE */
|
|
|
|
BX_SMF void MOVUPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVSS_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVUPS_WpsVps(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVSS_WssVss(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVLPS_VpsMq(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVLPS_MqVps(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVHPS_VpsMq(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVHPS_MqVps(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVAPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVAPS_WpsVps(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTPI2PS_VpsQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTSI2SS_VssEd(bxInstruction_c *i);
|
2007-08-31 22:09:34 +04:00
|
|
|
BX_SMF void MOVNTPS_MpsVps(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void CVTTPS2PI_PqWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTTSS2SI_GdWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTPS2PI_PqWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTSS2SI_GdWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void UCOMISS_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void COMISS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVMSKPS_GdVRps(bxInstruction_c *i);
|
|
|
|
BX_SMF void SQRTPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void SQRTSS_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void RSQRTPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void RSQRTSS_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void RCPPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void RCPSS_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void ADDPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void ADDSS_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void MULPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void MULSS_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void SUBPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void SUBSS_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void MINPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void MINSS_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void DIVPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void DIVSS_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void MAXPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void MAXSS_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSHUFW_PqQqIb(bxInstruction_c *i);
|
2007-10-01 23:59:37 +04:00
|
|
|
BX_SMF void PSHUFLW_VdqWdqIb(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void CMPPS_VpsWpsIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void CMPSS_VssWssIb(bxInstruction_c *i);
|
2007-04-19 20:12:21 +04:00
|
|
|
BX_SMF void PINSRW_PqEwIb(bxInstruction_c *i);
|
2005-09-23 20:45:41 +04:00
|
|
|
BX_SMF void PEXTRW_GdPqIb(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void SHUFPS_VpsWpsIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVMSKB_GdPRq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMINUB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMAXUB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PAVGB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PAVGW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULHUW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVNTQ_MqPq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMINSW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMAXSW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSADBW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void MASKMOVQ_PqPRq(bxInstruction_c *i);
|
|
|
|
/* SSE */
|
|
|
|
|
|
|
|
/* SSE2 */
|
|
|
|
BX_SMF void MOVSD_VsdWsd(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVSD_WsdVsd(bxInstruction_c *i);
|
2005-09-23 20:45:41 +04:00
|
|
|
BX_SMF void CVTPI2PD_VpdQq(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void CVTSI2SD_VsdEd(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTTPD2PI_PqWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTTSD2SI_GdWsd(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTPD2PI_PqWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTSD2SI_GdWsd(bxInstruction_c *i);
|
|
|
|
BX_SMF void UCOMISD_VsdWsd(bxInstruction_c *i);
|
|
|
|
BX_SMF void COMISD_VpdWpd(bxInstruction_c *i);
|
2005-09-23 20:45:41 +04:00
|
|
|
BX_SMF void MOVMSKPD_GdVRpd(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void SQRTPD_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void SQRTSD_VsdWsd(bxInstruction_c *i);
|
|
|
|
BX_SMF void ADDPD_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void ADDSD_VsdWsd(bxInstruction_c *i);
|
|
|
|
BX_SMF void MULPD_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void MULSD_VsdWsd(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTPS2PD_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTPD2PS_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTSD2SS_VsdWsd(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTSS2SD_VssWss(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTDQ2PS_VpsWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTPS2DQ_VdqWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTTPS2DQ_VdqWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void SUBPD_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void SUBSD_VsdWsd(bxInstruction_c *i);
|
|
|
|
BX_SMF void MINPD_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void MINSD_VsdWsd(bxInstruction_c *i);
|
|
|
|
BX_SMF void DIVPD_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void DIVSD_VsdWsd(bxInstruction_c *i);
|
|
|
|
BX_SMF void MAXPD_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void MAXSD_VsdWsd(bxInstruction_c *i);
|
2007-10-01 23:59:37 +04:00
|
|
|
BX_SMF void PUNPCKLBW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PUNPCKLWD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void UNPCKLPS_VpsWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PACKSSWB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPGTB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPGTW_VdqWdq(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void PCMPGTD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PACKUSWB_VdqWdq(bxInstruction_c *i);
|
2007-10-01 23:59:37 +04:00
|
|
|
BX_SMF void PUNPCKHBW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PUNPCKHWD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void UNPCKHPS_VpsWdq(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void PACKSSDW_VdqWdq(bxInstruction_c *i);
|
2007-10-01 23:59:37 +04:00
|
|
|
BX_SMF void PUNPCKLQDQ_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PUNPCKHQDQ_VdqWdq(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void MOVD_VdqEd(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSHUFD_VdqWdqIb(bxInstruction_c *i);
|
2007-10-01 23:59:37 +04:00
|
|
|
BX_SMF void PSHUFHW_VdqWdqIb(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void PCMPEQB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPEQW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPEQD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVD_EdVd(bxInstruction_c *i);
|
2002-11-08 15:47:24 +03:00
|
|
|
BX_SMF void MOVQ_VqWq(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void CMPPD_VpdWpdIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void CMPSD_VsdWsdIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVNTI_MdGd(bxInstruction_c *i);
|
2007-04-19 20:12:21 +04:00
|
|
|
BX_SMF void PINSRW_VdqEwIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PEXTRW_GdUdqIb(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void SHUFPD_VpdWpdIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLQ_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDQ_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDQ_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULLW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVQ_WqVq(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVDQ2Q_PqVRq(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVQ2DQ_VdqQq(bxInstruction_c *i);
|
2007-04-19 20:12:21 +04:00
|
|
|
BX_SMF void PMOVMSKB_GdUdq(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void PSUBUSB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBUSW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMINUB_VdqWdq(bxInstruction_c *i);
|
2007-03-23 01:51:41 +03:00
|
|
|
BX_SMF void ANDPS_VpsWps(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void PADDUSB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDUSW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMAXUB_VdqWdq(bxInstruction_c *i);
|
2007-03-23 01:51:41 +03:00
|
|
|
BX_SMF void ANDNPS_VpsWps(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void PAVGB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRAW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRAD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PAVGW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULHUW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULHW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTTPD2DQ_VqWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTPD2DQ_VqWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void CVTDQ2PD_VpdWq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBSB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBSW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMINSW_VdqWdq(bxInstruction_c *i);
|
2007-03-23 01:51:41 +03:00
|
|
|
BX_SMF void ORPS_VpsWps(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void PADDSB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDSW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMAXSW_VdqWdq(bxInstruction_c *i);
|
2007-03-23 01:51:41 +03:00
|
|
|
BX_SMF void XORPS_VpsWps(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void PSLLW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLQ_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULUDQ_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULUDQ_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMADDWD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSADBW_VdqWdq(bxInstruction_c *i);
|
2007-04-19 20:12:21 +04:00
|
|
|
BX_SMF void MASKMOVDQU_VdqUdq(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
BX_SMF void PSUBB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBQ_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSUBQ_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PADDD_VdqWdq(bxInstruction_c *i);
|
2006-02-17 16:34:31 +03:00
|
|
|
BX_SMF void PSRLW_UdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRAW_UdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLW_UdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLD_UdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRAD_UdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLD_UdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLQ_UdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSRLDQ_UdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLQ_UdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSLLDQ_UdqIb(bxInstruction_c *i);
|
2002-10-16 21:37:35 +04:00
|
|
|
/* SSE2 */
|
|
|
|
|
2006-04-06 22:30:05 +04:00
|
|
|
/* SSE3 */
|
2003-08-30 01:20:52 +04:00
|
|
|
BX_SMF void MOVDDUP_VpdWq(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVSLDUP_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void MOVSHDUP_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void HADDPD_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void HADDPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void HSUBPD_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void HSUBPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void ADDSUBPD_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void ADDSUBPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void LDDQU_VdqMdq(bxInstruction_c *i);
|
2006-04-06 22:30:05 +04:00
|
|
|
/* SSE3 */
|
|
|
|
|
2007-10-01 23:59:37 +04:00
|
|
|
// 3-byte opcodes
|
2007-04-19 20:12:21 +04:00
|
|
|
#if (BX_SUPPORT_SSE >= 4) || (BX_SUPPORT_SSE >= 3 && BX_SUPPORT_SSE_EXTENSION > 0)
|
2007-03-15 00:15:15 +03:00
|
|
|
/* SSE3E */
|
2006-04-06 22:30:05 +04:00
|
|
|
BX_SMF void PSHUFB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHADDW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHADDD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHADDSW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMADDUBSW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHSUBSW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHSUBW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHSUBD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSIGNB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSIGNW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSIGND_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULHRSW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PABSB_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PABSW_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PABSD_PqQq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PALIGNR_PqQqIb(bxInstruction_c *i);
|
|
|
|
|
|
|
|
BX_SMF void PSHUFB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHADDW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHADDD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHADDSW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMADDUBSW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHSUBSW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHSUBW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHSUBD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSIGNB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSIGNW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PSIGND_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULHRSW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PABSB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PABSW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PABSD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PALIGNR_VdqWdqIb(bxInstruction_c *i);
|
2007-03-15 00:15:15 +03:00
|
|
|
/* SSE3E */
|
2003-08-30 01:20:52 +04:00
|
|
|
|
2007-08-31 22:09:34 +04:00
|
|
|
/* SSE4.1 */
|
2007-04-19 20:12:21 +04:00
|
|
|
BX_SMF void PBLENDVB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void BLENDVPS_VpsWps(bxInstruction_c *i);
|
|
|
|
BX_SMF void BLENDVPD_VpdWpd(bxInstruction_c *i);
|
|
|
|
BX_SMF void PTEST_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULDQ_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPEQQ_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PACKUSDW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVSXBW_VdqWq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVSXBD_VdqWd(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVSXBQ_VdqWw(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVSXWD_VdqWq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVSXWQ_VdqWd(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVSXDQ_VdqWq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVZXBW_VdqWq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVZXBD_VdqWd(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVZXBQ_VdqWw(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVZXWD_VdqWq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVZXWQ_VdqWd(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMOVZXDQ_VdqWq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMINSB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMINSD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMINUW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMINUD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMAXSB_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMAXSD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMAXUW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMAXUD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PMULLD_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PHMINPOSUW_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void ROUNDPS_VpsWpsIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void ROUNDPD_VpdWpdIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void ROUNDSS_VssWssIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void ROUNDSD_VsdWsdIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void BLENDPS_VpsWpsIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void BLENDPD_VpdWpdIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PBLENDW_VdqWdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PEXTRB_HbdUdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PEXTRW_HwdUdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PEXTRD_HdUdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void EXTRACTPS_HdUpsIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PINSRB_VdqEbIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void INSERTPS_VpsWssIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PINSRD_VdqEdIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void DPPS_VpsWpsIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void DPPD_VpdWpdIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void MPSADBW_VdqWdqIb(bxInstruction_c *i);
|
2007-10-20 21:03:33 +04:00
|
|
|
BX_SMF void MOVNTDQA_VdqMdq(bxInstruction_c *i);
|
2007-08-31 22:09:34 +04:00
|
|
|
/* SSE4.1 */
|
2007-10-01 23:59:37 +04:00
|
|
|
|
|
|
|
/* SSE4.2 */
|
|
|
|
BX_SMF void CRC32_GdEb(bxInstruction_c *i);
|
|
|
|
BX_SMF void CRC32_GdEv(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPGTQ_VdqWdq(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPESTRM_VdqWdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPESTRI_VdqWdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPISTRM_VdqWdqIb(bxInstruction_c *i);
|
|
|
|
BX_SMF void PCMPISTRI_VdqWdqIb(bxInstruction_c *i);
|
|
|
|
/* SSE4.2 */
|
2007-04-19 20:12:21 +04:00
|
|
|
#endif
|
|
|
|
|
2007-08-31 22:09:34 +04:00
|
|
|
/*** Duplicate SSE instructions ***/
|
|
|
|
// Although in implementation, these instructions are aliased to the
|
|
|
|
// another function, it's nice to have them call a separate function when
|
|
|
|
// the decoder is being tested in stand-alone mode.
|
|
|
|
#ifdef STAND_ALONE_DECODER
|
|
|
|
BX_SMF void MOVUPD_VpdWpd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVUPD_WpdVpd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVAPD_VpdWpd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVAPD_WpdVpd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVDQU_VdqWdq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVDQU_WdqVdq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVDQA_VdqWdq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVDQA_WdqVdq(bxInstruction_c *);
|
2007-10-01 23:59:37 +04:00
|
|
|
BX_SMF void PUNPCKHDQ_VdqWdq(bxInstruction_c *);
|
|
|
|
BX_SMF void PUNPCKLDQ_VdqWdq(bxInstruction_c *);
|
2007-08-31 22:09:34 +04:00
|
|
|
BX_SMF void ANDPD_VpdWpd(bxInstruction_c *);
|
|
|
|
BX_SMF void ANDNPD_VpdWpd(bxInstruction_c *);
|
|
|
|
BX_SMF void ORPD_VpdWpd(bxInstruction_c *);
|
|
|
|
BX_SMF void XORPD_VpdWpd(bxInstruction_c *);
|
|
|
|
BX_SMF void PAND_VdqWdq(bxInstruction_c *);
|
|
|
|
BX_SMF void PANDN_VdqWdq(bxInstruction_c *);
|
|
|
|
BX_SMF void POR_VdqWdq(bxInstruction_c *);
|
|
|
|
BX_SMF void PXOR_VdqWdq(bxInstruction_c *);
|
2007-10-01 23:59:37 +04:00
|
|
|
BX_SMF void UNPCKHPD_VpdWdq(bxInstruction_c *);
|
|
|
|
BX_SMF void UNPCKLPD_VpdWdq(bxInstruction_c *);
|
2007-08-31 22:09:34 +04:00
|
|
|
BX_SMF void MOVLPD_VsdMq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVLPD_MqVsd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVHPD_VsdMq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVHPD_MqVsd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVNTPD_MdqVpd(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVNTDQ_MdqVdq(bxInstruction_c *);
|
|
|
|
#else
|
|
|
|
|
|
|
|
#if BX_SUPPORT_SSE >= 2
|
|
|
|
#define SSE2_ALIAS(i) i
|
|
|
|
#else
|
|
|
|
#define SSE2_ALIAS(i) BxError
|
|
|
|
#endif
|
|
|
|
|
2007-10-01 23:59:37 +04:00
|
|
|
#define MOVUPD_VpdWpd /* 66 0f 10 */ SSE2_ALIAS(MOVUPS_VpsWps) /* 0f 10 */
|
|
|
|
#define MOVUPD_WpdVpd /* 66 0f 11 */ SSE2_ALIAS(MOVUPS_WpsVps) /* 0f 11 */
|
|
|
|
#define MOVAPD_VpdWpd /* 66 0f 28 */ SSE2_ALIAS(MOVAPS_VpsWps) /* 0f 28 */
|
|
|
|
#define MOVAPD_WpdVpd /* 66 0f 29 */ SSE2_ALIAS(MOVAPS_WpsVps) /* 0f 29 */
|
|
|
|
#define MOVDQU_VdqWdq /* f3 0f 6f */ SSE2_ALIAS(MOVUPS_VpsWps) /* 0f 10 */
|
|
|
|
#define MOVDQU_WdqVdq /* f3 0f 7f */ SSE2_ALIAS(MOVUPS_WpsVps) /* 0f 11 */
|
|
|
|
#define MOVDQA_VdqWdq /* 66 0f 6f */ SSE2_ALIAS(MOVAPS_VpsWps) /* 0f 28 */
|
|
|
|
#define MOVDQA_WdqVdq /* 66 0f 7f */ SSE2_ALIAS(MOVAPS_WpsVps) /* 0f 29 */
|
2007-08-31 22:09:34 +04:00
|
|
|
|
2007-10-01 23:59:37 +04:00
|
|
|
#define PUNPCKLDQ_VdqWdq /* 66 0f 62 */ SSE2_ALIAS(UNPCKLPS_VpsWdq) /* 0f 14 */
|
|
|
|
#define PUNPCKHDQ_VdqWdq /* 66 0f 6a */ SSE2_ALIAS(UNPCKHPS_VpsWdq) /* 0f 15 */
|
2007-08-31 22:09:34 +04:00
|
|
|
|
2007-10-01 23:59:37 +04:00
|
|
|
#define PAND_VdqWdq /* 66 0f db */ SSE2_ALIAS(ANDPS_VpsWps) /* 0f 54 */
|
|
|
|
#define PANDN_VdqWdq /* 66 0f df */ SSE2_ALIAS(ANDNPS_VpsWps) /* 0f 55 */
|
|
|
|
#define POR_VdqWdq /* 66 0f eb */ SSE2_ALIAS(ORPS_VpsWps) /* 0f 56 */
|
|
|
|
#define PXOR_VdqWdq /* 66 0f ef */ SSE2_ALIAS(XORPS_VpsWps) /* 0f 57 */
|
2007-08-31 22:09:34 +04:00
|
|
|
|
2007-10-01 23:59:37 +04:00
|
|
|
#define ANDPD_VpdWpd /* 66 0f 54 */ SSE2_ALIAS(ANDPS_VpsWps) /* 0f 54 */
|
|
|
|
#define ANDNPD_VpdWpd /* 66 0f 55 */ SSE2_ALIAS(ANDNPS_VpsWps) /* 0f 55 */
|
|
|
|
#define ORPD_VpdWpd /* 66 0f 56 */ SSE2_ALIAS(ORPS_VpsWps) /* 0f 56 */
|
|
|
|
#define XORPD_VpdWpd /* 66 0f 57 */ SSE2_ALIAS(XORPS_VpsWps) /* 0f 57 */
|
2007-08-31 22:09:34 +04:00
|
|
|
|
2007-10-01 23:59:37 +04:00
|
|
|
#define MOVLPD_VsdMq /* 66 0f 12 */ SSE2_ALIAS(MOVLPS_VpsMq) /* 0f 12 */
|
|
|
|
#define MOVLPD_MqVsd /* 66 0f 13 */ SSE2_ALIAS(MOVLPS_MqVps) /* 0f 13 */
|
|
|
|
#define MOVHPD_VsdMq /* 66 0f 16 */ SSE2_ALIAS(MOVHPS_VpsMq) /* 0f 16 */
|
|
|
|
#define MOVHPD_MqVsd /* 66 0f 17 */ SSE2_ALIAS(MOVHPS_MqVps) /* 0f 17 */
|
2007-08-31 22:09:34 +04:00
|
|
|
|
2007-10-01 23:59:37 +04:00
|
|
|
#define MOVNTPD_MpdVpd /* 66 0f 2b */ SSE2_ALIAS(MOVNTPS_MpsVps) /* 0f 2b */
|
|
|
|
#define MOVNTDQ_MdqVdq /* 66 0f e7 */ SSE2_ALIAS(MOVNTPS_MpsVps) /* 0f 2b */
|
2007-08-31 22:09:34 +04:00
|
|
|
|
2007-10-01 23:59:37 +04:00
|
|
|
#define UNPCKLPD_VpdWdq /* 66 0f 14 */ PUNPCKLQDQ_VdqWdq /* 66 0f 6c */
|
|
|
|
#define UNPCKHPD_VpdWdq /* 66 0f 15 */ PUNPCKHQDQ_VdqWdq /* 66 0f 6d */
|
2007-08-31 22:09:34 +04:00
|
|
|
|
|
|
|
#endif // #ifdef STAND_ALONE_DECODER
|
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void CMPXCHG_XBTS(bxInstruction_c *);
|
|
|
|
BX_SMF void CMPXCHG_IBTS(bxInstruction_c *);
|
|
|
|
BX_SMF void CMPXCHG_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void CMPXCHG_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void CMPXCHG8B(bxInstruction_c *);
|
|
|
|
BX_SMF void XADD_EbGb(bxInstruction_c *);
|
|
|
|
BX_SMF void XADD_EdGd(bxInstruction_c *);
|
|
|
|
BX_SMF void RETnear32_Iw(bxInstruction_c *);
|
|
|
|
BX_SMF void RETnear16_Iw(bxInstruction_c *);
|
|
|
|
BX_SMF void RETfar32_Iw(bxInstruction_c *);
|
|
|
|
BX_SMF void RETfar16_Iw(bxInstruction_c *);
|
|
|
|
|
2004-05-11 01:05:51 +04:00
|
|
|
#if BX_CPU_LEVEL == 2
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void LOADALL(bxInstruction_c *);
|
2004-05-11 01:05:51 +04:00
|
|
|
#endif
|
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void CMOV_GdEd(bxInstruction_c *);
|
|
|
|
BX_SMF void CMOV_GwEw(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void ADD_EwGw(bxInstruction_c *);
|
2007-11-16 11:30:22 +03:00
|
|
|
BX_SMF void ADD_GwEwR(bxInstruction_c *);
|
|
|
|
BX_SMF void ADD_GwEwM(bxInstruction_c *);
|
2002-09-29 23:21:38 +04:00
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void ADD_AXIw(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_GwEw(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_AXIw(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_GwEw(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_AXIw(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_EwIw(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_GwEw(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_AXIw(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_GwEw(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_AXIw(bxInstruction_c *);
|
|
|
|
BX_SMF void CWDE(bxInstruction_c *);
|
|
|
|
BX_SMF void CDQ(bxInstruction_c *);
|
|
|
|
BX_SMF void XADD_EwGw(bxInstruction_c *);
|
2002-09-29 23:21:38 +04:00
|
|
|
|
2007-11-16 11:30:22 +03:00
|
|
|
BX_SMF void ADD_EwMIw(bxInstruction_c *);
|
|
|
|
BX_SMF void ADD_EwRIw(bxInstruction_c *);
|
2002-09-29 23:21:38 +04:00
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void ADC_EwIw(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_EwIw(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_EwIw(bxInstruction_c *);
|
|
|
|
BX_SMF void NEG_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void INC_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void DEC_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void CMPXCHG_EwGw(bxInstruction_c *);
|
|
|
|
BX_SMF void MUL_AXEw(bxInstruction_c *);
|
|
|
|
BX_SMF void IMUL_AXEw(bxInstruction_c *);
|
|
|
|
BX_SMF void DIV_AXEw(bxInstruction_c *);
|
|
|
|
BX_SMF void IDIV_AXEw(bxInstruction_c *);
|
|
|
|
BX_SMF void IMUL_GwEwIw(bxInstruction_c *);
|
|
|
|
BX_SMF void IMUL_GwEw(bxInstruction_c *);
|
|
|
|
BX_SMF void NOP(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_RLIb(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_RHIb(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_RXIw(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_ERXId(bxInstruction_c *);
|
|
|
|
BX_SMF void INC_RX(bxInstruction_c *);
|
|
|
|
BX_SMF void DEC_RX(bxInstruction_c *);
|
|
|
|
BX_SMF void INC_ERX(bxInstruction_c *);
|
|
|
|
BX_SMF void DEC_ERX(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH_RX(bxInstruction_c *);
|
|
|
|
BX_SMF void POP_RX(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH_ERX(bxInstruction_c *);
|
|
|
|
BX_SMF void POP_ERX(bxInstruction_c *);
|
|
|
|
BX_SMF void POP_Ew(bxInstruction_c *);
|
|
|
|
BX_SMF void POP_Ed(bxInstruction_c *);
|
|
|
|
BX_SMF void XCHG_RXAX(bxInstruction_c *);
|
|
|
|
BX_SMF void XCHG_ERXEAX(bxInstruction_c *);
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2007-09-19 23:38:10 +04:00
|
|
|
BX_SMF void POPCNT_GwEw(bxInstruction_c *);
|
|
|
|
BX_SMF void POPCNT_GdEd(bxInstruction_c *);
|
|
|
|
|
2002-09-13 04:15:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
// 64 bit extensions
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void ADD_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void ADD_GqEq(bxInstruction_c *);
|
|
|
|
BX_SMF void ADD_RAXId(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_GqEq(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_RAXId(bxInstruction_c *);
|
2004-11-21 02:26:32 +03:00
|
|
|
BX_SMF void SUB_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_GqEq(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_RAXId(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void SBB_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_GqEq(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_RAXId(bxInstruction_c *);
|
|
|
|
|
2004-11-21 02:26:32 +03:00
|
|
|
BX_SMF void OR_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_GqEq(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_RAXId(bxInstruction_c *);
|
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void AND_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_GqEq(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_RAXId(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void XOR_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_GqEq(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_RAXId(bxInstruction_c *);
|
2004-11-21 02:26:32 +03:00
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void CMP_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_GqEq(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_RAXId(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void PUSH64_Id(bxInstruction_c *);
|
|
|
|
|
2004-11-21 02:26:32 +03:00
|
|
|
BX_SMF void TEST_RAXId(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void TEST_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void XCHG_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void LEA_GqM(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void MOV_RAXOq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_OqRAX(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_EAXOq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_OqEAX(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_AXOq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_OqAX(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_ALOq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_OqAL(bxInstruction_c *);
|
2004-11-21 02:26:32 +03:00
|
|
|
BX_SMF void MOV_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_GqEq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_EqId(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
2004-11-21 02:26:32 +03:00
|
|
|
BX_SMF void MOVSQ_XqYq(bxInstruction_c *);
|
|
|
|
BX_SMF void CMPSQ_XqYq(bxInstruction_c *);
|
|
|
|
BX_SMF void STOSQ_YqRAX(bxInstruction_c *);
|
|
|
|
BX_SMF void LODSQ_RAXXq(bxInstruction_c *);
|
|
|
|
BX_SMF void SCASQ_RAXXq(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
2007-01-05 16:40:47 +03:00
|
|
|
BX_SMF void REP_MOVSQ_XqYq(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_CMPSQ_XqYq(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_STOSQ_YqRAX(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_LODSQ_RAXXq(bxInstruction_c *);
|
|
|
|
BX_SMF void REP_SCASQ_RAXXq(bxInstruction_c *);
|
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void RETnear64(bxInstruction_c *);
|
|
|
|
BX_SMF void ENTER64_IwIb(bxInstruction_c *);
|
|
|
|
BX_SMF void LEAVE64(bxInstruction_c *);
|
|
|
|
BX_SMF void RETfar64(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void IRET64(bxInstruction_c *);
|
|
|
|
|
2007-10-22 21:41:41 +04:00
|
|
|
BX_SMF void CALL_Jq(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void JMP_Jq(bxInstruction_c *);
|
2007-11-12 21:20:15 +03:00
|
|
|
|
|
|
|
BX_SMF void JO_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JNO_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JB_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JNB_Jq(bxInstruction_c *);
|
2007-11-12 00:26:10 +03:00
|
|
|
BX_SMF void JZ_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JNZ_Jq(bxInstruction_c *);
|
2007-11-12 21:20:15 +03:00
|
|
|
BX_SMF void JBE_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JNBE_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JS_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JNS_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JP_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JNP_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JL_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JNL_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JLE_Jq(bxInstruction_c *);
|
|
|
|
BX_SMF void JNLE_Jq(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
|
|
|
BX_SMF void MOV_CqRq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_DqRq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_RqCq(bxInstruction_c *);
|
|
|
|
BX_SMF void MOV_RqDq(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void SHLD_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void SHRD_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void IMUL_GqEq(bxInstruction_c *);
|
2004-11-21 02:26:32 +03:00
|
|
|
BX_SMF void IMUL_GqEqId(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
|
|
|
BX_SMF void MOVZX_GqEb(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVZX_GqEw(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVSX_GqEb(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVSX_GqEw(bxInstruction_c *);
|
|
|
|
BX_SMF void MOVSX_GqEd(bxInstruction_c *);
|
|
|
|
|
2004-09-18 00:47:19 +04:00
|
|
|
BX_SMF void BSF_GqEq(bxInstruction_c *);
|
|
|
|
BX_SMF void BSR_GqEq(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void BT_EqGq(bxInstruction_c *);
|
2005-07-25 08:18:20 +04:00
|
|
|
BX_SMF void BT_EqIb(bxInstruction_c *);
|
|
|
|
|
2004-09-18 00:47:19 +04:00
|
|
|
BX_SMF void BTS_EqGq(bxInstruction_c *);
|
2005-07-25 08:18:20 +04:00
|
|
|
BX_SMF void BTS_EqIb(bxInstruction_c *);
|
2004-09-18 00:47:19 +04:00
|
|
|
BX_SMF void BTR_EqGq(bxInstruction_c *);
|
2005-07-25 08:18:20 +04:00
|
|
|
BX_SMF void BTR_EqIb(bxInstruction_c *);
|
2004-09-18 00:47:19 +04:00
|
|
|
BX_SMF void BTC_EqGq(bxInstruction_c *);
|
2005-07-25 08:18:20 +04:00
|
|
|
BX_SMF void BTC_EqIb(bxInstruction_c *);
|
2004-09-18 00:47:19 +04:00
|
|
|
|
2006-05-07 22:58:47 +04:00
|
|
|
BX_SMF void BSWAP_RRX(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
|
|
|
BX_SMF void ADD_EqId(bxInstruction_c *);
|
|
|
|
BX_SMF void OR_EqId(bxInstruction_c *);
|
|
|
|
BX_SMF void ADC_EqId(bxInstruction_c *);
|
|
|
|
BX_SMF void SBB_EqId(bxInstruction_c *);
|
|
|
|
BX_SMF void AND_EqId(bxInstruction_c *);
|
|
|
|
BX_SMF void SUB_EqId(bxInstruction_c *);
|
|
|
|
BX_SMF void XOR_EqId(bxInstruction_c *);
|
|
|
|
BX_SMF void CMP_EqId(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void ROL_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void ROR_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void RCL_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void RCR_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void SHL_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void SHR_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void SAR_Eq(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void TEST_EqId(bxInstruction_c *);
|
|
|
|
BX_SMF void NOT_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void NEG_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void MUL_RAXEq(bxInstruction_c *);
|
|
|
|
BX_SMF void IMUL_RAXEq(bxInstruction_c *);
|
|
|
|
BX_SMF void DIV_RAXEq(bxInstruction_c *);
|
|
|
|
BX_SMF void IDIV_RAXEq(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void INC_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void DEC_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void CALL_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void CALL64_Ep(bxInstruction_c *);
|
|
|
|
BX_SMF void JMP_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void JMP64_Ep(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH_Eq(bxInstruction_c *);
|
2005-08-08 23:56:11 +04:00
|
|
|
BX_SMF void PUSHF_Fq(bxInstruction_c *);
|
|
|
|
BX_SMF void POPF_Fq(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
|
|
|
|
BX_SMF void CMPXCHG_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void CDQE(bxInstruction_c *);
|
|
|
|
BX_SMF void CQO(bxInstruction_c *);
|
|
|
|
BX_SMF void XADD_EqGq(bxInstruction_c *);
|
|
|
|
BX_SMF void RETnear64_Iw(bxInstruction_c *);
|
|
|
|
BX_SMF void RETfar64_Iw(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void CMOV_GqEq(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void MOV_RRXIq(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH_RRX(bxInstruction_c *);
|
|
|
|
BX_SMF void POP_RRX(bxInstruction_c *);
|
|
|
|
BX_SMF void POP_Eq(bxInstruction_c *);
|
|
|
|
BX_SMF void XCHG_RRXRAX(bxInstruction_c *);
|
|
|
|
|
|
|
|
BX_SMF void PUSH64_FS(bxInstruction_c *);
|
|
|
|
BX_SMF void POP64_FS(bxInstruction_c *);
|
|
|
|
BX_SMF void PUSH64_GS(bxInstruction_c *);
|
|
|
|
BX_SMF void POP64_GS(bxInstruction_c *);
|
2002-09-25 16:54:41 +04:00
|
|
|
|
2007-04-10 00:28:15 +04:00
|
|
|
BX_SMF void LSS_GqMp(bxInstruction_c *);
|
|
|
|
BX_SMF void LFS_GqMp(bxInstruction_c *);
|
|
|
|
BX_SMF void LGS_GqMp(bxInstruction_c *);
|
|
|
|
|
2007-01-27 01:12:05 +03:00
|
|
|
BX_SMF void SGDT64_Ms(bxInstruction_c *);
|
|
|
|
BX_SMF void SIDT64_Ms(bxInstruction_c *);
|
|
|
|
BX_SMF void LGDT64_Ms(bxInstruction_c *);
|
|
|
|
BX_SMF void LIDT64_Ms(bxInstruction_c *);
|
|
|
|
|
2002-09-25 16:54:41 +04:00
|
|
|
BX_SMF void SYSCALL(bxInstruction_c *i);
|
|
|
|
BX_SMF void SYSRET(bxInstruction_c *i);
|
|
|
|
|
2002-09-25 18:09:08 +04:00
|
|
|
BX_SMF void SWAPGS(bxInstruction_c *i);
|
|
|
|
|
2002-09-27 11:01:02 +04:00
|
|
|
BX_SMF void LOOPNE64_Jb(bxInstruction_c *);
|
|
|
|
BX_SMF void LOOPE64_Jb(bxInstruction_c *);
|
|
|
|
BX_SMF void LOOP64_Jb(bxInstruction_c *);
|
|
|
|
BX_SMF void JCXZ64_Jb(bxInstruction_c *);
|
2005-05-20 00:25:16 +04:00
|
|
|
|
2005-08-05 16:47:33 +04:00
|
|
|
BX_SMF void RDTSCP(bxInstruction_c *);
|
2005-05-20 00:25:16 +04:00
|
|
|
BX_SMF void CMPXCHG16B(bxInstruction_c *);
|
2007-09-19 23:38:10 +04:00
|
|
|
|
|
|
|
BX_SMF void POPCNT_GqEq(bxInstruction_c *);
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif // #if BX_SUPPORT_X86_64
|
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void INVLPG(bxInstruction_c *);
|
|
|
|
BX_SMF void RSM(bxInstruction_c *);
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void WRMSR(bxInstruction_c *);
|
|
|
|
BX_SMF void RDTSC(bxInstruction_c *);
|
2003-10-24 22:34:16 +04:00
|
|
|
BX_SMF void RDPMC(bxInstruction_c *);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void RDMSR(bxInstruction_c *);
|
2003-01-20 23:10:31 +03:00
|
|
|
BX_SMF void SYSENTER(bxInstruction_c *);
|
|
|
|
BX_SMF void SYSEXIT(bxInstruction_c *);
|
2005-03-22 21:19:55 +03:00
|
|
|
|
2007-10-12 01:29:01 +04:00
|
|
|
BX_SMF void MONITOR(bxInstruction_c *);
|
|
|
|
BX_SMF void MWAIT(bxInstruction_c *);
|
|
|
|
|
2007-01-29 00:27:31 +03:00
|
|
|
BX_SMF unsigned fetchDecode32(Bit8u *, bxInstruction_c *, unsigned);
|
2002-09-13 04:15:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2002-09-19 23:17:20 +04:00
|
|
|
BX_SMF unsigned fetchDecode64(Bit8u *, bxInstruction_c *, unsigned);
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif
|
2006-02-23 21:23:31 +03:00
|
|
|
BX_SMF bxInstruction_c* fetchInstruction(bxInstruction_c *, bx_address);
|
2002-09-18 02:50:53 +04:00
|
|
|
BX_SMF void UndefinedOpcode(bxInstruction_c *);
|
|
|
|
BX_SMF void BxError(bxInstruction_c *i);
|
2003-03-17 03:41:01 +03:00
|
|
|
|
2007-11-13 20:30:54 +03:00
|
|
|
BX_SMF void BxResolveDummy(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
|
|
|
|
BX_SMF void BxResolve16Mod0Rm0(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod0Rm1(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod0Rm2(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod0Rm3(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod0Rm4(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod0Rm5(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod0Rm6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod0Rm7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
|
|
|
|
BX_SMF void BxResolve16Mod1or2Rm0(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod1or2Rm1(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod1or2Rm2(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod1or2Rm3(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod1or2Rm4(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod1or2Rm5(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod1or2Rm6(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve16Mod1or2Rm7(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
|
|
|
|
BX_SMF void BxResolve32Mod0Rm(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve32Mod0Base(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve32Mod0Disp(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve32Mod0BaseIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve32Mod0DispIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
|
|
|
|
BX_SMF void BxResolve32Mod1or2Rm(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve32Mod1or2Base(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve32Mod1or2BaseIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2002-09-13 04:15:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2007-11-13 20:30:54 +03:00
|
|
|
BX_SMF void BxResolve32Mod0Rip(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve64Mod0Rip(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
|
|
|
|
BX_SMF void BxResolve64Mod0Rm(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve64Mod0Base(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve64Mod0Disp(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve64Mod0BaseIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve64Mod0DispIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
|
|
|
|
BX_SMF void BxResolve64Mod1or2Rm(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve64Mod1or2Base(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void BxResolve64Mod1or2BaseIndex(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif // #if BX_SUPPORT_X86_64
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-CLASS-CPU-END>
|
2002-09-13 04:15:23 +04:00
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
#if BX_DEBUGGER
|
|
|
|
BX_SMF void dbg_take_irq(void);
|
|
|
|
BX_SMF void dbg_force_interrupt(unsigned vector);
|
|
|
|
BX_SMF void dbg_take_dma(void);
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF bx_bool dbg_set_reg(unsigned reg, Bit32u val);
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF Bit32u dbg_get_reg(unsigned reg);
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF bx_bool dbg_get_sreg(bx_dbg_sreg_t *sreg, unsigned sreg_no);
|
2006-06-11 20:40:37 +04:00
|
|
|
BX_SMF void dbg_get_tr(bx_dbg_sreg_t *sreg);
|
|
|
|
BX_SMF void dbg_get_ldtr(bx_dbg_sreg_t *sreg);
|
|
|
|
BX_SMF void dbg_get_gdtr(bx_dbg_global_sreg_t *sreg);
|
|
|
|
BX_SMF void dbg_get_idtr(bx_dbg_global_sreg_t *sreg);
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF unsigned dbg_query_pending(void);
|
2006-05-24 20:46:57 +04:00
|
|
|
BX_SMF bx_bool dbg_check_begin_instr_bpoint(void);
|
|
|
|
BX_SMF bx_bool dbg_check_end_instr_bpoint(void);
|
2001-04-10 05:04:59 +04:00
|
|
|
#endif
|
2007-03-06 20:47:18 +03:00
|
|
|
#if BX_DEBUGGER || BX_EXTERNAL_DEBUGGER || BX_GDBSTUB
|
|
|
|
BX_SMF bx_bool dbg_instruction_prolog(void);
|
|
|
|
BX_SMF bx_bool dbg_instruction_epilog(void);
|
|
|
|
#endif
|
2002-10-03 08:53:53 +04:00
|
|
|
#if BX_DEBUGGER || BX_DISASM || BX_INSTRUMENTATION || BX_GDBSTUB
|
2006-06-17 16:09:55 +04:00
|
|
|
BX_SMF bx_bool dbg_xlate_linear2phy(bx_address linear, bx_phy_address *phy);
|
2001-04-10 05:04:59 +04:00
|
|
|
#endif
|
|
|
|
BX_SMF void atexit(void);
|
2003-02-13 18:04:11 +03:00
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
// now for some ancillary functions...
|
2006-04-29 11:12:13 +04:00
|
|
|
BX_SMF void cpu_loop(Bit32u max_instr_count);
|
2002-10-05 18:51:25 +04:00
|
|
|
BX_SMF unsigned handleAsyncEvent(void);
|
2005-02-12 17:00:13 +03:00
|
|
|
BX_SMF void boundaryFetch(Bit8u *fetchPtr, unsigned remainingInPage, bxInstruction_c *i);
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF void prefetch(void);
|
2004-06-18 18:11:11 +04:00
|
|
|
BX_SMF BX_CPP_INLINE void invalidate_prefetch_q(void)
|
2004-12-14 01:26:36 +03:00
|
|
|
{
|
2002-09-19 23:17:20 +04:00
|
|
|
BX_CPU_THIS_PTR eipPageWindowSize = 0;
|
2004-12-14 01:26:36 +03:00
|
|
|
}
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF void write_virtual_checks(bx_segment_reg_t *seg, bx_address offset, unsigned length) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void read_virtual_checks(bx_segment_reg_t *seg, bx_address offset, unsigned length) BX_CPP_AttrRegparmN(3);
|
2007-10-11 01:48:46 +04:00
|
|
|
BX_SMF void execute_virtual_checks(bx_segment_reg_t *seg, bx_address offset, unsigned length) BX_CPP_AttrRegparmN(3);
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF void write_virtual_byte(unsigned seg, bx_address offset, Bit8u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void write_virtual_word(unsigned seg, bx_address offset, Bit16u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void write_virtual_dword(unsigned seg, bx_address offset, Bit32u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void write_virtual_qword(unsigned seg, bx_address offset, Bit64u *data) BX_CPP_AttrRegparmN(3);
|
2003-10-24 22:34:16 +04:00
|
|
|
BX_SMF void write_virtual_dqword(unsigned s, bx_address off, Bit8u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void write_virtual_dqword_aligned(unsigned s, bx_address off, Bit8u *data) BX_CPP_AttrRegparmN(3);
|
2004-06-18 18:11:11 +04:00
|
|
|
#if BX_SUPPORT_FPU
|
|
|
|
BX_SMF void write_virtual_tword(unsigned seg, bx_address offset, floatx80 *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
#endif
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF void read_virtual_byte(unsigned seg, bx_address offset, Bit8u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void read_virtual_word(unsigned seg, bx_address offset, Bit16u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void read_virtual_dword(unsigned seg, bx_address offset, Bit32u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void read_virtual_qword(unsigned seg, bx_address offset, Bit64u *data) BX_CPP_AttrRegparmN(3);
|
2003-10-24 22:34:16 +04:00
|
|
|
BX_SMF void read_virtual_dqword(unsigned s, bx_address off, Bit8u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void read_virtual_dqword_aligned(unsigned s, bx_address off, Bit8u *data) BX_CPP_AttrRegparmN(3);
|
2004-06-18 18:11:11 +04:00
|
|
|
#if BX_SUPPORT_FPU
|
|
|
|
BX_SMF void read_virtual_tword(unsigned seg, bx_address offset, floatx80 *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
#endif
|
2007-10-19 14:14:33 +04:00
|
|
|
// write of word/dword to new stack could happen only in legacy mode
|
|
|
|
BX_SMF void write_new_stack_word(bx_segment_reg_t *seg, bx_address offset, bx_bool user, Bit16u data);
|
|
|
|
BX_SMF void write_new_stack_dword(bx_segment_reg_t *seg, bx_address offset, bx_bool user, Bit32u data);
|
|
|
|
// write of qword to new stack could happen only in 64-bit mode
|
|
|
|
// (so stack segment is not relavant)
|
2007-10-19 16:40:19 +04:00
|
|
|
BX_SMF void write_new_stack_qword(bx_address offset, bx_bool user, Bit64u data);
|
2003-10-24 22:34:16 +04:00
|
|
|
|
2007-08-01 00:25:52 +04:00
|
|
|
#if BX_SUPPORT_MISALIGNED_SSE
|
|
|
|
|
|
|
|
#define readVirtualDQwordAligned(s, off, data) \
|
|
|
|
if (! MXCSR.get_misaligned_exception_mask()) \
|
|
|
|
read_virtual_dqword_aligned(s, off, data); \
|
|
|
|
else \
|
|
|
|
read_virtual_dqword(s, off, data);
|
|
|
|
|
|
|
|
#define writeVirtualDQwordAligned(s, off, data) \
|
|
|
|
if (! MXCSR.get_misaligned_exception_mask()) \
|
|
|
|
write_virtual_dqword_aligned(s, off, data); \
|
|
|
|
else \
|
|
|
|
write_virtual_dqword(s, off, data);
|
|
|
|
|
|
|
|
#else // BX_SUPPORT_MISALIGNED_SSE = 0
|
|
|
|
|
|
|
|
#define readVirtualDQwordAligned(s, off, data) \
|
|
|
|
read_virtual_dqword_aligned(s, off, data)
|
|
|
|
|
|
|
|
#define writeVirtualDQwordAligned(s, off, data) \
|
|
|
|
write_virtual_dqword_aligned(s, off, data)
|
|
|
|
|
|
|
|
#endif
|
2003-03-03 02:59:12 +03:00
|
|
|
|
|
|
|
BX_SMF void read_RMW_virtual_byte(unsigned seg, bx_address offset, Bit8u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void read_RMW_virtual_word(unsigned seg, bx_address offset, Bit16u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void read_RMW_virtual_dword(unsigned seg, bx_address offset, Bit32u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void read_RMW_virtual_qword(unsigned seg, bx_address offset, Bit64u *data) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void write_RMW_virtual_byte(Bit8u val8) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void write_RMW_virtual_word(Bit16u val16) BX_CPP_AttrRegparmN(1);
|
2005-08-24 00:01:54 +04:00
|
|
|
BX_SMF void write_RMW_virtual_dword(Bit32u val32) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void write_RMW_virtual_qword(Bit64u val64) BX_CPP_AttrRegparmN(1);
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2005-08-24 00:01:54 +04:00
|
|
|
#if BX_SupportGuest2HostTLB
|
|
|
|
BX_SMF Bit8u* v2h_read_byte(bx_address laddr, unsigned pl) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF Bit16u* v2h_read_word(bx_address laddr, unsigned pl) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF Bit32u* v2h_read_dword(bx_address laddr, unsigned pl) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF Bit64u* v2h_read_qword(bx_address laddr, unsigned pl) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF Bit8u* v2h_write_byte(bx_address laddr, unsigned pl) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF Bit16u* v2h_write_word(bx_address laddr, unsigned pl) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF Bit32u* v2h_write_dword(bx_address laddr, unsigned pl) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF Bit64u* v2h_write_qword(bx_address laddr, unsigned pl) BX_CPP_AttrRegparmN(2);
|
|
|
|
#endif
|
|
|
|
|
2006-05-12 21:04:19 +04:00
|
|
|
BX_SMF void branch_near32(Bit32u new_EIP) BX_CPP_AttrRegparmN(1);
|
2005-04-18 01:51:59 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
BX_SMF void branch_near64(bxInstruction_c *i) BX_CPP_AttrRegparmN(1);
|
|
|
|
#endif
|
2005-07-31 21:57:27 +04:00
|
|
|
BX_SMF void branch_far32(bx_selector_t *selector,
|
|
|
|
bx_descriptor_t *descriptor, Bit32u eip, Bit8u cpl);
|
|
|
|
BX_SMF void branch_far64(bx_selector_t *selector,
|
|
|
|
bx_descriptor_t *descriptor, bx_address rip, Bit8u cpl);
|
2005-04-18 01:51:59 +04:00
|
|
|
|
2005-07-04 21:44:08 +04:00
|
|
|
#if BX_SupportRepeatSpeedups
|
|
|
|
BX_SMF Bit32u FastRepMOVSB(bxInstruction_c *i, unsigned srcSeg, bx_address srcOff,
|
2006-05-08 00:45:42 +04:00
|
|
|
unsigned dstSeg, bx_address dstOff, Bit32u byteCount);
|
2005-07-04 21:44:08 +04:00
|
|
|
BX_SMF Bit32u FastRepMOVSW(bxInstruction_c *i, unsigned srcSeg, bx_address srcOff,
|
2006-05-08 00:45:42 +04:00
|
|
|
unsigned dstSeg, bx_address dstOff, Bit32u wordCount);
|
2005-07-04 21:44:08 +04:00
|
|
|
BX_SMF Bit32u FastRepMOVSD(bxInstruction_c *i, unsigned srcSeg, bx_address srcOff,
|
2006-05-08 00:45:42 +04:00
|
|
|
unsigned dstSeg, bx_address dstOff, Bit32u dwordCount);
|
2005-07-04 21:44:08 +04:00
|
|
|
|
|
|
|
BX_SMF Bit32u FastRepSTOSB(bxInstruction_c *i, unsigned dstSeg, bx_address dstOff,
|
2006-05-08 00:45:42 +04:00
|
|
|
Bit8u val, Bit32u byteCount);
|
2005-07-04 21:44:08 +04:00
|
|
|
BX_SMF Bit32u FastRepSTOSW(bxInstruction_c *i, unsigned dstSeg, bx_address dstOff,
|
2006-05-08 00:45:42 +04:00
|
|
|
Bit16u val, Bit32u wordCount);
|
2005-07-04 21:44:08 +04:00
|
|
|
BX_SMF Bit32u FastRepSTOSD(bxInstruction_c *i, unsigned dstSeg, bx_address dstOff,
|
2006-05-08 00:45:42 +04:00
|
|
|
Bit32u val, Bit32u dwordCount);
|
|
|
|
|
|
|
|
BX_SMF Bit32u FastRepINSW(bxInstruction_c *i, bx_address dstOff,
|
|
|
|
Bit16u port, Bit32u wordCount);
|
|
|
|
BX_SMF Bit32u FastRepOUTSW(bxInstruction_c *i, unsigned srcSeg, bx_address srcOff,
|
|
|
|
Bit16u port, Bit32u wordCount);
|
2005-07-04 21:44:08 +04:00
|
|
|
#endif
|
|
|
|
|
2007-01-05 16:40:47 +03:00
|
|
|
BX_SMF void repeat(bxInstruction_c *i, BxExecutePtr_t execute);
|
|
|
|
BX_SMF void repeat_ZFL(bxInstruction_c *i, BxExecutePtr_t execute);
|
|
|
|
|
2002-09-13 04:15:23 +04:00
|
|
|
BX_SMF void access_linear(bx_address address, unsigned length, unsigned pl,
|
2005-07-29 10:29:57 +04:00
|
|
|
unsigned rw, void *data) BX_CPP_AttrRegparmN(3);
|
2007-08-30 20:48:10 +04:00
|
|
|
BX_SMF void page_fault(unsigned fault, bx_address laddr, unsigned pl, unsigned rw, unsigned access_type);
|
|
|
|
BX_SMF bx_phy_address translate_linear(bx_address laddr, unsigned pl, unsigned rw, unsigned access_type);
|
2007-11-07 13:40:40 +03:00
|
|
|
BX_SMF BX_CPP_INLINE bx_phy_address itranslate_linear(bx_address laddr, unsigned pl)
|
|
|
|
{
|
|
|
|
return translate_linear(laddr, pl, BX_READ, CODE_ACCESS);
|
|
|
|
}
|
|
|
|
BX_SMF BX_CPP_INLINE bx_phy_address dtranslate_linear(bx_address laddr, unsigned pl, unsigned rw)
|
|
|
|
{
|
|
|
|
return translate_linear(laddr, pl, rw, DATA_ACCESS);
|
|
|
|
}
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF void TLB_flush(bx_bool invalidateGlobal);
|
2006-03-02 01:32:24 +03:00
|
|
|
BX_SMF void TLB_invlpg(bx_address laddr);
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF void TLB_init(void);
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF void set_INTR(bx_bool value);
|
2007-10-25 03:02:09 +04:00
|
|
|
BX_SMF const char *strseg(bx_segment_reg_t *seg) BX_CPP_AttrRegparmN(1);
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF void interrupt(Bit8u vector, bx_bool is_INT, bx_bool is_error_code,
|
2001-04-10 05:04:59 +04:00
|
|
|
Bit16u error_code);
|
2005-04-12 22:08:10 +04:00
|
|
|
BX_SMF void real_mode_int(Bit8u vector, bx_bool is_INT, bx_bool is_error_code,
|
|
|
|
Bit16u error_code);
|
|
|
|
BX_SMF void protected_mode_int(Bit8u vector, bx_bool is_INT, bx_bool is_error_code,
|
|
|
|
Bit16u error_code);
|
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
BX_SMF void long_mode_int(Bit8u vector, bx_bool is_INT, bx_bool is_error_code,
|
|
|
|
Bit16u error_code);
|
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
#if BX_CPU_LEVEL >= 2
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF void exception(unsigned vector, Bit16u error_code, bx_bool is_INT)
|
2002-10-07 02:08:18 +04:00
|
|
|
BX_CPP_AttrNoReturn();
|
2001-04-10 05:04:59 +04:00
|
|
|
#endif
|
2006-03-29 22:08:13 +04:00
|
|
|
BX_SMF void smram_save_state(Bit32u *smm_saved_state);
|
|
|
|
BX_SMF bx_bool smram_restore_state(const Bit32u *smm_saved_state);
|
2004-11-02 20:31:14 +03:00
|
|
|
BX_SMF int int_number(bx_segment_reg_t *seg);
|
2006-04-05 21:31:35 +04:00
|
|
|
BX_SMF void SetCR0(Bit32u val_32);
|
|
|
|
BX_SMF void CR3_change(bx_phy_address value) BX_CPP_AttrRegparmN(1);
|
|
|
|
#if BX_CPU_LEVEL >= 4
|
|
|
|
BX_SMF bx_bool SetCR4(Bit32u val_32);
|
|
|
|
#endif
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF void pagingCR0Changed(Bit32u oldCR0, Bit32u newCR0) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF void pagingCR4Changed(Bit32u oldCR4, Bit32u newCR4) BX_CPP_AttrRegparmN(2);
|
Now, when you compile with --enable-guest2host-tlb, non-paged
mode uses the notion of the guest-to-host TLB. This has the
benefit of allowing more uniform and streamlined acceleration
code in access.cc which does not have to check if CR0.PG
is set, eliminating a few instructions per guest access.
Shaved just a little off execution time, as expected.
Also, access_linear now breaks accesses which span two pages,
into two calls the the physical memory routines, when paging
is off, just like it always has for paging on. Besides
being more uniform, this allows the physical memory access
routines to known the complete data item is contained
within a single physical page, and stop reapplying the
A20ADDR() macro to pointers as it increments them.
Perhaps things can be optimized a little more now there too...
I renamed the routines to {read,write}PhysicalPage() as
a reminder that these routines now operate on data
solely within one page.
I also added a little code so that the paging module is
notified when the A20 line is tweaked, so it can dump
whatever mappings it wants to.
2002-09-05 06:31:24 +04:00
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF void reset(unsigned source);
|
2006-04-05 21:31:35 +04:00
|
|
|
BX_SMF void shutdown(void);
|
|
|
|
BX_SMF void handleCpuModeChange(void);
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF void jump_protected(bxInstruction_c *, Bit16u cs, bx_address disp) BX_CPP_AttrRegparmN(3);
|
2005-08-02 22:44:20 +04:00
|
|
|
BX_SMF void jmp_task_gate(bx_descriptor_t *gate_descriptor) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void jmp_call_gate16(bx_descriptor_t *gate_descriptor) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void jmp_call_gate32(bx_descriptor_t *gate_descriptor) BX_CPP_AttrRegparmN(1);
|
|
|
|
#if BX_SUPPORT_X86_64
|
2006-03-22 23:47:11 +03:00
|
|
|
BX_SMF void jmp_call_gate64(bx_selector_t *selector) BX_CPP_AttrRegparmN(1);
|
2005-08-02 22:44:20 +04:00
|
|
|
#endif
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF void call_protected(bxInstruction_c *, Bit16u cs, bx_address disp) BX_CPP_AttrRegparmN(3);
|
2005-08-04 23:38:51 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2006-03-22 23:47:11 +03:00
|
|
|
BX_SMF void call_gate64(bx_selector_t *selector) BX_CPP_AttrRegparmN(1);
|
2005-08-04 23:38:51 +04:00
|
|
|
#endif
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF void return_protected(bxInstruction_c *, Bit16u pop_bytes) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF void iret_protected(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
2005-08-04 01:19:11 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
BX_SMF void long_iret(bxInstruction_c *) BX_CPP_AttrRegparmN(1);
|
|
|
|
#endif
|
2006-01-09 22:34:52 +03:00
|
|
|
BX_SMF void validate_seg_reg(unsigned seg);
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF void validate_seg_regs(void);
|
2005-10-17 17:06:09 +04:00
|
|
|
BX_SMF void stack_return_to_v86(Bit32u new_eip, Bit32u raw_cs_selector, Bit32u flags32);
|
|
|
|
BX_SMF void iret16_stack_return_from_v86(bxInstruction_c *);
|
|
|
|
BX_SMF void iret32_stack_return_from_v86(bxInstruction_c *);
|
2005-03-13 23:18:37 +03:00
|
|
|
#if BX_SUPPORT_VME
|
2005-03-10 01:01:13 +03:00
|
|
|
BX_SMF void v86_redirect_interrupt(Bit32u vector);
|
2005-03-12 22:34:18 +03:00
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF void init_v8086_mode(void);
|
2005-09-03 15:39:26 +04:00
|
|
|
BX_SMF void task_switch_load_selector(bx_segment_reg_t *seg,
|
|
|
|
bx_selector_t *selector, Bit16u raw_selector, Bit8u cs_rpl);
|
2005-08-28 21:37:37 +04:00
|
|
|
BX_SMF void task_switch(bx_selector_t *selector, bx_descriptor_t *descriptor,
|
|
|
|
unsigned source, Bit32u dword1, Bit32u dword2);
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF void get_SS_ESP_from_TSS(unsigned pl, Bit16u *ss, Bit32u *esp);
|
2002-09-13 04:15:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
BX_SMF void get_RSP_from_TSS(unsigned pl, Bit64u *rsp);
|
|
|
|
#endif
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF void write_flags(Bit16u flags, bx_bool change_IOPL, bx_bool change_IF) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void writeEFlags(Bit32u eflags, Bit32u changeMask) BX_CPP_AttrRegparmN(2); // Newer variant.
|
2004-06-18 18:11:11 +04:00
|
|
|
#if BX_SUPPORT_FPU || BX_SUPPORT_SSE >= 1
|
|
|
|
BX_SMF void write_eflags_fpu_compare(int float_relation);
|
|
|
|
#endif
|
2005-06-16 21:25:04 +04:00
|
|
|
BX_SMF Bit32u force_flags(void);
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF Bit16u read_flags(void);
|
|
|
|
BX_SMF Bit32u read_eflags(void);
|
|
|
|
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF Bit8u inp8(Bit16u addr) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void outp8(Bit16u addr, Bit8u value) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF Bit16u inp16(Bit16u addr) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void outp16(Bit16u addr, Bit16u value) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF Bit32u inp32(Bit16u addr) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF void outp32(Bit16u addr, Bit32u value) BX_CPP_AttrRegparmN(2);
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF bx_bool allow_io(Bit16u addr, unsigned len);
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF void parse_selector(Bit16u raw_selector, bx_selector_t *selector) BX_CPP_AttrRegparmN(2);
|
|
|
|
BX_SMF void parse_descriptor(Bit32u dword1, Bit32u dword2, bx_descriptor_t *temp) BX_CPP_AttrRegparmN(3);
|
2006-04-25 19:35:26 +04:00
|
|
|
BX_SMF Bit8u ar_byte(const bx_descriptor_t *d) BX_CPP_AttrRegparmN(1);
|
2006-05-27 18:02:34 +04:00
|
|
|
BX_SMF void set_ar_byte(bx_descriptor_t *d, Bit8u ar_byte) BX_CPP_AttrRegparmN(2);
|
2006-04-25 19:35:26 +04:00
|
|
|
BX_SMF Bit32u get_descriptor_l(const bx_descriptor_t *) BX_CPP_AttrRegparmN(1);
|
|
|
|
BX_SMF Bit32u get_descriptor_h(const bx_descriptor_t *) BX_CPP_AttrRegparmN(1);
|
2006-04-23 21:16:27 +04:00
|
|
|
BX_SMF Bit16u get_segment_ar_data(const bx_descriptor_t *d) BX_CPP_AttrRegparmN(1);
|
2006-04-05 21:31:35 +04:00
|
|
|
BX_SMF bx_bool set_segment_ar_data(bx_segment_reg_t *seg, Bit16u raw_selector,
|
|
|
|
bx_address base, Bit32u limit, Bit16u ar_data);
|
2005-08-02 22:44:20 +04:00
|
|
|
BX_SMF void check_cs(bx_descriptor_t *descriptor, Bit16u cs_raw, Bit8u check_rpl, Bit8u check_cpl);
|
2007-10-19 02:44:39 +04:00
|
|
|
// the basic assumption of the code that load_cs and load_ss cannot fail !
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF void load_cs(bx_selector_t *selector, bx_descriptor_t *descriptor, Bit8u cpl) BX_CPP_AttrRegparmN(3);
|
|
|
|
BX_SMF void load_ss(bx_selector_t *selector, bx_descriptor_t *descriptor, Bit8u cpl) BX_CPP_AttrRegparmN(3);
|
2006-03-22 23:47:11 +03:00
|
|
|
BX_SMF void fetch_raw_descriptor(const bx_selector_t *selector,
|
2005-12-12 22:44:06 +03:00
|
|
|
Bit32u *dword1, Bit32u *dword2, unsigned exception) BX_CPP_AttrRegparmN(3);
|
2006-03-22 23:47:11 +03:00
|
|
|
BX_SMF bx_bool fetch_raw_descriptor2(const bx_selector_t *selector,
|
2005-08-02 22:44:20 +04:00
|
|
|
Bit32u *dword1, Bit32u *dword2) BX_CPP_AttrRegparmN(3);
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF void load_seg_reg(bx_segment_reg_t *seg, Bit16u new_value) BX_CPP_AttrRegparmN(2);
|
2002-09-24 20:39:33 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2006-03-22 23:47:11 +03:00
|
|
|
BX_SMF void fetch_raw_descriptor64(const bx_selector_t *selector,
|
2005-12-12 22:44:06 +03:00
|
|
|
Bit32u *dword1, Bit32u *dword2, Bit32u *dword3, unsigned exception_no);
|
2007-03-15 00:15:15 +03:00
|
|
|
BX_SMF void loadSRegLMNominal(unsigned seg, unsigned selector, unsigned dpl);
|
2002-09-24 20:39:33 +04:00
|
|
|
#endif
|
2007-10-19 02:44:39 +04:00
|
|
|
BX_SMF void push_16(Bit16u value16);
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF void push_32(Bit32u value32);
|
2002-09-13 04:15:23 +04:00
|
|
|
BX_SMF void push_64(Bit64u value64);
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF void pop_16(Bit16u *value16_ptr);
|
|
|
|
BX_SMF void pop_32(Bit32u *value32_ptr);
|
2002-09-13 04:15:23 +04:00
|
|
|
BX_SMF void pop_64(Bit64u *value64_ptr);
|
2003-03-03 02:59:12 +03:00
|
|
|
BX_SMF bx_bool can_push(bx_descriptor_t *descriptor, Bit32u esp, Bit32u bytes) BX_CPP_AttrRegparmN(3);
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF bx_bool can_pop(Bit32u bytes);
|
2005-02-17 00:27:21 +03:00
|
|
|
BX_SMF void decrementESPForPush(unsigned nBytes, Bit32u *eSP);
|
2001-04-10 05:04:59 +04:00
|
|
|
BX_SMF void sanity_checks(void);
|
2006-04-25 18:42:57 +04:00
|
|
|
BX_SMF void assert_checks(void);
|
2006-02-28 22:50:08 +03:00
|
|
|
BX_SMF void enter_system_management_mode(void);
|
2006-04-08 00:47:32 +04:00
|
|
|
BX_SMF void deliver_NMI(void);
|
|
|
|
BX_SMF void deliver_SMI(void);
|
2005-03-31 00:53:04 +04:00
|
|
|
BX_SMF void debug(bx_address offset);
|
2005-12-19 20:58:08 +03:00
|
|
|
#if BX_DISASM
|
|
|
|
BX_SMF void debug_disasm_instruction(bx_address offset);
|
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
#if BX_X86_DEBUGGER
|
|
|
|
// x86 hardware debug support
|
2006-05-13 16:49:45 +04:00
|
|
|
BX_SMF Bit32u hwdebug_compare(bx_address laddr, unsigned size,
|
2001-04-10 05:04:59 +04:00
|
|
|
unsigned opa, unsigned opb);
|
|
|
|
#endif
|
|
|
|
|
2004-12-17 13:50:49 +03:00
|
|
|
BX_SMF Bit32u get_cpu_version_information(void);
|
|
|
|
BX_SMF Bit32u get_extended_cpuid_features(void);
|
|
|
|
BX_SMF Bit32u get_std_cpuid_features(void);
|
2007-10-12 23:30:51 +04:00
|
|
|
BX_SMF void set_cpuid_defaults(void);
|
2004-12-17 13:50:49 +03:00
|
|
|
|
2005-11-27 00:36:51 +03:00
|
|
|
BX_SMF BX_CPP_INLINE unsigned which_cpu(void) { return BX_CPU_THIS_PTR bx_cpuid; }
|
|
|
|
BX_SMF BX_CPP_INLINE const bx_gen_reg_t *get_gen_regfile() { return BX_CPU_THIS_PTR gen_reg; }
|
|
|
|
|
|
|
|
BX_CPP_INLINE Bit8u get_CPL(void) { return (BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].selector.rpl); }
|
|
|
|
|
|
|
|
BX_CPP_INLINE Bit8u get_reg8l(unsigned reg);
|
|
|
|
BX_CPP_INLINE Bit8u get_reg8h(unsigned reg);
|
2006-01-31 22:45:34 +03:00
|
|
|
BX_CPP_INLINE void set_reg8l(unsigned reg, Bit8u val);
|
|
|
|
BX_CPP_INLINE void set_reg8h(unsigned reg, Bit8u val);
|
2005-11-27 00:36:51 +03:00
|
|
|
|
|
|
|
BX_CPP_INLINE bx_address get_ip(void);
|
2006-01-31 22:45:34 +03:00
|
|
|
BX_CPP_INLINE void set_ip(bx_address ip);
|
2005-11-27 00:36:51 +03:00
|
|
|
|
|
|
|
BX_CPP_INLINE Bit16u get_reg16(unsigned reg);
|
2006-01-31 22:45:34 +03:00
|
|
|
BX_CPP_INLINE void set_reg16(unsigned reg, Bit16u val);
|
2006-05-24 20:46:57 +04:00
|
|
|
BX_CPP_INLINE Bit32u get_reg32(unsigned reg);
|
2006-01-31 22:45:34 +03:00
|
|
|
BX_CPP_INLINE void set_reg32(unsigned reg, Bit32u val);
|
2005-11-27 00:36:51 +03:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
BX_CPP_INLINE Bit64u get_reg64(unsigned reg);
|
2006-01-31 22:45:34 +03:00
|
|
|
BX_CPP_INLINE void set_reg64(unsigned reg, Bit64u val);
|
2005-11-27 00:36:51 +03:00
|
|
|
#endif
|
|
|
|
|
|
|
|
BX_CPP_INLINE bx_address get_segment_base(unsigned seg);
|
|
|
|
|
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
BX_CPP_INLINE Bit32u get_EFER(void);
|
|
|
|
#endif
|
2002-09-05 23:46:20 +04:00
|
|
|
|
2002-09-22 22:22:24 +04:00
|
|
|
DECLARE_EFLAG_ACCESSOR (ID, 21)
|
2005-02-04 01:08:34 +03:00
|
|
|
DECLARE_EFLAG_ACCESSOR (VIP, 20)
|
|
|
|
DECLARE_EFLAG_ACCESSOR (VIF, 19)
|
2007-08-01 00:25:52 +04:00
|
|
|
#if BX_SUPPORT_ALIGNMENT_CHECK
|
|
|
|
DECLARE_EFLAG_ACCESSOR_AC( 18)
|
|
|
|
#else
|
2002-09-22 22:22:24 +04:00
|
|
|
DECLARE_EFLAG_ACCESSOR (AC, 18)
|
2007-08-01 00:25:52 +04:00
|
|
|
#endif
|
2002-09-22 22:22:24 +04:00
|
|
|
DECLARE_EFLAG_ACCESSOR_VM( 17)
|
|
|
|
DECLARE_EFLAG_ACCESSOR (RF, 16)
|
|
|
|
DECLARE_EFLAG_ACCESSOR (NT, 14)
|
|
|
|
DECLARE_EFLAG_ACCESSOR_IOPL( 12)
|
2007-08-01 00:25:52 +04:00
|
|
|
DECLARE_EFLAG_ACCESSOR (DF, 10)
|
2002-09-22 22:22:24 +04:00
|
|
|
DECLARE_EFLAG_ACCESSOR (IF, 9)
|
|
|
|
DECLARE_EFLAG_ACCESSOR (TF, 8)
|
2002-09-12 22:10:46 +04:00
|
|
|
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF BX_CPP_INLINE bx_bool real_mode(void);
|
2006-02-14 22:00:08 +03:00
|
|
|
BX_SMF BX_CPP_INLINE bx_bool smm_mode(void);
|
2002-10-25 15:44:41 +04:00
|
|
|
BX_SMF BX_CPP_INLINE bx_bool protected_mode(void);
|
|
|
|
BX_SMF BX_CPP_INLINE bx_bool v8086_mode(void);
|
2006-10-04 23:08:40 +04:00
|
|
|
BX_SMF BX_CPP_INLINE bx_bool long_mode(void);
|
2005-12-14 23:05:40 +03:00
|
|
|
BX_SMF BX_CPP_INLINE unsigned get_cpu_mode(void);
|
2004-09-16 01:48:57 +04:00
|
|
|
|
2006-01-21 15:06:03 +03:00
|
|
|
#if BX_CPU_LEVEL >= 5
|
|
|
|
BX_SMF Bit64u get_TSC();
|
|
|
|
BX_SMF void set_TSC(Bit32u tsc);
|
|
|
|
#endif
|
|
|
|
|
2005-03-22 21:19:55 +03:00
|
|
|
#if BX_SUPPORT_FPU
|
|
|
|
BX_SMF void print_state_FPU(void);
|
|
|
|
BX_SMF void prepareFPU(bxInstruction_c *i, bx_bool = 1, bx_bool = 1);
|
|
|
|
BX_SMF void FPU_check_pending_exceptions(void);
|
|
|
|
BX_SMF void FPU_stack_underflow(int stnr, int pop_stack = 0);
|
|
|
|
BX_SMF void FPU_stack_overflow(void);
|
|
|
|
BX_SMF int FPU_exception(int exception);
|
2006-03-29 22:08:13 +04:00
|
|
|
BX_SMF int fpu_save_environment(bxInstruction_c *i);
|
|
|
|
BX_SMF int fpu_load_environment(bxInstruction_c *i);
|
2005-03-22 21:19:55 +03:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#if BX_SUPPORT_MMX || BX_SUPPORT_SSE
|
|
|
|
BX_SMF void prepareMMX(void);
|
|
|
|
BX_SMF void prepareFPU2MMX(void); /* cause transition from FPU to MMX technology state */
|
|
|
|
BX_SMF void print_state_MMX(void);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if BX_SUPPORT_SSE
|
|
|
|
BX_SMF void prepareSSE(void);
|
|
|
|
BX_SMF void check_exceptionsSSE(int);
|
2006-01-24 22:03:55 +03:00
|
|
|
BX_SMF void print_state_SSE(void);
|
2005-03-22 21:19:55 +03:00
|
|
|
#endif
|
2007-11-01 21:03:48 +03:00
|
|
|
|
|
|
|
#if BX_SUPPORT_MONITOR_MWAIT
|
|
|
|
BX_SMF bx_bool is_monitor(bx_phy_address addr, unsigned len);
|
|
|
|
BX_SMF void check_monitor(bx_phy_address addr, unsigned len);
|
|
|
|
#endif
|
2004-09-16 01:48:57 +04:00
|
|
|
};
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-07-30 00:15:19 +04:00
|
|
|
#if BX_SUPPORT_ICACHE
|
2002-09-19 23:17:20 +04:00
|
|
|
|
2006-04-05 21:31:35 +04:00
|
|
|
BX_CPP_INLINE void BX_CPU_C::updateFetchModeMask(void)
|
2004-10-21 22:20:40 +04:00
|
|
|
{
|
2006-05-20 00:04:33 +04:00
|
|
|
fetchModeMask =
|
2002-09-19 23:17:20 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2006-05-20 00:04:33 +04:00
|
|
|
((BX_CPU_THIS_PTR cpu_mode == BX_MODE_LONG_64)<<30) |
|
2002-09-19 23:17:20 +04:00
|
|
|
#endif
|
2006-05-20 00:04:33 +04:00
|
|
|
(BX_CPU_THIS_PTR sregs[BX_SEG_REG_CS].cache.u.segment.d_b << 31);
|
2004-10-21 22:20:40 +04:00
|
|
|
}
|
2002-09-19 23:17:20 +04:00
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
#if BX_X86_DEBUGGER
|
|
|
|
#define BX_HWDebugInstruction 0x00
|
|
|
|
#define BX_HWDebugMemW 0x01
|
|
|
|
#define BX_HWDebugIO 0x02
|
|
|
|
#define BX_HWDebugMemRW 0x03
|
|
|
|
#endif
|
|
|
|
|
2005-11-27 00:36:51 +03:00
|
|
|
#include <assert.h>
|
|
|
|
|
|
|
|
BX_CPP_INLINE bx_address BX_CPU_C::get_segment_base(unsigned seg)
|
|
|
|
{
|
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
if ((BX_CPU_THIS_PTR cpu_mode == BX_MODE_LONG_64) && (seg < BX_SEG_REG_FS))
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
return (BX_CPU_THIS_PTR sregs[seg].cache.u.segment.base);
|
|
|
|
}
|
|
|
|
|
|
|
|
BX_CPP_INLINE Bit8u BX_CPU_C::get_reg8l(unsigned reg)
|
|
|
|
{
|
|
|
|
assert(reg < BX_GENERAL_REGISTERS);
|
|
|
|
return (BX_CPU_THIS_PTR gen_reg[reg].word.byte.rl);
|
|
|
|
}
|
|
|
|
|
2006-01-31 22:45:34 +03:00
|
|
|
BX_CPP_INLINE void BX_CPU_C::set_reg8l(unsigned reg, Bit8u val)
|
2005-11-27 00:36:51 +03:00
|
|
|
{
|
|
|
|
assert(reg < BX_GENERAL_REGISTERS);
|
|
|
|
BX_CPU_THIS_PTR gen_reg[reg].word.byte.rl = val;
|
|
|
|
}
|
|
|
|
|
|
|
|
BX_CPP_INLINE Bit8u BX_CPU_C::get_reg8h(unsigned reg)
|
2004-12-17 01:21:35 +03:00
|
|
|
{
|
2005-11-27 00:36:51 +03:00
|
|
|
assert(reg < BX_GENERAL_REGISTERS);
|
|
|
|
return (BX_CPU_THIS_PTR gen_reg[reg].word.byte.rh);
|
2003-02-13 18:51:22 +03:00
|
|
|
}
|
2003-02-13 18:04:11 +03:00
|
|
|
|
2006-01-31 22:45:34 +03:00
|
|
|
BX_CPP_INLINE void BX_CPU_C::set_reg8h(unsigned reg, Bit8u val)
|
2005-11-27 00:36:51 +03:00
|
|
|
{
|
|
|
|
assert(reg < BX_GENERAL_REGISTERS);
|
|
|
|
BX_CPU_THIS_PTR gen_reg[reg].word.byte.rh = val;
|
|
|
|
}
|
2002-09-13 05:09:10 +04:00
|
|
|
|
2006-01-31 22:45:34 +03:00
|
|
|
#if BX_SUPPORT_X86_64
|
2005-11-27 00:36:51 +03:00
|
|
|
BX_CPP_INLINE bx_address BX_CPU_C::get_ip(void)
|
2004-12-17 01:21:35 +03:00
|
|
|
{
|
2007-10-19 02:44:39 +04:00
|
|
|
return (BX_CPU_THIS_PTR eip_reg.rip);
|
2006-01-31 22:45:34 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
BX_CPP_INLINE void BX_CPU_C::set_ip(bx_address ip)
|
|
|
|
{
|
2007-10-19 02:44:39 +04:00
|
|
|
BX_CPU_THIS_PTR eip_reg.rip = ip;
|
2006-01-31 22:45:34 +03:00
|
|
|
}
|
2005-11-27 00:36:51 +03:00
|
|
|
#else
|
2006-01-31 22:45:34 +03:00
|
|
|
BX_CPP_INLINE bx_address BX_CPU_C::get_ip(void)
|
|
|
|
{
|
2007-10-19 02:44:39 +04:00
|
|
|
return (BX_CPU_THIS_PTR eip_reg.dword.eip);
|
2006-01-31 22:45:34 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
BX_CPP_INLINE void BX_CPU_C::set_ip(bx_address ip)
|
|
|
|
{
|
2007-10-19 02:44:39 +04:00
|
|
|
BX_CPU_THIS_PTR eip_reg.dword.eip = ip;
|
2005-09-29 21:32:32 +04:00
|
|
|
}
|
2006-01-31 22:45:34 +03:00
|
|
|
#endif
|
2005-09-29 21:32:32 +04:00
|
|
|
|
2005-11-27 00:36:51 +03:00
|
|
|
BX_CPP_INLINE Bit16u BX_CPU_C::get_reg16(unsigned reg)
|
|
|
|
{
|
|
|
|
assert(reg < BX_GENERAL_REGISTERS);
|
|
|
|
return (BX_CPU_THIS_PTR gen_reg[reg].word.rx);
|
|
|
|
}
|
|
|
|
|
2006-01-31 22:45:34 +03:00
|
|
|
BX_CPP_INLINE void BX_CPU_C::set_reg16(unsigned reg, Bit16u val)
|
2005-11-27 00:36:51 +03:00
|
|
|
{
|
|
|
|
assert(reg < BX_GENERAL_REGISTERS);
|
|
|
|
BX_CPU_THIS_PTR gen_reg[reg].word.rx = val;
|
|
|
|
}
|
|
|
|
|
|
|
|
BX_CPP_INLINE Bit32u BX_CPU_C::get_reg32(unsigned reg)
|
|
|
|
{
|
|
|
|
assert(reg < BX_GENERAL_REGISTERS);
|
|
|
|
return (BX_CPU_THIS_PTR gen_reg[reg].dword.erx);
|
|
|
|
}
|
|
|
|
|
2006-01-31 22:45:34 +03:00
|
|
|
BX_CPP_INLINE void BX_CPU_C::set_reg32(unsigned reg, Bit32u val)
|
2005-11-27 00:36:51 +03:00
|
|
|
{
|
|
|
|
assert(reg < BX_GENERAL_REGISTERS);
|
|
|
|
BX_CPU_THIS_PTR gen_reg[reg].dword.erx = val;
|
|
|
|
}
|
|
|
|
|
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
BX_CPP_INLINE Bit64u BX_CPU_C::get_reg64(unsigned reg)
|
|
|
|
{
|
|
|
|
assert(reg < BX_GENERAL_REGISTERS);
|
|
|
|
return (BX_CPU_THIS_PTR gen_reg[reg].rrx);
|
|
|
|
}
|
|
|
|
|
2006-01-31 22:45:34 +03:00
|
|
|
BX_CPP_INLINE void BX_CPU_C::set_reg64(unsigned reg, Bit64u val)
|
2005-11-27 00:36:51 +03:00
|
|
|
{
|
|
|
|
assert(reg < BX_GENERAL_REGISTERS);
|
|
|
|
BX_CPU_THIS_PTR gen_reg[reg].rrx = val;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2005-09-29 21:32:32 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
BX_CPP_INLINE Bit32u BX_CPU_C::get_EFER(void)
|
|
|
|
{
|
2007-09-11 00:47:08 +04:00
|
|
|
return (BX_CPU_THIS_PTR efer.sce << 0) |
|
|
|
|
(BX_CPU_THIS_PTR efer.lme << 8) |
|
|
|
|
(BX_CPU_THIS_PTR efer.lma << 10) |
|
|
|
|
(BX_CPU_THIS_PTR efer.nxe << 11) |
|
|
|
|
(BX_CPU_THIS_PTR efer.ffxsr << 14);
|
2005-09-29 21:32:32 +04:00
|
|
|
}
|
|
|
|
#endif
|
2002-09-05 23:46:20 +04:00
|
|
|
|
2004-12-17 01:21:35 +03:00
|
|
|
BX_CPP_INLINE bx_bool BX_CPU_C::real_mode(void)
|
|
|
|
{
|
2005-03-15 22:00:04 +03:00
|
|
|
return (BX_CPU_THIS_PTR cpu_mode == BX_MODE_IA32_REAL);
|
2003-02-13 18:04:11 +03:00
|
|
|
}
|
2002-09-18 02:50:53 +04:00
|
|
|
|
2006-02-14 22:00:08 +03:00
|
|
|
BX_CPP_INLINE bx_bool BX_CPU_C::smm_mode(void)
|
|
|
|
{
|
2006-02-14 23:03:14 +03:00
|
|
|
return (BX_CPU_THIS_PTR in_smm);
|
2006-02-14 22:00:08 +03:00
|
|
|
}
|
|
|
|
|
2004-12-17 01:21:35 +03:00
|
|
|
BX_CPP_INLINE bx_bool BX_CPU_C::v8086_mode(void)
|
|
|
|
{
|
2005-03-15 22:00:04 +03:00
|
|
|
return (BX_CPU_THIS_PTR cpu_mode == BX_MODE_IA32_V8086);
|
2003-02-13 18:04:11 +03:00
|
|
|
}
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-12-17 01:21:35 +03:00
|
|
|
BX_CPP_INLINE bx_bool BX_CPU_C::protected_mode(void)
|
|
|
|
{
|
2005-03-30 01:37:06 +04:00
|
|
|
return (BX_CPU_THIS_PTR cpu_mode >= BX_MODE_IA32_PROTECTED);
|
2003-02-13 18:04:11 +03:00
|
|
|
}
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2006-10-04 23:08:40 +04:00
|
|
|
BX_CPP_INLINE unsigned BX_CPU_C::long_mode(void)
|
|
|
|
{
|
|
|
|
#if BX_SUPPORT_X86_64
|
2007-09-11 00:47:08 +04:00
|
|
|
return BX_CPU_THIS_PTR efer.lma;
|
2006-10-04 23:08:40 +04:00
|
|
|
#else
|
|
|
|
return 0;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2005-12-14 23:05:40 +03:00
|
|
|
BX_CPP_INLINE unsigned BX_CPU_C::get_cpu_mode(void)
|
|
|
|
{
|
|
|
|
return (BX_CPU_THIS_PTR cpu_mode);
|
|
|
|
}
|
|
|
|
|
2002-10-25 15:44:41 +04:00
|
|
|
BOCHSAPI extern const bx_bool bx_parity_lookup[256];
|
2002-09-08 08:08:14 +04:00
|
|
|
|
2005-09-29 21:32:32 +04:00
|
|
|
BX_CPP_INLINE void BX_CPU_C::set_PF_base(Bit8u val)
|
|
|
|
{
|
2005-06-15 00:55:57 +04:00
|
|
|
BX_CPU_THIS_PTR lf_flags_status &= 0xffff0f;
|
|
|
|
val = bx_parity_lookup[val]; // Always returns 0 or 1.
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 &= ~(1<<2);
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 |= val<<2;
|
|
|
|
}
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-08-12 01:26:23 +04:00
|
|
|
// *******************
|
|
|
|
// OSZAPC
|
|
|
|
// *******************
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-08-12 01:26:23 +04:00
|
|
|
/* op1, op2, result */
|
|
|
|
#define SET_FLAGS_OSZAPC_SIZE(size, lf_op1, lf_op2, lf_result, ins) { \
|
2005-06-15 00:55:57 +04:00
|
|
|
BX_CPU_THIS_PTR oszapc.op1##size = lf_op1; \
|
|
|
|
BX_CPU_THIS_PTR oszapc.op2##size = lf_op2; \
|
|
|
|
BX_CPU_THIS_PTR oszapc.result##size = lf_result; \
|
|
|
|
BX_CPU_THIS_PTR oszapc.instr = ins; \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status = BX_LF_MASK_OSZAPC; \
|
2004-08-12 01:26:23 +04:00
|
|
|
}
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_8(op1, op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_SIZE(_8, op1, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_16(op1, op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_SIZE(_16, op1, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_32(op1, op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_SIZE(_32, op1, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
#define SET_FLAGS_OSZAPC_64(op1, op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_SIZE(_64, op1, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-08-12 01:26:23 +04:00
|
|
|
/* op1 and result only */
|
|
|
|
#define SET_FLAGS_OSZAPC_S1_SIZE(size, lf_op1, lf_result, ins) { \
|
2005-06-15 00:55:57 +04:00
|
|
|
BX_CPU_THIS_PTR oszapc.op1##size = lf_op1; \
|
|
|
|
BX_CPU_THIS_PTR oszapc.result##size = lf_result; \
|
|
|
|
BX_CPU_THIS_PTR oszapc.instr = ins; \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status = BX_LF_MASK_OSZAPC; \
|
2004-08-12 01:26:23 +04:00
|
|
|
}
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_S1_8(op1, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S1_SIZE(_8, op1, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_S1_16(op1, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S1_SIZE(_16, op1, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_S1_32(op1, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S1_SIZE(_32, op1, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
#define SET_FLAGS_OSZAPC_S1_64(op1, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S1_SIZE(_64, op1, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-08-12 01:26:23 +04:00
|
|
|
/* op2 and result only */
|
|
|
|
#define SET_FLAGS_OSZAPC_S2_SIZE(size, lf_op2, lf_result, ins) { \
|
2005-06-15 00:55:57 +04:00
|
|
|
BX_CPU_THIS_PTR oszapc.op2##size = lf_op2; \
|
|
|
|
BX_CPU_THIS_PTR oszapc.result##size = lf_result; \
|
|
|
|
BX_CPU_THIS_PTR oszapc.instr = ins; \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status = BX_LF_MASK_OSZAPC; \
|
2004-08-12 01:26:23 +04:00
|
|
|
}
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_S2_8(op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S2_SIZE(_8, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_S2_16(op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S2_SIZE(_16, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_S2_32(op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S2_SIZE(_32, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
#define SET_FLAGS_OSZAPC_S2_64(op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S2_SIZE(_64, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* op1 and op2 only */
|
|
|
|
#define SET_FLAGS_OSZAPC_S1S2_SIZE(size, lf_op1, lf_op2, ins) { \
|
2005-06-15 00:55:57 +04:00
|
|
|
BX_CPU_THIS_PTR oszapc.op1##size = lf_op1; \
|
|
|
|
BX_CPU_THIS_PTR oszapc.op2##size = lf_op2; \
|
|
|
|
BX_CPU_THIS_PTR oszapc.instr = ins; \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status = BX_LF_MASK_OSZAPC; \
|
2004-08-12 01:26:23 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
#define SET_FLAGS_OSZAPC_S1S2_8(op1, op2, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S1S2_SIZE(_8, op1, op2, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_S1S2_16(op1, op2, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S1S2_SIZE(_16, op1, op2, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_S1S2_32(op1, op2, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S1S2_SIZE(_32, op1, op2, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
#define SET_FLAGS_OSZAPC_S1S2_64(op1, op2, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_S1S2_SIZE(_64, op1, op2, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-08-12 01:26:23 +04:00
|
|
|
/* result only */
|
|
|
|
#define SET_FLAGS_OSZAPC_RESULT_SIZE(size, lf_result, ins) { \
|
2005-06-15 00:55:57 +04:00
|
|
|
BX_CPU_THIS_PTR oszapc.result##size = lf_result; \
|
|
|
|
BX_CPU_THIS_PTR oszapc.instr = ins; \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status = BX_LF_MASK_OSZAPC; \
|
2004-08-12 01:26:23 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
#define SET_FLAGS_OSZAPC_RESULT_8(result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_RESULT_SIZE(_8, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_RESULT_16(result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_RESULT_SIZE(_16, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAPC_RESULT_32(result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_RESULT_SIZE(_32, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
#define SET_FLAGS_OSZAPC_RESULT_64(result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAPC_RESULT_SIZE(_64, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#endif
|
2002-09-13 04:15:23 +04:00
|
|
|
|
2004-08-12 01:26:23 +04:00
|
|
|
// *******************
|
|
|
|
// OSZAP
|
|
|
|
// *******************
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-08-15 00:00:24 +04:00
|
|
|
/* op1, op2, result */
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAP_SIZE(size, lf_op1, lf_op2, lf_result, ins) { \
|
2005-06-15 00:55:57 +04:00
|
|
|
BX_CPU_THIS_PTR oszap.op1##size = lf_op1; \
|
|
|
|
BX_CPU_THIS_PTR oszap.op2##size = lf_op2; \
|
|
|
|
BX_CPU_THIS_PTR oszap.result##size = lf_result; \
|
|
|
|
BX_CPU_THIS_PTR oszap.instr = ins; \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status = (BX_CPU_THIS_PTR lf_flags_status & 0x00000f) | BX_LF_MASK_OSZAP; \
|
2004-08-12 01:26:23 +04:00
|
|
|
}
|
2002-09-13 04:15:23 +04:00
|
|
|
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAP_8(op1, op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAP_SIZE(_8, op1, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAP_16(op1, op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAP_SIZE(_16, op1, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OSZAP_32(op1, op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAP_SIZE(_32, op1, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
#define SET_FLAGS_OSZAP_64(op1, op2, result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAP_SIZE(_64, op1, op2, result, ins)
|
2004-08-12 01:26:23 +04:00
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2004-08-15 00:00:24 +04:00
|
|
|
/* result only */
|
|
|
|
#define SET_FLAGS_OSZAP_RESULT_SIZE(size, lf_result, ins) { \
|
2005-06-15 00:55:57 +04:00
|
|
|
BX_CPU_THIS_PTR oszap.result##size = lf_result; \
|
|
|
|
BX_CPU_THIS_PTR oszap.instr = ins; \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status = (BX_CPU_THIS_PTR lf_flags_status & 0x00000f) | BX_LF_MASK_OSZAP; \
|
2004-08-15 00:00:24 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
#define SET_FLAGS_OSZAP_RESULT_8(result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAP_RESULT_SIZE(_8, result, ins)
|
2004-08-15 00:00:24 +04:00
|
|
|
#define SET_FLAGS_OSZAP_RESULT_16(result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAP_RESULT_SIZE(_16, result, ins)
|
2004-08-15 00:00:24 +04:00
|
|
|
#define SET_FLAGS_OSZAP_RESULT_32(result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAP_RESULT_SIZE(_32, result, ins)
|
2004-08-15 00:00:24 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
|
|
|
#define SET_FLAGS_OSZAP_RESULT_64(result, ins) \
|
2005-06-15 00:55:57 +04:00
|
|
|
SET_FLAGS_OSZAP_RESULT_SIZE(_64, result, ins)
|
2004-08-15 00:00:24 +04:00
|
|
|
#endif
|
|
|
|
|
2005-02-04 01:08:34 +03:00
|
|
|
IMPLEMENT_EFLAG_ACCESSOR (ID, 21)
|
|
|
|
IMPLEMENT_EFLAG_ACCESSOR (VIP, 20)
|
|
|
|
IMPLEMENT_EFLAG_ACCESSOR (VIF, 19)
|
2007-08-01 00:25:52 +04:00
|
|
|
#if BX_SUPPORT_ALIGNMENT_CHECK
|
|
|
|
IMPLEMENT_EFLAG_ACCESSOR_AC( 18)
|
|
|
|
#else
|
2005-02-04 01:08:34 +03:00
|
|
|
IMPLEMENT_EFLAG_ACCESSOR (AC, 18)
|
2007-08-01 00:25:52 +04:00
|
|
|
#endif
|
2005-02-04 01:08:34 +03:00
|
|
|
IMPLEMENT_EFLAG_ACCESSOR_VM( 17)
|
|
|
|
IMPLEMENT_EFLAG_ACCESSOR (RF, 16)
|
|
|
|
IMPLEMENT_EFLAG_ACCESSOR (NT, 14)
|
|
|
|
IMPLEMENT_EFLAG_ACCESSOR_IOPL( 12)
|
2007-08-01 00:25:52 +04:00
|
|
|
IMPLEMENT_EFLAG_ACCESSOR (DF, 10)
|
2005-02-04 01:08:34 +03:00
|
|
|
IMPLEMENT_EFLAG_ACCESSOR (IF, 9)
|
|
|
|
IMPLEMENT_EFLAG_ACCESSOR (TF, 8)
|
2002-09-12 22:10:46 +04:00
|
|
|
|
2005-09-29 21:32:32 +04:00
|
|
|
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-DEFINES-DECODE-START>
|
2004-08-12 01:26:23 +04:00
|
|
|
//
|
|
|
|
// For decoding...
|
|
|
|
//
|
2001-04-10 05:04:59 +04:00
|
|
|
|
|
|
|
#define BX_TASK_FROM_JUMP 10
|
|
|
|
#define BX_TASK_FROM_CALL_OR_INT 11
|
|
|
|
#define BX_TASK_FROM_IRET 12
|
|
|
|
|
|
|
|
// If the Immediate bit is set, the lowest 3 bits of the attribute
|
|
|
|
// specify which kinds of immediate data a required by instruction.
|
|
|
|
|
|
|
|
#define BxImmediate 0x000f // bits 3..0: any immediate
|
|
|
|
#define BxImmediate_Ib 0x0001 // 8 bits regardless
|
|
|
|
#define BxImmediate_Ib_SE 0x0002 // sign extend to OS size
|
|
|
|
#define BxImmediate_Iv 0x0003 // 16 or 32 depending on OS size
|
|
|
|
#define BxImmediate_Iw 0x0004 // 16 bits regardless
|
|
|
|
#define BxImmediate_IvIw 0x0005 // call_Ap
|
|
|
|
#define BxImmediate_IwIb 0x0006 // enter_IwIb
|
2007-01-13 01:47:21 +03:00
|
|
|
#define BxImmediate_O 0x0007 // MOV_ALOd, mov_OdAL, mov_eAXOv, mov_OveAX
|
2001-04-10 05:04:59 +04:00
|
|
|
#define BxImmediate_BrOff8 0x0008 // Relative branch offset byte
|
2007-10-22 21:41:41 +04:00
|
|
|
#define BxImmediate_BrOff16 0x0009 // Relative branch offset word, not encodable in 64-bit mode
|
|
|
|
#define BxImmediate_BrOff32 0x000A // Relative branch offset dword
|
2002-09-13 04:15:23 +04:00
|
|
|
#if BX_SUPPORT_X86_64
|
2007-10-22 21:41:41 +04:00
|
|
|
#define BxImmediate_Iq 0x000B // 64 bit override
|
2002-09-13 04:15:23 +04:00
|
|
|
#endif
|
2001-04-10 05:04:59 +04:00
|
|
|
|
2003-08-28 23:25:23 +04:00
|
|
|
// Lookup for opcode and attributes in another opcode tables
|
|
|
|
// Totally 7 opcode groups supported
|
|
|
|
#define BxGroupX 0x0070 // bits 6..4: opcode groups definition
|
|
|
|
#define BxGroupN 0x0010 // Group encoding: 001
|
|
|
|
#define BxPrefixSSE 0x0020 // Group encoding: 010
|
|
|
|
#define BxSplitMod11b 0x0030 // Group encoding: 011
|
2003-12-27 16:50:06 +03:00
|
|
|
#define BxFPGroup 0x0040 // Group encoding: 100
|
2006-03-22 23:47:11 +03:00
|
|
|
#define BxRMGroup 0x0050 // Group encoding: 101
|
2006-04-06 22:30:05 +04:00
|
|
|
#define Bx3ByteOpIndex 0x0060 // Group encoding: 110
|
|
|
|
#define Bx3ByteOpTable 0x0070 // Group encoding: 111
|
2003-08-28 23:25:23 +04:00
|
|
|
|
|
|
|
#define BxPrefix 0x0080 // bit 7
|
2007-11-15 20:57:56 +03:00
|
|
|
#define BxLockable 0x0100 // bit 8
|
|
|
|
#define Bx3ByteOpcode 0x0200 // bit 9
|
2003-08-28 23:25:23 +04:00
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
#define BxGroup1 BxGroupN
|
|
|
|
#define BxGroup2 BxGroupN
|
|
|
|
#define BxGroup3 BxGroupN
|
|
|
|
#define BxGroup4 BxGroupN
|
|
|
|
#define BxGroup5 BxGroupN
|
|
|
|
#define BxGroup6 BxGroupN
|
|
|
|
#define BxGroup7 BxGroupN
|
|
|
|
#define BxGroup8 BxGroupN
|
|
|
|
#define BxGroup9 BxGroupN
|
|
|
|
|
2002-10-16 21:37:35 +04:00
|
|
|
#define BxGroup12 BxGroupN
|
|
|
|
#define BxGroup13 BxGroupN
|
|
|
|
#define BxGroup14 BxGroupN
|
2002-09-13 04:15:23 +04:00
|
|
|
#define BxGroup15 BxGroupN
|
2002-10-16 21:37:35 +04:00
|
|
|
#define BxGroup16 BxGroupN
|
2005-03-22 21:19:55 +03:00
|
|
|
// <TAG-DEFINES-DECODE-END>
|
2002-09-13 04:15:23 +04:00
|
|
|
|
2002-09-18 09:36:48 +04:00
|
|
|
// Can be used as LHS or RHS.
|
|
|
|
#define RMAddr(i) (BX_CPU_THIS_PTR address_xlation.rm_addr)
|
|
|
|
|
2003-05-15 20:41:17 +04:00
|
|
|
#define setEFlagsOSZAPC(flags32) { \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 = \
|
2002-10-08 02:51:58 +04:00
|
|
|
(BX_CPU_THIS_PTR eflags.val32 & ~EFlagsOSZAPCMask) | \
|
2003-05-15 20:41:17 +04:00
|
|
|
(flags32 & EFlagsOSZAPCMask); \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status = 0; \
|
2005-06-15 00:55:57 +04:00
|
|
|
}
|
2002-10-08 02:51:58 +04:00
|
|
|
|
2003-05-15 20:41:17 +04:00
|
|
|
#define setEFlagsOSZAP(flags32) { \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 = \
|
|
|
|
(BX_CPU_THIS_PTR eflags.val32 & ~EFlagsOSZAPMask) | \
|
|
|
|
(flags32 & EFlagsOSZAPMask); \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status &= 0x00000f; \
|
2005-06-15 00:55:57 +04:00
|
|
|
}
|
2002-10-08 02:51:58 +04:00
|
|
|
|
2004-08-12 01:26:23 +04:00
|
|
|
#define SET_FLAGS_OxxxxC(new_of, new_cf) { \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 &= ~((1<<11) | (1<<0)); \
|
|
|
|
BX_CPU_THIS_PTR eflags.val32 |= ((!!new_of)<<11) | ((!!new_cf)<<0); \
|
|
|
|
BX_CPU_THIS_PTR lf_flags_status &= 0x0ffff0; \
|
2005-06-15 00:55:57 +04:00
|
|
|
}
|
2002-10-08 02:51:58 +04:00
|
|
|
|
2001-04-10 05:04:59 +04:00
|
|
|
#endif // #ifndef BX_CPU_H
|