File:  [RetroPC.NET] / np2 / i286x / Attic / i286.h
Revision 1.2: download - view: text, annotated - select for diffs
Fri Oct 17 16:17:20 2003 JST (22 years ago) by yui
Branches: MAIN
CVS tags: rel_036, HEAD
fix CPU (T.Yui)

//----------------------------------------------------------------------------
//
//  i286y : 80286 Engine for Pentium  ver0.02
//
//                               Copyright by Yui/Studio Milmake 1999-2000
//
//----------------------------------------------------------------------------

enum {
	I286_MEMREADMAX		= 0xa4000,
	I286_MEMWRITEMAX	= 0xa0000
};

typedef struct {
	BYTE	al;
	BYTE	ah;
	BYTE	cl;
	BYTE	ch;
	BYTE	dl;
	BYTE	dh;
	BYTE	bl;
	BYTE	bh;
	BYTE	sp_l;
	BYTE	sp_h;
	BYTE	bp_l;
	BYTE	bp_h;
	BYTE	si_l;
	BYTE	si_h;
	BYTE	di_l;
	BYTE	di_h;
	BYTE	es_l;
	BYTE	es_h;
	BYTE	cs_l;
	BYTE	cs_h;
	BYTE	ss_l;
	BYTE	ss_h;
	BYTE	ds_l;
	BYTE	ds_h;

	BYTE	flag_l;
	BYTE	flag_h;
	BYTE	ip_l;
	BYTE	ip_h;
} I286REG8;

typedef struct {
	UINT16	ax;
	UINT16	cx;
	UINT16	dx;
	UINT16	bx;
	UINT16	sp;
	UINT16	bp;
	UINT16	si;
	UINT16	di;
	UINT16	es;
	UINT16	cs;
	UINT16	ss;
	UINT16	ds;
	UINT16	flag;
	UINT16	ip;
} I286REG16;

typedef struct {
	UINT16	limit;
	UINT16	base;
	BYTE	base24;
	BYTE	reserved;
} I286DTR;


typedef struct {
	union {
		I286REG8	b;
		I286REG16	w;
	}		r;
	UINT32	es_base;
	UINT32	cs_base;
	UINT32	ss_base;
	UINT32	ds_base;
	UINT32	ss_fix;
	UINT32	ds_fix;
	UINT16	prefix;
	BYTE	trap;
	BYTE	cpu_type;
	UINT32	pf_semaphore;
	UINT32	repbak;
	UINT32	inport;
	BYTE	prefetchque[4];
	I286DTR	GDTR;
	I286DTR	IDTR;
	UINT16	MSW;
} I286REG;


#ifdef __cplusplus
extern "C" {
#endif

extern	I286REG		i286reg;
extern	const BYTE	iflags[];


#define		I286_MEM		mem

#define		I286_REG		i286reg.r
#define		I286_SEGREG		i286reg.r.w.es

#define		I286_AX			i286reg.r.w.ax
#define		I286_BX			i286reg.r.w.bx
#define		I286_CX			i286reg.r.w.cx
#define		I286_DX			i286reg.r.w.dx
#define		I286_SI			i286reg.r.w.si
#define		I286_DI			i286reg.r.w.di
#define		I286_BP			i286reg.r.w.bp
#define		I286_SP			i286reg.r.w.sp
#define		I286_CS			i286reg.r.w.cs
#define		I286_DS			i286reg.r.w.ds
#define		I286_ES			i286reg.r.w.es
#define		I286_SS			i286reg.r.w.ss
#define		I286_IP			i286reg.r.w.ip

#define		SEG_BASE		i286reg.es_base
#define		ES_BASE			i286reg.es_base
#define		CS_BASE			i286reg.cs_base
#define		SS_BASE			i286reg.ss_base
#define		DS_BASE			i286reg.ds_base
#define		SS_FIX			i286reg.ss_fix
#define		DS_FIX			i286reg.ds_fix

#define		I286_AL			i286reg.r.b.al
#define		I286_BL			i286reg.r.b.bl
#define		I286_CL			i286reg.r.b.cl
#define		I286_DL			i286reg.r.b.dl
#define		I286_AH			i286reg.r.b.ah
#define		I286_BH			i286reg.r.b.bh
#define		I286_CH			i286reg.r.b.ch
#define		I286_DH			i286reg.r.b.dh

#define		I286_FLAG		i286reg.r.w.flag
#define		I286_FLAGL		i286reg.r.b.flag_l
#define		I286_FLAGH		i286reg.r.b.flag_h
#define		I286_TRAP		i286reg.trap
#define		I286_OV			i286reg.ovflag

enum {
	C_FLAG			= 0x0001,
	P_FLAG			= 0x0004,
	A_FLAG			= 0x0010,
	Z_FLAG			= 0x0040,
	S_FLAG			= 0x0080,
	T_FLAG			= 0x0100,
	I_FLAG			= 0x0200,
	D_FLAG			= 0x0400,
	O_FLAG			= 0x0800
};

#define		CPUTYPE			i286reg.cpu_type
#define		CPUTYPE_V30		0x01

// ver0.28
#define		REPPOSBAK		i286reg.repbak
#define		PREFIX_SMP		i286reg.pf_semaphore

#define		isI286DI		(!(I286_FLAG & I_FLAG))
#define		isI286EI		(I286_FLAG & I_FLAG)
#define		I286_CLI		I286_FLAG &= ~I_FLAG;				\
							I286_TRAP = 0;
#define		I286_STI		I286_FLAG |= I_FLAG;				\
							I286_TRAP = (I286_FLAG >> 8) & 1;


void i286_initialize(void);
void i286_reset(void);
void i286_resetprefetch(void);

void CPUCALL i286_interrupt(BYTE vect);

void i286(void);
void i286_step(void);

void v30(void);
void v30_step(void);

#ifdef __cplusplus
}
#endif


RetroPC.NET-CVS <cvs@retropc.net>