1 /* Multi-Z80 32 Bit emulator */
3 /* Copyright 1996, Neil Bradley, All rights reserved
7 * The mZ80 emulator may be distributed in unmodified form to any medium.
9 * mZ80 May not be sold, or sold as a part of a commercial package without
10 * the express written permission of Neil Bradley (neil@synthcom.com). This
13 * Modified versions of mZ80 may not be publicly redistributed without author
14 * approval (neil@synthcom.com). This includes distributing via a publicly
15 * accessible LAN. You may make your own source modifications and distribute
16 * mZ80 in object only form.
18 * mZ80 Licensing for commercial applications is available. Please email
19 * neil@synthcom.com for details.
21 * Synthcom Systems, Inc, and Neil Bradley will not be held responsible for
22 * any damage done by the use of mZ80. It is purely "as-is".
24 * If you use mZ80 in a freeware application, credit in the following text:
26 * "Multi-Z80 CPU emulator by Neil Bradley (neil@synthcom.com)"
28 * must accompany the freeware application within the application itself or
29 * in the documentation.
33 * If you find problems with mZ80, please email the author so they can get
34 * resolved. If you find a bug and fix it, please also email the author so
35 * that those bug fixes can be propogated to the installed base of mZ80
36 * users. If you find performance improvements or problems with mZ80, please
37 * email the author with your changes/suggestions and they will be rolled in
38 * with subsequent releases of mZ80.
40 * The whole idea of this emulator is to have the fastest available 32 bit
41 * Multi-z80 emulator for the PC, giving maximum performance.
44 /* General z80 based defines */
52 #define UINT32 uint32_t
56 #define UINT16 uint16_t
76 #define UINTPTR uintptr_t
83 #ifndef _MEMORYREADWRITEBYTE_
84 #define _MEMORYREADWRITEBYTE_
86 struct MemoryWriteByte
90 void (*memoryCall
)(UINT32
, UINT8
, struct MemoryWriteByte
*);
98 UINT8 (*memoryCall
)(UINT32
, struct MemoryReadByte
*);
102 #endif // _MEMORYREADWRITEBYTE_
108 void (*IOCall
)(UINT16
, UINT8
, struct z80PortWrite
*);
116 UINT16 (*IOCall
)(UINT16
, struct z80PortRead
*);
133 #ifdef WORDS_BIGENDIAN
145 #define z80AF z80af.af
146 #define z80A z80af.half.a
147 #define z80F z80af.half.f
155 #ifdef WORDS_BIGENDIAN
167 #define z80BC z80bc.bc
168 #define z80B z80bc.half.b
169 #define z80C z80bc.half.c
177 #ifdef WORDS_BIGENDIAN
189 #define z80DE z80de.de
190 #define z80D z80de.half.d
191 #define z80E z80de.half.e
199 #ifdef WORDS_BIGENDIAN
211 #define z80HL z80hl.hl
212 #define z80H z80hl.half.h
213 #define z80L z80hl.half.l
215 #define z80SP z80sp.sp
223 #ifdef WORDS_BIGENDIAN
235 #define z80IX z80ix.ix
236 #define z80XH z80ix.half.xh
237 #define z80XL z80ix.half.xl
245 #ifdef WORDS_BIGENDIAN
257 #define z80IY z80iy.iy
258 #define z80YH z80iy.half.yh
259 #define z80YL z80iy.half.yl
264 struct MemoryReadByte
*z80MemRead
;
265 struct MemoryWriteByte
*z80MemWrite
;
266 struct z80PortRead
*z80IoRead
;
267 struct z80PortWrite
*z80IoWrite
;
268 UINT32 z80clockticks
;
270 UINT32 z80interruptMode
;
293 // These are the enumerations used for register access. DO NOT ALTER THEIR
294 // ORDER! It must match the same order as in the mz80.c/mz80.asm files!
326 CPUREG_Z80_HALFCARRY
,
337 extern UINT32
mz80exec(UINT32
);
338 extern UINT32
mz80GetContextSize(void);
339 extern UINT32
mz80GetElapsedTicks(UINT32
);
340 extern void mz80ReleaseTimeslice(void);
341 extern void mz80GetContext(void *);
342 extern void mz80SetContext(void *);
343 extern void mz80reset(void);
344 extern void mz80ClearPendingInterrupt(void);
345 extern UINT32
mz80int(UINT32
);
346 extern UINT32
mz80nmi(void);
347 extern void mz80init(void);
348 extern UINT32 z80intAddr
;
349 extern UINT32 z80nmiAddr
;
351 // Debugger useful routines
353 extern UINT8
mz80SetRegisterValue(void *, UINT32
, UINT32
);
354 extern UINT32
mz80GetRegisterValue(void *, UINT32
);
355 extern UINT32
mz80GetRegisterTextValue(void *, UINT32
, UINT8
*);
356 extern UINT8
*mz80GetRegisterName(UINT32
);
358 // Memory/IO read/write commands
369 #define VALUE_DWORD 2
376 extern void mz80WriteValue(UINT8 bWhat
, UINT32 dwAddr
, UINT32 dwData
);
377 extern UINT32
mz80ReadValue(UINT8 bWhat
, UINT32 dwAddr
);
381 #define Z80_FLAG_CARRY 0x01
382 #define Z80_FLAG_NEGATIVE 0x02
383 #define Z80_FLAG_OVERFLOW_PARITY 0x04
384 #define Z80_FLAG_UNDEFINED1 0x08
385 #define Z80_FLAG_HALF_CARRY 0x10
386 #define Z80_FLAG_UNDEFINED2 0x20
387 #define Z80_FLAG_ZERO 0x40
388 #define Z80_FLAG_SIGN 0x80
393 typedef struct mz80context CONTEXTMZ80
;