1 /******************************************************************************
\r
3 * CZ80 XY opcode include source file
\r
4 * CZ80 emulator version 0.9
\r
5 * Copyright 2004-2005 Stéphane Dallongeville
\r
9 *****************************************************************************/
\r
11 #if CZ80_USE_JUMPTABLE
\r
12 goto *JumpTableXY[Opcode];
\r
18 /*-----------------------------------------
\r
20 -----------------------------------------*/
\r
24 /*-----------------------------------------
\r
25 LD r8 (same register)
\r
26 -----------------------------------------*/
\r
28 OPXY(0x40): // LD B,B
\r
29 OPXY(0x49): // LD C,C
\r
30 OPXY(0x52): // LD D,D
\r
31 OPXY(0x5b): // LD E,E
\r
32 OPXY(0x64): // LD H,H
\r
33 OPXY(0x6d): // LD L,L
\r
34 OPXY(0x7f): // LD A,A
\r
37 /*-----------------------------------------
\r
39 -----------------------------------------*/
\r
41 OPXY(0x41): // LD B,C
\r
42 OPXY(0x42): // LD B,D
\r
43 OPXY(0x43): // LD B,E
\r
44 OPXY(0x47): // LD B,A
\r
46 OPXY(0x48): // LD C,B
\r
47 OPXY(0x4a): // LD C,D
\r
48 OPXY(0x4b): // LD C,E
\r
49 OPXY(0x4f): // LD C,A
\r
51 OPXY(0x50): // LD D,B
\r
52 OPXY(0x51): // LD D,C
\r
53 OPXY(0x53): // LD D,E
\r
54 OPXY(0x57): // LD D,A
\r
56 OPXY(0x58): // LD E,B
\r
57 OPXY(0x59): // LD E,C
\r
58 OPXY(0x5a): // LD E,D
\r
59 OPXY(0x5f): // LD E,A
\r
61 OPXY(0x78): // LD A,B
\r
62 OPXY(0x79): // LD A,C
\r
63 OPXY(0x7a): // LD A,D
\r
64 OPXY(0x7b): // LD A,E
\r
67 OPXY(0x44): // LD B,HX
\r
68 OPXY(0x4c): // LD C,HX
\r
69 OPXY(0x54): // LD D,HX
\r
70 OPXY(0x5c): // LD E,HX
\r
71 OPXY(0x7c): // LD A,HX
\r
72 zR8((Opcode >> 3) & 7) = data->B.H;
\r
75 OPXY(0x45): // LD B,LX
\r
76 OPXY(0x4d): // LD C,LX
\r
77 OPXY(0x55): // LD D,LX
\r
78 OPXY(0x5d): // LD E,LX
\r
79 OPXY(0x7d): // LD A,LX
\r
80 zR8((Opcode >> 3) & 7) = data->B.L;
\r
83 OPXY(0x60): // LD HX,B
\r
84 OPXY(0x61): // LD HX,C
\r
85 OPXY(0x62): // LD HX,D
\r
86 OPXY(0x63): // LD HX,E
\r
87 OPXY(0x67): // LD HX,A
\r
88 data->B.H = zR8(Opcode & 7);
\r
91 OPXY(0x68): // LD LX,B
\r
92 OPXY(0x69): // LD LX,C
\r
93 OPXY(0x6a): // LD LX,D
\r
94 OPXY(0x6b): // LD LX,E
\r
95 OPXY(0x6f): // LD LX,A
\r
96 data->B.L = zR8(Opcode & 7);
\r
99 OPXY(0x65): // LD HX,LX
\r
100 data->B.H = data->B.L;
\r
103 OPXY(0x6c): // LD LX,HX
\r
104 data->B.L = data->B.H;
\r
107 OPXY(0x06): // LD B,#imm
\r
108 OPXY(0x0e): // LD C,#imm
\r
109 OPXY(0x16): // LD D,#imm
\r
110 OPXY(0x1e): // LD E,#imm
\r
111 OPXY(0x3e): // LD A,#imm
\r
114 OPXY(0x26): // LD HX,#imm
\r
115 data->B.H = READ_ARG();
\r
118 OPXY(0x2e): // LD LX,#imm
\r
119 data->B.L = READ_ARG();
\r
122 OPXY(0x0a): // LD A,(BC)
\r
123 goto OP_LOAD_A_mBC;
\r
125 OPXY(0x1a): // LD A,(DE)
\r
126 goto OP_LOAD_A_mDE;
\r
128 OPXY(0x3a): // LD A,(nn)
\r
129 goto OP_LOAD_A_mNN;
\r
131 OPXY(0x02): // LD (BC),A
\r
132 goto OP_LOAD_mBC_A;
\r
134 OPXY(0x12): // LD (DE),A
\r
135 goto OP_LOAD_mDE_A;
\r
137 OPXY(0x32): // LD (nn),A
\r
138 goto OP_LOAD_mNN_A;
\r
140 OPXY(0x46): // LD B,(IX+o)
\r
141 OPXY(0x4e): // LD C,(IX+o)
\r
142 OPXY(0x56): // LD D,(IX+o)
\r
143 OPXY(0x5e): // LD E,(IX+o)
\r
144 OPXY(0x66): // LD H,(IX+o)
\r
145 OPXY(0x6e): // LD L,(IX+o)
\r
146 OPXY(0x7e): // LD A,(IX+o)
\r
147 adr = data->W + (INT8)READ_ARG();
\r
148 zR8((Opcode >> 3) & 7) = READ_MEM8(adr);
\r
151 OPXY(0x70): // LD (IX+o),B
\r
152 OPXY(0x71): // LD (IX+o),C
\r
153 OPXY(0x72): // LD (IX+o),D
\r
154 OPXY(0x73): // LD (IX+o),E
\r
155 OPXY(0x74): // LD (IX+o),H
\r
156 OPXY(0x75): // LD (IX+o),L
\r
157 OPXY(0x77): // LD (IX+o),A
\r
158 adr = data->W + (INT8)READ_ARG();
\r
159 WRITE_MEM8(adr, zR8(Opcode & 7));
\r
162 OPXY(0x36): // LD (IX+o),#imm
\r
163 adr = data->W + (INT8)READ_ARG();
\r
164 WRITE_MEM8(adr, READ_ARG());
\r
167 /*-----------------------------------------
\r
169 -----------------------------------------*/
\r
171 OPXY(0x01): // LD BC,nn
\r
172 OPXY(0x11): // LD DE,nn
\r
173 goto OP_LOAD_RR_imm16;
\r
175 OPXY(0x21): // LD IX,nn
\r
176 data->W = READ_ARG16();
\r
179 OPXY(0x31): // LD SP,nn
\r
180 goto OP_LOAD_SP_imm16;
\r
182 OPXY(0x2a): // LD IX,(w)
\r
185 OPXY(0x22): // LD (w),IX
\r
188 OPXY(0xf9): // LD SP,IX
\r
191 /*-----------------------------------------
\r
193 -----------------------------------------*/
\r
195 OPXY(0xc1): // POP BC
\r
196 OPXY(0xd1): // POP DE
\r
197 OPXY(0xf1): // POP AF
\r
200 OPXY(0xe1): // POP IX
\r
203 /*-----------------------------------------
\r
205 -----------------------------------------*/
\r
207 OPXY(0xc5): // PUSH BC
\r
208 OPXY(0xd5): // PUSH DE
\r
209 OPXY(0xf5): // PUSH AF
\r
212 OPXY(0xe5): // PUSH IX
\r
215 /*-----------------------------------------
\r
217 -----------------------------------------*/
\r
219 OPXY(0x08): // EX AF,AF'
\r
222 OPXY(0xeb): // EX DE,HL
\r
228 OPXY(0xe3): // EX (SP),IX
\r
231 /*-----------------------------------------
\r
233 -----------------------------------------*/
\r
235 OPXY(0x04): // INC B
\r
236 OPXY(0x0c): // INC C
\r
237 OPXY(0x14): // INC D
\r
238 OPXY(0x1c): // INC E
\r
239 OPXY(0x3c): // INC A
\r
242 OPXY(0x24): // INC HX
\r
244 zF = (zF & CF) | SZHV_inc[data->B.H];
\r
247 OPXY(0x2c): // INC LX
\r
249 zF = (zF & CF) | SZHV_inc[data->B.L];
\r
252 OPXY(0x34): // INC (IX+o)
\r
253 adr = data->W + (INT8)READ_ARG();
\r
257 /*-----------------------------------------
\r
259 -----------------------------------------*/
\r
261 OPXY(0x05): // DEC B
\r
262 OPXY(0x0d): // DEC C
\r
263 OPXY(0x15): // DEC D
\r
264 OPXY(0x1d): // DEC E
\r
265 OPXY(0x3d): // DEC A
\r
268 OPXY(0x25): // DEC HX
\r
270 zF = (zF & CF) | SZHV_dec[data->B.H];
\r
273 OPXY(0x2d): // DEC LX
\r
275 zF = (zF & CF) | SZHV_dec[data->B.L];
\r
278 OPXY(0x35): // DEC (IX+o)
\r
279 adr = data->W + (INT8)READ_ARG();
\r
283 /*-----------------------------------------
\r
285 -----------------------------------------*/
\r
287 OPXY(0x80): // ADD A,B
\r
288 OPXY(0x81): // ADD A,C
\r
289 OPXY(0x82): // ADD A,D
\r
290 OPXY(0x83): // ADD A,E
\r
291 OPXY(0x87): // ADD A,A
\r
294 OPXY(0xc6): // ADD A,n
\r
297 OPXY(0x84): // ADD A,HX
\r
302 OPXY(0x85): // ADD A,LX
\r
307 OPXY(0x86): // ADD A,(IX+o)
\r
308 adr = data->W + (INT8)READ_ARG();
\r
309 val = READ_MEM8(adr);
\r
313 /*-----------------------------------------
\r
315 -----------------------------------------*/
\r
317 OPXY(0x88): // ADC A,B
\r
318 OPXY(0x89): // ADC A,C
\r
319 OPXY(0x8a): // ADC A,D
\r
320 OPXY(0x8b): // ADC A,E
\r
321 OPXY(0x8f): // ADC A,A
\r
324 OPXY(0xce): // ADC A,n
\r
327 OPXY(0x8c): // ADC A,HX
\r
332 OPXY(0x8d): // ADC A,LX
\r
337 OPXY(0x8e): // ADC A,(IX+o)
\r
338 adr = data->W + (INT8)READ_ARG();
\r
339 val = READ_MEM8(adr);
\r
343 /*-----------------------------------------
\r
345 -----------------------------------------*/
\r
347 OPXY(0x90): // SUB B
\r
348 OPXY(0x91): // SUB C
\r
349 OPXY(0x92): // SUB D
\r
350 OPXY(0x93): // SUB E
\r
351 OPXY(0x97): // SUB A
\r
354 OPXY(0xd6): // SUB A,n
\r
357 OPXY(0x94): // SUB HX
\r
362 OPXY(0x95): // SUB LX
\r
367 OPXY(0x96): // SUB (IX+o)
\r
368 adr = data->W + (INT8)READ_ARG();
\r
369 val = READ_MEM8(adr);
\r
373 /*-----------------------------------------
\r
375 -----------------------------------------*/
\r
377 OPXY(0x98): // SBC A,B
\r
378 OPXY(0x99): // SBC A,C
\r
379 OPXY(0x9a): // SBC A,D
\r
380 OPXY(0x9b): // SBC A,E
\r
381 OPXY(0x9f): // SBC A,A
\r
384 OPXY(0xde): // SBC A,n
\r
387 OPXY(0x9c): // SBC A,HX
\r
392 OPXY(0x9d): // SBC A,LX
\r
397 OPXY(0x9e): // SBC A,(IX+o)
\r
398 adr = data->W + (INT8)READ_ARG();
\r
399 val = READ_MEM8(adr);
\r
403 /*-----------------------------------------
\r
405 -----------------------------------------*/
\r
407 OPXY(0xb8): // CP B
\r
408 OPXY(0xb9): // CP C
\r
409 OPXY(0xba): // CP D
\r
410 OPXY(0xbb): // CP E
\r
411 OPXY(0xbf): // CP A
\r
414 OPXY(0xfe): // CP n
\r
417 OPXY(0xbc): // CP HX
\r
422 OPXY(0xbd): // CP LX
\r
427 OPXY(0xbe): // CP (IX+o)
\r
428 adr = data->W + (INT8)READ_ARG();
\r
429 val = READ_MEM8(adr);
\r
433 /*-----------------------------------------
\r
435 -----------------------------------------*/
\r
437 OPXY(0xa0): // AND B
\r
438 OPXY(0xa1): // AND C
\r
439 OPXY(0xa2): // AND D
\r
440 OPXY(0xa3): // AND E
\r
441 OPXY(0xa7): // AND A
\r
444 OPXY(0xe6): // AND A,n
\r
447 OPXY(0xa4): // AND HX
\r
452 OPXY(0xa5): // AND LX
\r
457 OPXY(0xa6): // AND (IX+o)
\r
458 adr = data->W + (INT8)READ_ARG();
\r
459 val = READ_MEM8(adr);
\r
463 /*-----------------------------------------
\r
465 -----------------------------------------*/
\r
467 OPXY(0xa8): // XOR B
\r
468 OPXY(0xa9): // XOR C
\r
469 OPXY(0xaa): // XOR D
\r
470 OPXY(0xab): // XOR E
\r
471 OPXY(0xaf): // XOR A
\r
474 OPXY(0xee): // XOR A,n
\r
477 OPXY(0xac): // XOR HX
\r
482 OPXY(0xad): // XOR LX
\r
487 OPXY(0xae): // XOR (IX+o)
\r
488 adr = data->W + (INT8)READ_ARG();
\r
489 val = READ_MEM8(adr);
\r
493 /*-----------------------------------------
\r
495 -----------------------------------------*/
\r
497 OPXY(0xb0): // OR B
\r
498 OPXY(0xb1): // OR C
\r
499 OPXY(0xb2): // OR D
\r
500 OPXY(0xb3): // OR E
\r
501 OPXY(0xb7): // OR A
\r
504 OPXY(0xf6): // OR A,n
\r
507 OPXY(0xb4): // OR HX
\r
512 OPXY(0xb5): // OR LX
\r
517 OPXY(0xb6): // OR (IX+o)
\r
518 adr = data->W + (INT8)READ_ARG();
\r
519 val = READ_MEM8(adr);
\r
523 /*-----------------------------------------
\r
524 MISC ARITHMETIC & CPU CONTROL
\r
525 -----------------------------------------*/
\r
539 OPXY(0x76): // HALT
\r
548 /*-----------------------------------------
\r
550 -----------------------------------------*/
\r
552 OPXY(0x03): // INC BC
\r
555 OPXY(0x13): // INC DE
\r
558 OPXY(0x23): // INC IX
\r
561 OPXY(0x33): // INC SP
\r
564 /*-----------------------------------------
\r
566 -----------------------------------------*/
\r
568 OPXY(0x0b): // DEC BC
\r
571 OPXY(0x1b): // DEC DE
\r
574 OPXY(0x2b): // DEC IX
\r
577 OPXY(0x3b): // DEC SP
\r
580 /*-----------------------------------------
\r
582 -----------------------------------------*/
\r
584 OPXY(0x09): // ADD IX,BC
\r
585 goto OP_ADD16_xx_BC;
\r
587 OPXY(0x19): // ADD IX,DE
\r
588 goto OP_ADD16_xx_DE;
\r
590 OPXY(0x29): // ADD IX,IX
\r
591 goto OP_ADD16_xx_xx;
\r
593 OPXY(0x39): // ADD IX,SP
\r
594 goto OP_ADD16_xx_SP;
\r
596 /*-----------------------------------------
\r
598 -----------------------------------------*/
\r
600 OPXY(0x07): // RLCA
\r
603 OPXY(0x0f): // RRCA
\r
612 /*-----------------------------------------
\r
614 -----------------------------------------*/
\r
616 OPXY(0xc3): // JP nn
\r
619 OPXY(0xe9): // JP (IX)
\r
622 OPXY(0xc2): // JP NZ,nn
\r
625 OPXY(0xca): // JP Z,nn
\r
628 OPXY(0xd2): // JP NC,nn
\r
631 OPXY(0xda): // JP C,nn
\r
634 OPXY(0xe2): // JP PO,nn
\r
637 OPXY(0xea): // JP PE,nn
\r
640 OPXY(0xf2): // JP P,nn
\r
643 OPXY(0xfa): // JP M,nn
\r
646 /*-----------------------------------------
\r
648 -----------------------------------------*/
\r
650 OPXY(0x10): // DJNZ n
\r
653 OPXY(0x18): // JR n
\r
656 OPXY(0x20): // JR NZ,n
\r
659 OPXY(0x28): // JR Z,n
\r
662 OPXY(0x30): // JR NC,n
\r
665 OPXY(0x38): // JR C,n
\r
668 /*-----------------------------------------
\r
670 -----------------------------------------*/
\r
672 OPXY(0xcd): // CALL nn
\r
675 OPXY(0xc4): // CALL NZ,nn
\r
678 OPXY(0xcc): // CALL Z,nn
\r
681 OPXY(0xd4): // CALL NC,nn
\r
684 OPXY(0xdc): // CALL C,nn
\r
687 OPXY(0xe4): // CALL PO,nn
\r
690 OPXY(0xec): // CALL PE,nn
\r
693 OPXY(0xf4): // CALL P,nn
\r
696 OPXY(0xfc): // CALL M,nn
\r
699 /*-----------------------------------------
\r
701 -----------------------------------------*/
\r
706 OPXY(0xc0): // RET NZ
\r
709 OPXY(0xc8): // RET Z
\r
712 OPXY(0xd0): // RET NC
\r
715 OPXY(0xd8): // RET C
\r
718 OPXY(0xe0): // RET PO
\r
721 OPXY(0xe8): // RET PE
\r
724 OPXY(0xf0): // RET P
\r
727 OPXY(0xf8): // RET M
\r
730 /*-----------------------------------------
\r
732 -----------------------------------------*/
\r
734 OPXY(0xc7): // RST 0
\r
735 OPXY(0xcf): // RST 1
\r
736 OPXY(0xd7): // RST 2
\r
737 OPXY(0xdf): // RST 3
\r
738 OPXY(0xe7): // RST 4
\r
739 OPXY(0xef): // RST 5
\r
740 OPXY(0xf7): // RST 6
\r
741 OPXY(0xff): // RST 7
\r
744 /*-----------------------------------------
\r
746 -----------------------------------------*/
\r
748 OPXY(0xd3): // OUT (n),A
\r
751 /*-----------------------------------------
\r
753 -----------------------------------------*/
\r
755 OPXY(0xdb): // IN A,(n)
\r
758 /*-----------------------------------------
\r
760 -----------------------------------------*/
\r
762 OPXY(0xcb): // XYCB prefix (BIT & SHIFT INSTRUCTIONS)
\r
767 adr = data->W + (INT8)READ_ARG();
\r
768 Opcode = READ_ARG();
\r
769 #if CZ80_EMULATE_R_EXACTLY
\r
772 #include "cz80_opXYCB.c"
\r
775 OPXY(0xed): // ED prefix
\r
778 OPXY(0xdd): // DD prefix (IX)
\r
781 OPXY(0xfd): // FD prefix (IY)
\r
784 #if !CZ80_USE_JUMPTABLE
\r