Mercurial > repos > blastem
view z80inst.h @ 217:acd29e2664c6
Added testcases file. Some fixes to test generator for dealing with indexed mode with base and index reg the same. Added support for blastem headless mode in test runner.
author | Mike Pavone <pavone@retrodev.com> |
---|---|
date | Sat, 20 Apr 2013 00:29:14 -0700 |
parents | 4d4559b04c59 |
children | d9bf8e61c33c |
line wrap: on
line source
#include <stdint.h> enum { Z80_LD, Z80_PUSH, Z80_POP, Z80_EX, Z80_EXX, Z80_LDI, Z80_LDIR, Z80_LDD, Z80_LDDR, Z80_CPI, Z80_CPIR, Z80_CPD, Z80_CPDR, Z80_ADD, Z80_ADC, Z80_SUB, Z80_SBC, Z80_AND, Z80_OR, Z80_XOR, Z80_CP, Z80_INC, Z80_DEC, Z80_DAA, Z80_CPL, Z80_NEG, Z80_CCF, Z80_SCF, Z80_NOP, Z80_HALT, Z80_DI, Z80_EI, Z80_IM, Z80_RLC, Z80_RL, Z80_RRC, Z80_RR, Z80_SLA, Z80_SRA, Z80_SLL, Z80_SRL, Z80_RLD, Z80_RRD, Z80_BIT, Z80_SET, Z80_RES, Z80_JP, Z80_JPCC, Z80_JR, Z80_JRCC, Z80_DJNZ, Z80_CALL, Z80_CALLCC, Z80_RET, Z80_RETCC, Z80_RETI, Z80_RETN, Z80_RST, Z80_IN, Z80_INI, Z80_INIR, Z80_IND, Z80_INDR, Z80_OUT, Z80_OUTI, Z80_OTIR, Z80_OUTD, Z80_OTDR }; enum { Z80_B=0, Z80_C, Z80_D, Z80_E, Z80_H, Z80_L, Z80_IXH, Z80_IXL, Z80_IYH, Z80_IYL, Z80_I, Z80_R, Z80_A, Z80_BC, Z80_DE, Z80_HL, Z80_SP, Z80_AF, Z80_IX, Z80_IY, Z80_UNUSED }; #define Z80_IMMED_FLAG 0x80 #define Z80_USE_IMMED (Z80_IMMED_FLAG|Z80_UNUSED) enum { Z80_CC_NZ, Z80_CC_Z, Z80_CC_NC, Z80_CC_C, Z80_CC_PO, Z80_CC_PE, Z80_CC_P, Z80_CC_M }; enum { Z80_REG, Z80_REG_INDIRECT, Z80_IMMED, Z80_IMMED_INDIRECT, Z80_IX_DISPLACE, Z80_IY_DISPLACE }; #define Z80_DIR 0x80 typedef struct { uint8_t op; uint8_t reg; uint8_t addr_mode; uint8_t ea_reg; uint16_t immed; } z80inst; uint8_t * z80_decode(uint8_t * istream, z80inst * decoded); int z80_disasm(z80inst * decoded, char * dst);