shithub: scc

Download patch

ref: f967fb57f65afdb0a33e56b1ad9f15bb72366001
parent: 5247d32a51b1bfab5b5c63d1894a3f896a9b9212
author: Roberto E. Vargas Caballero <k0ga@shike2.com>
date: Fri Jan 19 09:35:39 EST 2018

[as] Change the filesystem tree

The file organization was very confusing and was common to
have related files in different directories. This new
structure is simple and have all the benefits and none
of the problems of the old one.

--- a/as/Makefile
+++ b/as/Makefile
@@ -26,7 +26,7 @@
 clean:
 	rm -f *.o
 	rm -f target/*/*.o
-	rm -f target/*/instbl.c
+	rm -f target/*/*tbl.c
 	rm -f as-*
 
 distclean: clean
--- a/as/gendep.sh
+++ b/as/gendep.sh
@@ -15,7 +15,7 @@
 while read i
 do
 	cat <<EOF
-include target/$i/target.mk
+include target/$i.mk
 
 \$(OBJ-$i): \$(HDR)
 all: as-$i
--- /dev/null
+++ b/as/gentbl.awk
@@ -1,0 +1,109 @@
+
+BEGIN		{
+		printf "#include \"../../../inc/scc.h\"\n"\
+		       "#include \"../../as.h\"\n"\
+		       "#include \"../" family "/proc.h\"\n"
+		nop = 0; nvar = 0
+
+		rules = "target/" family "/rules.dat" 
+		while (getline < rules > 0) {
+			regex[++nregs] = $1
+			value[nregs] = $2
+		}
+		close("target/rules.awk")
+}
+		{sub(/#.*/,"")}
+
+$7 !~ cpu	{next}
+
+/^$/		{next}
+
+		{
+		if (opstart[$1] == 0) {
+			opstart[$1] = nvar
+			opnames[nop++] = $1
+		}
+		opcount[$1]++
+		opargs[nvar] = $3
+		opsize[nvar] = $4
+		opbytes[nvar] = ($5 == "none") ? "" : $5
+		opformat[nvar++] = $6
+		formats[$6] = 1
+}
+
+END		{
+		for (i in formats)
+			printf "Format %s;\n", i
+
+		printf "int nr_ins = %d;\n\n", nop
+		print "struct ins instab[] = {"
+		for (i = 0; i < nop; i++) {
+			n = opnames[i]
+			start = opstart[n]
+			end = start + opcount[n]
+			printf "\t{.str = \"%s\", .begin = %d, .end = %d},\n",
+			       n, start, end | "sort"
+		}
+		close("sort")
+		printf "};\n\n"
+
+		print "struct op optab[] = {"
+		for (i = 0; i < nvar; i++) {
+			printf "\t/* %d */\n", i
+			printf "\t{\n" \
+			       "\t\t.size = %d,\n"\
+			       "\t\t.format = %s,\n",
+			       opsize[i], opformat[i]
+
+			if (opbytes[i] != "")
+				printf "\t\t.bytes = (unsigned char [%d]) {%s},\n",
+				        opsize[i],
+				        opbytes[i]
+
+			a = str2args(opargs[i])
+			if (a != "")
+				printf "\t\t.args = (unsigned char []) {%s}\n", a
+
+			print "\t},"
+		}
+		print "};"
+}
+
+function str2args(s, args, i, j, out, n, found)
+{
+	n = split(s, args, /,/)
+	if (n == 0 || args[1] == "none")
+		return ""
+	for (i = 1; i <= n; i++) {
+		a = args[i]
+		found = 0
+		for (j = 1; j <= nregs; j++) {
+			if (match(a, "^" regex[j])) {
+				out = out value[j]
+				found = 1
+				break
+			}
+		}
+
+		if (!found) {
+			print FILENAME ":" NR ":" \
+			      $0 ":wrong arg", a > "/dev/stderr"
+			exit 1
+		}
+
+		a = substr(a, RLENGTH+1)
+		if (a ~ /^\+$/) {
+			return out "|AREP"
+		} else if (a ~ /^\?$/) {
+			return out "|AOPT"
+		} else if (a != "") {
+			print FILENAME ":" NR ":" \
+			      $0 ": trailing chars: ", a > "/dev/stderr"
+			exit 1
+		}
+		out = out ","
+	}
+	out = out "0"
+
+	return out
+}
--- /dev/null
+++ b/as/gentbl.sh
@@ -1,0 +1,33 @@
+#!/bin/sh
+
+
+set -e
+
+while test $# -gt 0
+do
+	case $1 in
+	-c)
+		cpu=$2
+		shift
+		;;
+	-f)
+		family=$2
+		shift
+		;;
+	*)
+		echo gen.sh:incorrect parameter:$1 >&2
+		exit 1
+		;;
+	esac
+	shift
+done
+
+echo cpu=${cpu:=z80} family=${family:=x80}
+
+rm -f  $$.c target/$family/${cpu}tbl.c
+trap "rm -f $$.c" 0 2 3
+
+awk '!/^$/ {print $1,NR,$2,$3,$4,$5,$6}' target/$family/$family.dat |
+sort -k1 -k2n |
+awk -v cpu=`echo $cpu | tr a-z A-Z` -v family=$family -f gentbl.awk  > $$.c &&
+mv $$.c target/$family/${cpu}tbl.c
--- /dev/null
+++ b/as/target/amd64.mk
@@ -1,0 +1,9 @@
+
+amd64_LST = target/x86/amd64tbl.o target/x86/amd64.o target/x86/ins.o
+
+$(amd64_LST): target/x86/proc.h
+
+target/x86/amd64tbl.c: gentbl.awk target/x86/x86.dat target/x86/rules.dat
+	./gentbl.sh -f x86 -c amd64
+
+OBJ-amd64 = $(OBJ) $(amd64_LST)
--- a/as/target/amd64/ins.c
+++ /dev/null
@@ -1,7 +1,0 @@
-static char sccsid[] = "@(#) ./as/target/amd64/ins.c";
-
-#include "../../../inc/scc.h"
-#include "../../as.h"
-
-TUINT maxaddr = 0xFFFFFFFFFFFFFFFF;
-int endian = LITTLE_ENDIAN;
--- a/as/target/amd64/proc.c
+++ /dev/null
@@ -1,16 +1,0 @@
-static char sccsid[] = "@(#) ./as/target/amd64/proc.c";
-
-#include "../../../inc/scc.h"
-#include "../../as.h"
-
-
-void
-iarch(void)
-{
-}
-
-int
-match(Op *op, Node **args)
-{
-	return 1;
-}
--- a/as/target/amd64/target.mk
+++ /dev/null
@@ -1,15 +1,0 @@
-
-AMD64_LST = target/amd64/instbl.o target/amd64/ins.o target/amd64/proc.o
-
-$(AMD64_LST): target/x86/proc.h
-
-target/amd64/instbl.c: target/gen.awk target/x86/x86.dat target/x86/rules.dat
-	set -e ;\
-	rm -f $@;\
-	trap "rm -f $$$$.c" 0 2 3; \
-	awk '!/^$$/ {print $$1,NR,$$2,$$3,$$4,$$5,$$6}' target/x86/x86.dat | \
-	sort -k1 -k2n | \
-	awk -v cpu=BITS64 -v family=x86 \
-		-f target/gen.awk  > $$$$.c && mv $$$$.c $@
-
-OBJ-amd64 = $(OBJ) $(AMD64_LST)
--- a/as/target/gen.awk
+++ /dev/null
@@ -1,109 +1,0 @@
-
-BEGIN		{
-		printf "#include \"../../../inc/scc.h\"\n"\
-		       "#include \"../../as.h\"\n"\
-		       "#include \"../" family "/proc.h\"\n"
-		nop = 0; nvar = 0
-
-		rules = "target/" family "/rules.dat" 
-		while (getline < rules > 0) {
-			regex[++nregs] = $1
-			value[nregs] = $2
-		}
-		close("target/rules.awk")
-}
-		{sub(/#.*/,"")}
-
-$7 !~ cpu	{next}
-
-/^$/		{next}
-
-		{
-		if (opstart[$1] == 0) {
-			opstart[$1] = nvar
-			opnames[nop++] = $1
-		}
-		opcount[$1]++
-		opargs[nvar] = $3
-		opsize[nvar] = $4
-		opbytes[nvar] = ($5 == "none") ? "" : $5
-		opformat[nvar++] = $6
-		formats[$6] = 1
-}
-
-END		{
-		for (i in formats)
-			printf "Format %s;\n", i
-
-		printf "int nr_ins = %d;\n\n", nop
-		print "struct ins instab[] = {"
-		for (i = 0; i < nop; i++) {
-			n = opnames[i]
-			start = opstart[n]
-			end = start + opcount[n]
-			printf "\t{.str = \"%s\", .begin = %d, .end = %d},\n",
-			       n, start, end | "sort"
-		}
-		close("sort")
-		printf "};\n\n"
-
-		print "struct op optab[] = {"
-		for (i = 0; i < nvar; i++) {
-			printf "\t/* %d */\n", i
-			printf "\t{\n" \
-			       "\t\t.size = %d,\n"\
-			       "\t\t.format = %s,\n",
-			       opsize[i], opformat[i]
-
-			if (opbytes[i] != "")
-				printf "\t\t.bytes = (unsigned char [%d]) {%s},\n",
-				        opsize[i],
-				        opbytes[i]
-
-			a = str2args(opargs[i])
-			if (a != "")
-				printf "\t\t.args = (unsigned char []) {%s}\n", a
-
-			print "\t},"
-		}
-		print "};"
-}
-
-function str2args(s, args, i, j, out, n, found)
-{
-	n = split(s, args, /,/)
-	if (n == 0 || args[1] == "none")
-		return ""
-	for (i = 1; i <= n; i++) {
-		a = args[i]
-		found = 0
-		for (j = 1; j <= nregs; j++) {
-			if (match(a, "^" regex[j])) {
-				out = out value[j]
-				found = 1
-				break
-			}
-		}
-
-		if (!found) {
-			print FILENAME ":" NR ":" \
-			      $0 ":wrong arg", a > "/dev/stderr"
-			exit 1
-		}
-
-		a = substr(a, RLENGTH+1)
-		if (a ~ /^\+$/) {
-			return out "|AREP"
-		} else if (a ~ /^\?$/) {
-			return out "|AOPT"
-		} else if (a != "") {
-			print FILENAME ":" NR ":" \
-			      $0 ": trailing chars: ", a > "/dev/stderr"
-			exit 1
-		}
-		out = out ","
-	}
-	out = out "0"
-
-	return out
-}
--- /dev/null
+++ b/as/target/i386.mk
@@ -1,0 +1,9 @@
+
+i386_LST = target/x86/i386tbl.o target/x86/i386.o target/x86/ins.o
+
+$(i386_LST): target/x86/proc.h
+
+target/x86/i386tbl.c: gentbl.awk target/x86/x86.dat target/x86/rules.dat
+	./gentbl.sh -f x86 -c i386
+
+OBJ-i386 = $(OBJ) $(i386_LST)
--- a/as/target/i386/ins.c
+++ /dev/null
@@ -1,7 +1,0 @@
-static char sccsid[] = "@(#) ./as/target/i386/ins.c";
-
-#include "../../../inc/scc.h"
-#include "../../as.h"
-
-TUINT maxaddr = 0xFFFFFFFF;
-int endian = LITTLE_ENDIAN;
--- a/as/target/i386/proc.c
+++ /dev/null
@@ -1,130 +1,0 @@
-static char sccsid[] = "@(#) ./as/target/i386/proc.c";
-
-#include <stdlib.h>
-
-#include "../../../inc/scc.h"
-#include "../../as.h"
-#include "../x86/proc.h"
-
-void
-iarch(void)
-{
-	static struct {
-		char *name;
-		char type;
-	} regs[] = {
-		"CS", AREG_CS,
-		"DS", AREG_DS,
-		"SS", AREG_SS,
-		"ES", AREG_ES,
-		"FS", AREG_FS,
-		"GS", AREG_GS,
-
-		"AX", AREG_AX,
-		"AL", AREG_AL,
-		"AH", AREG_AH,
-		"EAX", AREG_EAX,
-
-		"BC", AREG_BX,
-		"BL", AREG_BL,
-		"BH", AREG_BH,
-		"EBX", AREG_EBX,
-
-		"CX", AREG_CX,
-		"CL", AREG_CL,
-		"CH", AREG_CH,
-		"ECX", AREG_ECX,
-
-		"DX", AREG_DX,
-		"DL", AREG_DL,
-		"DH", AREG_DH,
-		"EDX", AREG_EDX,
-
-		"SI", AREG_SI,
-		"ESI", AREG_ESI,
-		"DI", AREG_DI,
-		"EDI", AREG_EDI,
-
-		"SP", AREG_SP,
-		"ESP", AREG_ESP,
-
-		"BP", AREG_BP,
-		"EBP", AREG_EBP,
-
-		"R0", AREG_R0,
-		"MM0", AREG_MM0,
-		"R1", AREG_R1,
-		"MM1", AREG_MM1,
-		"R2", AREG_R2,
-		"MM2", AREG_MM2,
-		"R3", AREG_R3,
-		"MM3", AREG_MM3,
-		"R4", AREG_R4,
-		"MM4", AREG_MM4,
-		"R5", AREG_R5,
-		"MM5", AREG_MM5,
-		"R6", AREG_R6,
-		"MM6", AREG_MM6,
-		"R7", AREG_R7,
-		"MM7", AREG_MM7,
-
-		"XMM0", AREG_XMM0,
-		"XMM1", AREG_XMM1,
-		"XMM2", AREG_XMM2,
-		"XMM3", AREG_XMM3,
-		"XMM4", AREG_XMM4,
-		"XMM5", AREG_XMM5,
-		"XMM6", AREG_XMM6,
-		"XMM7", AREG_XMM7,
-
-		"YMM0", AREG_YMM0,
-		"YMM1", AREG_YMM1,
-		"YMM2", AREG_YMM2,
-		"YMM3", AREG_YMM3,
-		"YMM4", AREG_YMM4,
-		"YMM5", AREG_YMM5,
-		"YMM6", AREG_YMM6,
-		"YMM7", AREG_YMM7,
-
-		"MXCSR", AREG_MXCSR,
-
-		NULL
-	}, *bp;
-
-	for (bp = regs; bp->name; ++bp) {
-		Symbol *sym = lookup(bp->name);
-		sym->flags = FREG;
-		sym->value = bp->type;
-	}
-}
-
-int
-match(Op *op, Node **args)
-{
-	unsigned char *p;
-	int a, olda;
-
-	if (!op->args)
-		return args == NULL;
-
-	for (p = op->args; *p; ++p) {
-		if (*p != AREP)
-			a = *p;
-		else
-			--p;
-
-		switch (a) {
-		case AIMM8:
-		case AIMM16:
-		case AIMM32:
-		case AIMM64:
-		case AREG_AL:
-		case AREG_AH:
-		case AREG_AX:
-		case AREG_EAX:
-		default:
-			abort();
-		}
-	}
-	return 1;
-}
--- a/as/target/i386/target.mk
+++ /dev/null
@@ -1,15 +1,0 @@
-
-I386_LST = target/i386/instbl.o target/i386/ins.o target/i386/proc.o
-
-$(I386_LST): target/x86/proc.h
-
-target/i386/instbl.c: target/gen.awk target/x86/x86.dat
-	set -e ;\
-	rm -f $@;\
-	trap "rm -f $$$$.c" 0 2 3; \
-	awk '!/^$$/ {print $$1,NR,$$2,$$3,$$4,$$5,$$6}' target/x86/x86.dat | \
-	sort -k1 -k2n | \
-	awk -v cpu=BITS32 -v family=x86 \
-		-f target/gen.awk > $$$$.c && mv $$$$.c $@
-
-OBJ-i386 = $(OBJ) $(I386_LST)
--- a/as/target/x80/ins.c
+++ b/as/target/x80/ins.c
@@ -1,4 +1,4 @@
-static char sccsid[] = "@(#) ./as/target/z80/ins.c";
+static char sccsid[] = "@(#) ./as/target/x80/ins.c";
 
 #include <stdlib.h>
 #include <string.h>
@@ -13,6 +13,140 @@
  *	- Decoding Z80 opcodes - of use to disassembler and emulator
  *	  writers - by Cristian Dinu.
  */
+
+int
+match(Op *op, Node **args)
+{
+	unsigned char *p;
+	int arg, class;
+	Node *np;
+
+	if (!op->args)
+		return args == NULL;
+
+	for (p = op->args; arg = *p; ++p) {
+		if (arg & AREP)
+			--p;
+		if ((np = *args++) == NULL)
+			return (arg & (AREP|AOPT)) != 0;
+
+		arg &= ~(AREP|AOPT);
+		switch (arg) {
+		case AINDER_C:
+			arg = AREG_C;
+			goto indirect;
+		case AINDER_HL:
+			arg = AREG_HL;
+			goto indirect;
+		case AINDER_DE:
+			arg = AREG_DE;
+			goto indirect;
+		case AINDER_BC:
+			arg = AREG_BC;
+			goto indirect;
+		case AINDER_IX:
+			arg = AREG_IX;
+			goto indirect;
+		case AINDER_IY:
+			arg = AREG_IY;
+			goto indirect;
+		case AINDER_SP:
+			arg = AREG_SP;
+		indirect:
+			if (np->addr != AINDIR)
+				return 0;
+			np = np->left;
+		case AREG_A:
+		case AREG_I:
+		case AREG_R:
+		case AREG_F:
+		case AREG_HL:
+		case AREG_BC:
+		case AREG_DE:
+		case AREG_IY:
+		case AREG_IX:
+		case AREG_SP:
+		case AREG_AF:
+		case AREG_AF_:
+			if (np->addr != AREG || np->sym->value != arg)
+				return 0;
+			break;
+		case AREG_RCLASS:
+			class = RCLASS;
+			goto check_class;
+		case AREG_PCLASS:
+			class = PCLASS;
+			goto check_class;
+		case AREG_QCLASS:
+			class = QCLASS;
+			goto check_class;
+		case AREG_QQCLASS:
+			class = QQCLASS;
+			goto check_class;
+		case AREG_PPCLASS:
+			class = PPCLASS;
+			goto check_class;
+		case AREG_RRCLASS:
+			class = RRCLASS;
+			goto check_class;
+		case AREG_CCCLASS:
+			class = CCCLASS;
+			goto check_class;
+		case AREG_SSCLASS:
+			class = SSCLASS;
+			goto check_class;
+		case AREG_DDCLASS:
+			class = DDCLASS;
+		check_class:
+			if ((getclass(np) & class) == 0)
+				return 0;
+			break;
+		case AINDEX_IY:
+			arg = AREG_IY;
+			goto index_address;
+		case AINDEX_IX:
+			arg = AREG_IX;
+		index_address:
+			if (np->addr != AINDEX)
+				return 0;
+			if (np->left->left->sym->value != arg)
+				return 0;
+			if (toobig(np, arg))
+				error("overflow in index");
+			break;
+		case ARST:
+			if (np->addr != AIMM)
+				return 0;
+			if ((np->sym->value & ~0x38) != 0)
+				return 0;
+			break;
+		case AZERO:
+		case AIMM3:
+		case AIMM8:
+		case AIMM16:
+		case AIMM32:
+		case AIMM64:
+			if (np->addr != AIMM)
+				return 0;
+			if (toobig(np, arg))
+				error("overflow in immediate operand");
+			break;
+		case ASYM:
+			if (np->addr != AIMM || np->op != IDEN)
+				return 0;
+			break;
+		case ADIRECT:
+		case ASTR:
+			if (np->addr != arg)
+				return 0;
+			break;
+		default:
+			abort();
+		}
+	}
+
+	return *args == NULL;
+}
 
 int
 getclass(Node *np)
--- /dev/null
+++ b/as/target/x80/z80-test.s
@@ -1,0 +1,1136 @@
+	NOP		/ 00
+	LD	%BC,64	/ 01 40 00
+	LD	[%BC],%A	/ 02
+	INC	%BC	/ 03
+	INC	%B	/ 04
+	DEC	%B	/ 05
+	LD	%B,32	/ 06 20
+	RLCA		/ 07
+	EX	%AF,%AF'	/ 08
+	ADD	%HL,%BC	/ 09
+	LD	%A,[%BC]	/ 0A
+	DEC	%BC	/ 0B
+	INC	%C	/ 0C
+	DEC	%C	/ 0D
+	LD	%C,64	/ 0E 40
+	RRCA		/ 0F
+L1:	DJNZ	L1	/ 10 02
+	LD	%DE,32	/ 11 20 00
+	LD	[%DE],%A	/ 12
+	INC	%DE	/ 13
+	INC	%D	/ 14
+	DEC	%D	/ 15
+	LD	%D,64	/ 16 40
+	RLA		/ 17
+L2:	JR	L2	/ 18 02
+	ADD	%HL,%DE	/ 19
+	LD	%A,[%DE]	/ 1A
+	DEC	%DE	/ 1B
+	INC	%E	/ 1C
+	DEC	%E	/ 1D
+	LD	%E,64	/ 1E 40
+	RRA		/ 1F
+L3:	JR	%NZ,L3	/ 20 02
+	LD	%HL,32	/ 21 20 00
+	LD	[32768],%HL	/ 22 00 80
+	INC	%HL	/ 23
+	INC	%H	/ 24
+	DEC	%H	/ 25
+	LD	%H,64	/ 26 40
+	DAA		/ 27
+L4:	JR	%Z,L4	/ 28 02
+	ADD	%HL,%HL	/ 29
+	LD	%HL, [16384]	/ 2A 00 40
+	DEC	%HL	/ 2B
+	INC	%L	/ 2C
+	DEC	%L	/ 2D
+	LD	%L,32	/ 2E 20
+	CPL		/ 2F
+L5:	JR	%NC,L5	/ 30 02
+	LD	%SP,64	/ 31 40 00
+	LD	[32768],%A	/ 32 00 80
+	INC	%SP	/ 33
+	INC	[%HL]	/ 34
+	DEC	[%HL]	/ 35
+	LD	[%HL],32	/ 36 20
+	SCF		/ 37
+L6:	JR	%C,L6	/ 38 02
+	ADD	%HL,%SP	/ 39
+	LD	%A,[16384]	/ 3A 00 40
+	DEC	%SP	/ 3B
+	INC	%A	/ 3C
+	DEC	%A	/ 3D
+	LD	%A,32	/ 3E 20
+	CCF		/ 3F
+	LD	%B,%B	/ 40
+	LD	%B,%C	/ 41
+	LD	%B,%D	/ 42
+	LD	%B,%E	/ 43
+	LD	%B,%H	/ 44
+	LD	%B,%L	/ 45
+	LD	%B,[%HL]	/ 46
+	LD	%B,%A	/ 47
+	LD	%C,%B	/ 48
+	LD	%C,%C	/ 49
+	LD	%C,%D	/ 4A
+	LD	%C,%E	/ 4B
+	LD	%C,%H	/ 4C
+	LD	%C,%L	/ 4D
+	LD	%C,[%HL]	/ 4E
+	LD	%C,%A	/ 4F
+	LD	%D,%B	/ 50
+	LD	%D,%C	/ 51
+	LD	%D,%D	/ 52
+	LD	%D,%E	/ 53
+	LD	%D,%H	/ 54
+	LD	%D,%L	/ 55
+	LD	%D,[%HL]	/ 56
+	LD	%D,%A	/ 57
+	LD	%E,%B	/ 58
+	LD	%E,%C	/ 59
+	LD	%E,%D	/ 5A
+	LD	%E,%E	/ 5B
+	LD	%E,%H	/ 5C
+	LD	%E,%L	/ 5D
+	LD	%E,[%HL]	/ 5E
+	LD	%E,%A	/ 5F
+	LD	%H,%B	/ 60
+	LD	%H,%C	/ 61
+	LD	%H,%D	/ 62
+	LD	%H,%E	/ 63
+	LD	%H,%H	/ 64
+	LD	%H,%L	/ 65
+	LD	%H,[%HL]	/ 66
+	LD	%H,%A	/ 67
+	LD	%L,%B	/ 68
+	LD	%L,%C	/ 69
+	LD	%L,%D	/ 6A
+	LD	%L,%E	/ 6B
+	LD	%L,%H	/ 6C
+	LD	%L,%L	/ 6D
+	LD	%L,[%HL]	/ 6E
+	LD	%L,%A	/ 6F
+	LD	[%HL],%B	/ 70
+	LD	[%HL],%C	/ 71
+	LD	[%HL],%D	/ 72
+	LD	[%HL],%E	/ 73
+	LD	[%HL],%H	/ 74
+	LD	[%HL],%L	/ 75
+	HALT		/ 76
+	LD	[%HL],%A	/ 77
+	LD	%A,%B	/ 78
+	LD	%A,%C	/ 79
+	LD	%A,%D	/ 7A
+	LD	%A,%E	/ 7B
+	LD	%A,%H	/ 7C
+	LD	%A,%L	/ 7D
+	LD	%A,[%HL]	/ 7E
+	LD	%A,%A	/ 7F
+	ADD	%A,%B	/ 80
+	ADD	%A,%C	/ 81
+	ADD	%A,%D	/ 82
+	ADD	%A,%E	/ 83
+	ADD	%A,%H	/ 84
+	ADD	%A,%L	/ 85
+	ADD	%A,[%HL]	/ 86
+	ADD	%A,%A	/ 87
+	ADC	%A,%B	/ 88
+	ADC	%A,%C	/ 89
+	ADC	%A,%D	/ 8A
+	ADC	%A,%E	/ 8B
+	ADC	%A,%H	/ 8C
+	ADC	%A,%L	/ 8D
+	ADC	%A,[%HL]	/ 8E
+	ADC	%A,%A	/ 8F
+	SUB	%A,%B	/ 90
+	SUB	%A,%C	/ 91
+	SUB	%A,%D	/ 92
+	SUB	%A,%E	/ 93
+	SUB	%A,%H	/ 94
+	SUB	%A,%L	/ 95
+	SUB	%A,[%HL]	/ 96
+	SUB	%A,%A	/ 97
+	SBC	%A,%B	/ 98
+	SBC	%A,%C	/ 99
+	SBC	%A,%D	/ 9A
+	SBC	%A,%E	/ 9B
+	SBC	%A,%H	/ 9C
+	SBC	%A,%L	/ 9D
+	SBC	%A,[%HL]	/ 9E
+	SBC	%A,%A	/ 9F
+	AND	%A,%B	/ A0
+	AND	%A,%C	/ A1
+	AND	%A,%D	/ A2
+	AND	%A,%E	/ A3
+	AND	%A,%H	/ A4
+	AND	%A,%L	/ A5
+	AND	%A,[%HL]	/ A6
+	AND	%A,%A	/ A7
+	XOR	%A,%B	/ A8
+	XOR	%A,%C	/ A9
+	XOR	%A,%D	/ AA
+	XOR	%A,%E	/ AB
+	XOR	%A,%H	/ AC
+	XOR	%A,%L	/ AD
+	XOR	%A,[%HL]	/ AE
+	XOR	%A,%A	/ AF
+	OR	%A,%B	/ B0
+	OR	%A,%C	/ B1
+	OR	%A,%D	/ B2
+	OR	%A,%E	/ B3
+	OR	%A,%H	/ B4
+	OR	%A,%L	/ B5
+	OR	%A,[%HL]	/ B6
+	OR	%A,%A	/ B7
+	CP	%A,%B	/ B8
+	CP	%A,%C	/ B9
+	CP	%A,%D	/ BA
+	CP	%A,%E	/ BB
+	CP	%A,%H	/ BC
+	CP	%A,%L	/ BD
+	CP	%A,[%HL]	/ BE
+	CP	%A,%A	/ BF
+	RET	%NZ	/ C0
+	POP	%BC	/ C1
+	JP	%NZ,16384	/ C2 00 40
+	JP	32768	/ C3 00 80
+	CALL	%NZ,32768	/ C4 00 80
+	PUSH	%BC	/ C5
+	ADD	%A,32	/ C6 20
+	RST	0	/ C7
+	RET	%Z	/ C8
+	RET		/ C9
+	JP	%Z,32768	/ CA 00 80
+	RLC	%B	/ CB 00
+	RLC	%C	/ CB 01
+	RLC	%D	/ CB 02
+	RLC	%E	/ CB 03
+	RLC	%H	/ CB 04
+	RLC	%L	/ CB 05
+	RLC	[%HL]	/ CB 06
+	RLC	%A	/ CB 07
+	RRC	%B	/ CB 08
+	RRC	%C	/ CB 09
+	RRC	%D	/ CB 0A
+	RRC	%E	/ CB 0B
+	RRC	%H	/ CB 0C
+	RRC	%L	/ CB 0D
+	RRC	[%HL]	/ CB 0E
+	RRC	%A	/ CB 0F
+	RL	%B	/ CB 10
+	RL	%C	/ CB 11
+	RL	%D	/ CB 12
+	RL	%E	/ CB 13
+	RL	%H	/ CB 14
+	RL	%L	/ CB 15
+	RL	[%HL]	/ CB 16
+	RL	%A	/ CB 17
+	RR	%B	/ CB 18
+	RR	%C	/ CB 19
+	RR	%D	/ CB 1A
+	RR	%E	/ CB 1B
+	RR	%H	/ CB 1C
+	RR	%L	/ CB 1D
+	RR	[%HL]	/ CB 1E
+	RR	%A	/ CB 1F
+	SLA	%B	/ CB 20
+	SLA	%C	/ CB 21
+	SLA	%D	/ CB 22
+	SLA	%E	/ CB 23
+	SLA	%H	/ CB 24
+	SLA	%L	/ CB 25
+	SLA	[%HL]	/ CB 26
+	SLA	%A	/ CB 27
+	SRA	%B	/ CB 28
+	SRA	%C	/ CB 29
+	SRA	%D	/ CB 2A
+	SRA	%E	/ CB 2B
+	SRA	%H	/ CB 2C
+	SRA	%L	/ CB 2D
+	SRA	[%HL]	/ CB 2E
+	SRA	%A	/ CB 2F
+	SLL	%B	/ CB 30
+	SLL	%C	/ CB 31
+	SLL	%D	/ CB 32
+	SLL	%E	/ CB 33
+	SLL	%H	/ CB 34
+	SLL	%L	/ CB 35
+	SLL	[%HL]	/ CB 36
+	SLL	%A	/ CB 37
+	SRL	%B	/ CB 38
+	SRL	%C	/ CB 39
+	SRL	%D	/ CB 3A
+	SRL	%E	/ CB 3B
+	SRL	%H	/ CB 3C
+	SRL	%L	/ CB 3D
+	SRL	[%HL]	/ CB 3E
+	SRL	%A	/ CB 3F
+	BIT	0,%B	/ CB 40
+	BIT	0,%C	/ CB 41
+	BIT	0,%D	/ CB 42
+	BIT	0,%E	/ CB 43
+	BIT	0,%H	/ CB 44
+	BIT	0,%L	/ CB 45
+	BIT	0,[%HL]	/ CB 46
+	BIT	0,%A	/ CB 47
+	BIT	1,%B	/ CB 48
+	BIT	1,%C	/ CB 49
+	BIT	1,%D	/ CB 4A
+	BIT	1,%E	/ CB 4B
+	BIT	1,%H	/ CB 4C
+	BIT	1,%L	/ CB 4D
+	BIT	1,[%HL]	/ CB 4E
+	BIT	1,%A	/ CB 4F
+	BIT	2,%B	/ CB 50
+	BIT	2,%C	/ CB 51
+	BIT	2,%D	/ CB 52
+	BIT	2,%E	/ CB 53
+	BIT	2,%H	/ CB 54
+	BIT	2,%L	/ CB 55
+	BIT	2,[%HL]	/ CB 56
+	BIT	2,%A	/ CB 57
+	BIT	3,%B	/ CB 58
+	BIT	3,%C	/ CB 59
+	BIT	3,%D	/ CB 5A
+	BIT	3,%E	/ CB 5B
+	BIT	3,%H	/ CB 5C
+	BIT	3,%L	/ CB 5D
+	BIT	3,[%HL]	/ CB 5E
+	BIT	3,%A	/ CB 5F
+	BIT	4,%B	/ CB 60
+	BIT	4,%C	/ CB 61
+	BIT	4,%D	/ CB 62
+	BIT	4,%E	/ CB 63
+	BIT	4,%H	/ CB 64
+	BIT	4,%L	/ CB 65
+	BIT	4,[%HL]	/ CB 66
+	BIT	4,%A	/ CB 67
+	BIT	5,%B	/ CB 68
+	BIT	5,%C	/ CB 69
+	BIT	5,%D	/ CB 6A
+	BIT	5,%E	/ CB 6B
+	BIT	5,%H	/ CB 6C
+	BIT	5,%L	/ CB 6D
+	BIT	5,[%HL]	/ CB 6E
+	BIT	5,%A	/ CB 6F
+	BIT	6,%B	/ CB 70
+	BIT	6,%C	/ CB 71
+	BIT	6,%D	/ CB 72
+	BIT	6,%E	/ CB 73
+	BIT	6,%H	/ CB 74
+	BIT	6,%L	/ CB 75
+	BIT	6,[%HL]	/ CB 76
+	BIT	6,%A	/ CB 77
+	BIT	7,%B	/ CB 78
+	BIT	7,%C	/ CB 79
+	BIT	7,%D	/ CB 7A
+	BIT	7,%E	/ CB 7B
+	BIT	7,%H	/ CB 7C
+	BIT	7,%L	/ CB 7D
+	BIT	7,[%HL]	/ CB 7E
+	BIT	7,%A	/ CB 7F
+	RES	0,%B	/ CB 80
+	RES	0,%C	/ CB 81
+	RES	0,%D	/ CB 82
+	RES	0,%E	/ CB 83
+	RES	0,%H	/ CB 84
+	RES	0,%L	/ CB 85
+	RES	0,[%HL]	/ CB 86
+	RES	0,%A	/ CB 87
+	RES	1,%B	/ CB 88
+	RES	1,%C	/ CB 89
+	RES	1,%D	/ CB 8A
+	RES	1,%E	/ CB 8B
+	RES	1,%H	/ CB 8C
+	RES	1,%L	/ CB 8D
+	RES	1,[%HL]	/ CB 8E
+	RES	1,%A	/ CB 8F
+	RES	2,%B	/ CB 90
+	RES	2,%C	/ CB 91
+	RES	2,%D	/ CB 92
+	RES	2,%E	/ CB 93
+	RES	2,%H	/ CB 94
+	RES	2,%L	/ CB 95
+	RES	2,[%HL]	/ CB 96
+	RES	2,%A	/ CB 97
+	RES	3,%B	/ CB 98
+	RES	3,%C	/ CB 99
+	RES	3,%D	/ CB 9A
+	RES	3,%E	/ CB 9B
+	RES	3,%H	/ CB 9C
+	RES	3,%L	/ CB 9D
+	RES	3,[%HL]	/ CB 9E
+	RES	3,%A	/ CB 9F
+	RES	4,%B	/ CB A0
+	RES	4,%C	/ CB A1
+	RES	4,%D	/ CB A2
+	RES	4,%E	/ CB A3
+	RES	4,%H	/ CB A4
+	RES	4,%L	/ CB A5
+	RES	4,[%HL]	/ CB A6
+	RES	4,%A	/ CB A7
+	RES	5,%B	/ CB A8
+	RES	5,%C	/ CB A9
+	RES	5,%D	/ CB AA
+	RES	5,%E	/ CB AB
+	RES	5,%H	/ CB AC
+	RES	5,%L	/ CB AD
+	RES	5,[%HL]	/ CB AE
+	RES	5,%A	/ CB AF
+	RES	6,%B	/ CB B0
+	RES	6,%C	/ CB B1
+	RES	6,%D	/ CB B2
+	RES	6,%E	/ CB B3
+	RES	6,%H	/ CB B4
+	RES	6,%L	/ CB B5
+	RES	6,[%HL]	/ CB B6
+	RES	6,%A	/ CB B7
+	RES	7,%B	/ CB B8
+	RES	7,%C	/ CB B9
+	RES	7,%D	/ CB BA
+	RES	7,%E	/ CB BB
+	RES	7,%H	/ CB BC
+	RES	7,%L	/ CB BD
+	RES	7,[%HL]	/ CB BE
+	RES	7,%A	/ CB BF
+	SET	0,%B	/ CB C0
+	SET	0,%C	/ CB C1
+	SET	0,%D	/ CB C2
+	SET	0,%E	/ CB C3
+	SET	0,%H	/ CB C4
+	SET	0,%L	/ CB C5
+	SET	0,[%HL]	/ CB C6
+	SET	0,%A	/ CB C7
+	SET	1,%B	/ CB C8
+	SET	1,%C	/ CB C9
+	SET	1,%D	/ CB CA
+	SET	1,%E	/ CB CB
+	SET	1,%H	/ CB CC
+	SET	1,%L	/ CB CD
+	SET	1,[%HL]	/ CB CE
+	SET	1,%A	/ CB CF
+	SET	2,%B	/ CB D0
+	SET	2,%C	/ CB D1
+	SET	2,%D	/ CB D2
+	SET	2,%E	/ CB D3
+	SET	2,%H	/ CB D4
+	SET	2,%L	/ CB D5
+	SET	2,[%HL]	/ CB D6
+	SET	2,%A	/ CB D7
+	SET	3,%B	/ CB D8
+	SET	3,%C	/ CB D9
+	SET	3,%D	/ CB DA
+	SET	3,%E	/ CB DB
+	SET	3,%H	/ CB DC
+	SET	3,%L	/ CB DD
+	SET	3,[%HL]	/ CB DE
+	SET	3,%A	/ CB DF
+	SET	4,%B	/ CB E0
+	SET	4,%C	/ CB E1
+	SET	4,%D	/ CB E2
+	SET	4,%E	/ CB E3
+	SET	4,%H	/ CB E4
+	SET	4,%L	/ CB E5
+	SET	4,[%HL]	/ CB E6
+	SET	4,%A	/ CB E7
+	SET	5,%B	/ CB E8
+	SET	5,%C	/ CB E9
+	SET	5,%D	/ CB EA
+	SET	5,%E	/ CB EB
+	SET	5,%H	/ CB EC
+	SET	5,%L	/ CB ED
+	SET	5,[%HL]	/ CB EE
+	SET	5,%A	/ CB EF
+	SET	6,%B	/ CB F0
+	SET	6,%C	/ CB F1
+	SET	6,%D	/ CB F2
+	SET	6,%E	/ CB F3
+	SET	6,%H	/ CB F4
+	SET	6,%L	/ CB F5
+	SET	6,[%HL]	/ CB F6
+	SET	6,%A	/ CB F7
+	SET	7,%B	/ CB F8
+	SET	7,%C	/ CB F9
+	SET	7,%D	/ CB FA
+	SET	7,%E	/ CB FB
+	SET	7,%H	/ CB FC
+	SET	7,%L	/ CB FD
+	SET	7,[%HL]	/ CB FE
+	SET	7,%A	/ CB FF
+	CALL	%Z,16384	/ CC 00 40
+	CALL	16384	/ CD 00 40
+	ADC	%A,64	/ CE 40
+	RST	8	/ CF
+	RET	%NC	/ D0
+	POP	%DE	/ D1
+	JP	%NC,16384	/ D2 00 40
+	OUT	[153],%A	/ D3 99
+	CALL	%NC,32768	/ D4 00 80
+	PUSH	%DE	/ D5
+	SUB	%A,32	/ D6 20
+	RST	16	/ D7
+	RET	%C	/ D8
+	EXX		/ D9
+	JP	%C,16384	/ DA 00 40
+	IN	%A,[153]	/ DB 99
+	CALL	%C,32768	/ DC 00 80
+	ADD	%IX,%BC	/ DD 09
+	ADD	%IX,%DE	/ DD 19
+	LD	%IX,64	/ DD 21 40 00
+	LD	[32768],%IX	/ DD 22 00 80
+	INC	%IX	/ DD 23
+	INC	%IXH	/ DD 24
+	DEC	%IXH	/ DD 25
+	LD	%IXH,32	/ DD 26 20
+	ADD	%IX,%IX	/ DD 29
+	LD	%IX,[16384]	/ DD 2A 00 40
+	DEC	%IX	/ DD 2B
+	INC	%IXL	/ DD 2C
+	DEC	%IXL	/ DD 2D
+	LD	%IXL,64	/ DD 2E 40
+	INC	[%IX + 32]	/ DD 34 20
+	DEC	[%IX + 16]	/ DD 35 10
+	LD	[%IX + 64],128	/ DD 36 40 80
+	ADD	%IX,%SP	/ DD 39
+	LD	%B,%IXH	/ DD 44
+	LD	%B,%IXL	/ DD 45
+	LD	%B,[%IX + 32]	/ DD 46 20
+	LD	%C,%IXH	/ DD 4C
+	LD	%C,%IXL	/ DD 4D
+	LD	%C,[%IX + 48]	/ DD 4E 30
+	LD	%D,%IXH	/ DD 54
+	LD	%D,%IXL	/ DD 55
+	LD	%D,[%IX + 32]	/ DD 56 20
+	LD	%E,%IXH	/ DD 5C
+	LD	%E,%IXL	/ DD 5D
+	LD	%E,[%IX + 64]	/ DD 5E 40
+	LD	%IXH,%B	/ DD 60
+	LD	%IXH,%C	/ DD 61
+	LD	%IXH,%D	/ DD 62
+	LD	%IXH,%E	/ DD 63
+	LD	%IXH,%IXH	/ DD 64
+	LD	%IXH,%IXL	/ DD 65
+	LD	%H,[%IX + 16]	/ DD 66 10
+	LD	%IXH,%A	/ DD 67
+	LD	%IXL,%B	/ DD 68
+	LD	%IXL,%C	/ DD 69
+	LD	%IXL,%D	/ DD 6A
+	LD	%IXL,%E	/ DD 6B
+	LD	%IXL,%IXH	/ DD 6C
+	LD	%IXL,%IXL	/ DD 6D
+	LD	%L,[%IX + 48]	/ DD 6E 30
+	LD	%IXL,%A	/ DD 6F
+	LD	[%IX + 64],%B	/ DD 70 40
+	LD	[%IX + 16],%C	/ DD 71 10
+	LD	[%IX + 32],%D	/ DD 72 20
+	LD	[%IX + 48],%E	/ DD 73 30
+	LD	[%IX + 16],%H	/ DD 74 10
+	LD	[%IX + 32],%L	/ DD 75 20
+	LD	[%IX + 48],%A	/ DD 77 30
+	LD	%A,%IXH	/ DD 7C
+	LD	%A,%IXL	/ DD 7D
+	LD	%A,[%IX + 16]	/ DD 7E 10
+	ADD	%A,%IXH	/ DD 84
+	ADD	%A,%IXL	/ DD 85
+	ADD	%A,[%IX + 32]	/ DD 86 20
+	ADC	%A,%IXH	/ DD 8C
+	ADC	%A,%IXL	/ DD 8D
+	ADC	%A,[%IX + 48]	/ DD 8E 30
+	SUB	%A,%IXH	/ DD 94
+	SUB	%A,%IXL	/ DD 95
+	SUB	%A,[%IX + 16]	/ DD 96 10
+	SBC	%A,%IXH	/ DD 9C
+	SBC	%A,%IXL	/ DD 9D
+	SBC	%A,[%IX + 32]	/ DD 9E 20
+	AND	%A,%IXH	/ DD A4
+	AND	%A,%IXL	/ DD A5
+	AND	%A,[%IX + 48]	/ DD A6 30
+	XOR	%A,%IXH	/ DD AC
+	XOR	%A,%IXL	/ DD AD
+	XOR	%A,[%IX + 16]	/ DD AE 10
+	OR	%A,%IXH	/ DD B4
+	OR	%A,%IXL	/ DD B5
+	OR	%A,[%IX + 32]	/ DD B6 20
+	CP	%A,%IXH	/ DD BC
+	CP	%A,%IXL	/ DD BD
+	CP	%A,[%IX + 48]	/ DD BE 30
+	RLC	[%IX + 16],%B	/ DD CB 10 00
+	RLC	[%IX + 32],%C	/ DD CB 20 01
+	RLC	[%IX + 48],%D	/ DD CB 30 02
+	RLC	[%IX + 64],%E	/ DD CB 40 03
+	RLC	[%IX + 16],%H	/ DD CB 10 04
+	RLC	[%IX + 32],%L	/ DD CB 20 05
+	RLC	[%IX + 64]	/ DD CB 40 06
+	RLC	[%IX + 16],%A	/ DD CB 10 07
+	RRC	[%IX + 32],%B 	/ DD CB 20 08
+	RRC	[%IX + 48],%C	/ DD CB 30 09
+	RRC	[%IX + 64],%D	/ DD CB 40 0A
+	RRC	[%IX + 16],%E	/ DD CB 10 0B
+	RRC	[%IX + 32],%H	/ DD CB 20 0C
+	RRC	[%IX + 48],%L	/ DD CB 30 0D
+	RRC	[%IX + 16]	/ DD CB 10 0E
+	RRC	[%IX + 16],%A	/ DD CB 10 0F
+	RL	[%IX + 32],%B	/ DD CB 20 10
+	RL	[%IX + 48],%C	/ DD CB 30 11
+	RL	[%IX + 64],%D	/ DD CB 40 12
+	RL	[%IX + 16],%E	/ DD CB 10 13
+	RL	[%IX + 32],%H	/ DD CB 20 14
+	RL	[%IX + 48],%L	/ DD CB 30 15
+	RL	[%IX + 32]	/ DD CB 20 16
+	RL	[%IX + 16],%A	/ DD CB 10 17
+	RR	[%IX + 32],%B	/ DD CB 20 18
+	RR	[%IX + 48],%C	/ DD CB 30 19
+	RR	[%IX + 64],%D	/ DD CB 40 1A
+	RR	[%IX + 16],%E	/ DD CB 10 1B
+	RR	[%IX + 32],%H	/ DD CB 20 1C
+	RR	[%IX + 48],%L	/ DD CB 30 1D
+	RR	[%IX + 48]	/ DD CB 30 1E
+	RR	[%IX + 16],%A	/ DD CB 10 1F
+	SLA	[%IX + 32],%B	/ DD CB 20 20
+	SLA	[%IX + 48],%C	/ DD CB 30 21
+	SLA	[%IX + 64],%D	/ DD CB 40 22
+	SLA	[%IX + 16],%E	/ DD CB 10 23
+	SLA	[%IX + 32],%H	/ DD CB 20 24
+	SLA	[%IX + 48],%L	/ DD CB 30 25
+	SLA	[%IX + 64]	/ DD CB 40 26
+	SLA	[%IX + 16],%A	/ DD CB 10 27
+	SRA	[%IX + 32],%B	/ DD CB 20 28
+	SRA	[%IX + 48],%C	/ DD CB 30 29
+	SRA	[%IX + 64],%D	/ DD CB 40 2A
+	SRA	[%IX + 16],%E	/ DD CB 10 2B
+	SRA	[%IX + 32],%H	/ DD CB 20 2C
+	SRA	[%IX + 48],%L	/ DD CB 30 2D
+	SRA	[%IX + 16]	/ DD CB 10 2E
+	SRA	[%IX + 16],%A	/ DD CB 10 2F
+	SLL	[%IX + 32],%B	/ DD CB 20 30
+	SLL	[%IX + 48],%C	/ DD CB 30 31
+	SLL	[%IX + 64],%D	/ DD CB 40 32
+	SLL	[%IX + 16],%E	/ DD CB 10 33
+	SLL	[%IX + 32],%H	/ DD CB 20 34
+	SLL	[%IX + 48],%L	/ DD CB 30 35
+	SLL	[%IX + 32]	/ DD CB 20 36
+	SLL	[%IX + 16],%A	/ DD CB 10 37
+	SRL	[%IX + 32],%B	/ DD CB 20 38
+	SRL	[%IX + 48],%C	/ DD CB 30 39
+	SRL	[%IX + 64],%D	/ DD CB 40 3A
+	SRL	[%IX + 16],%E	/ DD CB 10 3B
+	SRL	[%IX + 32],%H	/ DD CB 20 3C
+	SRL	[%IX + 48],%L	/ DD CB 30 3D
+	SRL	[%IX + 48]	/ DD CB 30 3E
+	SRL	[%IX + 64],%A	/ DD CB 40 3F
+	BIT	0,[%IX + 16]	/ DD CB 10 46
+	BIT	1,[%IX + 32]	/ DD CB 20 4E
+	BIT	2,[%IX + 48]	/ DD CB 30 56
+	BIT	3,[%IX + 64]	/ DD CB 40 5E
+	BIT	4,[%IX + 16]	/ DD CB 10 66
+	BIT	5,[%IX + 32]	/ DD CB 20 6E
+	BIT	6,[%IX + 48]	/ DD CB 30 76
+	BIT	7,[%IX + 64]	/ DD CB 40 7E
+	RES	0,[%IX + 16],%B	/ DD CB 10 80
+	RES	0,[%IX + 32],%C	/ DD CB 20 81
+	RES	0,[%IX + 48],%D	/ DD CB 30 82
+	RES	0,[%IX + 64],%E	/ DD CB 40 83
+	RES	0,[%IX + 16],%H	/ DD CB 10 84
+	RES	0,[%IX + 32],%L	/ DD CB 20 85
+	RES	0,[%IX + 48]	/ DD CB 30 86
+	RES	0,[%IX + 64],%A	/ DD CB 40 87
+	RES	1,[%IX + 16],%B	/ DD CB 10 88
+	RES	1,[%IX + 32],%C	/ DD CB 20 89
+	RES	1,[%IX + 48],%D	/ DD CB 30 8A
+	RES	1,[%IX + 64],%E	/ DD CB 40 8B
+	RES	1,[%IX + 16],%H	/ DD CB 10 8C
+	RES	1,[%IX + 32],%L	/ DD CB 20 8D
+	RES	1,[%IX + 48]	/ DD CB 30 8E
+	RES	1,[%IX + 64],%A	/ DD CB 40 8F
+	RES	2,[%IX + 16],%B	/ DD CB 10 90
+	RES	2,[%IX + 32],%C	/ DD CB 20 91
+	RES	2,[%IX + 48],%D	/ DD CB 30 92
+	RES	2,[%IX + 64],%E	/ DD CB 40 93
+	RES	2,[%IX + 16],%H	/ DD CB 10 94
+	RES	2,[%IX + 32],%L	/ DD CB 20 95
+	RES	2,[%IX + 48]	/ DD CB 30 96
+	RES	2,[%IX + 64],%A	/ DD CB 40 97
+	RES	3,[%IX + 16],%B	/ DD CB 10 98
+	RES	3,[%IX + 32],%C	/ DD CB 20 99
+	RES	3,[%IX + 48],%D	/ DD CB 30 9A
+	RES	3,[%IX + 64],%E	/ DD CB 40 9B
+	RES	3,[%IX + 16],%H	/ DD CB 10 9C
+	RES	3,[%IX + 32],%L	/ DD CB 20 9D
+	RES	3,[%IX + 48]	/ DD CB 30 9E
+	RES	3,[%IX + 64],%A	/ DD CB 40 9F
+	RES	4,[%IX + 16],%B	/ DD CB 10 A0
+	RES	4,[%IX + 32],%C	/ DD CB 20 A1
+	RES	4,[%IX + 48],%D	/ DD CB 30 A2
+	RES	4,[%IX + 64],%E	/ DD CB 40 A3
+	RES	4,[%IX + 16],%H	/ DD CB 10 A4
+	RES	4,[%IX + 32],%L	/ DD CB 20 A5
+	RES	4,[%IX + 48]	/ DD CB 30 A6
+	RES	4,[%IX + 64],%A	/ DD CB 40 A7
+	RES	5,[%IX + 16],%B	/ DD CB 10 A8
+	RES	5,[%IX + 32],%C	/ DD CB 20 A9
+	RES	5,[%IX + 48],%D	/ DD CB 30 AA
+	RES	5,[%IX + 64],%E	/ DD CB 40 AB
+	RES	5,[%IX + 16],%H	/ DD CB 10 AC
+	RES	5,[%IX + 32],%L	/ DD CB 20 AD
+	RES	5,[%IX + 48]	/ DD CB 30 AE
+	RES	5,[%IX + 64],%A	/ DD CB 40 AF
+	RES	6,[%IX + 16],%B	/ DD CB 10 B0
+	RES	6,[%IX + 32],%C	/ DD CB 20 B1
+	RES	6,[%IX + 48],%D	/ DD CB 30 B2
+	RES	6,[%IX + 64],%E	/ DD CB 40 B3
+	RES	6,[%IX + 16],%H	/ DD CB 10 B4
+	RES	6,[%IX + 32],%L	/ DD CB 20 B5
+	RES	6,[%IX + 48]	/ DD CB 30 B6
+	RES	6,[%IX + 64],%A	/ DD CB 40 B7
+	RES	7,[%IX + 16],%B	/ DD CB 10 B8
+	RES	7,[%IX + 32],%C	/ DD CB 20 B9
+	RES	7,[%IX + 48],%D	/ DD CB 30 BA
+	RES	7,[%IX + 64],%E	/ DD CB 40 BB
+	RES	7,[%IX + 16],%H	/ DD CB 10 BC
+	RES	7,[%IX + 32],%L	/ DD CB 20 BD
+	RES	7,[%IX + 48]	/ DD CB 30 BE
+	RES	7,[%IX + 64],%A	/ DD CB 40 BF
+	SET	0,[%IX + 16],%B	/ DD CB 10 C0
+	SET	0,[%IX + 32],%C	/ DD CB 20 C1
+	SET	0,[%IX + 48],%D	/ DD CB 30 C2
+	SET	0,[%IX + 64],%E	/ DD CB 40 C3
+	SET	0,[%IX + 16],%H	/ DD CB 10 C4
+	SET	0,[%IX + 32],%L	/ DD CB 20 C5
+	SET	0,[%IX + 48]	/ DD CB 30 C6
+	SET	0,[%IX + 64],%A	/ DD CB 40 C7
+	SET	1,[%IX + 16],%B	/ DD CB 10 C8
+	SET	1,[%IX + 32],%C	/ DD CB 20 C9
+	SET	1,[%IX + 48],%D	/ DD CB 30 CA
+	SET	1,[%IX + 64],%E	/ DD CB 40 CB
+	SET	1,[%IX + 16],%H	/ DD CB 10 CC
+	SET	1,[%IX + 32],%L	/ DD CB 20 CD
+	SET	1,[%IX + 48]	/ DD CB 30 CE
+	SET	1,[%IX + 64],%A	/ DD CB 40 CF
+	SET	2,[%IX + 16],%B	/ DD CB 10 D0
+	SET	2,[%IX + 32],%C	/ DD CB 20 D1
+	SET	2,[%IX + 48],%D	/ DD CB 30 D2
+	SET	2,[%IX + 64],%E	/ DD CB 40 D3
+	SET	2,[%IX + 16],%H	/ DD CB 10 D4
+	SET	2,[%IX + 32],%L	/ DD CB 20 D5
+	SET	2,[%IX + 48]	/ DD CB 30 D6
+	SET	2,[%IX + 64],%A	/ DD CB 40 D7
+	SET	3,[%IX + 16],%B	/ DD CB 10 D8
+	SET	3,[%IX + 32],%C	/ DD CB 20 D9
+	SET	3,[%IX + 48],%D	/ DD CB 30 DA
+	SET	3,[%IX + 64],%E	/ DD CB 40 DB
+	SET	3,[%IX + 16],%H	/ DD CB 10 DC
+	SET	3,[%IX + 32],%L	/ DD CB 20 DD
+	SET	3,[%IX + 48]	/ DD CB 30 DE
+	SET	3,[%IX + 64],%A	/ DD CB 40 DF
+	SET	4,[%IX + 16],%B	/ DD CB 10 E0
+	SET	4,[%IX + 32],%C	/ DD CB 20 E1
+	SET	4,[%IX + 48],%D	/ DD CB 30 E2
+	SET	4,[%IX + 64],%E	/ DD CB 40 E3
+	SET	4,[%IX + 16],%H	/ DD CB 10 E4
+	SET	4,[%IX + 32],%L	/ DD CB 20 E5
+	SET	4,[%IX + 48]	/ DD CB 30 E6
+	SET	4,[%IX + 64],%A	/ DD CB 40 E7
+	SET	5,[%IX + 16],%B	/ DD CB 10 E8
+	SET	5,[%IX + 32],%C	/ DD CB 20 E9
+	SET	5,[%IX + 48],%D	/ DD CB 30 EA
+	SET	5,[%IX + 64],%E	/ DD CB 40 EB
+	SET	5,[%IX + 16],%H	/ DD CB 10 EC
+	SET	5,[%IX + 32],%L	/ DD CB 20 ED
+	SET	5,[%IX + 48]	/ DD CB 30 EE
+	SET	5,[%IX + 64],%A	/ DD CB 40 EF
+	SET	6,[%IX + 16],%B	/ DD CB 10 F0
+	SET	6,[%IX + 32],%C	/ DD CB 20 F1
+	SET	6,[%IX + 48],%D	/ DD CB 30 F2
+	SET	6,[%IX + 64],%E	/ DD CB 40 F3
+	SET	6,[%IX + 16],%H	/ DD CB 10 F4
+	SET	6,[%IX + 32],%L	/ DD CB 20 F5
+	SET	6,[%IX + 48]	/ DD CB 30 F6
+	SET	6,[%IX + 64],%A	/ DD CB 40 F7
+	SET	7,[%IX + 16],%B	/ DD CB 10 F8
+	SET	7,[%IX + 32],%C	/ DD CB 20 F9
+	SET	7,[%IX + 48],%D	/ DD CB 30 FA
+	SET	7,[%IX + 64],%E	/ DD CB 40 FB
+	SET	7,[%IX + 16],%H	/ DD CB 10 FC
+	SET	7,[%IX + 32],%L	/ DD CB 20 FD
+	SET	7,[%IX + 48]	/ DD CB 30 FE
+	SET	7,[%IX + 64],%A	/ DD CB 40 FF
+	POP	%IX	/ DD E1
+	EX	[%SP],%IX	/ DD E3
+	PUSH	%IX	/ DD E5
+	JP	[%IX]	/ DD E9
+	LD	%SP,%IX	/ DD F9
+	SBC	%A,64	/ DE 40
+	RST	24	/ DF
+	RET	%PO	/ E0
+	POP	%HL	/ E1
+	JP	%PO,32768	/ E2 00 80
+	EX	[%SP],%HL	/ E3
+	CALL	%PO,16384	/ E4 00 40
+	PUSH	%HL	/ E5
+	AND	%A,16	/ E6 10
+	RST	32	/ E7
+	RET	%PE	/ E8
+	JP	[%HL]	/ E9
+	JP	%PE,16384	/ EA 00 40
+	EX	%DE,%HL	/ EB
+	CALL	%PE,16384	/ EC 00 40
+	IN	%B,[%C]	/ ED 40
+	OUT	[%C],%B	/ ED 41
+	SBC	%HL,%BC	/ ED 42
+	LD	[32768],%BC	/ ED 43 00 80
+	NEG		/ ED 44
+	RETN		/ ED 45
+	IM	0	/ ED 46
+	LD	%I,%A	/ ED 47
+	IN	%C,[%C]	/ ED 48
+	OUT	[%C],%C	/ ED 49
+	ADC	%HL,%BC	/ ED 4A
+	LD	%BC,[16384]	/ ED 4B 00 40
+	RETI		/ ED 4D
+	LD	%R,%A	/ ED 4F
+	IN	%D,[%C]	/ ED 50
+	OUT	[%C],%D	/ ED 51
+	SBC	%HL,%DE	/ ED 52
+	LD	[32768],%DE	/ ED 53 00 80
+	IM	1	/ ED 56
+	LD	%A,%I	/ ED 57
+	IN	%E,[%C]	/ ED 58
+	OUT	[%C],%E	/ ED 59
+	ADC	%HL,%DE	/ ED 5A
+	LD	%DE,[16384]	/ ED 5B 00 40
+	IM	2	/ ED 5E
+	LD	%A,%R	/ ED 5F
+	IN	%H,[%C]	/ ED 60
+	OUT	[%C],%H	/ ED 61
+	SBC	%HL,%HL	/ ED 62
+	RRD		/ ED 67
+	IN	%L,[%C]	/ ED 68
+	OUT	[%C],%L	/ ED 69
+	ADC	%HL,%HL	/ ED 6A
+	RLD		/ ED 6F
+	IN	%F,[%C]	/ ED 70
+	OUT	[%C],0	/ ED 71
+	SBC	%HL,%SP	/ ED 72
+	LD	[16384],%SP	/ ED 73 00 40
+	IN	%A,[%C]	/ ED 78
+	OUT	[%C],%A	/ ED 79
+	ADC	%HL,%SP	/ ED 7A
+	LD	%SP,[32768]	/ ED 7B 00 80
+	LDI		/ ED A0
+	CPI		/ ED A1
+	INI		/ ED A2
+	OUTI		/ ED A3
+	LDD		/ ED A8
+	CPD		/ ED A9
+	IND		/ ED AA
+	OUTD		/ ED AB
+	LDIR		/ ED B0
+	CPIR		/ ED B1
+	INIR		/ ED B2
+	OTIR		/ ED B3
+	LDDR		/ ED B8
+	CPDR		/ ED B9
+	INDR		/ ED BA
+	OTDR		/ ED BB
+	XOR	%A,32	/ EE 20
+	RST	40	/ EF
+	RET	%P	/ F0
+	POP	%AF	/ F1
+	JP	%P,32768	/ F2 00 80
+	DI		/ F3
+	CALL	%P,16384	/ F4 00 40
+	PUSH	%AF	/ F5
+	OR	%A,32	/ F6 20
+	RST	48	/ F7
+	RET	%M	/ F8
+	LD	%SP,%HL	/ F9
+	JP	%M,32768	/ FA 00 80
+	EI		/ FB
+	CALL	%M,16384	/ FC 00 40
+	ADD	%IY,%BC	/ FD 09
+	ADD	%IY,%DE	/ FD 19
+	LD	%IY,32768	/ FD 21 00 80
+	LD	[16384],%IY	/ FD 22 00 40
+	INC	%IY	/ FD 23
+	INC	%IYH	/ FD 24
+	DEC	%IYH	/ FD 25
+	LD	%IYH,32	/ FD 26 20
+	ADD	%IY,%IY	/ FD 29
+	LD	%IY,[32768]	/ FD 2A 00 80
+	DEC	%IY	/ FD 2B
+	INC	%IYL	/ FD 2C
+	DEC	%IYL	/ FD 2D
+	LD	%IYL,16	/ FD 2E 10
+	INC	[%IY + 32]	/ FD 34 20
+	DEC	[%IY + 48]	/ FD 35 30
+	LD	[%IY + 64],16	/ FD 36 40 10
+	ADD	%IY,%SP	/ FD 39
+	LD	%B,%IYH	/ FD 44
+	LD	%B,%IYL	/ FD 45
+	LD	%B,[%IY + 32]	/ FD 46 20
+	LD	%C,%IYH	/ FD 4C
+	LD	%C,%IYL	/ FD 4D
+	LD	%C,[%IY + 48]	/ FD 4E 30
+	LD	%D,%IYH	/ FD 54
+	LD	%D,%IYL	/ FD 55
+	LD	%D,[%IY + 64]	/ FD 56 40
+	LD	%E,%IYH	/ FD 5C
+	LD	%E,%IYL	/ FD 5D
+	LD	%E,[%IY + 16]	/ FD 5E 10
+	LD	%IYH,%B	/ FD 60
+	LD	%IYH,%C	/ FD 61
+	LD	%IYH,%D	/ FD 62
+	LD	%IYH,%E	/ FD 63
+	LD	%IYH,%IYH	/ FD 64
+	LD	%IYH,%IYL	/ FD 65
+	LD	%H,[%IY + 32]	/ FD 66 20
+	LD	%IYH,%A	/ FD 67
+	LD	%IYL,%B	/ FD 68
+	LD	%IYL,%C	/ FD 69
+	LD	%IYL,%D	/ FD 6A
+	LD	%IYL,%E	/ FD 6B
+	LD	%IYL,%IYH	/ FD 6C
+	LD	%IYL,%IYL	/ FD 6D
+	LD	%L,[%IY + 48]	/ FD 6E 30
+	LD	%IYL,%A	/ FD 6F
+	LD	[%IY + 64],%B	/ FD 70 40
+	LD	[%IY + 16],%C	/ FD 71 10
+	LD	[%IY + 32],%D	/ FD 72 20
+	LD	[%IY + 48],%E	/ FD 73 30
+	LD	[%IY + 64],%H	/ FD 74 40
+	LD	[%IY + 16],%L	/ FD 75 10
+	LD	[%IY + 32],%A	/ FD 77 20
+	LD	%A,%IYH	/ FD 7C
+	LD	%A,%IYL	/ FD 7D
+	LD	%A,[%IY + 48]	/ FD 7E 30
+	ADD	%A,%IYH	/ FD 84
+	ADD	%A,%IYL	/ FD 85
+	ADD	%A,[%IY + 64]	/ FD 86 40
+	ADC	%A,%IYH	/ FD 8C
+	ADC	%A,%IYL	/ FD 8D
+	ADC	%A,[%IY + 16]	/ FD 8E 10
+	SUB	%A,%IYH	/ FD 94
+	SUB	%A,%IYL	/ FD 95
+	SUB	%A,[%IY + 32]	/ FD 96 20
+	SBC	%A,%IYH	/ FD 9C
+	SBC	%A,%IYL	/ FD 9D
+	SBC	%A,[%IY + 48]	/ FD 9E 30
+	AND	%A,%IYH	/ FD A4
+	AND	%A,%IYL	/ FD A5
+	AND	%A,[%IY + 64]	/ FD A6 40
+	XOR	%A,%IYH	/ FD AC
+	XOR	%A,%IYL	/ FD AD
+	XOR	%A,[%IY + 16]	/ FD AE 10
+	OR	%A,%IYH	/ FD B4
+	OR	%A,%IYL	/ FD B5
+	OR	%A,[%IY + 32]	/ FD B6 20
+	CP	%A,%IYH	/ FD BC
+	CP	%A,%IYL	/ FD BD
+	CP	%A,[%IY + 48]	/ FD BE 30
+	RLC	[%IY + 16],%B	/ FD CB 10 00
+	RLC	[%IY + 32],%C	/ FD CB 20 01
+	RLC	[%IY + 48],%D	/ FD CB 30 02
+	RLC	[%IY + 64],%E	/ FD CB 40 03
+	RLC	[%IY + 16],%H	/ FD CB 10 04
+	RLC	[%IY + 32],%L	/ FD CB 20 05
+	RLC	[%IY + 16]	/ FD CB 10 06
+	RLC	[%IY + 32],%A	/ FD CB 20 07
+	RRC	[%IY + 48],%B	/ FD CB 30 08
+	RRC	[%IY + 64],%C	/ FD CB 40 09
+	RRC	[%IY + 16],%D	/ FD CB 10 0A
+	RRC	[%IY + 32],%E	/ FD CB 20 0B
+	RRC	[%IY + 48],%H	/ FD CB 30 0C
+	RRC	[%IY + 64],%L	/ FD CB 40 0D
+	RRC	[%IY + 32]	/ FD CB 20 0E
+	RRC	[%IY + 16],%A	/ FD CB 10 0F
+	RL	[%IY + 32],%B	/ FD CB 20 10
+	RL	[%IY + 48],%C	/ FD CB 30 11
+	RL	[%IY + 64],%D	/ FD CB 40 12
+	RL	[%IY + 16],%E	/ FD CB 10 13
+	RL	[%IY + 32],%H	/ FD CB 20 14
+	RL	[%IY + 48],%L	/ FD CB 30 15
+	RL	[%IY + 48]	/ FD CB 30 16
+	RL	[%IY + 16],%A	/ FD CB 10 17
+	RR	[%IY + 32],%B	/ FD CB 20 18
+	RR	[%IY + 48],%C	/ FD CB 30 19
+	RR	[%IY + 64],%D	/ FD CB 40 1A
+	RR	[%IY + 16],%E	/ FD CB 10 1B
+	RR	[%IY + 32],%H	/ FD CB 20 1C
+	RR	[%IY + 48],%L	/ FD CB 30 1D
+	RR	[%IY + 64]	/ FD CB 40 1E
+	RR	[%IY + 16],%A	/ FD CB 10 1F
+	SLA	[%IY + 32],%B	/ FD CB 20 20
+	SLA	[%IY + 48],%C	/ FD CB 30 21
+	SLA	[%IY + 64],%D	/ FD CB 40 22
+	SLA	[%IY + 16],%E	/ FD CB 10 23
+	SLA	[%IY + 32],%H	/ FD CB 20 24
+	SLA	[%IY + 48],%L	/ FD CB 30 25
+	SLA	[%IY + 16]	/ FD CB 10 26
+	SLA	[%IY + 16],%A	/ FD CB 10 27
+	SRA	[%IY + 32],%B	/ FD CB 20 28
+	SRA	[%IY + 48],%C	/ FD CB 30 29
+	SRA	[%IY + 64],%D	/ FD CB 40 2A
+	SRA	[%IY + 16],%E	/ FD CB 10 2B
+	SRA	[%IY + 32],%H	/ FD CB 20 2C
+	SRA	[%IY + 48],%L	/ FD CB 30 2D
+	SRA	[%IY + 32]	/ FD CB 20 2E
+	SRA	[%IY + 48],%A	/ FD CB 30 2F
+	SLL	[%IY + 16],%B	/ FD CB 10 30
+	SLL	[%IY + 32],%C	/ FD CB 20 31
+	SLL	[%IY + 48],%D	/ FD CB 30 32
+	SLL	[%IY + 64],%E	/ FD CB 40 33
+	SLL	[%IY + 16],%H	/ FD CB 10 34
+	SLL	[%IY + 32],%L	/ FD CB 20 35
+	SLL	[%IY + 48]	/ FD CB 30 36
+	SLL	[%IY + 16],%A	/ FD CB 10 37
+	SRL	[%IY + 32],%B	/ FD CB 20 38
+	SRL	[%IY + 48],%C	/ FD CB 30 39
+	SRL	[%IY + 64],%D	/ FD CB 40 3A
+	SRL	[%IY + 16],%E	/ FD CB 10 3B
+	SRL	[%IY + 32],%H	/ FD CB 20 3C
+	SRL	[%IY + 48],%L	/ FD CB 30 3D
+	SRL	[%IY + 64]	/ FD CB 40 3E
+	SRL	[%IY + 16],%A	/ FD CB 10 3F
+	BIT	0,[%IY + 16]	/ FD CB 10 46
+	BIT	1,[%IY + 32]	/ FD CB 20 4E
+	BIT	2,[%IY + 48]	/ FD CB 30 56
+	BIT	3,[%IY + 64]	/ FD CB 40 5E
+	BIT	4,[%IY + 16]	/ FD CB 10 66
+	BIT	5,[%IY + 32]	/ FD CB 20 6E
+	BIT	6,[%IY + 48]	/ FD CB 30 76
+	BIT	7,[%IY + 64]	/ FD CB 40 7E
+	RES	0,[%IY + 16],%B	/ FD CB 10 80
+	RES	0,[%IY + 32],%C	/ FD CB 20 81
+	RES	0,[%IY + 48],%D	/ FD CB 30 82
+	RES	0,[%IY + 64],%E	/ FD CB 40 83
+	RES	0,[%IY + 16],%H	/ FD CB 10 84
+	RES	0,[%IY + 32],%L	/ FD CB 20 85
+	RES	0,[%IY + 48]	/ FD CB 30 86
+	RES	0,[%IY + 64],%A	/ FD CB 40 87
+	RES	1,[%IY + 16],%B	/ FD CB 10 88
+	RES	1,[%IY + 32],%C	/ FD CB 20 89
+	RES	1,[%IY + 48],%D	/ FD CB 30 8A
+	RES	1,[%IY + 64],%E	/ FD CB 40 8B
+	RES	1,[%IY + 16],%H	/ FD CB 10 8C
+	RES	1,[%IY + 32],%L	/ FD CB 20 8D
+	RES	1,[%IY + 48]	/ FD CB 30 8E
+	RES	1,[%IY + 64],%A	/ FD CB 40 8F
+	RES	2,[%IY + 16],%B	/ FD CB 10 90
+	RES	2,[%IY + 32],%C	/ FD CB 20 91
+	RES	2,[%IY + 48],%D	/ FD CB 30 92
+	RES	2,[%IY + 64],%E	/ FD CB 40 93
+	RES	2,[%IY + 16],%H	/ FD CB 10 94
+	RES	2,[%IY + 32],%L	/ FD CB 20 95
+	RES	2,[%IY + 48]	/ FD CB 30 96
+	RES	2,[%IY + 64],%A	/ FD CB 40 97
+	RES	3,[%IY + 16],%B	/ FD CB 10 98
+	RES	3,[%IY + 32],%C	/ FD CB 20 99
+	RES	3,[%IY + 48],%D	/ FD CB 30 9A
+	RES	3,[%IY + 64],%E	/ FD CB 40 9B
+	RES	3,[%IY + 16],%H	/ FD CB 10 9C
+	RES	3,[%IY + 32],%L	/ FD CB 20 9D
+	RES	3,[%IY + 48]	/ FD CB 30 9E
+	RES	3,[%IY + 64],%A	/ FD CB 40 9F
+	RES	4,[%IY + 16],%B	/ FD CB 10 A0
+	RES	4,[%IY + 32],%C	/ FD CB 20 A1
+	RES	4,[%IY + 48],%D	/ FD CB 30 A2
+	RES	4,[%IY + 64],%E	/ FD CB 40 A3
+	RES	4,[%IY + 16],%H	/ FD CB 10 A4
+	RES	4,[%IY + 32],%L	/ FD CB 20 A5
+	RES	4,[%IY + 48]	/ FD CB 30 A6
+	RES	4,[%IY + 64],%A	/ FD CB 40 A7
+	RES	5,[%IY + 16],%B	/ FD CB 10 A8
+	RES	5,[%IY + 32],%C	/ FD CB 20 A9
+	RES	5,[%IY + 48],%D	/ FD CB 30 AA
+	RES	5,[%IY + 64],%E	/ FD CB 40 AB
+	RES	5,[%IY + 16],%H	/ FD CB 10 AC
+	RES	5,[%IY + 32],%L	/ FD CB 20 AD
+	RES	5,[%IY + 48]	/ FD CB 30 AE
+	RES	5,[%IY + 64],%A	/ FD CB 40 AF
+	RES	6,[%IY + 16],%B	/ FD CB 10 B0
+	RES	6,[%IY + 32],%C	/ FD CB 20 B1
+	RES	6,[%IY + 48],%D	/ FD CB 30 B2
+	RES	6,[%IY + 64],%E	/ FD CB 40 B3
+	RES	6,[%IY + 16],%H	/ FD CB 10 B4
+	RES	6,[%IY + 32],%L	/ FD CB 20 B5
+	RES	6,[%IY + 48]	/ FD CB 30 B6
+	RES	6,[%IY + 64],%A	/ FD CB 40 B7
+	RES	7,[%IY + 16],%B	/ FD CB 10 B8
+	RES	7,[%IY + 32],%C	/ FD CB 20 B9
+	RES	7,[%IY + 48],%D	/ FD CB 30 BA
+	RES	7,[%IY + 64],%E	/ FD CB 40 BB
+	RES	7,[%IY + 16],%H	/ FD CB 10 BC
+	RES	7,[%IY + 32],%L	/ FD CB 20 BD
+	RES	7,[%IY + 48]	/ FD CB 30 BE
+	RES	7,[%IY + 64],%A	/ FD CB 40 BF
+	SET	0,[%IY + 16],%B	/ FD CB 10 C0
+	SET	0,[%IY + 32],%C	/ FD CB 20 C1
+	SET	0,[%IY + 48],%D	/ FD CB 30 C2
+	SET	0,[%IY + 64],%E	/ FD CB 40 C3
+	SET	0,[%IY + 16],%H	/ FD CB 10 C4
+	SET	0,[%IY + 32],%L	/ FD CB 20 C5
+	SET	0,[%IY + 48]	/ FD CB 30 C6
+	SET	0,[%IY + 64],%A	/ FD CB 40 C7
+	SET	1,[%IY + 16],%B	/ FD CB 10 C8
+	SET	1,[%IY + 32],%C	/ FD CB 20 C9
+	SET	1,[%IY + 48],%D	/ FD CB 30 CA
+	SET	1,[%IY + 64],%E	/ FD CB 40 CB
+	SET	1,[%IY + 16],%H	/ FD CB 10 CC
+	SET	1,[%IY + 32],%L	/ FD CB 20 CD
+	SET	1,[%IY + 48]	/ FD CB 30 CE
+	SET	1,[%IY + 64],%A	/ FD CB 40 CF
+	SET	2,[%IY + 16],%B	/ FD CB 10 D0
+	SET	2,[%IY + 32],%C	/ FD CB 20 D1
+	SET	2,[%IY + 48],%D	/ FD CB 30 D2
+	SET	2,[%IY + 64],%E	/ FD CB 40 D3
+	SET	2,[%IY + 16],%H	/ FD CB 10 D4
+	SET	2,[%IY + 32],%L	/ FD CB 20 D5
+	SET	2,[%IY + 48]	/ FD CB 30 D6
+	SET	2,[%IY + 64],%A	/ FD CB 40 D7
+	SET	3,[%IY + 16],%B	/ FD CB 10 D8
+	SET	3,[%IY + 32],%C	/ FD CB 20 D9
+	SET	3,[%IY + 48],%D	/ FD CB 30 DA
+	SET	3,[%IY + 64],%E	/ FD CB 40 DB
+	SET	3,[%IY + 16],%H	/ FD CB 10 DC
+	SET	3,[%IY + 32],%L	/ FD CB 20 DD
+	SET	3,[%IY + 48]	/ FD CB 30 DE
+	SET	3,[%IY + 64],%A	/ FD CB 40 DF
+	SET	4,[%IY + 16],%B	/ FD CB 10 E0
+	SET	4,[%IY + 32],%C	/ FD CB 20 E1
+	SET	4,[%IY + 48],%D	/ FD CB 30 E2
+	SET	4,[%IY + 64],%E	/ FD CB 40 E3
+	SET	4,[%IY + 16],%H	/ FD CB 10 E4
+	SET	4,[%IY + 32],%L	/ FD CB 20 E5
+	SET	4,[%IY + 48]	/ FD CB 30 E6
+	SET	4,[%IY + 64],%A	/ FD CB 40 E7
+	SET	5,[%IY + 16],%B	/ FD CB 10 E8
+	SET	5,[%IY + 32],%C	/ FD CB 20 E9
+	SET	5,[%IY + 48],%D	/ FD CB 30 EA
+	SET	5,[%IY + 64],%E	/ FD CB 40 EB
+	SET	5,[%IY + 16],%H	/ FD CB 10 EC
+	SET	5,[%IY + 32],%L	/ FD CB 20 ED
+	SET	5,[%IY + 48]	/ FD CB 30 EE
+	SET	5,[%IY + 64],%A	/ FD CB 40 EF
+	SET	6,[%IY + 16],%B	/ FD CB 10 F0
+	SET	6,[%IY + 32],%C	/ FD CB 20 F1
+	SET	6,[%IY + 48],%D	/ FD CB 30 F2
+	SET	6,[%IY + 64],%E	/ FD CB 40 F3
+	SET	6,[%IY + 16],%H	/ FD CB 10 F4
+	SET	6,[%IY + 32],%L	/ FD CB 20 F5
+	SET	6,[%IY + 48]	/ FD CB 30 F6
+	SET	6,[%IY + 64],%A	/ FD CB 40 F7
+	SET	7,[%IY + 16],%B	/ FD CB 10 F8
+	SET	7,[%IY + 32],%C	/ FD CB 20 F9
+	SET	7,[%IY + 48],%D	/ FD CB 30 FA
+	SET	7,[%IY + 64],%E	/ FD CB 40 FB
+	SET	7,[%IY + 16],%H	/ FD CB 10 FC
+	SET	7,[%IY + 32],%L	/ FD CB 20 FD
+	SET	7,[%IY + 48]	/ FD CB 30 FE
+	SET	7,[%IY + 64],%A	/ FD CB 40 FF
+	POP	%IY	/ FD E1
+	EX	[%SP],%IY	/ FD E3
+	PUSH	%IY	/ FD E5
+	JP	[%IY]	/ FD E9
+	LD	%SP,%IY	/ FD F9
+	CP	%A,32	/ FE 20
+	RST	56	/ FF
--- /dev/null
+++ b/as/target/x80/z80.c
@@ -1,0 +1,64 @@
+static char sccsid[] = "@(#) ./as/target/x80/z80.c";
+
+#include <stdlib.h>
+
+#include "../../../inc/scc.h"
+#include "../../as.h"
+#include "../x80/proc.h"
+
+TUINT maxaddr = 0xFFFFFFFF;
+int endian = LITTLE_ENDIAN;
+
+void
+iarch(void)
+{
+	static struct {
+		char *name;
+		char type;
+	} regs[] = {
+		"AF", AREG_AF,
+		"A", AREG_A,
+		"F", AREG_F,
+
+		"BC", AREG_BC,
+		"B", AREG_B,
+		"C", AREG_C,
+
+		"HL", AREG_HL,
+		"H", AREG_H,
+		"L", AREG_L,
+
+		"DE", AREG_DE,
+		"D", AREG_D,
+		"E", AREG_E,
+
+		"IX", AREG_IX,
+		"IXL", AREG_IXL,
+		"IXH", AREG_IXH,
+
+		"IY", AREG_IY,
+		"IYL", AREG_IYL,
+		"IYH", AREG_IYH,
+
+		"R", AREG_R,
+		"I", AREG_I,
+		"AF'", AREG_AF_,
+		"SP", AREG_SP,
+
+		"NZ", AREG_NZ,
+		"Z", AREG_Z,
+		"NC", AREG_NC,
+		"PO", AREG_PO,
+		"PE", AREG_PE,
+		"P", AREG_P,
+		"M", AREG_M,
+
+		NULL,
+	}, *bp;
+
+	for (bp = regs; bp->name; ++bp) {
+		Symbol *sym = lookup(bp->name);
+		sym->flags = FREG;
+		sym->value = bp->type;
+	}
+}
--- /dev/null
+++ b/as/target/x86/amd64.c
@@ -1,0 +1,12 @@
+static char sccsid[] = "@(#) ./as/target/x86/amd64.c";
+
+#include "../../../inc/scc.h"
+#include "../../as.h"
+
+TUINT maxaddr = 0xFFFFFFFFFFFFFFFF;
+int endian = LITTLE_ENDIAN;
+
+void
+iarch(void)
+{
+}
--- /dev/null
+++ b/as/target/x86/i386.c
@@ -1,0 +1,100 @@
+static char sccsid[] = "@(#) ./as/target/x86/i386.c";
+
+#include "../../../inc/scc.h"
+#include "../../as.h"
+#include "../x86/proc.h"
+
+TUINT maxaddr = 0xFFFFFFFF;
+int endian = LITTLE_ENDIAN;
+
+void
+iarch(void)
+{
+	static struct {
+		char *name;
+		char type;
+	} regs[] = {
+		"CS", AREG_CS,
+		"DS", AREG_DS,
+		"SS", AREG_SS,
+		"ES", AREG_ES,
+		"FS", AREG_FS,
+		"GS", AREG_GS,
+
+		"AX", AREG_AX,
+		"AL", AREG_AL,
+		"AH", AREG_AH,
+		"EAX", AREG_EAX,
+
+		"BC", AREG_BX,
+		"BL", AREG_BL,
+		"BH", AREG_BH,
+		"EBX", AREG_EBX,
+
+		"CX", AREG_CX,
+		"CL", AREG_CL,
+		"CH", AREG_CH,
+		"ECX", AREG_ECX,
+
+		"DX", AREG_DX,
+		"DL", AREG_DL,
+		"DH", AREG_DH,
+		"EDX", AREG_EDX,
+
+		"SI", AREG_SI,
+		"ESI", AREG_ESI,
+		"DI", AREG_DI,
+		"EDI", AREG_EDI,
+
+		"SP", AREG_SP,
+		"ESP", AREG_ESP,
+
+		"BP", AREG_BP,
+		"EBP", AREG_EBP,
+
+		"R0", AREG_R0,
+		"MM0", AREG_MM0,
+		"R1", AREG_R1,
+		"MM1", AREG_MM1,
+		"R2", AREG_R2,
+		"MM2", AREG_MM2,
+		"R3", AREG_R3,
+		"MM3", AREG_MM3,
+		"R4", AREG_R4,
+		"MM4", AREG_MM4,
+		"R5", AREG_R5,
+		"MM5", AREG_MM5,
+		"R6", AREG_R6,
+		"MM6", AREG_MM6,
+		"R7", AREG_R7,
+		"MM7", AREG_MM7,
+
+		"XMM0", AREG_XMM0,
+		"XMM1", AREG_XMM1,
+		"XMM2", AREG_XMM2,
+		"XMM3", AREG_XMM3,
+		"XMM4", AREG_XMM4,
+		"XMM5", AREG_XMM5,
+		"XMM6", AREG_XMM6,
+		"XMM7", AREG_XMM7,
+
+		"YMM0", AREG_YMM0,
+		"YMM1", AREG_YMM1,
+		"YMM2", AREG_YMM2,
+		"YMM3", AREG_YMM3,
+		"YMM4", AREG_YMM4,
+		"YMM5", AREG_YMM5,
+		"YMM6", AREG_YMM6,
+		"YMM7", AREG_YMM7,
+
+		"MXCSR", AREG_MXCSR,
+
+		NULL
+	}, *bp;
+
+	for (bp = regs; bp->name; ++bp) {
+		Symbol *sym = lookup(bp->name);
+		sym->flags = FREG;
+		sym->value = bp->type;
+	}
+}
--- /dev/null
+++ b/as/target/x86/ins.c
@@ -1,0 +1,38 @@
+static char sccsid[] = "@(#) ./as/target/x86/ins.c";
+
+#include <stdlib.h>
+
+#include "../../../inc/scc.h"
+#include "../../as.h"
+#include "proc.h"
+
+int
+match(Op *op, Node **args)
+{
+	unsigned char *p;
+	int a, olda;
+
+	if (!op->args)
+		return args == NULL;
+
+	for (p = op->args; *p; ++p) {
+		if (*p != AREP)
+			a = *p;
+		else
+			--p;
+
+		switch (a) {
+		case AIMM8:
+		case AIMM16:
+		case AIMM32:
+		case AIMM64:
+		case AREG_AL:
+		case AREG_AH:
+		case AREG_AX:
+		case AREG_EAX:
+		default:
+			abort();
+		}
+	}
+	return 1;
+}
--- /dev/null
+++ b/as/target/z80.mk
@@ -1,0 +1,9 @@
+
+Z80_LST = target/x80/z80tbl.o target/x80/z80.o target/x80/ins.o
+
+$(Z80_LST): target/x80/proc.h
+
+target/x80/z80tbl.c: gentbl.awk target/x80/x80.dat target/x80/rules.dat
+	./gentbl.sh -f x80 -c z80
+
+OBJ-z80 = $(OBJ) $(Z80_LST)
--- a/as/target/z80/ins.c
+++ /dev/null
@@ -1,7 +1,0 @@
-static char sccsid[] = "@(#) ./as/target/z80/ins.c";
-
-#include "../../../inc/scc.h"
-#include "../../as.h"
-
-TUINT maxaddr = 0xFFFFFFFF;
-int endian = LITTLE_ENDIAN;
--- a/as/target/z80/proc.c
+++ /dev/null
@@ -1,195 +1,0 @@
-static char sccsid[] = "@(#) ./as/target/i386/proc.c";
-
-#include <stdlib.h>
-
-#include "../../../inc/scc.h"
-#include "../../as.h"
-#include "../x80/proc.h"
-
-void
-iarch(void)
-{
-	static struct {
-		char *name;
-		char type;
-	} regs[] = {
-		"AF", AREG_AF,
-		"A", AREG_A,
-		"F", AREG_F,
-
-		"BC", AREG_BC,
-		"B", AREG_B,
-		"C", AREG_C,
-
-		"HL", AREG_HL,
-		"H", AREG_H,
-		"L", AREG_L,
-
-		"DE", AREG_DE,
-		"D", AREG_D,
-		"E", AREG_E,
-
-		"IX", AREG_IX,
-		"IXL", AREG_IXL,
-		"IXH", AREG_IXH,
-
-		"IY", AREG_IY,
-		"IYL", AREG_IYL,
-		"IYH", AREG_IYH,
-
-		"R", AREG_R,
-		"I", AREG_I,
-		"AF'", AREG_AF_,
-		"SP", AREG_SP,
-
-		"NZ", AREG_NZ,
-		"Z", AREG_Z,
-		"NC", AREG_NC,
-		"PO", AREG_PO,
-		"PE", AREG_PE,
-		"P", AREG_P,
-		"M", AREG_M,
-
-		NULL,
-	}, *bp;
-
-	for (bp = regs; bp->name; ++bp) {
-		Symbol *sym = lookup(bp->name);
-		sym->flags = FREG;
-		sym->value = bp->type;
-	}
-}
-
-int
-match(Op *op, Node **args)
-{
-	unsigned char *p;
-	int arg, class;
-	Node *np;
-
-	if (!op->args)
-		return args == NULL;
-
-	for (p = op->args; arg = *p; ++p) {
-		if (arg & AREP)
-			--p;
-		if ((np = *args++) == NULL)
-			return (arg & (AREP|AOPT)) != 0;
-
-		arg &= ~(AREP|AOPT);
-		switch (arg) {
-		case AINDER_C:
-			arg = AREG_C;
-			goto indirect;
-		case AINDER_HL:
-			arg = AREG_HL;
-			goto indirect;
-		case AINDER_DE:
-			arg = AREG_DE;
-			goto indirect;
-		case AINDER_BC:
-			arg = AREG_BC;
-			goto indirect;
-		case AINDER_IX:
-			arg = AREG_IX;
-			goto indirect;
-		case AINDER_IY:
-			arg = AREG_IY;
-			goto indirect;
-		case AINDER_SP:
-			arg = AREG_SP;
-		indirect:
-			if (np->addr != AINDIR)
-				return 0;
-			np = np->left;
-		case AREG_A:
-		case AREG_I:
-		case AREG_R:
-		case AREG_F:
-		case AREG_HL:
-		case AREG_BC:
-		case AREG_DE:
-		case AREG_IY:
-		case AREG_IX:
-		case AREG_SP:
-		case AREG_AF:
-		case AREG_AF_:
-			if (np->addr != AREG || np->sym->value != arg)
-				return 0;
-			break;
-		case AREG_RCLASS:
-			class = RCLASS;
-			goto check_class;
-		case AREG_PCLASS:
-			class = PCLASS;
-			goto check_class;
-		case AREG_QCLASS:
-			class = QCLASS;
-			goto check_class;
-		case AREG_QQCLASS:
-			class = QQCLASS;
-			goto check_class;
-		case AREG_PPCLASS:
-			class = PPCLASS;
-			goto check_class;
-		case AREG_RRCLASS:
-			class = RRCLASS;
-			goto check_class;
-		case AREG_CCCLASS:
-			class = CCCLASS;
-			goto check_class;
-		case AREG_SSCLASS:
-			class = SSCLASS;
-			goto check_class;
-		case AREG_DDCLASS:
-			class = DDCLASS;
-		check_class:
-			if ((getclass(np) & class) == 0)
-				return 0;
-			break;
-		case AINDEX_IY:
-			arg = AREG_IY;
-			goto index_address;
-		case AINDEX_IX:
-			arg = AREG_IX;
-		index_address:
-			if (np->addr != AINDEX)
-				return 0;
-			if (np->left->left->sym->value != arg)
-				return 0;
-			if (toobig(np, arg))
-				error("overflow in index");
-			break;
-		case ARST:
-			if (np->addr != AIMM)
-				return 0;
-			if ((np->sym->value & ~0x38) != 0)
-				return 0;
-			break;
-		case AZERO:
-		case AIMM3:
-		case AIMM8:
-		case AIMM16:
-		case AIMM32:
-		case AIMM64:
-			if (np->addr != AIMM)
-				return 0;
-			if (toobig(np, arg))
-				error("overflow in immediate operand");
-			break;
-		case ASYM:
-			if (np->addr != AIMM || np->op != IDEN)
-				return 0;
-			break;
-		case ADIRECT:
-		case ASTR:
-			if (np->addr != arg)
-				return 0;
-			break;
-		default:
-			abort();
-		}
-	}
-
-	return *args == NULL;
-}
--- a/as/target/z80/target.mk
+++ /dev/null
@@ -1,15 +1,0 @@
-
-Z80_LST = target/z80/instbl.o target/z80/ins.o target/z80/proc.o target/x80/ins.o
-
-$(Z80_LST): target/x80/proc.h
-
-target/z80/instbl.c: target/gen.awk target/x80/x80.dat target/x80/rules.dat
-	set -e ;\
-	rm -f $@;\
-	trap "rm -f $$$$.c" 0 2 3; \
-	awk '!/^$$/ {print $$1,NR,$$2,$$3,$$4,$$5,$$6}' target/x80/x80.dat | \
-	sort -k1 -k2n | \
-	awk -v cpu=Z80 -v family=x80 \
-		-f target/gen.awk  > $$$$.c && mv $$$$.c $@
- 
-OBJ-z80 = $(OBJ) $(Z80_LST)
--- a/as/target/z80/test.s
+++ /dev/null
@@ -1,1136 +1,0 @@
-	NOP		/ 00
-	LD	%BC,64	/ 01 40 00
-	LD	[%BC],%A	/ 02
-	INC	%BC	/ 03
-	INC	%B	/ 04
-	DEC	%B	/ 05
-	LD	%B,32	/ 06 20
-	RLCA		/ 07
-	EX	%AF,%AF'	/ 08
-	ADD	%HL,%BC	/ 09
-	LD	%A,[%BC]	/ 0A
-	DEC	%BC	/ 0B
-	INC	%C	/ 0C
-	DEC	%C	/ 0D
-	LD	%C,64	/ 0E 40
-	RRCA		/ 0F
-L1:	DJNZ	L1	/ 10 02
-	LD	%DE,32	/ 11 20 00
-	LD	[%DE],%A	/ 12
-	INC	%DE	/ 13
-	INC	%D	/ 14
-	DEC	%D	/ 15
-	LD	%D,64	/ 16 40
-	RLA		/ 17
-L2:	JR	L2	/ 18 02
-	ADD	%HL,%DE	/ 19
-	LD	%A,[%DE]	/ 1A
-	DEC	%DE	/ 1B
-	INC	%E	/ 1C
-	DEC	%E	/ 1D
-	LD	%E,64	/ 1E 40
-	RRA		/ 1F
-L3:	JR	%NZ,L3	/ 20 02
-	LD	%HL,32	/ 21 20 00
-	LD	[32768],%HL	/ 22 00 80
-	INC	%HL	/ 23
-	INC	%H	/ 24
-	DEC	%H	/ 25
-	LD	%H,64	/ 26 40
-	DAA		/ 27
-L4:	JR	%Z,L4	/ 28 02
-	ADD	%HL,%HL	/ 29
-	LD	%HL, [16384]	/ 2A 00 40
-	DEC	%HL	/ 2B
-	INC	%L	/ 2C
-	DEC	%L	/ 2D
-	LD	%L,32	/ 2E 20
-	CPL		/ 2F
-L5:	JR	%NC,L5	/ 30 02
-	LD	%SP,64	/ 31 40 00
-	LD	[32768],%A	/ 32 00 80
-	INC	%SP	/ 33
-	INC	[%HL]	/ 34
-	DEC	[%HL]	/ 35
-	LD	[%HL],32	/ 36 20
-	SCF		/ 37
-L6:	JR	%C,L6	/ 38 02
-	ADD	%HL,%SP	/ 39
-	LD	%A,[16384]	/ 3A 00 40
-	DEC	%SP	/ 3B
-	INC	%A	/ 3C
-	DEC	%A	/ 3D
-	LD	%A,32	/ 3E 20
-	CCF		/ 3F
-	LD	%B,%B	/ 40
-	LD	%B,%C	/ 41
-	LD	%B,%D	/ 42
-	LD	%B,%E	/ 43
-	LD	%B,%H	/ 44
-	LD	%B,%L	/ 45
-	LD	%B,[%HL]	/ 46
-	LD	%B,%A	/ 47
-	LD	%C,%B	/ 48
-	LD	%C,%C	/ 49
-	LD	%C,%D	/ 4A
-	LD	%C,%E	/ 4B
-	LD	%C,%H	/ 4C
-	LD	%C,%L	/ 4D
-	LD	%C,[%HL]	/ 4E
-	LD	%C,%A	/ 4F
-	LD	%D,%B	/ 50
-	LD	%D,%C	/ 51
-	LD	%D,%D	/ 52
-	LD	%D,%E	/ 53
-	LD	%D,%H	/ 54
-	LD	%D,%L	/ 55
-	LD	%D,[%HL]	/ 56
-	LD	%D,%A	/ 57
-	LD	%E,%B	/ 58
-	LD	%E,%C	/ 59
-	LD	%E,%D	/ 5A
-	LD	%E,%E	/ 5B
-	LD	%E,%H	/ 5C
-	LD	%E,%L	/ 5D
-	LD	%E,[%HL]	/ 5E
-	LD	%E,%A	/ 5F
-	LD	%H,%B	/ 60
-	LD	%H,%C	/ 61
-	LD	%H,%D	/ 62
-	LD	%H,%E	/ 63
-	LD	%H,%H	/ 64
-	LD	%H,%L	/ 65
-	LD	%H,[%HL]	/ 66
-	LD	%H,%A	/ 67
-	LD	%L,%B	/ 68
-	LD	%L,%C	/ 69
-	LD	%L,%D	/ 6A
-	LD	%L,%E	/ 6B
-	LD	%L,%H	/ 6C
-	LD	%L,%L	/ 6D
-	LD	%L,[%HL]	/ 6E
-	LD	%L,%A	/ 6F
-	LD	[%HL],%B	/ 70
-	LD	[%HL],%C	/ 71
-	LD	[%HL],%D	/ 72
-	LD	[%HL],%E	/ 73
-	LD	[%HL],%H	/ 74
-	LD	[%HL],%L	/ 75
-	HALT		/ 76
-	LD	[%HL],%A	/ 77
-	LD	%A,%B	/ 78
-	LD	%A,%C	/ 79
-	LD	%A,%D	/ 7A
-	LD	%A,%E	/ 7B
-	LD	%A,%H	/ 7C
-	LD	%A,%L	/ 7D
-	LD	%A,[%HL]	/ 7E
-	LD	%A,%A	/ 7F
-	ADD	%A,%B	/ 80
-	ADD	%A,%C	/ 81
-	ADD	%A,%D	/ 82
-	ADD	%A,%E	/ 83
-	ADD	%A,%H	/ 84
-	ADD	%A,%L	/ 85
-	ADD	%A,[%HL]	/ 86
-	ADD	%A,%A	/ 87
-	ADC	%A,%B	/ 88
-	ADC	%A,%C	/ 89
-	ADC	%A,%D	/ 8A
-	ADC	%A,%E	/ 8B
-	ADC	%A,%H	/ 8C
-	ADC	%A,%L	/ 8D
-	ADC	%A,[%HL]	/ 8E
-	ADC	%A,%A	/ 8F
-	SUB	%A,%B	/ 90
-	SUB	%A,%C	/ 91
-	SUB	%A,%D	/ 92
-	SUB	%A,%E	/ 93
-	SUB	%A,%H	/ 94
-	SUB	%A,%L	/ 95
-	SUB	%A,[%HL]	/ 96
-	SUB	%A,%A	/ 97
-	SBC	%A,%B	/ 98
-	SBC	%A,%C	/ 99
-	SBC	%A,%D	/ 9A
-	SBC	%A,%E	/ 9B
-	SBC	%A,%H	/ 9C
-	SBC	%A,%L	/ 9D
-	SBC	%A,[%HL]	/ 9E
-	SBC	%A,%A	/ 9F
-	AND	%A,%B	/ A0
-	AND	%A,%C	/ A1
-	AND	%A,%D	/ A2
-	AND	%A,%E	/ A3
-	AND	%A,%H	/ A4
-	AND	%A,%L	/ A5
-	AND	%A,[%HL]	/ A6
-	AND	%A,%A	/ A7
-	XOR	%A,%B	/ A8
-	XOR	%A,%C	/ A9
-	XOR	%A,%D	/ AA
-	XOR	%A,%E	/ AB
-	XOR	%A,%H	/ AC
-	XOR	%A,%L	/ AD
-	XOR	%A,[%HL]	/ AE
-	XOR	%A,%A	/ AF
-	OR	%A,%B	/ B0
-	OR	%A,%C	/ B1
-	OR	%A,%D	/ B2
-	OR	%A,%E	/ B3
-	OR	%A,%H	/ B4
-	OR	%A,%L	/ B5
-	OR	%A,[%HL]	/ B6
-	OR	%A,%A	/ B7
-	CP	%A,%B	/ B8
-	CP	%A,%C	/ B9
-	CP	%A,%D	/ BA
-	CP	%A,%E	/ BB
-	CP	%A,%H	/ BC
-	CP	%A,%L	/ BD
-	CP	%A,[%HL]	/ BE
-	CP	%A,%A	/ BF
-	RET	%NZ	/ C0
-	POP	%BC	/ C1
-	JP	%NZ,16384	/ C2 00 40
-	JP	32768	/ C3 00 80
-	CALL	%NZ,32768	/ C4 00 80
-	PUSH	%BC	/ C5
-	ADD	%A,32	/ C6 20
-	RST	0	/ C7
-	RET	%Z	/ C8
-	RET		/ C9
-	JP	%Z,32768	/ CA 00 80
-	RLC	%B	/ CB 00
-	RLC	%C	/ CB 01
-	RLC	%D	/ CB 02
-	RLC	%E	/ CB 03
-	RLC	%H	/ CB 04
-	RLC	%L	/ CB 05
-	RLC	[%HL]	/ CB 06
-	RLC	%A	/ CB 07
-	RRC	%B	/ CB 08
-	RRC	%C	/ CB 09
-	RRC	%D	/ CB 0A
-	RRC	%E	/ CB 0B
-	RRC	%H	/ CB 0C
-	RRC	%L	/ CB 0D
-	RRC	[%HL]	/ CB 0E
-	RRC	%A	/ CB 0F
-	RL	%B	/ CB 10
-	RL	%C	/ CB 11
-	RL	%D	/ CB 12
-	RL	%E	/ CB 13
-	RL	%H	/ CB 14
-	RL	%L	/ CB 15
-	RL	[%HL]	/ CB 16
-	RL	%A	/ CB 17
-	RR	%B	/ CB 18
-	RR	%C	/ CB 19
-	RR	%D	/ CB 1A
-	RR	%E	/ CB 1B
-	RR	%H	/ CB 1C
-	RR	%L	/ CB 1D
-	RR	[%HL]	/ CB 1E
-	RR	%A	/ CB 1F
-	SLA	%B	/ CB 20
-	SLA	%C	/ CB 21
-	SLA	%D	/ CB 22
-	SLA	%E	/ CB 23
-	SLA	%H	/ CB 24
-	SLA	%L	/ CB 25
-	SLA	[%HL]	/ CB 26
-	SLA	%A	/ CB 27
-	SRA	%B	/ CB 28
-	SRA	%C	/ CB 29
-	SRA	%D	/ CB 2A
-	SRA	%E	/ CB 2B
-	SRA	%H	/ CB 2C
-	SRA	%L	/ CB 2D
-	SRA	[%HL]	/ CB 2E
-	SRA	%A	/ CB 2F
-	SLL	%B	/ CB 30
-	SLL	%C	/ CB 31
-	SLL	%D	/ CB 32
-	SLL	%E	/ CB 33
-	SLL	%H	/ CB 34
-	SLL	%L	/ CB 35
-	SLL	[%HL]	/ CB 36
-	SLL	%A	/ CB 37
-	SRL	%B	/ CB 38
-	SRL	%C	/ CB 39
-	SRL	%D	/ CB 3A
-	SRL	%E	/ CB 3B
-	SRL	%H	/ CB 3C
-	SRL	%L	/ CB 3D
-	SRL	[%HL]	/ CB 3E
-	SRL	%A	/ CB 3F
-	BIT	0,%B	/ CB 40
-	BIT	0,%C	/ CB 41
-	BIT	0,%D	/ CB 42
-	BIT	0,%E	/ CB 43
-	BIT	0,%H	/ CB 44
-	BIT	0,%L	/ CB 45
-	BIT	0,[%HL]	/ CB 46
-	BIT	0,%A	/ CB 47
-	BIT	1,%B	/ CB 48
-	BIT	1,%C	/ CB 49
-	BIT	1,%D	/ CB 4A
-	BIT	1,%E	/ CB 4B
-	BIT	1,%H	/ CB 4C
-	BIT	1,%L	/ CB 4D
-	BIT	1,[%HL]	/ CB 4E
-	BIT	1,%A	/ CB 4F
-	BIT	2,%B	/ CB 50
-	BIT	2,%C	/ CB 51
-	BIT	2,%D	/ CB 52
-	BIT	2,%E	/ CB 53
-	BIT	2,%H	/ CB 54
-	BIT	2,%L	/ CB 55
-	BIT	2,[%HL]	/ CB 56
-	BIT	2,%A	/ CB 57
-	BIT	3,%B	/ CB 58
-	BIT	3,%C	/ CB 59
-	BIT	3,%D	/ CB 5A
-	BIT	3,%E	/ CB 5B
-	BIT	3,%H	/ CB 5C
-	BIT	3,%L	/ CB 5D
-	BIT	3,[%HL]	/ CB 5E
-	BIT	3,%A	/ CB 5F
-	BIT	4,%B	/ CB 60
-	BIT	4,%C	/ CB 61
-	BIT	4,%D	/ CB 62
-	BIT	4,%E	/ CB 63
-	BIT	4,%H	/ CB 64
-	BIT	4,%L	/ CB 65
-	BIT	4,[%HL]	/ CB 66
-	BIT	4,%A	/ CB 67
-	BIT	5,%B	/ CB 68
-	BIT	5,%C	/ CB 69
-	BIT	5,%D	/ CB 6A
-	BIT	5,%E	/ CB 6B
-	BIT	5,%H	/ CB 6C
-	BIT	5,%L	/ CB 6D
-	BIT	5,[%HL]	/ CB 6E
-	BIT	5,%A	/ CB 6F
-	BIT	6,%B	/ CB 70
-	BIT	6,%C	/ CB 71
-	BIT	6,%D	/ CB 72
-	BIT	6,%E	/ CB 73
-	BIT	6,%H	/ CB 74
-	BIT	6,%L	/ CB 75
-	BIT	6,[%HL]	/ CB 76
-	BIT	6,%A	/ CB 77
-	BIT	7,%B	/ CB 78
-	BIT	7,%C	/ CB 79
-	BIT	7,%D	/ CB 7A
-	BIT	7,%E	/ CB 7B
-	BIT	7,%H	/ CB 7C
-	BIT	7,%L	/ CB 7D
-	BIT	7,[%HL]	/ CB 7E
-	BIT	7,%A	/ CB 7F
-	RES	0,%B	/ CB 80
-	RES	0,%C	/ CB 81
-	RES	0,%D	/ CB 82
-	RES	0,%E	/ CB 83
-	RES	0,%H	/ CB 84
-	RES	0,%L	/ CB 85
-	RES	0,[%HL]	/ CB 86
-	RES	0,%A	/ CB 87
-	RES	1,%B	/ CB 88
-	RES	1,%C	/ CB 89
-	RES	1,%D	/ CB 8A
-	RES	1,%E	/ CB 8B
-	RES	1,%H	/ CB 8C
-	RES	1,%L	/ CB 8D
-	RES	1,[%HL]	/ CB 8E
-	RES	1,%A	/ CB 8F
-	RES	2,%B	/ CB 90
-	RES	2,%C	/ CB 91
-	RES	2,%D	/ CB 92
-	RES	2,%E	/ CB 93
-	RES	2,%H	/ CB 94
-	RES	2,%L	/ CB 95
-	RES	2,[%HL]	/ CB 96
-	RES	2,%A	/ CB 97
-	RES	3,%B	/ CB 98
-	RES	3,%C	/ CB 99
-	RES	3,%D	/ CB 9A
-	RES	3,%E	/ CB 9B
-	RES	3,%H	/ CB 9C
-	RES	3,%L	/ CB 9D
-	RES	3,[%HL]	/ CB 9E
-	RES	3,%A	/ CB 9F
-	RES	4,%B	/ CB A0
-	RES	4,%C	/ CB A1
-	RES	4,%D	/ CB A2
-	RES	4,%E	/ CB A3
-	RES	4,%H	/ CB A4
-	RES	4,%L	/ CB A5
-	RES	4,[%HL]	/ CB A6
-	RES	4,%A	/ CB A7
-	RES	5,%B	/ CB A8
-	RES	5,%C	/ CB A9
-	RES	5,%D	/ CB AA
-	RES	5,%E	/ CB AB
-	RES	5,%H	/ CB AC
-	RES	5,%L	/ CB AD
-	RES	5,[%HL]	/ CB AE
-	RES	5,%A	/ CB AF
-	RES	6,%B	/ CB B0
-	RES	6,%C	/ CB B1
-	RES	6,%D	/ CB B2
-	RES	6,%E	/ CB B3
-	RES	6,%H	/ CB B4
-	RES	6,%L	/ CB B5
-	RES	6,[%HL]	/ CB B6
-	RES	6,%A	/ CB B7
-	RES	7,%B	/ CB B8
-	RES	7,%C	/ CB B9
-	RES	7,%D	/ CB BA
-	RES	7,%E	/ CB BB
-	RES	7,%H	/ CB BC
-	RES	7,%L	/ CB BD
-	RES	7,[%HL]	/ CB BE
-	RES	7,%A	/ CB BF
-	SET	0,%B	/ CB C0
-	SET	0,%C	/ CB C1
-	SET	0,%D	/ CB C2
-	SET	0,%E	/ CB C3
-	SET	0,%H	/ CB C4
-	SET	0,%L	/ CB C5
-	SET	0,[%HL]	/ CB C6
-	SET	0,%A	/ CB C7
-	SET	1,%B	/ CB C8
-	SET	1,%C	/ CB C9
-	SET	1,%D	/ CB CA
-	SET	1,%E	/ CB CB
-	SET	1,%H	/ CB CC
-	SET	1,%L	/ CB CD
-	SET	1,[%HL]	/ CB CE
-	SET	1,%A	/ CB CF
-	SET	2,%B	/ CB D0
-	SET	2,%C	/ CB D1
-	SET	2,%D	/ CB D2
-	SET	2,%E	/ CB D3
-	SET	2,%H	/ CB D4
-	SET	2,%L	/ CB D5
-	SET	2,[%HL]	/ CB D6
-	SET	2,%A	/ CB D7
-	SET	3,%B	/ CB D8
-	SET	3,%C	/ CB D9
-	SET	3,%D	/ CB DA
-	SET	3,%E	/ CB DB
-	SET	3,%H	/ CB DC
-	SET	3,%L	/ CB DD
-	SET	3,[%HL]	/ CB DE
-	SET	3,%A	/ CB DF
-	SET	4,%B	/ CB E0
-	SET	4,%C	/ CB E1
-	SET	4,%D	/ CB E2
-	SET	4,%E	/ CB E3
-	SET	4,%H	/ CB E4
-	SET	4,%L	/ CB E5
-	SET	4,[%HL]	/ CB E6
-	SET	4,%A	/ CB E7
-	SET	5,%B	/ CB E8
-	SET	5,%C	/ CB E9
-	SET	5,%D	/ CB EA
-	SET	5,%E	/ CB EB
-	SET	5,%H	/ CB EC
-	SET	5,%L	/ CB ED
-	SET	5,[%HL]	/ CB EE
-	SET	5,%A	/ CB EF
-	SET	6,%B	/ CB F0
-	SET	6,%C	/ CB F1
-	SET	6,%D	/ CB F2
-	SET	6,%E	/ CB F3
-	SET	6,%H	/ CB F4
-	SET	6,%L	/ CB F5
-	SET	6,[%HL]	/ CB F6
-	SET	6,%A	/ CB F7
-	SET	7,%B	/ CB F8
-	SET	7,%C	/ CB F9
-	SET	7,%D	/ CB FA
-	SET	7,%E	/ CB FB
-	SET	7,%H	/ CB FC
-	SET	7,%L	/ CB FD
-	SET	7,[%HL]	/ CB FE
-	SET	7,%A	/ CB FF
-	CALL	%Z,16384	/ CC 00 40
-	CALL	16384	/ CD 00 40
-	ADC	%A,64	/ CE 40
-	RST	8	/ CF
-	RET	%NC	/ D0
-	POP	%DE	/ D1
-	JP	%NC,16384	/ D2 00 40
-	OUT	[153],%A	/ D3 99
-	CALL	%NC,32768	/ D4 00 80
-	PUSH	%DE	/ D5
-	SUB	%A,32	/ D6 20
-	RST	16	/ D7
-	RET	%C	/ D8
-	EXX		/ D9
-	JP	%C,16384	/ DA 00 40
-	IN	%A,[153]	/ DB 99
-	CALL	%C,32768	/ DC 00 80
-	ADD	%IX,%BC	/ DD 09
-	ADD	%IX,%DE	/ DD 19
-	LD	%IX,64	/ DD 21 40 00
-	LD	[32768],%IX	/ DD 22 00 80
-	INC	%IX	/ DD 23
-	INC	%IXH	/ DD 24
-	DEC	%IXH	/ DD 25
-	LD	%IXH,32	/ DD 26 20
-	ADD	%IX,%IX	/ DD 29
-	LD	%IX,[16384]	/ DD 2A 00 40
-	DEC	%IX	/ DD 2B
-	INC	%IXL	/ DD 2C
-	DEC	%IXL	/ DD 2D
-	LD	%IXL,64	/ DD 2E 40
-	INC	[%IX + 32]	/ DD 34 20
-	DEC	[%IX + 16]	/ DD 35 10
-	LD	[%IX + 64],128	/ DD 36 40 80
-	ADD	%IX,%SP	/ DD 39
-	LD	%B,%IXH	/ DD 44
-	LD	%B,%IXL	/ DD 45
-	LD	%B,[%IX + 32]	/ DD 46 20
-	LD	%C,%IXH	/ DD 4C
-	LD	%C,%IXL	/ DD 4D
-	LD	%C,[%IX + 48]	/ DD 4E 30
-	LD	%D,%IXH	/ DD 54
-	LD	%D,%IXL	/ DD 55
-	LD	%D,[%IX + 32]	/ DD 56 20
-	LD	%E,%IXH	/ DD 5C
-	LD	%E,%IXL	/ DD 5D
-	LD	%E,[%IX + 64]	/ DD 5E 40
-	LD	%IXH,%B	/ DD 60
-	LD	%IXH,%C	/ DD 61
-	LD	%IXH,%D	/ DD 62
-	LD	%IXH,%E	/ DD 63
-	LD	%IXH,%IXH	/ DD 64
-	LD	%IXH,%IXL	/ DD 65
-	LD	%H,[%IX + 16]	/ DD 66 10
-	LD	%IXH,%A	/ DD 67
-	LD	%IXL,%B	/ DD 68
-	LD	%IXL,%C	/ DD 69
-	LD	%IXL,%D	/ DD 6A
-	LD	%IXL,%E	/ DD 6B
-	LD	%IXL,%IXH	/ DD 6C
-	LD	%IXL,%IXL	/ DD 6D
-	LD	%L,[%IX + 48]	/ DD 6E 30
-	LD	%IXL,%A	/ DD 6F
-	LD	[%IX + 64],%B	/ DD 70 40
-	LD	[%IX + 16],%C	/ DD 71 10
-	LD	[%IX + 32],%D	/ DD 72 20
-	LD	[%IX + 48],%E	/ DD 73 30
-	LD	[%IX + 16],%H	/ DD 74 10
-	LD	[%IX + 32],%L	/ DD 75 20
-	LD	[%IX + 48],%A	/ DD 77 30
-	LD	%A,%IXH	/ DD 7C
-	LD	%A,%IXL	/ DD 7D
-	LD	%A,[%IX + 16]	/ DD 7E 10
-	ADD	%A,%IXH	/ DD 84
-	ADD	%A,%IXL	/ DD 85
-	ADD	%A,[%IX + 32]	/ DD 86 20
-	ADC	%A,%IXH	/ DD 8C
-	ADC	%A,%IXL	/ DD 8D
-	ADC	%A,[%IX + 48]	/ DD 8E 30
-	SUB	%A,%IXH	/ DD 94
-	SUB	%A,%IXL	/ DD 95
-	SUB	%A,[%IX + 16]	/ DD 96 10
-	SBC	%A,%IXH	/ DD 9C
-	SBC	%A,%IXL	/ DD 9D
-	SBC	%A,[%IX + 32]	/ DD 9E 20
-	AND	%A,%IXH	/ DD A4
-	AND	%A,%IXL	/ DD A5
-	AND	%A,[%IX + 48]	/ DD A6 30
-	XOR	%A,%IXH	/ DD AC
-	XOR	%A,%IXL	/ DD AD
-	XOR	%A,[%IX + 16]	/ DD AE 10
-	OR	%A,%IXH	/ DD B4
-	OR	%A,%IXL	/ DD B5
-	OR	%A,[%IX + 32]	/ DD B6 20
-	CP	%A,%IXH	/ DD BC
-	CP	%A,%IXL	/ DD BD
-	CP	%A,[%IX + 48]	/ DD BE 30
-	RLC	[%IX + 16],%B	/ DD CB 10 00
-	RLC	[%IX + 32],%C	/ DD CB 20 01
-	RLC	[%IX + 48],%D	/ DD CB 30 02
-	RLC	[%IX + 64],%E	/ DD CB 40 03
-	RLC	[%IX + 16],%H	/ DD CB 10 04
-	RLC	[%IX + 32],%L	/ DD CB 20 05
-	RLC	[%IX + 64]	/ DD CB 40 06
-	RLC	[%IX + 16],%A	/ DD CB 10 07
-	RRC	[%IX + 32],%B 	/ DD CB 20 08
-	RRC	[%IX + 48],%C	/ DD CB 30 09
-	RRC	[%IX + 64],%D	/ DD CB 40 0A
-	RRC	[%IX + 16],%E	/ DD CB 10 0B
-	RRC	[%IX + 32],%H	/ DD CB 20 0C
-	RRC	[%IX + 48],%L	/ DD CB 30 0D
-	RRC	[%IX + 16]	/ DD CB 10 0E
-	RRC	[%IX + 16],%A	/ DD CB 10 0F
-	RL	[%IX + 32],%B	/ DD CB 20 10
-	RL	[%IX + 48],%C	/ DD CB 30 11
-	RL	[%IX + 64],%D	/ DD CB 40 12
-	RL	[%IX + 16],%E	/ DD CB 10 13
-	RL	[%IX + 32],%H	/ DD CB 20 14
-	RL	[%IX + 48],%L	/ DD CB 30 15
-	RL	[%IX + 32]	/ DD CB 20 16
-	RL	[%IX + 16],%A	/ DD CB 10 17
-	RR	[%IX + 32],%B	/ DD CB 20 18
-	RR	[%IX + 48],%C	/ DD CB 30 19
-	RR	[%IX + 64],%D	/ DD CB 40 1A
-	RR	[%IX + 16],%E	/ DD CB 10 1B
-	RR	[%IX + 32],%H	/ DD CB 20 1C
-	RR	[%IX + 48],%L	/ DD CB 30 1D
-	RR	[%IX + 48]	/ DD CB 30 1E
-	RR	[%IX + 16],%A	/ DD CB 10 1F
-	SLA	[%IX + 32],%B	/ DD CB 20 20
-	SLA	[%IX + 48],%C	/ DD CB 30 21
-	SLA	[%IX + 64],%D	/ DD CB 40 22
-	SLA	[%IX + 16],%E	/ DD CB 10 23
-	SLA	[%IX + 32],%H	/ DD CB 20 24
-	SLA	[%IX + 48],%L	/ DD CB 30 25
-	SLA	[%IX + 64]	/ DD CB 40 26
-	SLA	[%IX + 16],%A	/ DD CB 10 27
-	SRA	[%IX + 32],%B	/ DD CB 20 28
-	SRA	[%IX + 48],%C	/ DD CB 30 29
-	SRA	[%IX + 64],%D	/ DD CB 40 2A
-	SRA	[%IX + 16],%E	/ DD CB 10 2B
-	SRA	[%IX + 32],%H	/ DD CB 20 2C
-	SRA	[%IX + 48],%L	/ DD CB 30 2D
-	SRA	[%IX + 16]	/ DD CB 10 2E
-	SRA	[%IX + 16],%A	/ DD CB 10 2F
-	SLL	[%IX + 32],%B	/ DD CB 20 30
-	SLL	[%IX + 48],%C	/ DD CB 30 31
-	SLL	[%IX + 64],%D	/ DD CB 40 32
-	SLL	[%IX + 16],%E	/ DD CB 10 33
-	SLL	[%IX + 32],%H	/ DD CB 20 34
-	SLL	[%IX + 48],%L	/ DD CB 30 35
-	SLL	[%IX + 32]	/ DD CB 20 36
-	SLL	[%IX + 16],%A	/ DD CB 10 37
-	SRL	[%IX + 32],%B	/ DD CB 20 38
-	SRL	[%IX + 48],%C	/ DD CB 30 39
-	SRL	[%IX + 64],%D	/ DD CB 40 3A
-	SRL	[%IX + 16],%E	/ DD CB 10 3B
-	SRL	[%IX + 32],%H	/ DD CB 20 3C
-	SRL	[%IX + 48],%L	/ DD CB 30 3D
-	SRL	[%IX + 48]	/ DD CB 30 3E
-	SRL	[%IX + 64],%A	/ DD CB 40 3F
-	BIT	0,[%IX + 16]	/ DD CB 10 46
-	BIT	1,[%IX + 32]	/ DD CB 20 4E
-	BIT	2,[%IX + 48]	/ DD CB 30 56
-	BIT	3,[%IX + 64]	/ DD CB 40 5E
-	BIT	4,[%IX + 16]	/ DD CB 10 66
-	BIT	5,[%IX + 32]	/ DD CB 20 6E
-	BIT	6,[%IX + 48]	/ DD CB 30 76
-	BIT	7,[%IX + 64]	/ DD CB 40 7E
-	RES	0,[%IX + 16],%B	/ DD CB 10 80
-	RES	0,[%IX + 32],%C	/ DD CB 20 81
-	RES	0,[%IX + 48],%D	/ DD CB 30 82
-	RES	0,[%IX + 64],%E	/ DD CB 40 83
-	RES	0,[%IX + 16],%H	/ DD CB 10 84
-	RES	0,[%IX + 32],%L	/ DD CB 20 85
-	RES	0,[%IX + 48]	/ DD CB 30 86
-	RES	0,[%IX + 64],%A	/ DD CB 40 87
-	RES	1,[%IX + 16],%B	/ DD CB 10 88
-	RES	1,[%IX + 32],%C	/ DD CB 20 89
-	RES	1,[%IX + 48],%D	/ DD CB 30 8A
-	RES	1,[%IX + 64],%E	/ DD CB 40 8B
-	RES	1,[%IX + 16],%H	/ DD CB 10 8C
-	RES	1,[%IX + 32],%L	/ DD CB 20 8D
-	RES	1,[%IX + 48]	/ DD CB 30 8E
-	RES	1,[%IX + 64],%A	/ DD CB 40 8F
-	RES	2,[%IX + 16],%B	/ DD CB 10 90
-	RES	2,[%IX + 32],%C	/ DD CB 20 91
-	RES	2,[%IX + 48],%D	/ DD CB 30 92
-	RES	2,[%IX + 64],%E	/ DD CB 40 93
-	RES	2,[%IX + 16],%H	/ DD CB 10 94
-	RES	2,[%IX + 32],%L	/ DD CB 20 95
-	RES	2,[%IX + 48]	/ DD CB 30 96
-	RES	2,[%IX + 64],%A	/ DD CB 40 97
-	RES	3,[%IX + 16],%B	/ DD CB 10 98
-	RES	3,[%IX + 32],%C	/ DD CB 20 99
-	RES	3,[%IX + 48],%D	/ DD CB 30 9A
-	RES	3,[%IX + 64],%E	/ DD CB 40 9B
-	RES	3,[%IX + 16],%H	/ DD CB 10 9C
-	RES	3,[%IX + 32],%L	/ DD CB 20 9D
-	RES	3,[%IX + 48]	/ DD CB 30 9E
-	RES	3,[%IX + 64],%A	/ DD CB 40 9F
-	RES	4,[%IX + 16],%B	/ DD CB 10 A0
-	RES	4,[%IX + 32],%C	/ DD CB 20 A1
-	RES	4,[%IX + 48],%D	/ DD CB 30 A2
-	RES	4,[%IX + 64],%E	/ DD CB 40 A3
-	RES	4,[%IX + 16],%H	/ DD CB 10 A4
-	RES	4,[%IX + 32],%L	/ DD CB 20 A5
-	RES	4,[%IX + 48]	/ DD CB 30 A6
-	RES	4,[%IX + 64],%A	/ DD CB 40 A7
-	RES	5,[%IX + 16],%B	/ DD CB 10 A8
-	RES	5,[%IX + 32],%C	/ DD CB 20 A9
-	RES	5,[%IX + 48],%D	/ DD CB 30 AA
-	RES	5,[%IX + 64],%E	/ DD CB 40 AB
-	RES	5,[%IX + 16],%H	/ DD CB 10 AC
-	RES	5,[%IX + 32],%L	/ DD CB 20 AD
-	RES	5,[%IX + 48]	/ DD CB 30 AE
-	RES	5,[%IX + 64],%A	/ DD CB 40 AF
-	RES	6,[%IX + 16],%B	/ DD CB 10 B0
-	RES	6,[%IX + 32],%C	/ DD CB 20 B1
-	RES	6,[%IX + 48],%D	/ DD CB 30 B2
-	RES	6,[%IX + 64],%E	/ DD CB 40 B3
-	RES	6,[%IX + 16],%H	/ DD CB 10 B4
-	RES	6,[%IX + 32],%L	/ DD CB 20 B5
-	RES	6,[%IX + 48]	/ DD CB 30 B6
-	RES	6,[%IX + 64],%A	/ DD CB 40 B7
-	RES	7,[%IX + 16],%B	/ DD CB 10 B8
-	RES	7,[%IX + 32],%C	/ DD CB 20 B9
-	RES	7,[%IX + 48],%D	/ DD CB 30 BA
-	RES	7,[%IX + 64],%E	/ DD CB 40 BB
-	RES	7,[%IX + 16],%H	/ DD CB 10 BC
-	RES	7,[%IX + 32],%L	/ DD CB 20 BD
-	RES	7,[%IX + 48]	/ DD CB 30 BE
-	RES	7,[%IX + 64],%A	/ DD CB 40 BF
-	SET	0,[%IX + 16],%B	/ DD CB 10 C0
-	SET	0,[%IX + 32],%C	/ DD CB 20 C1
-	SET	0,[%IX + 48],%D	/ DD CB 30 C2
-	SET	0,[%IX + 64],%E	/ DD CB 40 C3
-	SET	0,[%IX + 16],%H	/ DD CB 10 C4
-	SET	0,[%IX + 32],%L	/ DD CB 20 C5
-	SET	0,[%IX + 48]	/ DD CB 30 C6
-	SET	0,[%IX + 64],%A	/ DD CB 40 C7
-	SET	1,[%IX + 16],%B	/ DD CB 10 C8
-	SET	1,[%IX + 32],%C	/ DD CB 20 C9
-	SET	1,[%IX + 48],%D	/ DD CB 30 CA
-	SET	1,[%IX + 64],%E	/ DD CB 40 CB
-	SET	1,[%IX + 16],%H	/ DD CB 10 CC
-	SET	1,[%IX + 32],%L	/ DD CB 20 CD
-	SET	1,[%IX + 48]	/ DD CB 30 CE
-	SET	1,[%IX + 64],%A	/ DD CB 40 CF
-	SET	2,[%IX + 16],%B	/ DD CB 10 D0
-	SET	2,[%IX + 32],%C	/ DD CB 20 D1
-	SET	2,[%IX + 48],%D	/ DD CB 30 D2
-	SET	2,[%IX + 64],%E	/ DD CB 40 D3
-	SET	2,[%IX + 16],%H	/ DD CB 10 D4
-	SET	2,[%IX + 32],%L	/ DD CB 20 D5
-	SET	2,[%IX + 48]	/ DD CB 30 D6
-	SET	2,[%IX + 64],%A	/ DD CB 40 D7
-	SET	3,[%IX + 16],%B	/ DD CB 10 D8
-	SET	3,[%IX + 32],%C	/ DD CB 20 D9
-	SET	3,[%IX + 48],%D	/ DD CB 30 DA
-	SET	3,[%IX + 64],%E	/ DD CB 40 DB
-	SET	3,[%IX + 16],%H	/ DD CB 10 DC
-	SET	3,[%IX + 32],%L	/ DD CB 20 DD
-	SET	3,[%IX + 48]	/ DD CB 30 DE
-	SET	3,[%IX + 64],%A	/ DD CB 40 DF
-	SET	4,[%IX + 16],%B	/ DD CB 10 E0
-	SET	4,[%IX + 32],%C	/ DD CB 20 E1
-	SET	4,[%IX + 48],%D	/ DD CB 30 E2
-	SET	4,[%IX + 64],%E	/ DD CB 40 E3
-	SET	4,[%IX + 16],%H	/ DD CB 10 E4
-	SET	4,[%IX + 32],%L	/ DD CB 20 E5
-	SET	4,[%IX + 48]	/ DD CB 30 E6
-	SET	4,[%IX + 64],%A	/ DD CB 40 E7
-	SET	5,[%IX + 16],%B	/ DD CB 10 E8
-	SET	5,[%IX + 32],%C	/ DD CB 20 E9
-	SET	5,[%IX + 48],%D	/ DD CB 30 EA
-	SET	5,[%IX + 64],%E	/ DD CB 40 EB
-	SET	5,[%IX + 16],%H	/ DD CB 10 EC
-	SET	5,[%IX + 32],%L	/ DD CB 20 ED
-	SET	5,[%IX + 48]	/ DD CB 30 EE
-	SET	5,[%IX + 64],%A	/ DD CB 40 EF
-	SET	6,[%IX + 16],%B	/ DD CB 10 F0
-	SET	6,[%IX + 32],%C	/ DD CB 20 F1
-	SET	6,[%IX + 48],%D	/ DD CB 30 F2
-	SET	6,[%IX + 64],%E	/ DD CB 40 F3
-	SET	6,[%IX + 16],%H	/ DD CB 10 F4
-	SET	6,[%IX + 32],%L	/ DD CB 20 F5
-	SET	6,[%IX + 48]	/ DD CB 30 F6
-	SET	6,[%IX + 64],%A	/ DD CB 40 F7
-	SET	7,[%IX + 16],%B	/ DD CB 10 F8
-	SET	7,[%IX + 32],%C	/ DD CB 20 F9
-	SET	7,[%IX + 48],%D	/ DD CB 30 FA
-	SET	7,[%IX + 64],%E	/ DD CB 40 FB
-	SET	7,[%IX + 16],%H	/ DD CB 10 FC
-	SET	7,[%IX + 32],%L	/ DD CB 20 FD
-	SET	7,[%IX + 48]	/ DD CB 30 FE
-	SET	7,[%IX + 64],%A	/ DD CB 40 FF
-	POP	%IX	/ DD E1
-	EX	[%SP],%IX	/ DD E3
-	PUSH	%IX	/ DD E5
-	JP	[%IX]	/ DD E9
-	LD	%SP,%IX	/ DD F9
-	SBC	%A,64	/ DE 40
-	RST	24	/ DF
-	RET	%PO	/ E0
-	POP	%HL	/ E1
-	JP	%PO,32768	/ E2 00 80
-	EX	[%SP],%HL	/ E3
-	CALL	%PO,16384	/ E4 00 40
-	PUSH	%HL	/ E5
-	AND	%A,16	/ E6 10
-	RST	32	/ E7
-	RET	%PE	/ E8
-	JP	[%HL]	/ E9
-	JP	%PE,16384	/ EA 00 40
-	EX	%DE,%HL	/ EB
-	CALL	%PE,16384	/ EC 00 40
-	IN	%B,[%C]	/ ED 40
-	OUT	[%C],%B	/ ED 41
-	SBC	%HL,%BC	/ ED 42
-	LD	[32768],%BC	/ ED 43 00 80
-	NEG		/ ED 44
-	RETN		/ ED 45
-	IM	0	/ ED 46
-	LD	%I,%A	/ ED 47
-	IN	%C,[%C]	/ ED 48
-	OUT	[%C],%C	/ ED 49
-	ADC	%HL,%BC	/ ED 4A
-	LD	%BC,[16384]	/ ED 4B 00 40
-	RETI		/ ED 4D
-	LD	%R,%A	/ ED 4F
-	IN	%D,[%C]	/ ED 50
-	OUT	[%C],%D	/ ED 51
-	SBC	%HL,%DE	/ ED 52
-	LD	[32768],%DE	/ ED 53 00 80
-	IM	1	/ ED 56
-	LD	%A,%I	/ ED 57
-	IN	%E,[%C]	/ ED 58
-	OUT	[%C],%E	/ ED 59
-	ADC	%HL,%DE	/ ED 5A
-	LD	%DE,[16384]	/ ED 5B 00 40
-	IM	2	/ ED 5E
-	LD	%A,%R	/ ED 5F
-	IN	%H,[%C]	/ ED 60
-	OUT	[%C],%H	/ ED 61
-	SBC	%HL,%HL	/ ED 62
-	RRD		/ ED 67
-	IN	%L,[%C]	/ ED 68
-	OUT	[%C],%L	/ ED 69
-	ADC	%HL,%HL	/ ED 6A
-	RLD		/ ED 6F
-	IN	%F,[%C]	/ ED 70
-	OUT	[%C],0	/ ED 71
-	SBC	%HL,%SP	/ ED 72
-	LD	[16384],%SP	/ ED 73 00 40
-	IN	%A,[%C]	/ ED 78
-	OUT	[%C],%A	/ ED 79
-	ADC	%HL,%SP	/ ED 7A
-	LD	%SP,[32768]	/ ED 7B 00 80
-	LDI		/ ED A0
-	CPI		/ ED A1
-	INI		/ ED A2
-	OUTI		/ ED A3
-	LDD		/ ED A8
-	CPD		/ ED A9
-	IND		/ ED AA
-	OUTD		/ ED AB
-	LDIR		/ ED B0
-	CPIR		/ ED B1
-	INIR		/ ED B2
-	OTIR		/ ED B3
-	LDDR		/ ED B8
-	CPDR		/ ED B9
-	INDR		/ ED BA
-	OTDR		/ ED BB
-	XOR	%A,32	/ EE 20
-	RST	40	/ EF
-	RET	%P	/ F0
-	POP	%AF	/ F1
-	JP	%P,32768	/ F2 00 80
-	DI		/ F3
-	CALL	%P,16384	/ F4 00 40
-	PUSH	%AF	/ F5
-	OR	%A,32	/ F6 20
-	RST	48	/ F7
-	RET	%M	/ F8
-	LD	%SP,%HL	/ F9
-	JP	%M,32768	/ FA 00 80
-	EI		/ FB
-	CALL	%M,16384	/ FC 00 40
-	ADD	%IY,%BC	/ FD 09
-	ADD	%IY,%DE	/ FD 19
-	LD	%IY,32768	/ FD 21 00 80
-	LD	[16384],%IY	/ FD 22 00 40
-	INC	%IY	/ FD 23
-	INC	%IYH	/ FD 24
-	DEC	%IYH	/ FD 25
-	LD	%IYH,32	/ FD 26 20
-	ADD	%IY,%IY	/ FD 29
-	LD	%IY,[32768]	/ FD 2A 00 80
-	DEC	%IY	/ FD 2B
-	INC	%IYL	/ FD 2C
-	DEC	%IYL	/ FD 2D
-	LD	%IYL,16	/ FD 2E 10
-	INC	[%IY + 32]	/ FD 34 20
-	DEC	[%IY + 48]	/ FD 35 30
-	LD	[%IY + 64],16	/ FD 36 40 10
-	ADD	%IY,%SP	/ FD 39
-	LD	%B,%IYH	/ FD 44
-	LD	%B,%IYL	/ FD 45
-	LD	%B,[%IY + 32]	/ FD 46 20
-	LD	%C,%IYH	/ FD 4C
-	LD	%C,%IYL	/ FD 4D
-	LD	%C,[%IY + 48]	/ FD 4E 30
-	LD	%D,%IYH	/ FD 54
-	LD	%D,%IYL	/ FD 55
-	LD	%D,[%IY + 64]	/ FD 56 40
-	LD	%E,%IYH	/ FD 5C
-	LD	%E,%IYL	/ FD 5D
-	LD	%E,[%IY + 16]	/ FD 5E 10
-	LD	%IYH,%B	/ FD 60
-	LD	%IYH,%C	/ FD 61
-	LD	%IYH,%D	/ FD 62
-	LD	%IYH,%E	/ FD 63
-	LD	%IYH,%IYH	/ FD 64
-	LD	%IYH,%IYL	/ FD 65
-	LD	%H,[%IY + 32]	/ FD 66 20
-	LD	%IYH,%A	/ FD 67
-	LD	%IYL,%B	/ FD 68
-	LD	%IYL,%C	/ FD 69
-	LD	%IYL,%D	/ FD 6A
-	LD	%IYL,%E	/ FD 6B
-	LD	%IYL,%IYH	/ FD 6C
-	LD	%IYL,%IYL	/ FD 6D
-	LD	%L,[%IY + 48]	/ FD 6E 30
-	LD	%IYL,%A	/ FD 6F
-	LD	[%IY + 64],%B	/ FD 70 40
-	LD	[%IY + 16],%C	/ FD 71 10
-	LD	[%IY + 32],%D	/ FD 72 20
-	LD	[%IY + 48],%E	/ FD 73 30
-	LD	[%IY + 64],%H	/ FD 74 40
-	LD	[%IY + 16],%L	/ FD 75 10
-	LD	[%IY + 32],%A	/ FD 77 20
-	LD	%A,%IYH	/ FD 7C
-	LD	%A,%IYL	/ FD 7D
-	LD	%A,[%IY + 48]	/ FD 7E 30
-	ADD	%A,%IYH	/ FD 84
-	ADD	%A,%IYL	/ FD 85
-	ADD	%A,[%IY + 64]	/ FD 86 40
-	ADC	%A,%IYH	/ FD 8C
-	ADC	%A,%IYL	/ FD 8D
-	ADC	%A,[%IY + 16]	/ FD 8E 10
-	SUB	%A,%IYH	/ FD 94
-	SUB	%A,%IYL	/ FD 95
-	SUB	%A,[%IY + 32]	/ FD 96 20
-	SBC	%A,%IYH	/ FD 9C
-	SBC	%A,%IYL	/ FD 9D
-	SBC	%A,[%IY + 48]	/ FD 9E 30
-	AND	%A,%IYH	/ FD A4
-	AND	%A,%IYL	/ FD A5
-	AND	%A,[%IY + 64]	/ FD A6 40
-	XOR	%A,%IYH	/ FD AC
-	XOR	%A,%IYL	/ FD AD
-	XOR	%A,[%IY + 16]	/ FD AE 10
-	OR	%A,%IYH	/ FD B4
-	OR	%A,%IYL	/ FD B5
-	OR	%A,[%IY + 32]	/ FD B6 20
-	CP	%A,%IYH	/ FD BC
-	CP	%A,%IYL	/ FD BD
-	CP	%A,[%IY + 48]	/ FD BE 30
-	RLC	[%IY + 16],%B	/ FD CB 10 00
-	RLC	[%IY + 32],%C	/ FD CB 20 01
-	RLC	[%IY + 48],%D	/ FD CB 30 02
-	RLC	[%IY + 64],%E	/ FD CB 40 03
-	RLC	[%IY + 16],%H	/ FD CB 10 04
-	RLC	[%IY + 32],%L	/ FD CB 20 05
-	RLC	[%IY + 16]	/ FD CB 10 06
-	RLC	[%IY + 32],%A	/ FD CB 20 07
-	RRC	[%IY + 48],%B	/ FD CB 30 08
-	RRC	[%IY + 64],%C	/ FD CB 40 09
-	RRC	[%IY + 16],%D	/ FD CB 10 0A
-	RRC	[%IY + 32],%E	/ FD CB 20 0B
-	RRC	[%IY + 48],%H	/ FD CB 30 0C
-	RRC	[%IY + 64],%L	/ FD CB 40 0D
-	RRC	[%IY + 32]	/ FD CB 20 0E
-	RRC	[%IY + 16],%A	/ FD CB 10 0F
-	RL	[%IY + 32],%B	/ FD CB 20 10
-	RL	[%IY + 48],%C	/ FD CB 30 11
-	RL	[%IY + 64],%D	/ FD CB 40 12
-	RL	[%IY + 16],%E	/ FD CB 10 13
-	RL	[%IY + 32],%H	/ FD CB 20 14
-	RL	[%IY + 48],%L	/ FD CB 30 15
-	RL	[%IY + 48]	/ FD CB 30 16
-	RL	[%IY + 16],%A	/ FD CB 10 17
-	RR	[%IY + 32],%B	/ FD CB 20 18
-	RR	[%IY + 48],%C	/ FD CB 30 19
-	RR	[%IY + 64],%D	/ FD CB 40 1A
-	RR	[%IY + 16],%E	/ FD CB 10 1B
-	RR	[%IY + 32],%H	/ FD CB 20 1C
-	RR	[%IY + 48],%L	/ FD CB 30 1D
-	RR	[%IY + 64]	/ FD CB 40 1E
-	RR	[%IY + 16],%A	/ FD CB 10 1F
-	SLA	[%IY + 32],%B	/ FD CB 20 20
-	SLA	[%IY + 48],%C	/ FD CB 30 21
-	SLA	[%IY + 64],%D	/ FD CB 40 22
-	SLA	[%IY + 16],%E	/ FD CB 10 23
-	SLA	[%IY + 32],%H	/ FD CB 20 24
-	SLA	[%IY + 48],%L	/ FD CB 30 25
-	SLA	[%IY + 16]	/ FD CB 10 26
-	SLA	[%IY + 16],%A	/ FD CB 10 27
-	SRA	[%IY + 32],%B	/ FD CB 20 28
-	SRA	[%IY + 48],%C	/ FD CB 30 29
-	SRA	[%IY + 64],%D	/ FD CB 40 2A
-	SRA	[%IY + 16],%E	/ FD CB 10 2B
-	SRA	[%IY + 32],%H	/ FD CB 20 2C
-	SRA	[%IY + 48],%L	/ FD CB 30 2D
-	SRA	[%IY + 32]	/ FD CB 20 2E
-	SRA	[%IY + 48],%A	/ FD CB 30 2F
-	SLL	[%IY + 16],%B	/ FD CB 10 30
-	SLL	[%IY + 32],%C	/ FD CB 20 31
-	SLL	[%IY + 48],%D	/ FD CB 30 32
-	SLL	[%IY + 64],%E	/ FD CB 40 33
-	SLL	[%IY + 16],%H	/ FD CB 10 34
-	SLL	[%IY + 32],%L	/ FD CB 20 35
-	SLL	[%IY + 48]	/ FD CB 30 36
-	SLL	[%IY + 16],%A	/ FD CB 10 37
-	SRL	[%IY + 32],%B	/ FD CB 20 38
-	SRL	[%IY + 48],%C	/ FD CB 30 39
-	SRL	[%IY + 64],%D	/ FD CB 40 3A
-	SRL	[%IY + 16],%E	/ FD CB 10 3B
-	SRL	[%IY + 32],%H	/ FD CB 20 3C
-	SRL	[%IY + 48],%L	/ FD CB 30 3D
-	SRL	[%IY + 64]	/ FD CB 40 3E
-	SRL	[%IY + 16],%A	/ FD CB 10 3F
-	BIT	0,[%IY + 16]	/ FD CB 10 46
-	BIT	1,[%IY + 32]	/ FD CB 20 4E
-	BIT	2,[%IY + 48]	/ FD CB 30 56
-	BIT	3,[%IY + 64]	/ FD CB 40 5E
-	BIT	4,[%IY + 16]	/ FD CB 10 66
-	BIT	5,[%IY + 32]	/ FD CB 20 6E
-	BIT	6,[%IY + 48]	/ FD CB 30 76
-	BIT	7,[%IY + 64]	/ FD CB 40 7E
-	RES	0,[%IY + 16],%B	/ FD CB 10 80
-	RES	0,[%IY + 32],%C	/ FD CB 20 81
-	RES	0,[%IY + 48],%D	/ FD CB 30 82
-	RES	0,[%IY + 64],%E	/ FD CB 40 83
-	RES	0,[%IY + 16],%H	/ FD CB 10 84
-	RES	0,[%IY + 32],%L	/ FD CB 20 85
-	RES	0,[%IY + 48]	/ FD CB 30 86
-	RES	0,[%IY + 64],%A	/ FD CB 40 87
-	RES	1,[%IY + 16],%B	/ FD CB 10 88
-	RES	1,[%IY + 32],%C	/ FD CB 20 89
-	RES	1,[%IY + 48],%D	/ FD CB 30 8A
-	RES	1,[%IY + 64],%E	/ FD CB 40 8B
-	RES	1,[%IY + 16],%H	/ FD CB 10 8C
-	RES	1,[%IY + 32],%L	/ FD CB 20 8D
-	RES	1,[%IY + 48]	/ FD CB 30 8E
-	RES	1,[%IY + 64],%A	/ FD CB 40 8F
-	RES	2,[%IY + 16],%B	/ FD CB 10 90
-	RES	2,[%IY + 32],%C	/ FD CB 20 91
-	RES	2,[%IY + 48],%D	/ FD CB 30 92
-	RES	2,[%IY + 64],%E	/ FD CB 40 93
-	RES	2,[%IY + 16],%H	/ FD CB 10 94
-	RES	2,[%IY + 32],%L	/ FD CB 20 95
-	RES	2,[%IY + 48]	/ FD CB 30 96
-	RES	2,[%IY + 64],%A	/ FD CB 40 97
-	RES	3,[%IY + 16],%B	/ FD CB 10 98
-	RES	3,[%IY + 32],%C	/ FD CB 20 99
-	RES	3,[%IY + 48],%D	/ FD CB 30 9A
-	RES	3,[%IY + 64],%E	/ FD CB 40 9B
-	RES	3,[%IY + 16],%H	/ FD CB 10 9C
-	RES	3,[%IY + 32],%L	/ FD CB 20 9D
-	RES	3,[%IY + 48]	/ FD CB 30 9E
-	RES	3,[%IY + 64],%A	/ FD CB 40 9F
-	RES	4,[%IY + 16],%B	/ FD CB 10 A0
-	RES	4,[%IY + 32],%C	/ FD CB 20 A1
-	RES	4,[%IY + 48],%D	/ FD CB 30 A2
-	RES	4,[%IY + 64],%E	/ FD CB 40 A3
-	RES	4,[%IY + 16],%H	/ FD CB 10 A4
-	RES	4,[%IY + 32],%L	/ FD CB 20 A5
-	RES	4,[%IY + 48]	/ FD CB 30 A6
-	RES	4,[%IY + 64],%A	/ FD CB 40 A7
-	RES	5,[%IY + 16],%B	/ FD CB 10 A8
-	RES	5,[%IY + 32],%C	/ FD CB 20 A9
-	RES	5,[%IY + 48],%D	/ FD CB 30 AA
-	RES	5,[%IY + 64],%E	/ FD CB 40 AB
-	RES	5,[%IY + 16],%H	/ FD CB 10 AC
-	RES	5,[%IY + 32],%L	/ FD CB 20 AD
-	RES	5,[%IY + 48]	/ FD CB 30 AE
-	RES	5,[%IY + 64],%A	/ FD CB 40 AF
-	RES	6,[%IY + 16],%B	/ FD CB 10 B0
-	RES	6,[%IY + 32],%C	/ FD CB 20 B1
-	RES	6,[%IY + 48],%D	/ FD CB 30 B2
-	RES	6,[%IY + 64],%E	/ FD CB 40 B3
-	RES	6,[%IY + 16],%H	/ FD CB 10 B4
-	RES	6,[%IY + 32],%L	/ FD CB 20 B5
-	RES	6,[%IY + 48]	/ FD CB 30 B6
-	RES	6,[%IY + 64],%A	/ FD CB 40 B7
-	RES	7,[%IY + 16],%B	/ FD CB 10 B8
-	RES	7,[%IY + 32],%C	/ FD CB 20 B9
-	RES	7,[%IY + 48],%D	/ FD CB 30 BA
-	RES	7,[%IY + 64],%E	/ FD CB 40 BB
-	RES	7,[%IY + 16],%H	/ FD CB 10 BC
-	RES	7,[%IY + 32],%L	/ FD CB 20 BD
-	RES	7,[%IY + 48]	/ FD CB 30 BE
-	RES	7,[%IY + 64],%A	/ FD CB 40 BF
-	SET	0,[%IY + 16],%B	/ FD CB 10 C0
-	SET	0,[%IY + 32],%C	/ FD CB 20 C1
-	SET	0,[%IY + 48],%D	/ FD CB 30 C2
-	SET	0,[%IY + 64],%E	/ FD CB 40 C3
-	SET	0,[%IY + 16],%H	/ FD CB 10 C4
-	SET	0,[%IY + 32],%L	/ FD CB 20 C5
-	SET	0,[%IY + 48]	/ FD CB 30 C6
-	SET	0,[%IY + 64],%A	/ FD CB 40 C7
-	SET	1,[%IY + 16],%B	/ FD CB 10 C8
-	SET	1,[%IY + 32],%C	/ FD CB 20 C9
-	SET	1,[%IY + 48],%D	/ FD CB 30 CA
-	SET	1,[%IY + 64],%E	/ FD CB 40 CB
-	SET	1,[%IY + 16],%H	/ FD CB 10 CC
-	SET	1,[%IY + 32],%L	/ FD CB 20 CD
-	SET	1,[%IY + 48]	/ FD CB 30 CE
-	SET	1,[%IY + 64],%A	/ FD CB 40 CF
-	SET	2,[%IY + 16],%B	/ FD CB 10 D0
-	SET	2,[%IY + 32],%C	/ FD CB 20 D1
-	SET	2,[%IY + 48],%D	/ FD CB 30 D2
-	SET	2,[%IY + 64],%E	/ FD CB 40 D3
-	SET	2,[%IY + 16],%H	/ FD CB 10 D4
-	SET	2,[%IY + 32],%L	/ FD CB 20 D5
-	SET	2,[%IY + 48]	/ FD CB 30 D6
-	SET	2,[%IY + 64],%A	/ FD CB 40 D7
-	SET	3,[%IY + 16],%B	/ FD CB 10 D8
-	SET	3,[%IY + 32],%C	/ FD CB 20 D9
-	SET	3,[%IY + 48],%D	/ FD CB 30 DA
-	SET	3,[%IY + 64],%E	/ FD CB 40 DB
-	SET	3,[%IY + 16],%H	/ FD CB 10 DC
-	SET	3,[%IY + 32],%L	/ FD CB 20 DD
-	SET	3,[%IY + 48]	/ FD CB 30 DE
-	SET	3,[%IY + 64],%A	/ FD CB 40 DF
-	SET	4,[%IY + 16],%B	/ FD CB 10 E0
-	SET	4,[%IY + 32],%C	/ FD CB 20 E1
-	SET	4,[%IY + 48],%D	/ FD CB 30 E2
-	SET	4,[%IY + 64],%E	/ FD CB 40 E3
-	SET	4,[%IY + 16],%H	/ FD CB 10 E4
-	SET	4,[%IY + 32],%L	/ FD CB 20 E5
-	SET	4,[%IY + 48]	/ FD CB 30 E6
-	SET	4,[%IY + 64],%A	/ FD CB 40 E7
-	SET	5,[%IY + 16],%B	/ FD CB 10 E8
-	SET	5,[%IY + 32],%C	/ FD CB 20 E9
-	SET	5,[%IY + 48],%D	/ FD CB 30 EA
-	SET	5,[%IY + 64],%E	/ FD CB 40 EB
-	SET	5,[%IY + 16],%H	/ FD CB 10 EC
-	SET	5,[%IY + 32],%L	/ FD CB 20 ED
-	SET	5,[%IY + 48]	/ FD CB 30 EE
-	SET	5,[%IY + 64],%A	/ FD CB 40 EF
-	SET	6,[%IY + 16],%B	/ FD CB 10 F0
-	SET	6,[%IY + 32],%C	/ FD CB 20 F1
-	SET	6,[%IY + 48],%D	/ FD CB 30 F2
-	SET	6,[%IY + 64],%E	/ FD CB 40 F3
-	SET	6,[%IY + 16],%H	/ FD CB 10 F4
-	SET	6,[%IY + 32],%L	/ FD CB 20 F5
-	SET	6,[%IY + 48]	/ FD CB 30 F6
-	SET	6,[%IY + 64],%A	/ FD CB 40 F7
-	SET	7,[%IY + 16],%B	/ FD CB 10 F8
-	SET	7,[%IY + 32],%C	/ FD CB 20 F9
-	SET	7,[%IY + 48],%D	/ FD CB 30 FA
-	SET	7,[%IY + 64],%E	/ FD CB 40 FB
-	SET	7,[%IY + 16],%H	/ FD CB 10 FC
-	SET	7,[%IY + 32],%L	/ FD CB 20 FD
-	SET	7,[%IY + 48]	/ FD CB 30 FE
-	SET	7,[%IY + 64],%A	/ FD CB 40 FF
-	POP	%IY	/ FD E1
-	EX	[%SP],%IY	/ FD E3
-	PUSH	%IY	/ FD E5
-	JP	[%IY]	/ FD E9
-	LD	%SP,%IY	/ FD F9
-	CP	%A,32	/ FE 20
-	RST	56	/ FF