summaryrefslogtreecommitdiff
path: root/decoders/z80/tables.py
diff options
context:
space:
mode:
authorDaniel Elstner <daniel.kitta@gmail.com>2014-02-18 22:03:45 +0100
committerDaniel Elstner <daniel.kitta@gmail.com>2014-02-24 22:00:12 +0100
commit26abbf3762e19d89ab578905aaba24e8764d1696 (patch)
tree66b85d63e0fd301326798e8b7188d2748a757952 /decoders/z80/tables.py
parent9eec72cb2bf132600db3330f49dace3bdf74080a (diff)
downloadlibsigrokdecode-26abbf3762e19d89ab578905aaba24e8764d1696.tar.gz
libsigrokdecode-26abbf3762e19d89ab578905aaba24e8764d1696.zip
z80: New decoder for disassembling Z80 CPU instructions.
Diffstat (limited to 'decoders/z80/tables.py')
-rw-r--r--decoders/z80/tables.py1081
1 files changed, 1081 insertions, 0 deletions
diff --git a/decoders/z80/tables.py b/decoders/z80/tables.py
new file mode 100644
index 0000000..b0d9e52
--- /dev/null
+++ b/decoders/z80/tables.py
@@ -0,0 +1,1081 @@
+##
+## This file is part of the libsigrokdecode project.
+##
+## Copyright (C) 2014 Daniel Elstner <daniel.kitta@gmail.com>
+##
+## This program is free software; you can redistribute it and/or modify
+## it under the terms of the GNU General Public License as published by
+## the Free Software Foundation; either version 3 of the License, or
+## (at your option) any later version.
+##
+## This program is distributed in the hope that it will be useful,
+## but WITHOUT ANY WARRANTY; without even the implied warranty of
+## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+## GNU General Public License for more details.
+##
+## You should have received a copy of the GNU General Public License
+## along with this program; if not, see <http://www.gnu.org/licenses/>.
+##
+
+'''
+Instruction tuple: (d, i, ro, wo, rep, format string)
+
+ The placeholders d and i are the number of bytes in the instruction
+ used for the displacement and the immediate operand, respectively. An
+ operand consisting of more than one byte is assembled in little endian
+ order.
+ The format string should refer to the {d} and {i} operands by name.
+ Displacements are interpreted as signed integers, whereas immediate
+ operands are always read as unsigned. The tables for instructions
+ operating on the IX/IY index registers additionally use {r} in the
+ format string as a placeholder for the register name.
+ The placeholders ro and wo are the number of bytes the instruction
+ is expected to read or write, respectively. These counts are used
+ for both memory and I/O access, but not for immediate operands.
+ A negative value indicates that the operand byte order is big endian
+ rather than the usual little endian.
+ The placeholder rep is a boolean used to mark repeating instructions.
+'''
+
+# Instructions without a prefix
+main_instructions = {
+ 0x00: (0, 0, 0, 0, False, 'NOP'),
+ 0x01: (0, 2, 0, 0, False, 'LD BC,{i:04X}h'),
+ 0x02: (0, 0, 0, 1, False, 'LD (BC),A'),
+ 0x03: (0, 0, 0, 0, False, 'INC BC'),
+ 0x04: (0, 0, 0, 0, False, 'INC B'),
+ 0x05: (0, 0, 0, 0, False, 'DEC B'),
+ 0x06: (0, 1, 0, 0, False, 'LD B,{i:02X}h'),
+ 0x07: (0, 0, 0, 0, False, 'RLCA'),
+ 0x08: (0, 0, 0, 0, False, 'EX AF,AF\''),
+ 0x09: (0, 0, 0, 0, False, 'ADD HL,BC'),
+ 0x0A: (0, 0, 1, 0, False, 'LD A,(BC)'),
+ 0x0B: (0, 0, 0, 0, False, 'DEC BC'),
+ 0x0C: (0, 0, 0, 0, False, 'INC C'),
+ 0x0D: (0, 0, 0, 0, False, 'DEC C'),
+ 0x0E: (0, 1, 0, 0, False, 'LD C,{i:02X}h'),
+ 0x0F: (0, 0, 0, 0, False, 'RRCA'),
+
+ 0x10: (1, 0, 0, 0, False, 'DJNZ {d:+d}'),
+ 0x11: (0, 2, 0, 0, False, 'LD DE,{i:04X}h'),
+ 0x12: (0, 0, 0, 1, False, 'LD (DE),A'),
+ 0x13: (0, 0, 0, 0, False, 'INC DE'),
+ 0x14: (0, 0, 0, 0, False, 'INC D'),
+ 0x15: (0, 0, 0, 0, False, 'DEC D'),
+ 0x16: (0, 1, 0, 0, False, 'LD D,{i:02X}h'),
+ 0x17: (0, 0, 0, 0, False, 'RLA'),
+ 0x18: (1, 0, 0, 0, False, 'JR {d:+d}'),
+ 0x19: (0, 0, 0, 0, False, 'ADD HL,DE'),
+ 0x1A: (0, 0, 1, 0, False, 'LD A,(DE)'),
+ 0x1B: (0, 0, 0, 0, False, 'DEC DE'),
+ 0x1C: (0, 0, 0, 0, False, 'INC E'),
+ 0x1D: (0, 0, 0, 0, False, 'DEC E'),
+ 0x1E: (0, 1, 0, 0, False, 'LD E,{i:02X}h'),
+ 0x1F: (0, 0, 0, 0, False, 'RRA'),
+
+ 0x20: (1, 0, 0, 0, False, 'JR NZ,{d:+d}'),
+ 0x21: (0, 2, 0, 0, False, 'LD HL,{i:04X}h'),
+ 0x22: (0, 2, 0, 2, False, 'LD ({i:04X}h),HL'),
+ 0x23: (0, 0, 0, 0, False, 'INC HL'),
+ 0x24: (0, 0, 0, 0, False, 'INC H'),
+ 0x25: (0, 0, 0, 0, False, 'DEC H'),
+ 0x26: (0, 1, 0, 0, False, 'LD H,{i:02X}h'),
+ 0x27: (0, 0, 0, 0, False, 'DAA'),
+ 0x28: (1, 0, 0, 0, False, 'JR Z,{d:+d}'),
+ 0x29: (0, 0, 0, 0, False, 'ADD HL,HL'),
+ 0x2A: (0, 2, 2, 0, False, 'LD HL,({i:04X}h)'),
+ 0x2B: (0, 0, 0, 0, False, 'DEC HL'),
+ 0x2C: (0, 0, 0, 0, False, 'INC L'),
+ 0x2D: (0, 0, 0, 0, False, 'DEC L'),
+ 0x2E: (0, 1, 0, 0, False, 'LD L,{i:02X}h'),
+ 0x2F: (0, 0, 0, 0, False, 'CPL'),
+
+ 0x30: (1, 0, 0, 0, False, 'JR NC,{d:+d}'),
+ 0x31: (0, 2, 0, 0, False, 'LD SP,{i:04X}h'),
+ 0x32: (0, 2, 0, 1, False, 'LD ({i:04X}h),A'),
+ 0x33: (0, 0, 0, 0, False, 'INC SP'),
+ 0x34: (0, 0, 1, 1, False, 'INC (HL)'),
+ 0x35: (0, 0, 1, 1, False, 'DEC (HL)'),
+ 0x36: (0, 1, 0, 1, False, 'LD (HL),{i:02X}h'),
+ 0x37: (0, 0, 0, 0, False, 'SCF'),
+ 0x38: (1, 0, 0, 0, False, 'JR C,{d:+d}'),
+ 0x39: (0, 0, 0, 0, False, 'ADD HL,SP'),
+ 0x3A: (0, 2, 1, 0, False, 'LD A,({i:04X}h)'),
+ 0x3B: (0, 0, 0, 0, False, 'DEC SP'),
+ 0x3C: (0, 0, 0, 0, False, 'INC A'),
+ 0x3D: (0, 0, 0, 0, False, 'DEC A'),
+ 0x3E: (0, 1, 0, 0, False, 'LD A,{i:02X}h'),
+ 0x3F: (0, 0, 0, 0, False, 'CCF'),
+
+ 0x40: (0, 0, 0, 0, False, 'LD B,B'),
+ 0x41: (0, 0, 0, 0, False, 'LD B,C'),
+ 0x42: (0, 0, 0, 0, False, 'LD B,D'),
+ 0x43: (0, 0, 0, 0, False, 'LD B,E'),
+ 0x44: (0, 0, 0, 0, False, 'LD B,H'),
+ 0x45: (0, 0, 0, 0, False, 'LD B,L'),
+ 0x46: (0, 0, 1, 0, False, 'LD B,(HL)'),
+ 0x47: (0, 0, 0, 0, False, 'LD B,A'),
+ 0x48: (0, 0, 0, 0, False, 'LD C,B'),
+ 0x49: (0, 0, 0, 0, False, 'LD C,C'),
+ 0x4A: (0, 0, 0, 0, False, 'LD C,D'),
+ 0x4B: (0, 0, 0, 0, False, 'LD C,E'),
+ 0x4C: (0, 0, 0, 0, False, 'LD C,H'),
+ 0x4D: (0, 0, 0, 0, False, 'LD C,L'),
+ 0x4E: (0, 0, 1, 0, False, 'LD C,(HL)'),
+ 0x4F: (0, 0, 0, 0, False, 'LD C,A'),
+
+ 0x50: (0, 0, 0, 0, False, 'LD D,B'),
+ 0x51: (0, 0, 0, 0, False, 'LD D,C'),
+ 0x52: (0, 0, 0, 0, False, 'LD D,D'),
+ 0x53: (0, 0, 0, 0, False, 'LD D,E'),
+ 0x54: (0, 0, 0, 0, False, 'LD D,H'),
+ 0x55: (0, 0, 0, 0, False, 'LD D,L'),
+ 0x56: (0, 0, 1, 0, False, 'LD D,(HL)'),
+ 0x57: (0, 0, 0, 0, False, 'LD D,A'),
+ 0x58: (0, 0, 0, 0, False, 'LD E,B'),
+ 0x59: (0, 0, 0, 0, False, 'LD E,C'),
+ 0x5A: (0, 0, 0, 0, False, 'LD E,D'),
+ 0x5B: (0, 0, 0, 0, False, 'LD E,E'),
+ 0x5C: (0, 0, 0, 0, False, 'LD E,H'),
+ 0x5D: (0, 0, 0, 0, False, 'LD E,L'),
+ 0x5E: (0, 0, 1, 0, False, 'LD E,(HL)'),
+ 0x5F: (0, 0, 0, 0, False, 'LD E,A'),
+
+ 0x60: (0, 0, 0, 0, False, 'LD H,B'),
+ 0x61: (0, 0, 0, 0, False, 'LD H,C'),
+ 0x62: (0, 0, 0, 0, False, 'LD H,D'),
+ 0x63: (0, 0, 0, 0, False, 'LD H,E'),
+ 0x64: (0, 0, 0, 0, False, 'LD H,H'),
+ 0x65: (0, 0, 0, 0, False, 'LD H,L'),
+ 0x66: (0, 0, 1, 0, False, 'LD H,(HL)'),
+ 0x67: (0, 0, 0, 0, False, 'LD H,A'),
+ 0x68: (0, 0, 0, 0, False, 'LD L,B'),
+ 0x69: (0, 0, 0, 0, False, 'LD L,C'),
+ 0x6A: (0, 0, 0, 0, False, 'LD L,D'),
+ 0x6B: (0, 0, 0, 0, False, 'LD L,E'),
+ 0x6C: (0, 0, 0, 0, False, 'LD L,H'),
+ 0x6D: (0, 0, 0, 0, False, 'LD L,L'),
+ 0x6E: (0, 0, 1, 0, False, 'LD L,(HL)'),
+ 0x6F: (0, 0, 0, 0, False, 'LD L,A'),
+
+ 0x70: (0, 0, 0, 1, False, 'LD (HL),B'),
+ 0x71: (0, 0, 0, 1, False, 'LD (HL),C'),
+ 0x72: (0, 0, 0, 1, False, 'LD (HL),D'),
+ 0x73: (0, 0, 0, 1, False, 'LD (HL),E'),
+ 0x74: (0, 0, 0, 1, False, 'LD (HL),H'),
+ 0x75: (0, 0, 0, 1, False, 'LD (HL),L'),
+ 0x76: (0, 0, 0, 0, False, 'HALT'),
+ 0x77: (0, 0, 0, 1, False, 'LD (HL),A'),
+ 0x78: (0, 0, 0, 0, False, 'LD A,B'),
+ 0x79: (0, 0, 0, 0, False, 'LD A,C'),
+ 0x7A: (0, 0, 0, 0, False, 'LD A,D'),
+ 0x7B: (0, 0, 0, 0, False, 'LD A,E'),
+ 0x7C: (0, 0, 0, 0, False, 'LD A,H'),
+ 0x7D: (0, 0, 0, 0, False, 'LD A,L'),
+ 0x7E: (0, 0, 1, 0, False, 'LD A,(HL)'),
+ 0x7F: (0, 0, 0, 0, False, 'LD A,A'),
+
+ 0x80: (0, 0, 0, 0, False, 'ADD A,B'),
+ 0x81: (0, 0, 0, 0, False, 'ADD A,C'),
+ 0x82: (0, 0, 0, 0, False, 'ADD A,D'),
+ 0x83: (0, 0, 0, 0, False, 'ADD A,E'),
+ 0x84: (0, 0, 0, 0, False, 'ADD A,H'),
+ 0x85: (0, 0, 0, 0, False, 'ADD A,L'),
+ 0x86: (0, 0, 1, 0, False, 'ADD A,(HL)'),
+ 0x87: (0, 0, 0, 0, False, 'ADD A,A'),
+ 0x88: (0, 0, 0, 0, False, 'ADC A,B'),
+ 0x89: (0, 0, 0, 0, False, 'ADC A,C'),
+ 0x8A: (0, 0, 0, 0, False, 'ADC A,D'),
+ 0x8B: (0, 0, 0, 0, False, 'ADC A,E'),
+ 0x8C: (0, 0, 0, 0, False, 'ADC A,H'),
+ 0x8D: (0, 0, 0, 0, False, 'ADC A,L'),
+ 0x8E: (0, 0, 1, 0, False, 'ADC A,(HL)'),
+ 0x8F: (0, 0, 0, 0, False, 'ADC A,A'),
+
+ 0x90: (0, 0, 0, 0, False, 'SUB B'),
+ 0x91: (0, 0, 0, 0, False, 'SUB C'),
+ 0x92: (0, 0, 0, 0, False, 'SUB D'),
+ 0x93: (0, 0, 0, 0, False, 'SUB E'),
+ 0x94: (0, 0, 0, 0, False, 'SUB H'),
+ 0x95: (0, 0, 0, 0, False, 'SUB L'),
+ 0x96: (0, 0, 1, 0, False, 'SUB (HL)'),
+ 0x97: (0, 0, 0, 0, False, 'SUB A'),
+ 0x98: (0, 0, 0, 0, False, 'SBC A,B'),
+ 0x99: (0, 0, 0, 0, False, 'SBC A,C'),
+ 0x9A: (0, 0, 0, 0, False, 'SBC A,D'),
+ 0x9B: (0, 0, 0, 0, False, 'SBC A,E'),
+ 0x9C: (0, 0, 0, 0, False, 'SBC A,H'),
+ 0x9D: (0, 0, 0, 0, False, 'SBC A,L'),
+ 0x9E: (0, 0, 1, 0, False, 'SBC A,(HL)'),
+ 0x9F: (0, 0, 0, 0, False, 'SBC A,A'),
+
+ 0xA0: (0, 0, 0, 0, False, 'AND B'),
+ 0xA1: (0, 0, 0, 0, False, 'AND C'),
+ 0xA2: (0, 0, 0, 0, False, 'AND D'),
+ 0xA3: (0, 0, 0, 0, False, 'AND E'),
+ 0xA4: (0, 0, 0, 0, False, 'AND H'),
+ 0xA5: (0, 0, 0, 0, False, 'AND L'),
+ 0xA6: (0, 0, 1, 0, False, 'AND (HL)'),
+ 0xA7: (0, 0, 0, 0, False, 'AND A'),
+ 0xA8: (0, 0, 0, 0, False, 'XOR B'),
+ 0xA9: (0, 0, 0, 0, False, 'XOR C'),
+ 0xAA: (0, 0, 0, 0, False, 'XOR D'),
+ 0xAB: (0, 0, 0, 0, False, 'XOR E'),
+ 0xAC: (0, 0, 0, 0, False, 'XOR H'),
+ 0xAD: (0, 0, 0, 0, False, 'XOR L'),
+ 0xAE: (0, 0, 1, 0, False, 'XOR (HL)'),
+ 0xAF: (0, 0, 0, 0, False, 'XOR A'),
+
+ 0xB0: (0, 0, 0, 0, False, 'OR B'),
+ 0xB1: (0, 0, 0, 0, False, 'OR C'),
+ 0xB2: (0, 0, 0, 0, False, 'OR D'),
+ 0xB3: (0, 0, 0, 0, False, 'OR E'),
+ 0xB4: (0, 0, 0, 0, False, 'OR H'),
+ 0xB5: (0, 0, 0, 0, False, 'OR L'),
+ 0xB6: (0, 0, 1, 0, False, 'OR (HL)'),
+ 0xB7: (0, 0, 0, 0, False, 'OR A'),
+ 0xB8: (0, 0, 0, 0, False, 'CP B'),
+ 0xB9: (0, 0, 0, 0, False, 'CP C'),
+ 0xBA: (0, 0, 0, 0, False, 'CP D'),
+ 0xBB: (0, 0, 0, 0, False, 'CP E'),
+ 0xBC: (0, 0, 0, 0, False, 'CP H'),
+ 0xBD: (0, 0, 0, 0, False, 'CP L'),
+ 0xBE: (0, 0, 1, 0, False, 'CP (HL)'),
+ 0xBF: (0, 0, 0, 0, False, 'CP A'),
+
+ 0xC0: (0, 0, 2, 0, False, 'RET NZ'),
+ 0xC1: (0, 0, 2, 0, False, 'POP BC'),
+ 0xC2: (0, 2, 0, 0, False, 'JP NZ,{i:04X}h'),
+ 0xC3: (0, 2, 0, 0, False, 'JP {i:04X}h'),
+ 0xC4: (0, 2, 0,-2, False, 'CALL NZ,{i:04X}h'),
+ 0xC5: (0, 0, 0,-2, False, 'PUSH BC'),
+ 0xC6: (0, 1, 0, 0, False, 'ADD A,{i:02X}h'),
+ 0xC7: (0, 0, 0,-2, False, 'RST 00h'),
+ 0xC8: (0, 0, 2, 0, False, 'RET Z'),
+ 0xC9: (0, 0, 2, 0, False, 'RET'),
+ 0xCA: (0, 2, 0, 0, False, 'JP Z,{i:04X}h'),
+
+ 0xCC: (0, 2, 0,-2, False, 'CALL Z,{i:04X}h'),
+ 0xCD: (0, 2, 0,-2, False, 'CALL {i:04X}h'),
+ 0xCE: (0, 1, 0, 0, False, 'ADC A,{i:02X}h'),
+ 0xCF: (0, 0, 0,-2, False, 'RST 08h'),
+
+ 0xD0: (0, 0, 2, 0, False, 'RET NC'),
+ 0xD1: (0, 0, 2, 0, False, 'POP DE'),
+ 0xD2: (0, 2, 0, 0, False, 'JP NC,{i:04X}h'),
+ 0xD3: (0, 1, 0, 1, False, 'OUT ({i:02X}h),A'),
+ 0xD4: (0, 2, 0,-2, False, 'CALL NC,{i:04X}h'),
+ 0xD5: (0, 0, 0,-2, False, 'PUSH DE'),
+ 0xD6: (0, 1, 0, 0, False, 'SUB {i:02X}h'),
+ 0xD7: (0, 0, 0,-2, False, 'RST 10h'),
+ 0xD8: (0, 0, 2, 0, False, 'RET C'),
+ 0xD9: (0, 0, 0, 0, False, 'EXX'),
+ 0xDA: (0, 2, 0, 0, False, 'JP C,{i:04X}h'),
+ 0xDB: (0, 1, 1, 0, False, 'IN A,({i:02X}h)'),
+ 0xDC: (0, 2, 0,-2, False, 'CALL C,{i:04X}h'),
+
+ 0xDE: (0, 1, 0, 0, False, 'SBC A,{i:02X}h'),
+ 0xDF: (0, 0, 0,-2, False, 'RST 18h'),
+
+ 0xE0: (0, 0, 2, 0, False, 'RET PO'),
+ 0xE1: (0, 0, 2, 0, False, 'POP HL'),
+ 0xE2: (0, 2, 0, 0, False, 'JP PO,{i:04X}h'),
+ 0xE3: (0, 0, 2, 2, False, 'EX (SP),HL'),
+ 0xE4: (0, 2, 0,-2, False, 'CALL PO,{i:04X}h'),
+ 0xE5: (0, 0, 0,-2, False, 'PUSH HL'),
+ 0xE6: (0, 1, 0, 0, False, 'AND {i:02X}h'),
+ 0xE7: (0, 0, 0,-2, False, 'RST 20h'),
+ 0xE8: (0, 0, 2, 0, False, 'RET PE'),
+ 0xE9: (0, 0, 0, 0, False, 'JP (HL)'),
+ 0xEA: (0, 2, 0, 0, False, 'JP PE,{i:04X}h'),
+ 0xEB: (0, 0, 0, 0, False, 'EX DE,HL'),
+ 0xEC: (0, 2, 0,-2, False, 'CALL PE,{i:04X}h'),
+
+ 0xEE: (0, 1, 0, 0, False, 'XOR {i:02X}h'),
+ 0xEF: (0, 0, 0,-2, False, 'RST 28h'),
+
+ 0xF0: (0, 0, 2, 0, False, 'RET P'),
+ 0xF1: (0, 0, 2, 0, False, 'POP AF'),
+ 0xF2: (0, 2, 0, 0, False, 'JP P,{i:04X}h'),
+ 0xF3: (0, 0, 0, 0, False, 'DI'),
+ 0xF4: (0, 2, 0,-2, False, 'CALL P,{i:04X}h'),
+ 0xF5: (0, 0, 0,-2, False, 'PUSH AF'),
+ 0xF6: (0, 1, 0, 0, False, 'OR {i:02X}h'),
+ 0xF7: (0, 0, 0,-2, False, 'RST 30h'),
+ 0xF8: (0, 0, 2, 0, False, 'RET M'),
+ 0xF9: (0, 0, 0, 0, False, 'LD SP,HL'),
+ 0xFA: (0, 2, 0, 0, False, 'JP M,{i:04X}h'),
+ 0xFB: (0, 0, 0, 0, False, 'EI'),
+ 0xFC: (0, 2, 0,-2, False, 'CALL M,{i:04X}h'),
+
+ 0xFE: (0, 1, 0, 0, False, 'CP {i:02X}h'),
+ 0xFF: (0, 0, 0,-2, False, 'RST 38h')
+}
+
+# Instructions with ED prefix
+extended_instructions = {
+ 0x40: (0, 0, 1, 0, False, 'IN B,(C)'),
+ 0x41: (0, 0, 0, 1, False, 'OUT (C),B'),
+ 0x42: (0, 0, 0, 0, False, 'SBC HL,BC'),
+ 0x43: (0, 2, 0, 2, False, 'LD ({i:04X}h),BC'),
+ 0x44: (0, 0, 0, 0, False, 'NEG'),
+ 0x45: (0, 0, 2, 0, False, 'RETN'),
+ 0x46: (0, 0, 0, 0, False, 'IM 0'),
+ 0x47: (0, 0, 0, 0, False, 'LD I,A'),
+ 0x48: (0, 0, 1, 0, False, 'IN C,(C)'),
+ 0x49: (0, 0, 0, 1, False, 'OUT (C),C'),
+ 0x4A: (0, 0, 0, 0, False, 'ADC HL,BC'),
+ 0x4B: (0, 2, 2, 0, False, 'LD BC,({i:04X}h)'),
+ 0x4C: (0, 0, 0, 0, False, 'NEG'),
+ 0x4D: (0, 0, 2, 0, False, 'RETI'),
+ 0x4E: (0, 0, 0, 0, False, 'IM 0/1'),
+ 0x4F: (0, 0, 0, 0, False, 'LD R,A'),
+
+ 0x50: (0, 0, 1, 0, False, 'IN D,(C)'),
+ 0x51: (0, 0, 0, 1, False, 'OUT (C),D'),
+ 0x52: (0, 0, 0, 0, False, 'SBC HL,DE'),
+ 0x53: (0, 2, 0, 2, False, 'LD ({i:04X}h),DE'),
+ 0x54: (0, 0, 0, 0, False, 'NEG'),
+ 0x55: (0, 0, 2, 0, False, 'RETN'),
+ 0x56: (0, 0, 0, 0, False, 'IM 1'),
+ 0x57: (0, 0, 0, 0, False, 'LD A,I'),
+ 0x58: (0, 0, 1, 0, False, 'IN E,(C)'),
+ 0x59: (0, 0, 0, 1, False, 'OUT (C),E'),
+ 0x5A: (0, 0, 0, 0, False, 'ADC HL,DE'),
+ 0x5B: (0, 2, 2, 0, False, 'LD DE,({i:04X}h)'),
+ 0x5C: (0, 0, 0, 0, False, 'NEG'),
+ 0x5D: (0, 0, 2, 0, False, 'RETN'),
+ 0x5E: (0, 0, 0, 0, False, 'IM 2'),
+ 0x5F: (0, 0, 0, 0, False, 'LD A,R'),
+
+ 0x60: (0, 0, 1, 0, False, 'IN H,(C)'),
+ 0x61: (0, 0, 0, 1, False, 'OUT (C),H'),
+ 0x62: (0, 0, 0, 0, False, 'SBC HL,HL'),
+ 0x63: (0, 2, 0, 2, False, 'LD ({i:04X}h),HL'),
+ 0x64: (0, 0, 0, 0, False, 'NEG'),
+ 0x65: (0, 0, 2, 0, False, 'RETN'),
+ 0x66: (0, 0, 0, 0, False, 'IM 0'),
+ 0x67: (0, 0, 1, 1, False, 'RRD'),
+ 0x68: (0, 0, 1, 0, False, 'IN L,(C)'),
+ 0x69: (0, 0, 0, 1, False, 'OUT (C),L'),
+ 0x6A: (0, 0, 0, 0, False, 'ADC HL,HL'),
+ 0x6B: (0, 2, 2, 0, False, 'LD HL,({i:04X}h)'),
+ 0x6C: (0, 0, 0, 0, False, 'NEG'),
+ 0x6D: (0, 0, 2, 0, False, 'RETN'),
+ 0x6E: (0, 0, 0, 0, False, 'IM 0/1'),
+ 0x6F: (0, 0, 1, 1, False, 'RLD'),
+
+ 0x70: (0, 0, 1, 0, False, 'IN (C)'),
+ 0x71: (0, 0, 0, 1, False, 'OUT (C),0'),
+ 0x72: (0, 0, 0, 0, False, 'SBC HL,SP'),
+ 0x73: (0, 2, 0, 2, False, 'LD ({i:04X}h),SP'),
+ 0x74: (0, 0, 0, 0, False, 'NEG'),
+ 0x75: (0, 0, 2, 0, False, 'RETN'),
+ 0x76: (0, 0, 0, 0, False, 'IM 1'),
+
+ 0x78: (0, 0, 1, 0, False, 'IN A,(C)'),
+ 0x79: (0, 0, 0, 1, False, 'OUT (C),A'),
+ 0x7A: (0, 0, 0, 0, False, 'ADC HL,SP'),
+ 0x7B: (0, 2, 2, 0, False, 'LD SP,({i:04X}h)'),
+ 0x7C: (0, 0, 0, 0, False, 'NEG'),
+ 0x7D: (0, 0, 2, 0, False, 'RETN'),
+ 0x7E: (0, 0, 0, 0, False, 'IM 2'),
+
+ 0xA0: (0, 0, 1, 1, False, 'LDI'),
+ 0xA1: (0, 0, 1, 0, False, 'CPI'),
+ 0xA2: (0, 0, 1, 1, False, 'INI'),
+ 0xA3: (0, 0, 1, 1, False, 'OUTI'),
+
+ 0xA8: (0, 0, 1, 1, False, 'LDD'),
+ 0xA9: (0, 0, 1, 0, False, 'CPD'),
+ 0xAA: (0, 0, 1, 1, False, 'IND'),
+ 0xAB: (0, 0, 1, 1, False, 'OUTD'),
+
+ 0xB0: (0, 0, 1, 1, True, 'LDIR'),
+ 0xB1: (0, 0, 1, 0, True, 'CPIR'),
+ 0xB2: (0, 0, 1, 1, True, 'INIR'),
+ 0xB3: (0, 0, 1, 1, True, 'OTIR'),
+
+ 0xB8: (0, 0, 1, 1, True, 'LDDR'),
+ 0xB9: (0, 0, 1, 0, True, 'CPDR'),
+ 0xBA: (0, 0, 1, 1, True, 'INDR'),
+ 0xBB: (0, 0, 1, 1, True, 'OTDR')
+}
+
+# Instructions with CB prefix
+bit_instructions = {
+ 0x00: (0, 0, 0, 0, False, 'RLC B'),
+ 0x01: (0, 0, 0, 0, False, 'RLC C'),
+ 0x02: (0, 0, 0, 0, False, 'RLC D'),
+ 0x03: (0, 0, 0, 0, False, 'RLC E'),
+ 0x04: (0, 0, 0, 0, False, 'RLC H'),
+ 0x05: (0, 0, 0, 0, False, 'RLC L'),
+ 0x06: (0, 0, 1, 1, False, 'RLC (HL)'),
+ 0x07: (0, 0, 0, 0, False, 'RLC A'),
+ 0x08: (0, 0, 0, 0, False, 'RRC B'),
+ 0x09: (0, 0, 0, 0, False, 'RRC C'),
+ 0x0A: (0, 0, 0, 0, False, 'RRC D'),
+ 0x0B: (0, 0, 0, 0, False, 'RRC E'),
+ 0x0C: (0, 0, 0, 0, False, 'RRC H'),
+ 0x0D: (0, 0, 0, 0, False, 'RRC L'),
+ 0x0E: (0, 0, 1, 1, False, 'RRC (HL)'),
+ 0x0F: (0, 0, 0, 0, False, 'RRC A'),
+
+ 0x10: (0, 0, 0, 0, False, 'RL B'),
+ 0x11: (0, 0, 0, 0, False, 'RL C'),
+ 0x12: (0, 0, 0, 0, False, 'RL D'),
+ 0x13: (0, 0, 0, 0, False, 'RL E'),
+ 0x14: (0, 0, 0, 0, False, 'RL H'),
+ 0x15: (0, 0, 0, 0, False, 'RL L'),
+ 0x16: (0, 0, 1, 1, False, 'RL (HL)'),
+ 0x17: (0, 0, 0, 0, False, 'RL A'),
+ 0x18: (0, 0, 0, 0, False, 'RR B'),
+ 0x19: (0, 0, 0, 0, False, 'RR C'),
+ 0x1A: (0, 0, 0, 0, False, 'RR D'),
+ 0x1B: (0, 0, 0, 0, False, 'RR E'),
+ 0x1C: (0, 0, 0, 0, False, 'RR H'),
+ 0x1D: (0, 0, 0, 0, False, 'RR L'),
+ 0x1E: (0, 0, 1, 1, False, 'RR (HL)'),
+ 0x1F: (0, 0, 0, 0, False, 'RR A'),
+
+ 0x20: (0, 0, 0, 0, False, 'SLA B'),
+ 0x21: (0, 0, 0, 0, False, 'SLA C'),
+ 0x22: (0, 0, 0, 0, False, 'SLA D'),
+ 0x23: (0, 0, 0, 0, False, 'SLA E'),
+ 0x24: (0, 0, 0, 0, False, 'SLA H'),
+ 0x25: (0, 0, 0, 0, False, 'SLA L'),
+ 0x26: (0, 0, 1, 1, False, 'SLA (HL)'),
+ 0x27: (0, 0, 0, 0, False, 'SLA A'),
+ 0x28: (0, 0, 0, 0, False, 'SRA B'),
+ 0x29: (0, 0, 0, 0, False, 'SRA C'),
+ 0x2A: (0, 0, 0, 0, False, 'SRA D'),
+ 0x2B: (0, 0, 0, 0, False, 'SRA E'),
+ 0x2C: (0, 0, 0, 0, False, 'SRA H'),
+ 0x2D: (0, 0, 0, 0, False, 'SRA L'),
+ 0x2E: (0, 0, 1, 1, False, 'SRA (HL)'),
+ 0x2F: (0, 0, 0, 0, False, 'SRA A'),
+
+ 0x30: (0, 0, 0, 0, False, 'SLL B'),
+ 0x31: (0, 0, 0, 0, False, 'SLL C'),
+ 0x32: (0, 0, 0, 0, False, 'SLL D'),
+ 0x33: (0, 0, 0, 0, False, 'SLL E'),
+ 0x34: (0, 0, 0, 0, False, 'SLL H'),
+ 0x35: (0, 0, 0, 0, False, 'SLL L'),
+ 0x36: (0, 0, 1, 1, False, 'SLL (HL)'),
+ 0x37: (0, 0, 0, 0, False, 'SLL A'),
+ 0x38: (0, 0, 0, 0, False, 'SRL B'),
+ 0x39: (0, 0, 0, 0, False, 'SRL C'),
+ 0x3A: (0, 0, 0, 0, False, 'SRL D'),
+ 0x3B: (0, 0, 0, 0, False, 'SRL E'),
+ 0x3C: (0, 0, 0, 0, False, 'SRL H'),
+ 0x3D: (0, 0, 0, 0, False, 'SRL L'),
+ 0x3E: (0, 0, 1, 1, False, 'SRL (HL)'),
+ 0x3F: (0, 0, 0, 0, False, 'SRL A'),
+
+ 0x40: (0, 0, 0, 0, False, 'BIT 0,B'),
+ 0x41: (0, 0, 0, 0, False, 'BIT 0,C'),
+ 0x42: (0, 0, 0, 0, False, 'BIT 0,D'),
+ 0x43: (0, 0, 0, 0, False, 'BIT 0,E'),
+ 0x44: (0, 0, 0, 0, False, 'BIT 0,H'),
+ 0x45: (0, 0, 0, 0, False, 'BIT 0,L'),
+ 0x46: (0, 0, 1, 0, False, 'BIT 0,(HL)'),
+ 0x47: (0, 0, 0, 0, False, 'BIT 0,A'),
+ 0x48: (0, 0, 0, 0, False, 'BIT 1,B'),
+ 0x49: (0, 0, 0, 0, False, 'BIT 1,C'),
+ 0x4A: (0, 0, 0, 0, False, 'BIT 1,D'),
+ 0x4B: (0, 0, 0, 0, False, 'BIT 1,E'),
+ 0x4C: (0, 0, 0, 0, False, 'BIT 1,H'),
+ 0x4D: (0, 0, 0, 0, False, 'BIT 1,L'),
+ 0x4E: (0, 0, 1, 0, False, 'BIT 1,(HL)'),
+ 0x4F: (0, 0, 0, 0, False, 'BIT 1,A'),
+
+ 0x50: (0, 0, 0, 0, False, 'BIT 2,B'),
+ 0x51: (0, 0, 0, 0, False, 'BIT 2,C'),
+ 0x52: (0, 0, 0, 0, False, 'BIT 2,D'),
+ 0x53: (0, 0, 0, 0, False, 'BIT 2,E'),
+ 0x54: (0, 0, 0, 0, False, 'BIT 2,H'),
+ 0x55: (0, 0, 0, 0, False, 'BIT 2,L'),
+ 0x56: (0, 0, 1, 0, False, 'BIT 2,(HL)'),
+ 0x57: (0, 0, 0, 0, False, 'BIT 2,A'),
+ 0x58: (0, 0, 0, 0, False, 'BIT 3,B'),
+ 0x59: (0, 0, 0, 0, False, 'BIT 3,C'),
+ 0x5A: (0, 0, 0, 0, False, 'BIT 3,D'),
+ 0x5B: (0, 0, 0, 0, False, 'BIT 3,E'),
+ 0x5C: (0, 0, 0, 0, False, 'BIT 3,H'),
+ 0x5D: (0, 0, 0, 0, False, 'BIT 3,L'),
+ 0x5E: (0, 0, 1, 0, False, 'BIT 3,(HL)'),
+ 0x5F: (0, 0, 0, 0, False, 'BIT 3,A'),
+
+ 0x60: (0, 0, 0, 0, False, 'BIT 4,B'),
+ 0x61: (0, 0, 0, 0, False, 'BIT 4,C'),
+ 0x62: (0, 0, 0, 0, False, 'BIT 4,D'),
+ 0x63: (0, 0, 0, 0, False, 'BIT 4,E'),
+ 0x64: (0, 0, 0, 0, False, 'BIT 4,H'),
+ 0x65: (0, 0, 0, 0, False, 'BIT 4,L'),
+ 0x66: (0, 0, 1, 0, False, 'BIT 4,(HL)'),
+ 0x67: (0, 0, 0, 0, False, 'BIT 4,A'),
+ 0x68: (0, 0, 0, 0, False, 'BIT 5,B'),
+ 0x69: (0, 0, 0, 0, False, 'BIT 5,C'),
+ 0x6A: (0, 0, 0, 0, False, 'BIT 5,D'),
+ 0x6B: (0, 0, 0, 0, False, 'BIT 5,E'),
+ 0x6C: (0, 0, 0, 0, False, 'BIT 5,H'),
+ 0x6D: (0, 0, 0, 0, False, 'BIT 5,L'),
+ 0x6E: (0, 0, 1, 0, False, 'BIT 5,(HL)'),
+ 0x6F: (0, 0, 0, 0, False, 'BIT 5,A'),
+
+ 0x70: (0, 0, 0, 0, False, 'BIT 6,B'),
+ 0x71: (0, 0, 0, 0, False, 'BIT 6,C'),
+ 0x72: (0, 0, 0, 0, False, 'BIT 6,D'),
+ 0x73: (0, 0, 0, 0, False, 'BIT 6,E'),
+ 0x74: (0, 0, 0, 0, False, 'BIT 6,H'),
+ 0x75: (0, 0, 0, 0, False, 'BIT 6,L'),
+ 0x76: (0, 0, 1, 0, False, 'BIT 6,(HL)'),
+ 0x77: (0, 0, 0, 0, False, 'BIT 6,A'),
+ 0x78: (0, 0, 0, 0, False, 'BIT 7,B'),
+ 0x79: (0, 0, 0, 0, False, 'BIT 7,C'),
+ 0x7A: (0, 0, 0, 0, False, 'BIT 7,D'),
+ 0x7B: (0, 0, 0, 0, False, 'BIT 7,E'),
+ 0x7C: (0, 0, 0, 0, False, 'BIT 7,H'),
+ 0x7D: (0, 0, 0, 0, False, 'BIT 7,L'),
+ 0x7E: (0, 0, 1, 0, False, 'BIT 7,(HL)'),
+ 0x7F: (0, 0, 0, 0, False, 'BIT 7,A'),
+
+ 0x80: (0, 0, 0, 0, False, 'RES 0,B'),
+ 0x81: (0, 0, 0, 0, False, 'RES 0,C'),
+ 0x82: (0, 0, 0, 0, False, 'RES 0,D'),
+ 0x83: (0, 0, 0, 0, False, 'RES 0,E'),
+ 0x84: (0, 0, 0, 0, False, 'RES 0,H'),
+ 0x85: (0, 0, 0, 0, False, 'RES 0,L'),
+ 0x86: (0, 0, 1, 1, False, 'RES 0,(HL)'),
+ 0x87: (0, 0, 0, 0, False, 'RES 0,A'),
+ 0x88: (0, 0, 0, 0, False, 'RES 1,B'),
+ 0x89: (0, 0, 0, 0, False, 'RES 1,C'),
+ 0x8A: (0, 0, 0, 0, False, 'RES 1,D'),
+ 0x8B: (0, 0, 0, 0, False, 'RES 1,E'),
+ 0x8C: (0, 0, 0, 0, False, 'RES 1,H'),
+ 0x8D: (0, 0, 0, 0, False, 'RES 1,L'),
+ 0x8E: (0, 0, 1, 1, False, 'RES 1,(HL)'),
+ 0x8F: (0, 0, 0, 0, False, 'RES 1,A'),
+
+ 0x90: (0, 0, 0, 0, False, 'RES 2,B'),
+ 0x91: (0, 0, 0, 0, False, 'RES 2,C'),
+ 0x92: (0, 0, 0, 0, False, 'RES 2,D'),
+ 0x93: (0, 0, 0, 0, False, 'RES 2,E'),
+ 0x94: (0, 0, 0, 0, False, 'RES 2,H'),
+ 0x95: (0, 0, 0, 0, False, 'RES 2,L'),
+ 0x96: (0, 0, 1, 1, False, 'RES 2,(HL)'),
+ 0x97: (0, 0, 0, 0, False, 'RES 2,A'),
+ 0x98: (0, 0, 0, 0, False, 'RES 3,B'),
+ 0x99: (0, 0, 0, 0, False, 'RES 3,C'),
+ 0x9A: (0, 0, 0, 0, False, 'RES 3,D'),
+ 0x9B: (0, 0, 0, 0, False, 'RES 3,E'),
+ 0x9C: (0, 0, 0, 0, False, 'RES 3,H'),
+ 0x9D: (0, 0, 0, 0, False, 'RES 3,L'),
+ 0x9E: (0, 0, 1, 1, False, 'RES 3,(HL)'),
+ 0x9F: (0, 0, 0, 0, False, 'RES 3,A'),
+
+ 0xA0: (0, 0, 0, 0, False, 'RES 4,B'),
+ 0xA1: (0, 0, 0, 0, False, 'RES 4,C'),
+ 0xA2: (0, 0, 0, 0, False, 'RES 4,D'),
+ 0xA3: (0, 0, 0, 0, False, 'RES 4,E'),
+ 0xA4: (0, 0, 0, 0, False, 'RES 4,H'),
+ 0xA5: (0, 0, 0, 0, False, 'RES 4,L'),
+ 0xA6: (0, 0, 1, 1, False, 'RES 4,(HL)'),
+ 0xA7: (0, 0, 0, 0, False, 'RES 4,A'),
+ 0xA8: (0, 0, 0, 0, False, 'RES 5,B'),
+ 0xA9: (0, 0, 0, 0, False, 'RES 5,C'),
+ 0xAA: (0, 0, 0, 0, False, 'RES 5,D'),
+ 0xAB: (0, 0, 0, 0, False, 'RES 5,E'),
+ 0xAC: (0, 0, 0, 0, False, 'RES 5,H'),
+ 0xAD: (0, 0, 0, 0, False, 'RES 5,L'),
+ 0xAE: (0, 0, 1, 1, False, 'RES 5,(HL)'),
+ 0xAF: (0, 0, 0, 0, False, 'RES 5,A'),
+
+ 0xB0: (0, 0, 0, 0, False, 'RES 6,B'),
+ 0xB1: (0, 0, 0, 0, False, 'RES 6,C'),
+ 0xB2: (0, 0, 0, 0, False, 'RES 6,D'),
+ 0xB3: (0, 0, 0, 0, False, 'RES 6,E'),
+ 0xB4: (0, 0, 0, 0, False, 'RES 6,H'),
+ 0xB5: (0, 0, 0, 0, False, 'RES 6,L'),
+ 0xB6: (0, 0, 1, 1, False, 'RES 6,(HL)'),
+ 0xB7: (0, 0, 0, 0, False, 'RES 6,A'),
+ 0xB8: (0, 0, 0, 0, False, 'RES 7,B'),
+ 0xB9: (0, 0, 0, 0, False, 'RES 7,C'),
+ 0xBA: (0, 0, 0, 0, False, 'RES 7,D'),
+ 0xBB: (0, 0, 0, 0, False, 'RES 7,E'),
+ 0xBC: (0, 0, 0, 0, False, 'RES 7,H'),
+ 0xBD: (0, 0, 0, 0, False, 'RES 7,L'),
+ 0xBE: (0, 0, 1, 1, False, 'RES 7,(HL)'),
+ 0xBF: (0, 0, 0, 0, False, 'RES 7,A'),
+
+ 0xC0: (0, 0, 0, 0, False, 'SET 0,B'),
+ 0xC1: (0, 0, 0, 0, False, 'SET 0,C'),
+ 0xC2: (0, 0, 0, 0, False, 'SET 0,D'),
+ 0xC3: (0, 0, 0, 0, False, 'SET 0,E'),
+ 0xC4: (0, 0, 0, 0, False, 'SET 0,H'),
+ 0xC5: (0, 0, 0, 0, False, 'SET 0,L'),
+ 0xC6: (0, 0, 1, 1, False, 'SET 0,(HL)'),
+ 0xC7: (0, 0, 0, 0, False, 'SET 0,A'),
+ 0xC8: (0, 0, 0, 0, False, 'SET 1,B'),
+ 0xC9: (0, 0, 0, 0, False, 'SET 1,C'),
+ 0xCA: (0, 0, 0, 0, False, 'SET 1,D'),
+ 0xCB: (0, 0, 0, 0, False, 'SET 1,E'),
+ 0xCC: (0, 0, 0, 0, False, 'SET 1,H'),
+ 0xCD: (0, 0, 0, 0, False, 'SET 1,L'),
+ 0xCE: (0, 0, 1, 1, False, 'SET 1,(HL)'),
+ 0xCF: (0, 0, 0, 0, False, 'SET 1,A'),
+
+ 0xD0: (0, 0, 0, 0, False, 'SET 2,B'),
+ 0xD1: (0, 0, 0, 0, False, 'SET 2,C'),
+ 0xD2: (0, 0, 0, 0, False, 'SET 2,D'),
+ 0xD3: (0, 0, 0, 0, False, 'SET 2,E'),
+ 0xD4: (0, 0, 0, 0, False, 'SET 2,H'),
+ 0xD5: (0, 0, 0, 0, False, 'SET 2,L'),
+ 0xD6: (0, 0, 1, 1, False, 'SET 2,(HL)'),
+ 0xD7: (0, 0, 0, 0, False, 'SET 2,A'),
+ 0xD8: (0, 0, 0, 0, False, 'SET 3,B'),
+ 0xD9: (0, 0, 0, 0, False, 'SET 3,C'),
+ 0xDA: (0, 0, 0, 0, False, 'SET 3,D'),
+ 0xDB: (0, 0, 0, 0, False, 'SET 3,E'),
+ 0xDC: (0, 0, 0, 0, False, 'SET 3,H'),
+ 0xDD: (0, 0, 0, 0, False, 'SET 3,L'),
+ 0xDE: (0, 0, 1, 1, False, 'SET 3,(HL)'),
+ 0xDF: (0, 0, 0, 0, False, 'SET 3,A'),
+
+ 0xE0: (0, 0, 0, 0, False, 'SET 4,B'),
+ 0xE1: (0, 0, 0, 0, False, 'SET 4,C'),
+ 0xE2: (0, 0, 0, 0, False, 'SET 4,D'),
+ 0xE3: (0, 0, 0, 0, False, 'SET 4,E'),
+ 0xE4: (0, 0, 0, 0, False, 'SET 4,H'),
+ 0xE5: (0, 0, 0, 0, False, 'SET 4,L'),
+ 0xE6: (0, 0, 1, 1, False, 'SET 4,(HL)'),
+ 0xE7: (0, 0, 0, 0, False, 'SET 4,A'),
+ 0xE8: (0, 0, 0, 0, False, 'SET 5,B'),
+ 0xE9: (0, 0, 0, 0, False, 'SET 5,C'),
+ 0xEA: (0, 0, 0, 0, False, 'SET 5,D'),
+ 0xEB: (0, 0, 0, 0, False, 'SET 5,E'),
+ 0xEC: (0, 0, 0, 0, False, 'SET 5,H'),
+ 0xED: (0, 0, 0, 0, False, 'SET 5,L'),
+ 0xEE: (0, 0, 1, 1, False, 'SET 5,(HL)'),
+ 0xEF: (0, 0, 0, 0, False, 'SET 5,A'),
+
+ 0xF0: (0, 0, 0, 0, False, 'SET 6,B'),
+ 0xF1: (0, 0, 0, 0, False, 'SET 6,C'),
+ 0xF2: (0, 0, 0, 0, False, 'SET 6,D'),
+ 0xF3: (0, 0, 0, 0, False, 'SET 6,E'),
+ 0xF4: (0, 0, 0, 0, False, 'SET 6,H'),
+ 0xF5: (0, 0, 0, 0, False, 'SET 6,L'),
+ 0xF6: (0, 0, 1, 1, False, 'SET 6,(HL)'),
+ 0xF7: (0, 0, 0, 0, False, 'SET 6,A'),
+ 0xF8: (0, 0, 0, 0, False, 'SET 7,B'),
+ 0xF9: (0, 0, 0, 0, False, 'SET 7,C'),
+ 0xFA: (0, 0, 0, 0, False, 'SET 7,D'),
+ 0xFB: (0, 0, 0, 0, False, 'SET 7,E'),
+ 0xFC: (0, 0, 0, 0, False, 'SET 7,H'),
+ 0xFD: (0, 0, 0, 0, False, 'SET 7,L'),
+ 0xFE: (0, 0, 1, 1, False, 'SET 7,(HL)'),
+ 0xFF: (0, 0, 0, 0, False, 'SET 7,A')
+}
+
+# Instructions with DD or FD prefix
+index_instructions = {
+ 0x09: (0, 0, 0, 0, False, 'ADD {r},BC'),
+
+ 0x19: (0, 0, 0, 0, False, 'ADD {r},DE'),
+
+ 0x21: (0, 2, 0, 0, False, 'LD {r},{i:04X}h'),
+ 0x22: (0, 2, 0, 2, False, 'LD ({i:04X}h),{r}'),
+ 0x23: (0, 0, 0, 0, False, 'INC {r}'),
+ 0x24: (0, 0, 0, 0, False, 'INC {r}h'),
+ 0x25: (0, 0, 0, 0, False, 'DEC {r}h'),
+ 0x26: (0, 1, 0, 0, False, 'LD {r}h,{i:02X}h'),
+
+ 0x29: (0, 0, 0, 0, False, 'ADD {r},{r}'),
+ 0x2A: (0, 2, 2, 0, False, 'LD {r},({i:04X}h)'),
+ 0x2B: (0, 0, 0, 0, False, 'DEC {r}'),
+ 0x2C: (0, 0, 0, 0, False, 'INC {r}l'),
+ 0x2D: (0, 0, 0, 0, False, 'DEC {r}l'),
+ 0x2E: (0, 1, 0, 0, False, 'LD {r}l,{i:02X}h'),
+
+ 0x34: (1, 0, 1, 1, False, 'INC ({r}{d:+d})'),
+ 0x35: (1, 0, 1, 1, False, 'DEC ({r}{d:+d})'),
+ 0x36: (1, 1, 0, 1, False, 'LD ({r}{d:+d}),{i:02X}h'),
+
+ 0x39: (0, 0, 0, 0, False, 'ADD {r},SP'),
+
+ 0x44: (0, 0, 0, 0, False, 'LD B,{r}h'),
+ 0x45: (0, 0, 0, 0, False, 'LD B,{r}l'),
+ 0x46: (1, 0, 1, 0, False, 'LD B,({r}{d:+d})'),
+
+ 0x4C: (0, 0, 0, 0, False, 'LD C,{r}h'),
+ 0x4D: (0, 0, 0, 0, False, 'LD C,{r}l'),
+ 0x4E: (1, 0, 1, 0, False, 'LD C,({r}{d:+d})'),
+
+ 0x54: (0, 0, 0, 0, False, 'LD D,{r}h'),
+ 0x55: (0, 0, 0, 0, False, 'LD D,{r}l'),
+ 0x56: (1, 0, 1, 0, False, 'LD D,({r}{d:+d})'),
+
+ 0x5C: (0, 0, 0, 0, False, 'LD E,{r}h'),
+ 0x5D: (0, 0, 0, 0, False, 'LD E,{r}l'),
+ 0x5E: (1, 0, 1, 0, False, 'LD E,({r}{d:+d})'),
+
+ 0x60: (0, 0, 0, 0, False, 'LD {r}h,B'),
+ 0x61: (0, 0, 0, 0, False, 'LD {r}h,C'),
+ 0x62: (0, 0, 0, 0, False, 'LD {r}h,D'),
+ 0x63: (0, 0, 0, 0, False, 'LD {r}h,E'),
+ 0x64: (0, 0, 0, 0, False, 'LD {r}h,{r}h'),
+ 0x65: (0, 0, 0, 0, False, 'LD {r}h,{r}l'),
+ 0x66: (1, 0, 1, 0, False, 'LD H,({r}{d:+d})'),
+ 0x67: (0, 0, 0, 0, False, 'LD {r}h,A'),
+ 0x68: (0, 0, 0, 0, False, 'LD {r}l,B'),
+ 0x69: (0, 0, 0, 0, False, 'LD {r}l,C'),
+ 0x6A: (0, 0, 0, 0, False, 'LD {r}l,D'),
+ 0x6B: (0, 0, 0, 0, False, 'LD {r}l,E'),
+ 0x6C: (0, 0, 0, 0, False, 'LD {r}l,{r}h'),
+ 0x6D: (0, 0, 0, 0, False, 'LD {r}l,{r}l'),
+ 0x6E: (1, 0, 1, 0, False, 'LD L,({r}{d:+d})'),
+ 0x6F: (0, 0, 0, 0, False, 'LD {r}l,A'),
+
+ 0x70: (1, 0, 0, 1, False, 'LD ({r}{d:+d}),B'),
+ 0x71: (1, 0, 0, 1, False, 'LD ({r}{d:+d}),C'),
+ 0x72: (1, 0, 0, 1, False, 'LD ({r}{d:+d}),D'),
+ 0x73: (1, 0, 0, 1, False, 'LD ({r}{d:+d}),E'),
+ 0x74: (1, 0, 0, 1, False, 'LD ({r}{d:+d}),H'),
+ 0x75: (1, 0, 0, 1, False, 'LD ({r}{d:+d}),L'),
+
+ 0x77: (1, 0, 0, 1, False, 'LD ({r}{d:+d}),A'),
+
+ 0x7C: (0, 0, 0, 0, False, 'LD A,{r}h'),
+ 0x7D: (0, 0, 0, 0, False, 'LD A,{r}l'),
+ 0x7E: (1, 0, 1, 0, False, 'LD A,({r}{d:+d})'),
+
+ 0x84: (0, 0, 0, 0, False, 'ADD A,{r}h'),
+ 0x85: (0, 0, 0, 0, False, 'ADD A,{r}l'),
+ 0x86: (1, 0, 1, 0, False, 'ADD A,({r}{d:+d})'),
+
+ 0x8C: (0, 0, 0, 0, False, 'ADC A,{r}h'),
+ 0x8D: (0, 0, 0, 0, False, 'ADC A,{r}l'),
+ 0x8E: (1, 0, 1, 0, False, 'ADC A,({r}{d:+d})'),
+
+ 0x94: (0, 0, 0, 0, False, 'SUB {r}h'),
+ 0x95: (0, 0, 0, 0, False, 'SUB {r}l'),
+ 0x96: (1, 0, 1, 0, False, 'SUB ({r}{d:+d})'),
+
+ 0x9C: (0, 0, 0, 0, False, 'SBC A,{r}h'),
+ 0x9D: (0, 0, 0, 0, False, 'SBC A,{r}l'),
+ 0x9E: (1, 0, 1, 0, False, 'SBC A,({r}{d:+d})'),
+
+ 0xA4: (0, 0, 0, 0, False, 'AND {r}h'),
+ 0xA5: (0, 0, 0, 0, False, 'AND {r}l'),
+ 0xA6: (1, 0, 1, 0, False, 'AND ({r}{d:+d})'),
+
+ 0xAC: (0, 0, 0, 0, False, 'XOR {r}h'),
+ 0xAD: (0, 0, 0, 0, False, 'XOR {r}l'),
+ 0xAE: (1, 0, 1, 0, False, 'XOR ({r}{d:+d})'),
+
+ 0xB4: (0, 0, 0, 0, False, 'OR {r}h'),
+ 0xB5: (0, 0, 0, 0, False, 'OR {r}l'),
+ 0xB6: (1, 0, 1, 0, False, 'OR ({r}{d:+d})'),
+
+ 0xBC: (0, 0, 0, 0, False, 'CP {r}h'),
+ 0xBD: (0, 0, 0, 0, False, 'CP {r}l'),
+ 0xBE: (1, 0, 1, 0, False, 'CP ({r}{d:+d})'),
+
+ 0xE1: (0, 0, 2, 0, False, 'POP {r}'),
+
+ 0xE3: (0, 0, 2, 2, False, 'EX (SP),{r}'),
+
+ 0xE5: (0, 0, 0,-2, False, 'PUSH {r}'),
+
+ 0xE9: (0, 0, 0, 0, False, 'JP ({r})'),
+
+ 0xF9: (0, 0, 0, 0, False, 'LD SP,{r}')
+}
+
+# Instructions with DD CB or FD CB prefix.
+# For these instructions, the displacement precedes the opcode byte.
+# This is handled as a special case in the code, and thus the entries
+# in this table specify 0 for the displacement length.
+index_bit_instructions = {
+ 0x00: (0, 0, 1, 1, False, 'RLC ({r}{d:+d}),B'),
+ 0x01: (0, 0, 1, 1, False, 'RLC ({r}{d:+d}),C'),
+ 0x02: (0, 0, 1, 1, False, 'RLC ({r}{d:+d}),D'),
+ 0x03: (0, 0, 1, 1, False, 'RLC ({r}{d:+d}),E'),
+ 0x04: (0, 0, 1, 1, False, 'RLC ({r}{d:+d}),H'),
+ 0x05: (0, 0, 1, 1, False, 'RLC ({r}{d:+d}),L'),
+ 0x06: (0, 0, 1, 1, False, 'RLC ({r}{d:+d})'),
+ 0x07: (0, 0, 1, 1, False, 'RLC ({r}{d:+d}),A'),
+ 0x08: (0, 0, 1, 1, False, 'RRC ({r}{d:+d}),B'),
+ 0x09: (0, 0, 1, 1, False, 'RRC ({r}{d:+d}),C'),
+ 0x0A: (0, 0, 1, 1, False, 'RRC ({r}{d:+d}),D'),
+ 0x0B: (0, 0, 1, 1, False, 'RRC ({r}{d:+d}),E'),
+ 0x0C: (0, 0, 1, 1, False, 'RRC ({r}{d:+d}),H'),
+ 0x0D: (0, 0, 1, 1, False, 'RRC ({r}{d:+d}),L'),
+ 0x0E: (0, 0, 1, 1, False, 'RRC ({r}{d:+d})'),
+ 0x0F: (0, 0, 1, 1, False, 'RRC ({r}{d:+d}),A'),
+
+ 0x10: (0, 0, 1, 1, False, 'RL ({r}{d:+d}),B'),
+ 0x11: (0, 0, 1, 1, False, 'RL ({r}{d:+d}),C'),
+ 0x12: (0, 0, 1, 1, False, 'RL ({r}{d:+d}),D'),
+ 0x13: (0, 0, 1, 1, False, 'RL ({r}{d:+d}),E'),
+ 0x14: (0, 0, 1, 1, False, 'RL ({r}{d:+d}),H'),
+ 0x15: (0, 0, 1, 1, False, 'RL ({r}{d:+d}),L'),
+ 0x16: (0, 0, 1, 1, False, 'RL ({r}{d:+d})'),
+ 0x17: (0, 0, 1, 1, False, 'RL ({r}{d:+d}),A'),
+ 0x18: (0, 0, 1, 1, False, 'RR ({r}{d:+d}),B'),
+ 0x19: (0, 0, 1, 1, False, 'RR ({r}{d:+d}),C'),
+ 0x1A: (0, 0, 1, 1, False, 'RR ({r}{d:+d}),D'),
+ 0x1B: (0, 0, 1, 1, False, 'RR ({r}{d:+d}),E'),
+ 0x1C: (0, 0, 1, 1, False, 'RR ({r}{d:+d}),H'),
+ 0x1D: (0, 0, 1, 1, False, 'RR ({r}{d:+d}),L'),
+ 0x1E: (0, 0, 1, 1, False, 'RR ({r}{d:+d})'),
+ 0x1F: (0, 0, 1, 1, False, 'RR ({r}{d:+d}),A'),
+
+ 0x20: (0, 0, 1, 1, False, 'SLA ({r}{d:+d}),B'),
+ 0x21: (0, 0, 1, 1, False, 'SLA ({r}{d:+d}),C'),
+ 0x22: (0, 0, 1, 1, False, 'SLA ({r}{d:+d}),D'),
+ 0x23: (0, 0, 1, 1, False, 'SLA ({r}{d:+d}),E'),
+ 0x24: (0, 0, 1, 1, False, 'SLA ({r}{d:+d}),H'),
+ 0x25: (0, 0, 1, 1, False, 'SLA ({r}{d:+d}),L'),
+ 0x26: (0, 0, 1, 1, False, 'SLA ({r}{d:+d})'),
+ 0x27: (0, 0, 1, 1, False, 'SLA ({r}{d:+d}),A'),
+ 0x28: (0, 0, 1, 1, False, 'SRA ({r}{d:+d}),B'),
+ 0x29: (0, 0, 1, 1, False, 'SRA ({r}{d:+d}),C'),
+ 0x2A: (0, 0, 1, 1, False, 'SRA ({r}{d:+d}),D'),
+ 0x2B: (0, 0, 1, 1, False, 'SRA ({r}{d:+d}),E'),
+ 0x2C: (0, 0, 1, 1, False, 'SRA ({r}{d:+d}),H'),
+ 0x2D: (0, 0, 1, 1, False, 'SRA ({r}{d:+d}),L'),
+ 0x2E: (0, 0, 1, 1, False, 'SRA ({r}{d:+d})'),
+ 0x2F: (0, 0, 1, 1, False, 'SRA ({r}{d:+d}),A'),
+
+ 0x30: (0, 0, 1, 1, False, 'SLL ({r}{d:+d}),B'),
+ 0x31: (0, 0, 1, 1, False, 'SLL ({r}{d:+d}),C'),
+ 0x32: (0, 0, 1, 1, False, 'SLL ({r}{d:+d}),D'),
+ 0x33: (0, 0, 1, 1, False, 'SLL ({r}{d:+d}),E'),
+ 0x34: (0, 0, 1, 1, False, 'SLL ({r}{d:+d}),H'),
+ 0x35: (0, 0, 1, 1, False, 'SLL ({r}{d:+d}),L'),
+ 0x36: (0, 0, 1, 1, False, 'SLL ({r}{d:+d})'),
+ 0x37: (0, 0, 1, 1, False, 'SLL ({r}{d:+d}),A'),
+ 0x38: (0, 0, 1, 1, False, 'SRL ({r}{d:+d}),B'),
+ 0x39: (0, 0, 1, 1, False, 'SRL ({r}{d:+d}),C'),
+ 0x3A: (0, 0, 1, 1, False, 'SRL ({r}{d:+d}),D'),
+ 0x3B: (0, 0, 1, 1, False, 'SRL ({r}{d:+d}),E'),
+ 0x3C: (0, 0, 1, 1, False, 'SRL ({r}{d:+d}),H'),
+ 0x3D: (0, 0, 1, 1, False, 'SRL ({r}{d:+d}),L'),
+ 0x3E: (0, 0, 1, 1, False, 'SRL ({r}{d:+d})'),
+ 0x3F: (0, 0, 1, 1, False, 'SRL ({r}{d:+d}),A'),
+
+ 0x40: (0, 0, 1, 0, False, 'BIT 0,({r}{d:+d})'),
+ 0x41: (0, 0, 1, 0, False, 'BIT 0,({r}{d:+d})'),
+ 0x42: (0, 0, 1, 0, False, 'BIT 0,({r}{d:+d})'),
+ 0x43: (0, 0, 1, 0, False, 'BIT 0,({r}{d:+d})'),
+ 0x44: (0, 0, 1, 0, False, 'BIT 0,({r}{d:+d})'),
+ 0x45: (0, 0, 1, 0, False, 'BIT 0,({r}{d:+d})'),
+ 0x46: (0, 0, 1, 0, False, 'BIT 0,({r}{d:+d})'),
+ 0x47: (0, 0, 1, 0, False, 'BIT 0,({r}{d:+d})'),
+ 0x48: (0, 0, 1, 0, False, 'BIT 1,({r}{d:+d})'),
+ 0x49: (0, 0, 1, 0, False, 'BIT 1,({r}{d:+d})'),
+ 0x4A: (0, 0, 1, 0, False, 'BIT 1,({r}{d:+d})'),
+ 0x4B: (0, 0, 1, 0, False, 'BIT 1,({r}{d:+d})'),
+ 0x4C: (0, 0, 1, 0, False, 'BIT 1,({r}{d:+d})'),
+ 0x4D: (0, 0, 1, 0, False, 'BIT 1,({r}{d:+d})'),
+ 0x4E: (0, 0, 1, 0, False, 'BIT 1,({r}{d:+d})'),
+ 0x4F: (0, 0, 1, 0, False, 'BIT 1,({r}{d:+d})'),
+
+ 0x50: (0, 0, 1, 0, False, 'BIT 2,({r}{d:+d})'),
+ 0x51: (0, 0, 1, 0, False, 'BIT 2,({r}{d:+d})'),
+ 0x52: (0, 0, 1, 0, False, 'BIT 2,({r}{d:+d})'),
+ 0x53: (0, 0, 1, 0, False, 'BIT 2,({r}{d:+d})'),
+ 0x54: (0, 0, 1, 0, False, 'BIT 2,({r}{d:+d})'),
+ 0x55: (0, 0, 1, 0, False, 'BIT 2,({r}{d:+d})'),
+ 0x56: (0, 0, 1, 0, False, 'BIT 2,({r}{d:+d})'),
+ 0x57: (0, 0, 1, 0, False, 'BIT 2,({r}{d:+d})'),
+ 0x58: (0, 0, 1, 0, False, 'BIT 3,({r}{d:+d})'),
+ 0x59: (0, 0, 1, 0, False, 'BIT 3,({r}{d:+d})'),
+ 0x5A: (0, 0, 1, 0, False, 'BIT 3,({r}{d:+d})'),
+ 0x5B: (0, 0, 1, 0, False, 'BIT 3,({r}{d:+d})'),
+ 0x5C: (0, 0, 1, 0, False, 'BIT 3,({r}{d:+d})'),
+ 0x5D: (0, 0, 1, 0, False, 'BIT 3,({r}{d:+d})'),
+ 0x5E: (0, 0, 1, 0, False, 'BIT 3,({r}{d:+d})'),
+ 0x5F: (0, 0, 1, 0, False, 'BIT 3,({r}{d:+d})'),
+
+ 0x60: (0, 0, 1, 0, False, 'BIT 4,({r}{d:+d})'),
+ 0x61: (0, 0, 1, 0, False, 'BIT 4,({r}{d:+d})'),
+ 0x62: (0, 0, 1, 0, False, 'BIT 4,({r}{d:+d})'),
+ 0x63: (0, 0, 1, 0, False, 'BIT 4,({r}{d:+d})'),
+ 0x64: (0, 0, 1, 0, False, 'BIT 4,({r}{d:+d})'),
+ 0x65: (0, 0, 1, 0, False, 'BIT 4,({r}{d:+d})'),
+ 0x66: (0, 0, 1, 0, False, 'BIT 4,({r}{d:+d})'),
+ 0x67: (0, 0, 1, 0, False, 'BIT 4,({r}{d:+d})'),
+ 0x68: (0, 0, 1, 0, False, 'BIT 5,({r}{d:+d})'),
+ 0x69: (0, 0, 1, 0, False, 'BIT 5,({r}{d:+d})'),
+ 0x6A: (0, 0, 1, 0, False, 'BIT 5,({r}{d:+d})'),
+ 0x6B: (0, 0, 1, 0, False, 'BIT 5,({r}{d:+d})'),
+ 0x6C: (0, 0, 1, 0, False, 'BIT 5,({r}{d:+d})'),
+ 0x6D: (0, 0, 1, 0, False, 'BIT 5,({r}{d:+d})'),
+ 0x6E: (0, 0, 1, 0, False, 'BIT 5,({r}{d:+d})'),
+ 0x6F: (0, 0, 1, 0, False, 'BIT 5,({r}{d:+d})'),
+
+ 0x70: (0, 0, 1, 0, False, 'BIT 6,({r}{d:+d})'),
+ 0x71: (0, 0, 1, 0, False, 'BIT 6,({r}{d:+d})'),
+ 0x72: (0, 0, 1, 0, False, 'BIT 6,({r}{d:+d})'),
+ 0x73: (0, 0, 1, 0, False, 'BIT 6,({r}{d:+d})'),
+ 0x74: (0, 0, 1, 0, False, 'BIT 6,({r}{d:+d})'),
+ 0x75: (0, 0, 1, 0, False, 'BIT 6,({r}{d:+d})'),
+ 0x76: (0, 0, 1, 0, False, 'BIT 6,({r}{d:+d})'),
+ 0x77: (0, 0, 1, 0, False, 'BIT 6,({r}{d:+d})'),
+ 0x78: (0, 0, 1, 0, False, 'BIT 7,({r}{d:+d})'),
+ 0x79: (0, 0, 1, 0, False, 'BIT 7,({r}{d:+d})'),
+ 0x7A: (0, 0, 1, 0, False, 'BIT 7,({r}{d:+d})'),
+ 0x7B: (0, 0, 1, 0, False, 'BIT 7,({r}{d:+d})'),
+ 0x7C: (0, 0, 1, 0, False, 'BIT 7,({r}{d:+d})'),
+ 0x7D: (0, 0, 1, 0, False, 'BIT 7,({r}{d:+d})'),
+ 0x7E: (0, 0, 1, 0, False, 'BIT 7,({r}{d:+d})'),
+ 0x7F: (0, 0, 1, 0, False, 'BIT 7,({r}{d:+d})'),
+
+ 0x80: (0, 0, 1, 1, False, 'RES 0,({r}{d:+d}),B'),
+ 0x81: (0, 0, 1, 1, False, 'RES 0,({r}{d:+d}),C'),
+ 0x82: (0, 0, 1, 1, False, 'RES 0,({r}{d:+d}),D'),
+ 0x83: (0, 0, 1, 1, False, 'RES 0,({r}{d:+d}),E'),
+ 0x84: (0, 0, 1, 1, False, 'RES 0,({r}{d:+d}),H'),
+ 0x85: (0, 0, 1, 1, False, 'RES 0,({r}{d:+d}),L'),
+ 0x86: (0, 0, 1, 1, False, 'RES 0,({r}{d:+d})'),
+ 0x87: (0, 0, 1, 1, False, 'RES 0,({r}{d:+d}),A'),
+ 0x88: (0, 0, 1, 1, False, 'RES 1,({r}{d:+d}),B'),
+ 0x89: (0, 0, 1, 1, False, 'RES 1,({r}{d:+d}),C'),
+ 0x8A: (0, 0, 1, 1, False, 'RES 1,({r}{d:+d}),D'),
+ 0x8B: (0, 0, 1, 1, False, 'RES 1,({r}{d:+d}),E'),
+ 0x8C: (0, 0, 1, 1, False, 'RES 1,({r}{d:+d}),H'),
+ 0x8D: (0, 0, 1, 1, False, 'RES 1,({r}{d:+d}),L'),
+ 0x8E: (0, 0, 1, 1, False, 'RES 1,({r}{d:+d})'),
+ 0x8F: (0, 0, 1, 1, False, 'RES 1,({r}{d:+d}),A'),
+
+ 0x90: (0, 0, 1, 1, False, 'RES 2,({r}{d:+d}),B'),
+ 0x91: (0, 0, 1, 1, False, 'RES 2,({r}{d:+d}),C'),
+ 0x92: (0, 0, 1, 1, False, 'RES 2,({r}{d:+d}),D'),
+ 0x93: (0, 0, 1, 1, False, 'RES 2,({r}{d:+d}),E'),
+ 0x94: (0, 0, 1, 1, False, 'RES 2,({r}{d:+d}),H'),
+ 0x95: (0, 0, 1, 1, False, 'RES 2,({r}{d:+d}),L'),
+ 0x96: (0, 0, 1, 1, False, 'RES 2,({r}{d:+d})'),
+ 0x97: (0, 0, 1, 1, False, 'RES 2,({r}{d:+d}),A'),
+ 0x98: (0, 0, 1, 1, False, 'RES 3,({r}{d:+d}),B'),
+ 0x99: (0, 0, 1, 1, False, 'RES 3,({r}{d:+d}),C'),
+ 0x9A: (0, 0, 1, 1, False, 'RES 3,({r}{d:+d}),D'),
+ 0x9B: (0, 0, 1, 1, False, 'RES 3,({r}{d:+d}),E'),
+ 0x9C: (0, 0, 1, 1, False, 'RES 3,({r}{d:+d}),H'),
+ 0x9D: (0, 0, 1, 1, False, 'RES 3,({r}{d:+d}),L'),
+ 0x9E: (0, 0, 1, 1, False, 'RES 3,({r}{d:+d})'),
+ 0x9F: (0, 0, 1, 1, False, 'RES 3,({r}{d:+d}),A'),
+
+ 0xA0: (0, 0, 1, 1, False, 'RES 4,({r}{d:+d}),B'),
+ 0xA1: (0, 0, 1, 1, False, 'RES 4,({r}{d:+d}),C'),
+ 0xA2: (0, 0, 1, 1, False, 'RES 4,({r}{d:+d}),D'),
+ 0xA3: (0, 0, 1, 1, False, 'RES 4,({r}{d:+d}),E'),
+ 0xA4: (0, 0, 1, 1, False, 'RES 4,({r}{d:+d}),H'),
+ 0xA5: (0, 0, 1, 1, False, 'RES 4,({r}{d:+d}),L'),
+ 0xA6: (0, 0, 1, 1, False, 'RES 4,({r}{d:+d})'),
+ 0xA7: (0, 0, 1, 1, False, 'RES 4,({r}{d:+d}),A'),
+ 0xA8: (0, 0, 1, 1, False, 'RES 5,({r}{d:+d}),B'),
+ 0xA9: (0, 0, 1, 1, False, 'RES 5,({r}{d:+d}),C'),
+ 0xAA: (0, 0, 1, 1, False, 'RES 5,({r}{d:+d}),D'),
+ 0xAB: (0, 0, 1, 1, False, 'RES 5,({r}{d:+d}),E'),
+ 0xAC: (0, 0, 1, 1, False, 'RES 5,({r}{d:+d}),H'),
+ 0xAD: (0, 0, 1, 1, False, 'RES 5,({r}{d:+d}),L'),
+ 0xAE: (0, 0, 1, 1, False, 'RES 5,({r}{d:+d})'),
+ 0xAF: (0, 0, 1, 1, False, 'RES 5,({r}{d:+d}),A'),
+
+ 0xB0: (0, 0, 1, 1, False, 'RES 6,({r}{d:+d}),B'),
+ 0xB1: (0, 0, 1, 1, False, 'RES 6,({r}{d:+d}),C'),
+ 0xB2: (0, 0, 1, 1, False, 'RES 6,({r}{d:+d}),D'),
+ 0xB3: (0, 0, 1, 1, False, 'RES 6,({r}{d:+d}),E'),
+ 0xB4: (0, 0, 1, 1, False, 'RES 6,({r}{d:+d}),H'),
+ 0xB5: (0, 0, 1, 1, False, 'RES 6,({r}{d:+d}),L'),
+ 0xB6: (0, 0, 1, 1, False, 'RES 6,({r}{d:+d})'),
+ 0xB7: (0, 0, 1, 1, False, 'RES 6,({r}{d:+d}),A'),
+ 0xB8: (0, 0, 1, 1, False, 'RES 7,({r}{d:+d}),B'),
+ 0xB9: (0, 0, 1, 1, False, 'RES 7,({r}{d:+d}),C'),
+ 0xBA: (0, 0, 1, 1, False, 'RES 7,({r}{d:+d}),D'),
+ 0xBB: (0, 0, 1, 1, False, 'RES 7,({r}{d:+d}),E'),
+ 0xBC: (0, 0, 1, 1, False, 'RES 7,({r}{d:+d}),H'),
+ 0xBD: (0, 0, 1, 1, False, 'RES 7,({r}{d:+d}),L'),
+ 0xBE: (0, 0, 1, 1, False, 'RES 7,({r}{d:+d})'),
+ 0xBF: (0, 0, 1, 1, False, 'RES 7,({r}{d:+d}),A'),
+
+ 0xC0: (0, 0, 1, 1, False, 'SET 0,({r}{d:+d}),B'),
+ 0xC1: (0, 0, 1, 1, False, 'SET 0,({r}{d:+d}),C'),
+ 0xC2: (0, 0, 1, 1, False, 'SET 0,({r}{d:+d}),D'),
+ 0xC3: (0, 0, 1, 1, False, 'SET 0,({r}{d:+d}),E'),
+ 0xC4: (0, 0, 1, 1, False, 'SET 0,({r}{d:+d}),H'),
+ 0xC5: (0, 0, 1, 1, False, 'SET 0,({r}{d:+d}),L'),
+ 0xC6: (0, 0, 1, 1, False, 'SET 0,({r}{d:+d})'),
+ 0xC7: (0, 0, 1, 1, False, 'SET 0,({r}{d:+d}),A'),
+ 0xC8: (0, 0, 1, 1, False, 'SET 1,({r}{d:+d}),B'),
+ 0xC9: (0, 0, 1, 1, False, 'SET 1,({r}{d:+d}),C'),
+ 0xCA: (0, 0, 1, 1, False, 'SET 1,({r}{d:+d}),D'),
+ 0xCB: (0, 0, 1, 1, False, 'SET 1,({r}{d:+d}),E'),
+ 0xCC: (0, 0, 1, 1, False, 'SET 1,({r}{d:+d}),H'),
+ 0xCD: (0, 0, 1, 1, False, 'SET 1,({r}{d:+d}),L'),
+ 0xCE: (0, 0, 1, 1, False, 'SET 1,({r}{d:+d})'),
+ 0xCF: (0, 0, 1, 1, False, 'SET 1,({r}{d:+d}),A'),
+
+ 0xD0: (0, 0, 1, 1, False, 'SET 2,({r}{d:+d}),B'),
+ 0xD1: (0, 0, 1, 1, False, 'SET 2,({r}{d:+d}),C'),
+ 0xD2: (0, 0, 1, 1, False, 'SET 2,({r}{d:+d}),D'),
+ 0xD3: (0, 0, 1, 1, False, 'SET 2,({r}{d:+d}),E'),
+ 0xD4: (0, 0, 1, 1, False, 'SET 2,({r}{d:+d}),H'),
+ 0xD5: (0, 0, 1, 1, False, 'SET 2,({r}{d:+d}),L'),
+ 0xD6: (0, 0, 1, 1, False, 'SET 2,({r}{d:+d})'),
+ 0xD7: (0, 0, 1, 1, False, 'SET 2,({r}{d:+d}),A'),
+ 0xD8: (0, 0, 1, 1, False, 'SET 3,({r}{d:+d}),B'),
+ 0xD9: (0, 0, 1, 1, False, 'SET 3,({r}{d:+d}),C'),
+ 0xDA: (0, 0, 1, 1, False, 'SET 3,({r}{d:+d}),D'),
+ 0xDB: (0, 0, 1, 1, False, 'SET 3,({r}{d:+d}),E'),
+ 0xDC: (0, 0, 1, 1, False, 'SET 3,({r}{d:+d}),H'),
+ 0xDD: (0, 0, 1, 1, False, 'SET 3,({r}{d:+d}),L'),
+ 0xDE: (0, 0, 1, 1, False, 'SET 3,({r}{d:+d})'),
+ 0xDF: (0, 0, 1, 1, False, 'SET 3,({r}{d:+d}),A'),
+
+ 0xE0: (0, 0, 1, 1, False, 'SET 4,({r}{d:+d}),B'),
+ 0xE1: (0, 0, 1, 1, False, 'SET 4,({r}{d:+d}),C'),
+ 0xE2: (0, 0, 1, 1, False, 'SET 4,({r}{d:+d}),D'),
+ 0xE3: (0, 0, 1, 1, False, 'SET 4,({r}{d:+d}),E'),
+ 0xE4: (0, 0, 1, 1, False, 'SET 4,({r}{d:+d}),H'),
+ 0xE5: (0, 0, 1, 1, False, 'SET 4,({r}{d:+d}),L'),
+ 0xE6: (0, 0, 1, 1, False, 'SET 4,({r}{d:+d})'),
+ 0xE7: (0, 0, 1, 1, False, 'SET 4,({r}{d:+d}),A'),
+ 0xE8: (0, 0, 1, 1, False, 'SET 5,({r}{d:+d}),B'),
+ 0xE9: (0, 0, 1, 1, False, 'SET 5,({r}{d:+d}),C'),
+ 0xEA: (0, 0, 1, 1, False, 'SET 5,({r}{d:+d}),D'),
+ 0xEB: (0, 0, 1, 1, False, 'SET 5,({r}{d:+d}),E'),
+ 0xEC: (0, 0, 1, 1, False, 'SET 5,({r}{d:+d}),H'),
+ 0xED: (0, 0, 1, 1, False, 'SET 5,({r}{d:+d}),L'),
+ 0xEE: (0, 0, 1, 1, False, 'SET 5,({r}{d:+d})'),
+ 0xEF: (0, 0, 1, 1, False, 'SET 5,({r}{d:+d}),A'),
+
+ 0xF0: (0, 0, 1, 1, False, 'SET 6,({r}{d:+d}),B'),
+ 0xF1: (0, 0, 1, 1, False, 'SET 6,({r}{d:+d}),C'),
+ 0xF2: (0, 0, 1, 1, False, 'SET 6,({r}{d:+d}),D'),
+ 0xF3: (0, 0, 1, 1, False, 'SET 6,({r}{d:+d}),E'),
+ 0xF4: (0, 0, 1, 1, False, 'SET 6,({r}{d:+d}),H'),
+ 0xF5: (0, 0, 1, 1, False, 'SET 6,({r}{d:+d}),L'),
+ 0xF6: (0, 0, 1, 1, False, 'SET 6,({r}{d:+d})'),
+ 0xF7: (0, 0, 1, 1, False, 'SET 6,({r}{d:+d}),A'),
+ 0xF8: (0, 0, 1, 1, False, 'SET 7,({r}{d:+d}),B'),
+ 0xF9: (0, 0, 1, 1, False, 'SET 7,({r}{d:+d}),C'),
+ 0xFA: (0, 0, 1, 1, False, 'SET 7,({r}{d:+d}),D'),
+ 0xFB: (0, 0, 1, 1, False, 'SET 7,({r}{d:+d}),E'),
+ 0xFC: (0, 0, 1, 1, False, 'SET 7,({r}{d:+d}),H'),
+ 0xFD: (0, 0, 1, 1, False, 'SET 7,({r}{d:+d}),L'),
+ 0xFE: (0, 0, 1, 1, False, 'SET 7,({r}{d:+d})'),
+ 0xFF: (0, 0, 1, 1, False, 'SET 7,({r}{d:+d}),A')
+}
+
+instr_table_by_prefix = {
+ 0: (main_instructions, ''),
+ 0xED: (extended_instructions, ''),
+ 0xCB: (bit_instructions, ''),
+ 0xDD: (index_instructions, 'IX'),
+ 0xFD: (index_instructions, 'IY'),
+ 0xDDCB: (index_bit_instructions, 'IX'),
+ 0xFDCB: (index_bit_instructions, 'IY')
+}