85 lines
2.6 KiB
C
85 lines
2.6 KiB
C
#define ABRT_MASK 0x3f
|
|
/*An 'expected' exception is one that would be expected to occur on every execution
|
|
of this code path; eg a GPF due to being in v86 mode. An 'unexpected' exception is
|
|
one that would be unlikely to occur on the next exception, eg a page fault may be
|
|
fixed up by the exception handler and the next execution would not hit it.
|
|
|
|
This distinction is used by the dynarec; a block that hits an 'expected' exception
|
|
would be compiled, a block that hits an 'unexpected' exception would be rejected so
|
|
that we don't end up with an unnecessarily short block*/
|
|
#define ABRT_EXPECTED 0x80
|
|
|
|
extern uint8_t opcode, opcode2;
|
|
extern uint8_t flags_p;
|
|
extern uint8_t znptable8[256];
|
|
|
|
extern uint16_t zero, oldcs;
|
|
extern uint16_t lastcs, lastpc;
|
|
extern uint16_t *mod1add[2][8];
|
|
extern uint16_t znptable16[65536];
|
|
|
|
extern int x86_was_reset, trap;
|
|
extern int codegen_flat_ss, codegen_flat_ds;
|
|
extern int timetolive, keyboardtimer, trap;
|
|
extern int optype, stack32;
|
|
extern int oldcpl, cgate32, cpl_override;
|
|
extern int nmi_enable;
|
|
extern int oddeven, inttype;
|
|
|
|
extern uint32_t use32;
|
|
extern uint32_t rmdat, easeg;
|
|
extern uint32_t oxpc, flags_zn;
|
|
extern uint32_t abrt_error;
|
|
extern uint32_t backupregs[16];
|
|
extern uint32_t *mod1seg[8];
|
|
extern uint32_t *eal_r, *eal_w;
|
|
|
|
#define fetchdat rmdat
|
|
|
|
#define setznp168 setznp16
|
|
|
|
#define getr8(r) ((r & 4) ? cpu_state.regs[r & 3].b.h : cpu_state.regs[r & 3].b.l)
|
|
#define getr16(r) cpu_state.regs[r].w
|
|
#define getr32(r) cpu_state.regs[r].l
|
|
|
|
#define setr8(r, v) \
|
|
if (r & 4) \
|
|
cpu_state.regs[r & 3].b.h = v; \
|
|
else \
|
|
cpu_state.regs[r & 3].b.l = v;
|
|
#define setr16(r, v) cpu_state.regs[r].w = v
|
|
#define setr32(r, v) cpu_state.regs[r].l = v
|
|
|
|
#define fetchea() \
|
|
{ \
|
|
rmdat = readmemb(cs + pc); \
|
|
pc++; \
|
|
reg = (rmdat >> 3) & 7; \
|
|
mod = (rmdat >> 6) & 3; \
|
|
rm = rmdat & 7; \
|
|
if (mod != 3) \
|
|
fetcheal(); \
|
|
}
|
|
|
|
#define JMP 1
|
|
#define CALL 2
|
|
#define IRET 3
|
|
#define OPTYPE_INT 4
|
|
|
|
enum {
|
|
ABRT_NONE = 0,
|
|
ABRT_GEN,
|
|
ABRT_TS = 0xA,
|
|
ABRT_NP = 0xB,
|
|
ABRT_SS = 0xC,
|
|
ABRT_GPF = 0xD,
|
|
ABRT_PF = 0xE,
|
|
ABRT_DE = 0x40 /* INT 0, but we have to distinguish it from ABRT_NONE. */
|
|
};
|
|
|
|
extern void x86_doabrt(int x86_abrt);
|
|
extern void x86illegal(void);
|
|
extern void x86seg_reset(void);
|
|
extern void x86gpf(char *s, uint16_t error);
|
|
extern void x86gpf_expected(char *s, uint16_t error);
|