home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Aminet 18
/
aminetcdnumber181997.iso
/
Aminet
/
misc
/
emu
/
gbuk.lha
/
src
/
Z80.H
< prev
Wrap
C/C++ Source or Header
|
1996-11-06
|
6KB
|
155 lines
/** VGB: portable GameBoy emulator ***************************/
/** **/
/** Z80.h **/
/** **/
/** This file contains declarations relevant to emulation **/
/** of Z80 CPU. See GB.h for #defines related to drivers **/
/** and GameBoy emulation. **/
/** **/
/** Copyright (C) Marat Fayzullin 1994,1995,1996 **/
/** Marcel de Kogel 1996 **/
/** You are not allowed to distribute this software **/
/** commercially. Please, notify me, if you make any **/
/** changes to this file. **/
/*************************************************************/
//#define DEBUG /* Compile debugging version */
#ifdef __DJGPP__
#define LSB_FIRST
#define FAST_MEM
#endif
#ifdef __WATCOMC__
#define LSB_FIRST
#endif
#ifdef __GNUC__
#ifdef mc68000
#define FAST_MEM
#endif
#endif
#define S_FLAG 0x80
#define Z_FLAG 0x40
#define H_FLAG 0x10
#define P_FLAG 0x04
#define V_FLAG 0x04
#define N_FLAG 0x02
#define C_FLAG 0x01
/**********************************************************/
/*** NOTICE: sizeof(byte)=1 and sizeof(word)=2 ***/
/**********************************************************/
typedef unsigned char byte;
typedef unsigned short word;
typedef signed char offset;
/**********************************************************/
/*** #define LSB_FIRST for machines where least ***/
/*** signifcant byte goes first. ***/
/**********************************************************/
typedef union
{
#ifdef LSB_FIRST
struct { byte l,h; } B;
#else
struct { byte h,l; } B;
#endif
word W;
} pair;
typedef struct
{
pair AF,BC,DE,HL,PC,SP;
byte IFF,I;
} reg;
/*** Interrupts *******************************************/
/*** Interrupt-related variables. ***/
/**********************************************************/
extern int IPeriod; /* Number of commands between internal interrupts */
extern byte IntSync; /* Generate internal interrupts if IntSync==1 */
extern int ICount; /* Number of commands until next internal int-pt */
extern byte IFlag; /* If IFlag==1, generate interrupt and set to 0 */
/*** Trace and Trap ***************************************/
/*** Switches to turn tracing on and off in DEBUG mode. ***/
/**********************************************************/
#ifdef DEBUG
extern byte Trace; /* Tracing is on if Trace==1 */
extern word Trap; /* When PC==Trap, set Trace=1 */
#endif
/*** TrapBadOps *******************************************/
/*** When 1, print warnings of illegal Z80 instructions.***/
/**********************************************************/
extern byte TrapBadOps;
/*** CPURunning *******************************************/
/*** When 0, execution terminates. ***/
/**********************************************************/
extern byte CPURunning;
/*** Reset Z80 registers: *********************************/
/*** This function can be used to reset the register ***/
/*** file before starting execution with Z80(). It sets ***/
/*** the registers to their initial values. ***/
/**********************************************************/
extern void ResetZ80(reg *Regs);
/*** Interpret Z80 code: **********************************/
/*** Registers have initial values from Regs. PC value ***/
/*** at which emulation stopped is returned by this ***/
/*** function. ***/
#define __inline__ __inline
/**********************************************************/
/*** Interpret Z80 code: **********************************/
/*** Registers have initial values from Regs. PC value ***/
/*** at which emulation stopped is returned by this ***/
/*** function. ***/
/**********************************************************/
word Z80(reg Regs);
/**********************************************************/
/*** These functions are called when read or write to ***/
/*** RAM occurs. They perform actual reads abd writes. ***/
/**********************************************************/
//typedef void (*WriteMemFn) (word A,byte V) __attribute__ ((regparm(3)));
typedef void (*WriteMemFn) (word A,byte V);
extern WriteMemFn WriteMemFnTable[256];
extern byte *RAM,*Page[8];
#ifndef FAST_MEM
//void M_WRMEM(word A,byte V) __attribute__ ((regparm(3)));
//byte M_RDMEM(word A) __attribute__ ((regparm(3)));
void M_WRMEM(word A,byte V);
byte M_RDMEM(word A);
#else
extern __inline__ byte M_RDMEM (word A)
{
return(Page[A>>13][A&0x1FFF]);
}
extern __inline__ void M_WRMEM (word A,byte V)
{
(*WriteMemFnTable[A>>8])(A,V);
}
#endif
#ifdef DEBUG
/*** Single-step debugger *********************************/
/*** This function should exist if DEBUG is #defined. ***/
/*** If Trace==1 it is called after each command ***/
/*** executed by the CPU and given a pointer to the ***/
/*** register file. ***/
/**********************************************************/
void Debug(reg *R);
#endif
/*** Interrupt handler ************************************/
/*** This function should exist if INTERRUPTS is ***/
/*** #defined. It is called on each attempted interrupt ***/
/*** and should return an interrupt address to proceed ***/
/*** with interrupt or 0xFFFF to continue execution. ***/
/**********************************************************/
word Interrupt(void);