aboutsummaryrefslogtreecommitdiff
path: root/gas
diff options
context:
space:
mode:
Diffstat (limited to 'gas')
-rw-r--r--gas/ChangeLog15
-rw-r--r--gas/config/tc-z80.c610
-rw-r--r--gas/config/tc-z80.h21
-rw-r--r--gas/doc/c-z80.texi22
-rw-r--r--gas/testsuite/gas/z80/gbz80_all.d514
-rw-r--r--gas/testsuite/gas/z80/gbz80_all.s519
-rw-r--r--gas/testsuite/gas/z80/z80.exp6
-rw-r--r--gas/testsuite/gas/z80/z80n_all.d1208
-rw-r--r--gas/testsuite/gas/z80/z80n_all.s1242
-rw-r--r--gas/testsuite/gas/z80/z80n_reloc.d10
10 files changed, 4039 insertions, 128 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index b600180..1cc473b 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,3 +1,18 @@
+2020-02-07 Sergey Belyashov <sergey.belyashov@gmail.com>
+
+ PR 25469
+ * config/tc-z80.c: Add -gbz80 command line option to generate code
+ for the GameBoy Z80. Add support for generating DWARF.
+ * config/tc-z80.h: Add support for DWARF debug information
+ generation.
+ * doc/c-z80.texi: Document new command line option.
+ * testsuite/gas/z80/gbz80_all.d: New file.
+ * testsuite/gas/z80/gbz80_all.s: New file.
+ * testsuite/gas/z80/z80.exp: Run the new tests.
+ * testsuite/gas/z80/z80n_all.d: New file.
+ * testsuite/gas/z80/z80n_all.s: New file.
+ * testsuite/gas/z80/z80n_reloc.d: New file.
+
2020-02-06 H.J. Lu <hongjiu.lu@intel.com>
PR gas/25381
diff --git a/gas/config/tc-z80.c b/gas/config/tc-z80.c
index d823549..abe8c11 100644
--- a/gas/config/tc-z80.c
+++ b/gas/config/tc-z80.c
@@ -24,6 +24,7 @@
#include "subsegs.h"
#include "elf/z80.h"
#include "dwarf2dbg.h"
+#include "dw2gencfi.h"
/* Exported constants. */
const char comment_chars[] = ";\0";
@@ -43,6 +44,7 @@ enum options
OPTION_MACH_EZ80_Z80,
OPTION_MACH_EZ80_ADL,
OPTION_MACH_GBZ80,
+ OPTION_MACH_Z80N,
OPTION_MACH_INST,
OPTION_MACH_NO_INST,
OPTION_MACH_IUD,
@@ -63,6 +65,7 @@ enum options
#define INS_GBZ80 (1 << 2)
#define INS_Z180 (1 << 3)
#define INS_EZ80 (1 << 4)
+#define INS_Z80N (1 << 5)
#define INS_MARCH_MASK 0xffff
#define INS_IDX_HALF (1 << 16)
@@ -72,7 +75,7 @@ enum options
#define INS_ROT_II_LD (1 << 20) /* instructions like SLA (ii+d),r; which is: LD r,(ii+d); SLA r; LD (ii+d),r */
#define INS_TUNE_MASK 0xffff0000
-#define INS_NOT_GBZ80 (INS_Z80 | INS_Z180 | INS_R800 | INS_EZ80)
+#define INS_NOT_GBZ80 (INS_Z80 | INS_Z180 | INS_R800 | INS_EZ80 | INS_Z80N)
#define INS_ALL 0
#define INS_UNDOC (INS_IDX_HALF | INS_IN_F_C)
@@ -85,6 +88,8 @@ struct option md_longopts[] =
{ "z180", no_argument, NULL, OPTION_MACH_Z180},
{ "ez80", no_argument, NULL, OPTION_MACH_EZ80_Z80},
{ "ez80-adl", no_argument, NULL, OPTION_MACH_EZ80_ADL},
+ { "gbz80", no_argument, NULL, OPTION_MACH_GBZ80},
+ { "z80n", no_argument, NULL, OPTION_MACH_Z80N},
{ "fp-s", required_argument, NULL, OPTION_FP_SINGLE_FORMAT},
{ "fp-d", required_argument, NULL, OPTION_FP_DOUBLE_FORMAT},
{ "strict", no_argument, NULL, OPTION_MACH_FUD},
@@ -243,7 +248,7 @@ md_parse_option (int c, const char* arg)
ins_err = (ins_err & INS_MARCH_MASK) | (~INS_Z80 & INS_MARCH_MASK);
break;
case OPTION_MACH_R800:
- ins_ok = INS_R800 | INS_IDX_HALF;
+ ins_ok = INS_R800 | INS_IDX_HALF | INS_IN_F_C;
ins_err = INS_UNPORT;
break;
case OPTION_MACH_Z180:
@@ -251,12 +256,12 @@ md_parse_option (int c, const char* arg)
ins_err = INS_UNDOC | INS_UNPORT;
break;
case OPTION_MACH_EZ80_Z80:
- ins_ok = INS_EZ80;
+ ins_ok = INS_EZ80 | INS_IDX_HALF;
ins_err = (INS_UNDOC | INS_UNPORT) & ~INS_IDX_HALF;
cpu_mode = 0;
break;
case OPTION_MACH_EZ80_ADL:
- ins_ok = INS_EZ80;
+ ins_ok = INS_EZ80 | INS_IDX_HALF;
ins_err = (INS_UNDOC | INS_UNPORT) & ~INS_IDX_HALF;
cpu_mode = 1;
break;
@@ -264,6 +269,10 @@ md_parse_option (int c, const char* arg)
ins_ok = INS_GBZ80;
ins_err = INS_UNDOC | INS_UNPORT;
break;
+ case OPTION_MACH_Z80N:
+ ins_ok = INS_Z80N | INS_UNPORT | INS_UNDOC;
+ ins_err = 0;
+ break;
case OPTION_FP_SINGLE_FORMAT:
str_to_float = get_str_to_float (arg);
break;
@@ -325,11 +334,13 @@ md_show_usage (FILE * f)
{
fprintf (f, "\n\
CPU model options:\n\
- -z80\t\t\t assemble for Z80\n\
- -r800\t\t\t assemble for R800\n\
- -z180\t\t\t assemble for Z180\n\
- -ez80\t\t\t assemble for eZ80 in Z80 mode by default\n\
- -ez80-adl\t\t assemble for eZ80 in ADL mode by default\n\
+ -z80\t\t\t assemble for Zilog Z80\n\
+ -r800\t\t\t assemble for Ascii R800\n\
+ -z180\t\t\t assemble for Zilog Z180\n\
+ -ez80\t\t\t assemble for Zilog eZ80 in Z80 mode by default\n\
+ -ez80-adl\t\t assemble for Zilog eZ80 in ADL mode by default\n\
+ -gbz80\t\t assemble for GameBoy Z80\n\
+ -z80n\t\t\t assemble for Z80N\n\
\n\
Compatibility options:\n\
-local-prefix=TEXT\t treat labels prefixed by TEXT as local\n\
@@ -507,6 +518,9 @@ z80_md_end (void)
case INS_EZ80:
mach_type = cpu_mode ? bfd_mach_ez80_adl : bfd_mach_ez80_z80;
break;
+ case INS_Z80N:
+ mach_type = bfd_mach_z80n;
+ break;
default:
mach_type = 0;
}
@@ -536,6 +550,9 @@ z80_elf_final_processing (void)
case INS_EZ80:
elf_flags = cpu_mode ? EF_Z80_MACH_EZ80_ADL : EF_Z80_MACH_EZ80_Z80;
break;
+ case INS_Z80N:
+ elf_flags = EF_Z80_MACH_Z80N;
+ break;
default:
elf_flags = 0;
}
@@ -843,6 +860,22 @@ parse_exp_not_indexed (const char *s, expressionS *op)
}
op->X_md = indir = is_indir (p);
+ if (indir && (ins_ok & INS_GBZ80))
+ { /* check for instructions like ld a,(hl+), ld (hl-),a */
+ p = skip_space (p+1);
+ if (!strncasecmp (p, "hl", 2))
+ {
+ p = skip_space(p+2);
+ if (*skip_space(p+1) == ')' && (*p == '+' || *p == '-'))
+ {
+ op->X_op = O_md1;
+ op->X_add_symbol = NULL;
+ op->X_add_number = (*p == '+') ? REG_HL : -REG_HL;
+ input_line_pointer = (char*)skip_space(p + 1) + 1;
+ return input_line_pointer;
+ }
+ }
+ }
input_line_pointer = (char*) s ;
expression (op);
switch (op->X_op)
@@ -1122,7 +1155,6 @@ static void
emit_byte (expressionS * val, bfd_reloc_code_real_type r_type)
{
char *p;
- int lo, hi;
if (r_type == BFD_RELOC_8)
{
@@ -1141,15 +1173,12 @@ emit_byte (expressionS * val, bfd_reloc_code_real_type r_type)
}
else if (val->X_op == O_constant)
{
- lo = -128;
- hi = (BFD_RELOC_8 == r_type) ? 255 : 127;
-
- if ((val->X_add_number < lo) || (val->X_add_number > hi))
+ if ((val->X_add_number < -128) || (val->X_add_number >= 128))
{
if (r_type == BFD_RELOC_Z80_DISP8)
- as_bad (_("offset too large"));
+ as_bad (_("index overflow (%+ld)"), val->X_add_number);
else
- as_warn (_("overflow"));
+ as_bad (_("offset overflow (%+ld)"), val->X_add_number);
}
}
else
@@ -1340,6 +1369,51 @@ emit_s (char prefix, char opcode, const char *args)
}
static const char *
+emit_sub (char prefix, char opcode, const char *args)
+{
+ expressionS arg_s;
+ const char *p;
+
+ if (!(ins_ok & INS_GBZ80))
+ return emit_s (prefix, opcode, args);
+ p = parse_exp (args, & arg_s);
+ if (*p++ != ',')
+ {
+ error (_("bad instruction syntax"));
+ return p;
+ }
+
+ if (arg_s.X_md != 0 || arg_s.X_op != O_register || arg_s.X_add_number != REG_A)
+ ill_op ();
+
+ p = parse_exp (p, & arg_s);
+
+ emit_sx (prefix, opcode, & arg_s);
+ return p;
+}
+
+static const char *
+emit_swap (char prefix, char opcode, const char *args)
+{
+ expressionS reg;
+ const char *p;
+ char *q;
+
+ if (!(ins_ok & INS_Z80N))
+ return emit_mr (prefix, opcode, args);
+
+ /* check for alias swap a for swapnib of Z80N */
+ p = parse_exp (args, &reg);
+ if (reg.X_md != 0 || reg.X_op != O_register || reg.X_add_number != REG_A)
+ ill_op ();
+
+ q = frag_more (2);
+ *q++ = 0xED;
+ *q = 0x23;
+ return p;
+}
+
+static const char *
emit_call (char prefix ATTRIBUTE_UNUSED, char opcode, const char * args)
{
expressionS addr;
@@ -1425,6 +1499,12 @@ emit_jp (char prefix, char opcode, const char * args)
*q++ = (rnum & R_IX) ? 0xDD : 0xFD;
*q = prefix;
}
+ else if (addr.X_op == O_register && rnum == REG_C && (ins_ok & INS_Z80N))
+ {
+ q = frag_more (2);
+ *q++ = 0xED;
+ *q = 0x98;
+ }
else
ill_op ();
}
@@ -1496,6 +1576,31 @@ emit_pop (char prefix ATTRIBUTE_UNUSED, char opcode, const char * args)
}
static const char *
+emit_push (char prefix, char opcode, const char * args)
+{
+ expressionS arg;
+ const char *p;
+ char *q;
+
+ p = parse_exp (args, & arg);
+ if (arg.X_op == O_register)
+ return emit_pop (prefix, opcode, args);
+
+ if (arg.X_md || arg.X_op == O_md1 || !(ins_ok & INS_Z80N))
+ ill_op ();
+
+ q = frag_more (2);
+ *q++ = 0xED;
+ *q = 0x8A;
+
+ q = frag_more (2);
+ fix_new_exp (frag_now, q - frag_now->fr_literal, 2, &arg, FALSE,
+ BFD_RELOC_Z80_16_BE);
+
+ return p;
+}
+
+static const char *
emit_retcc (char prefix ATTRIBUTE_UNUSED, char opcode, const char * args)
{
char cc, *q;
@@ -1571,19 +1676,38 @@ emit_add (char prefix, char opcode, const char * args)
if ((term.X_md) || (term.X_op != O_register))
ill_op ();
else
- switch (term.X_add_number & ~R_INDEX)
+ switch (term.X_add_number)
{
case REG_A:
p = emit_s (0, prefix, p);
break;
+ case REG_SP:
+ p = parse_exp (p, &term);
+ if (!(ins_ok & INS_GBZ80) || term.X_md || term.X_op == O_register)
+ ill_op ();
+ q = frag_more (1);
+ *q = 0xE8;
+ emit_byte (&term, BFD_RELOC_Z80_DISP8);
+ break;
+ case REG_BC:
+ case REG_DE:
+ if (!(ins_ok & INS_Z80N))
+ {
+ ill_op ();
+ break;
+ }
+ /* Fall through. */
case REG_HL:
+ case REG_IX:
+ case REG_IY:
lhs = term.X_add_number;
p = parse_exp (p, &term);
- if ((!term.X_md) && (term.X_op == O_register))
+ rhs = term.X_add_number;
+ if (term.X_md != 0 || term.X_op == O_md1)
+ ill_op ();
+ else if ((term.X_op == O_register) && (rhs & R_ARITH) && (rhs == lhs || (rhs & ~R_INDEX) != REG_HL))
{
- rhs = term.X_add_number;
- if ((rhs & R_ARITH)
- && ((rhs == lhs) || ((rhs & ~R_INDEX) != REG_HL)))
+ if (1)
{
q = frag_more ((lhs & R_INDEX) ? 2 : 1);
if (lhs & R_INDEX)
@@ -1592,6 +1716,24 @@ emit_add (char prefix, char opcode, const char * args)
break;
}
}
+ else if (!(lhs & R_INDEX) && (ins_ok & INS_Z80N))
+ {
+ if (term.X_op == O_register && rhs == REG_A)
+ { /* ADD BC/DE/HL,A */
+ q = frag_more (2);
+ *q++ = 0xED;
+ *q = 0x33 - (lhs & 3);
+ break;
+ }
+ else if (term.X_op != O_register && term.X_op != O_md1)
+ { /* ADD BC/DE/HL,nn */
+ q = frag_more (2);
+ *q++ = 0xED;
+ *q = 0x36 - (lhs & 3);
+ emit_word (&term);
+ break;
+ }
+ }
/* Fall through. */
default:
ill_op ();
@@ -1628,6 +1770,27 @@ emit_bit (char prefix, char opcode, const char * args)
return p;
}
+/* BSLA DE,B; BSRA DE,B; BSRL DE,B; BSRF DE,B; BRLC DE,B (Z80N only) */
+static const char *
+emit_bshft (char prefix, char opcode, const char * args)
+{
+ expressionS r1, r2;
+ const char *p;
+ char *q;
+
+ p = parse_exp (args, & r1);
+ if (*p++ != ',')
+ error (_("bad instruction syntax"));
+ p = parse_exp (p, & r2);
+ if (r1.X_md || r1.X_op != O_register || r1.X_add_number != REG_DE ||
+ r2.X_md || r2.X_op != O_register || r2.X_add_number != REG_B)
+ ill_op ();
+ q = frag_more (2);
+ *q++ = prefix;
+ *q = opcode;
+ return p;
+}
+
static const char *
emit_jpcc (char prefix, char opcode, const char * args)
{
@@ -1726,13 +1889,21 @@ emit_in (char prefix ATTRIBUTE_UNUSED, char opcode ATTRIBUTE_UNUSED,
char *q;
p = parse_exp (args, &reg);
- if (*p++ != ',')
+ if (reg.X_md && reg.X_op == O_register && reg.X_add_number == REG_C)
+ { /* permit instruction in (c) as alias for in f,(c) */
+ port = reg;
+ reg.X_md = 0;
+ reg.X_add_number = REG_F;
+ }
+ else
{
- error (_("bad instruction syntax"));
- return p;
+ if (*p++ != ',')
+ {
+ error (_("bad instruction syntax"));
+ return p;
+ }
+ p = parse_exp (p, &port);
}
-
- p = parse_exp (p, &port);
if (reg.X_md == 0
&& reg.X_op == O_register
&& (reg.X_add_number <= 7 || reg.X_add_number == REG_F)
@@ -1958,7 +2129,15 @@ emit_ld_m_r (expressionS *dst, expressionS *src)
switch (dst->X_op)
{
case O_md1:
- prefix = (dst->X_add_number == REG_IX) ? 0xDD : 0xFD;
+ if (ins_ok & INS_GBZ80)
+ { /* LD (HL+),A or LD (HL-),A */
+ if (src->X_op != O_register || src->X_add_number != REG_A)
+ break;
+ *frag_more (1) = (dst->X_add_number == REG_HL) ? 0x22 : 0x32;
+ return;
+ }
+ else
+ prefix = (dst->X_add_number == REG_IX) ? 0xDD : 0xFD;
/* Fall through. */
case O_register:
switch (dst->X_add_number)
@@ -1998,7 +2177,7 @@ emit_ld_m_r (expressionS *dst, expressionS *src)
if (src->X_add_number == REG_A)
{
q = frag_more (1);
- *q = 0x32;
+ *q = (ins_ok & INS_GBZ80) ? 0xEA : 0x32;
emit_word (dst);
return;
}
@@ -2112,6 +2291,15 @@ emit_ld_r_m (expressionS *dst, expressionS *src)
switch (src->X_op)
{
case O_md1:
+ if (ins_ok & INS_GBZ80)
+ { /* LD A,(HL+) or LD A,(HL-) */
+ if (dst->X_op == O_register && dst->X_add_number == REG_A)
+ *frag_more (1) = (src->X_add_number == REG_HL) ? 0x2A : 0x3A;
+ else
+ ill_op ();
+ break;
+ }
+ /* Fall through. */
case O_register:
if (dst->X_add_number > 7)
ill_op ();
@@ -2140,7 +2328,7 @@ emit_ld_r_m (expressionS *dst, expressionS *src)
if (dst->X_add_number == REG_A)
{
q = frag_more (1);
- *q = 0x3A;
+ *q = (ins_ok & INS_GBZ80) ? 0xFA : 0x3A;
emit_word (src);
}
}
@@ -2208,8 +2396,6 @@ emit_ld_r_r (expressionS *dst, expressionS *src)
default:
ill_op ();
}
- if (ins_ok & INS_GBZ80)
- ill_op ();
opcode = 0xF9;
break;
case REG_HL:
@@ -2522,7 +2708,7 @@ emit_lddldi (char prefix, char opcode, const char * args)
p = parse_exp (args, & dst);
if (*p++ != ',')
error (_("bad instruction syntax"));
- p = parse_exp (args, & src);
+ p = parse_exp (p, & src);
if (dst.X_op != O_register || src.X_op != O_register)
ill_op ();
@@ -2568,12 +2754,18 @@ emit_ldh (char prefix ATTRIBUTE_UNUSED, char opcode ATTRIBUTE_UNUSED,
&& dst.X_op == O_register
&& dst.X_add_number == REG_A
&& src.X_md != 0
- && src.X_op != O_md1
- && src.X_op != O_register)
+ && src.X_op != O_md1)
{
- q = frag_more (1);
- *q = 0xF0;
- emit_byte (& src, BFD_RELOC_8);
+ if (src.X_op != O_register)
+ {
+ q = frag_more (1);
+ *q = 0xF0;
+ emit_byte (& src, BFD_RELOC_8);
+ }
+ else if (src.X_add_number == REG_C)
+ *frag_more (1) = 0xF2;
+ else
+ ill_op ();
}
else if (dst.X_md != 0
&& dst.X_op != O_md1
@@ -2605,6 +2797,29 @@ emit_ldh (char prefix ATTRIBUTE_UNUSED, char opcode ATTRIBUTE_UNUSED,
}
static const char *
+emit_ldhl (char prefix ATTRIBUTE_UNUSED, char opcode, const char * args)
+{
+ expressionS dst, src;
+ const char *p;
+ char *q;
+ p = parse_exp (args, & dst);
+ if (*p++ != ',')
+ {
+ error (_("bad instruction syntax"));
+ return p;
+ }
+
+ p = parse_exp (p, & src);
+ if (dst.X_md || dst.X_op != O_register || dst.X_add_number != REG_SP
+ || src.X_md || src.X_op == O_register || src.X_op == O_md1)
+ ill_op ();
+ q = frag_more (1);
+ *q = opcode;
+ emit_byte (& src, BFD_RELOC_Z80_DISP8);
+ return p;
+}
+
+static const char *
parse_lea_pea_args (const char * args, expressionS *op)
{
const char *p;
@@ -2700,13 +2915,76 @@ emit_mlt (char prefix, char opcode, const char * args)
ill_op ();
q = frag_more (2);
+ if (ins_ok & INS_Z80N)
+ {
+ if (arg.X_add_number != REG_DE)
+ ill_op ();
+ *q++ = 0xED;
+ *q = 0x30;
+ }
+ else
+ {
+ *q++ = prefix;
+ *q = opcode | ((arg.X_add_number & 3) << 4);
+ }
+
+ return p;
+}
+
+/* MUL D,E (Z80N only) */
+static const char *
+emit_mul (char prefix, char opcode, const char * args)
+{
+ expressionS r1, r2;
+ const char *p;
+ char *q;
+
+ p = parse_exp (args, & r1);
+ if (*p++ != ',')
+ error (_("bad instruction syntax"));
+ p = parse_exp (p, & r2);
+
+ if (r1.X_md != 0 || r1.X_op != O_register || r1.X_add_number != REG_D ||
+ r2.X_md != 0 || r2.X_op != O_register || r2.X_add_number != REG_E)
+ ill_op ();
+
+ q = frag_more (2);
*q++ = prefix;
- *q = opcode | ((arg.X_add_number & 3) << 4);
+ *q = opcode;
return p;
}
static const char *
+emit_nextreg (char prefix, char opcode ATTRIBUTE_UNUSED, const char * args)
+{
+ expressionS rr, nn;
+ const char *p;
+ char *q;
+
+ p = parse_exp (args, & rr);
+ if (*p++ != ',')
+ error (_("bad instruction syntax"));
+ p = parse_exp (p, & nn);
+ if (rr.X_md != 0 || rr.X_op == O_register || rr.X_op == O_md1 ||
+ nn.X_md != 0 || nn.X_op == O_md1)
+ ill_op ();
+ q = frag_more (2);
+ *q++ = prefix;
+ emit_byte (&rr, BFD_RELOC_8);
+ if (nn.X_op == O_register && nn.X_add_number == REG_A)
+ *q = 0x92;
+ else if (nn.X_op != O_register)
+ {
+ *q = 0x91;
+ emit_byte (&nn, BFD_RELOC_8);
+ }
+ else
+ ill_op ();
+ return p;
+}
+
+static const char *
emit_pea (char prefix, char opcode, const char * args)
{
expressionS arg;
@@ -2783,15 +3061,23 @@ emit_tst (char prefix, char opcode, const char *args)
if (arg_s.X_md)
ill_op ();
q = frag_more (2);
- *q++ = prefix;
- *q = opcode | 0x60;
+ if (ins_ok & INS_Z80N)
+ {
+ *q++ = 0xED;
+ *q = 0x27;
+ }
+ else
+ {
+ *q++ = prefix;
+ *q = opcode | 0x60;
+ }
emit_byte (& arg_s, BFD_RELOC_8);
}
return p;
}
static const char *
-emit_tstio (char prefix, char opcode, const char *args)
+emit_insn_n (char prefix, char opcode, const char *args)
{
expressionS arg;
const char *p;
@@ -3130,6 +3416,7 @@ const pseudo_typeS md_pseudo_table[] =
{ ".set", s_set, 0},
{ ".z180", set_inss, INS_Z180},
{ ".z80", set_inss, INS_Z80},
+ { ".z80n", set_inss, INS_Z80N},
{ "db" , emit_data, 1},
{ "d24", z80_cons, 3},
{ "d32", z80_cons, 4},
@@ -3152,6 +3439,11 @@ static table_t instab[] =
{ "add", 0x80, 0x09, emit_add, INS_ALL },
{ "and", 0x00, 0xA0, emit_s, INS_ALL },
{ "bit", 0xCB, 0x40, emit_bit, INS_ALL },
+ { "brlc", 0xED, 0x2C, emit_bshft,INS_Z80N },
+ { "bsla", 0xED, 0x28, emit_bshft,INS_Z80N },
+ { "bsra", 0xED, 0x29, emit_bshft,INS_Z80N },
+ { "bsrf", 0xED, 0x2B, emit_bshft,INS_Z80N },
+ { "bsrl", 0xED, 0x2A, emit_bshft,INS_Z80N },
{ "call", 0xCD, 0xC4, emit_jpcc, INS_ALL },
{ "ccf", 0x00, 0x3F, emit_insn, INS_ALL },
{ "cp", 0x00, 0xB8, emit_s, INS_ALL },
@@ -3191,15 +3483,24 @@ static table_t instab[] =
{ "ld", 0x00, 0x00, emit_ld, INS_ALL },
{ "ldd", 0xED, 0xA8, emit_lddldi,INS_ALL }, /* GBZ80 has special meaning */
{ "lddr", 0xED, 0xB8, emit_insn, INS_NOT_GBZ80 },
+ { "lddrx",0xED, 0xBC, emit_insn, INS_Z80N },
+ { "lddx", 0xED, 0xAC, emit_insn, INS_Z80N },
{ "ldh", 0xE0, 0x00, emit_ldh, INS_GBZ80 },
- { "ldhl", 0xE0, 0x00, emit_ldh, INS_GBZ80 },
+ { "ldhl", 0x00, 0xF8, emit_ldhl, INS_GBZ80 },
{ "ldi", 0xED, 0xA0, emit_lddldi,INS_ALL }, /* GBZ80 has special meaning */
{ "ldir", 0xED, 0xB0, emit_insn, INS_NOT_GBZ80 },
+ { "ldirx",0xED, 0xB4, emit_insn, INS_Z80N },
+ { "ldix", 0xED, 0xA4, emit_insn, INS_Z80N },
+ { "ldpirx",0xED,0xB7, emit_insn, INS_Z80N },
+ { "ldws", 0xED, 0xA5, emit_insn, INS_Z80N },
{ "lea", 0xED, 0x02, emit_lea, INS_EZ80 },
- { "mlt", 0xED, 0x4C, emit_mlt, INS_Z180|INS_EZ80 },
+ { "mirror",0xED,0x24, emit_insn, INS_Z80N },
+ { "mlt", 0xED, 0x4C, emit_mlt, INS_Z180|INS_EZ80|INS_Z80N },
+ { "mul", 0xED, 0x30, emit_mul, INS_Z80N },
{ "mulub",0xED, 0xC5, emit_mulub,INS_R800 },
{ "muluw",0xED, 0xC3, emit_muluw,INS_R800 },
- { "neg", 0xed, 0x44, emit_insn, INS_NOT_GBZ80 },
+ { "neg", 0xED, 0x44, emit_insn, INS_NOT_GBZ80 },
+ { "nextreg",0xED,0x91,emit_nextreg,INS_Z80N },
{ "nop", 0x00, 0x00, emit_insn, INS_ALL },
{ "or", 0x00, 0xB0, emit_s, INS_ALL },
{ "otd2r",0xED, 0xBC, emit_insn, INS_EZ80 },
@@ -3218,9 +3519,12 @@ static table_t instab[] =
{ "outd2",0xED, 0xAC, emit_insn, INS_EZ80 },
{ "outi", 0xED, 0xA3, emit_insn, INS_NOT_GBZ80 },
{ "outi2",0xED, 0xA4, emit_insn, INS_EZ80 },
+ { "outinb",0xED,0x90, emit_insn, INS_Z80N },
{ "pea", 0xED, 0x65, emit_pea, INS_EZ80 },
+ { "pixelad",0xED,0x94,emit_insn, INS_Z80N },
+ { "pixeldn",0xED,0x93,emit_insn, INS_Z80N },
{ "pop", 0x00, 0xC1, emit_pop, INS_ALL },
- { "push", 0x00, 0xC5, emit_pop, INS_ALL },
+ { "push", 0x00, 0xC5, emit_push, INS_ALL },
{ "res", 0xCB, 0x80, emit_bit, INS_ALL },
{ "ret", 0xC9, 0xC0, emit_retcc,INS_ALL },
{ "reti", 0xED, 0x4D, emit_reti, INS_ALL }, /*GBZ80 has its own opcode for it*/
@@ -3240,6 +3544,8 @@ static table_t instab[] =
{ "sbc", 0x98, 0x42, emit_adc, INS_ALL },
{ "scf", 0x00, 0x37, emit_insn, INS_ALL },
{ "set", 0xCB, 0xC0, emit_bit, INS_ALL },
+ { "setae",0xED, 0x95, emit_insn, INS_Z80N },
+ { "sl1", 0xCB, 0x30, emit_mr, INS_SLI },
{ "sla", 0xCB, 0x20, emit_mr, INS_ALL },
{ "sli", 0xCB, 0x30, emit_mr, INS_SLI },
{ "sll", 0xCB, 0x30, emit_mr, INS_SLI },
@@ -3248,10 +3554,12 @@ static table_t instab[] =
{ "srl", 0xCB, 0x38, emit_mr, INS_ALL },
{ "stmix",0xED, 0x7D, emit_insn, INS_EZ80 },
{ "stop", 0x00, 0x10, emit_insn, INS_GBZ80 },
- { "sub", 0x00, 0x90, emit_s, INS_ALL },
- { "swap", 0xCB, 0x30, emit_mr, INS_GBZ80 },
- { "tst", 0xED, 0x04, emit_tst, INS_Z180|INS_EZ80 },
- { "tstio",0xED, 0x74, emit_tstio,INS_Z180|INS_EZ80 },
+ { "sub", 0x00, 0x90, emit_sub, INS_ALL },
+ { "swap", 0xCB, 0x30, emit_swap, INS_GBZ80|INS_Z80N },
+ { "swapnib",0xED,0x23,emit_insn, INS_Z80N },
+ { "test", 0xED, 0x27, emit_insn_n, INS_Z80N },
+ { "tst", 0xED, 0x04, emit_tst, INS_Z180|INS_EZ80|INS_Z80N },
+ { "tstio",0xED, 0x74, emit_insn_n,INS_Z180|INS_EZ80 },
{ "xor", 0x00, 0xA8, emit_s, INS_ALL },
} ;
@@ -3294,139 +3602,146 @@ md_assemble (char *str)
insp = bsearch (&key, instab, ARRAY_SIZE (instab),
sizeof (instab[0]), key_cmp);
if (!insp || (insp->inss && !(insp->inss & ins_ok)))
- {
- as_bad (_("Unknown instruction '%s'"), buf);
- *frag_more (1) = 0;
- }
+ {
+ *frag_more (1) = 0;
+ as_bad (_("Unknown instruction `%s'"), buf);
+ }
else
{
p = insp->fp (insp->prefix, insp->opcode, p);
p = skip_space (p);
- if ((!err_flag) && *p)
- as_bad (_("junk at end of line, first unrecognized character is `%c'"),
- *p);
+ if ((!err_flag) && *p)
+ as_bad (_("junk at end of line, "
+ "first unrecognized character is `%c'"), *p);
}
}
end:
input_line_pointer = old_ptr;
}
+static int
+is_overflow (long value, unsigned bitsize)
+{
+ long fieldmask = (1 << bitsize) - 1;
+ long signmask = ~fieldmask;
+ long a = value & fieldmask;
+ long ss = a & signmask;
+ if (ss != 0 && ss != (signmask & fieldmask))
+ return 1;
+ return 0;
+}
+
void
-md_apply_fix (fixS * fixP, valueT* valP, segT seg ATTRIBUTE_UNUSED)
+md_apply_fix (fixS * fixP, valueT* valP, segT seg)
{
- long val = * (long *) valP;
+ long val = *valP;
char *p_lit = fixP->fx_where + fixP->fx_frag->fr_literal;
+ if (fixP->fx_addsy == NULL)
+ fixP->fx_done = 1;
+ else if (fixP->fx_pcrel)
+ {
+ segT s = S_GET_SEGMENT (fixP->fx_addsy);
+ if (s == seg || s == absolute_section)
+ {
+ val += S_GET_VALUE (fixP->fx_addsy);
+ fixP->fx_done = 1;
+ }
+ }
+
switch (fixP->fx_r_type)
{
case BFD_RELOC_8_PCREL:
- if (fixP->fx_addsy)
- {
- fixP->fx_no_overflow = 1;
- fixP->fx_done = 0;
- }
- else
- {
- fixP->fx_no_overflow = (-128 <= val && val < 128);
- if (!fixP->fx_no_overflow)
- as_bad_where (fixP->fx_file, fixP->fx_line,
- _("relative jump out of range"));
- *p_lit++ = val;
- fixP->fx_done = 1;
- }
+ case BFD_RELOC_Z80_DISP8:
+ case BFD_RELOC_8:
+ case BFD_RELOC_16:
+ case BFD_RELOC_24:
+ case BFD_RELOC_32:
+ case BFD_RELOC_Z80_16_BE:
+ fixP->fx_no_overflow = 0;
+ break;
+ default:
+ fixP->fx_no_overflow = 1;
break;
+ }
+ switch (fixP->fx_r_type)
+ {
+ case BFD_RELOC_8_PCREL:
case BFD_RELOC_Z80_DISP8:
- if (fixP->fx_addsy)
- {
- fixP->fx_no_overflow = 1;
- fixP->fx_done = 0;
- }
- else
- {
- fixP->fx_no_overflow = (-128 <= val && val < 128);
- if (!fixP->fx_no_overflow)
- as_bad_where (fixP->fx_file, fixP->fx_line,
- _("index offset out of range"));
- *p_lit++ = val;
- fixP->fx_done = 1;
- }
+ if (fixP->fx_done && (val < -0x80 || val > 0x7f))
+ as_bad_where (fixP->fx_file, fixP->fx_line,
+ _("8-bit signed offset out of range (%+ld)"), val);
+ *p_lit++ = val;
break;
case BFD_RELOC_Z80_BYTE0:
*p_lit++ = val;
- fixP->fx_no_overflow = 1;
- if (fixP->fx_addsy == NULL)
- fixP->fx_done = 1;
break;
case BFD_RELOC_Z80_BYTE1:
*p_lit++ = (val >> 8);
- fixP->fx_no_overflow = 1;
- if (fixP->fx_addsy == NULL)
- fixP->fx_done = 1;
break;
case BFD_RELOC_Z80_BYTE2:
*p_lit++ = (val >> 16);
- fixP->fx_no_overflow = 1;
- if (fixP->fx_addsy == NULL)
- fixP->fx_done = 1;
break;
case BFD_RELOC_Z80_BYTE3:
*p_lit++ = (val >> 24);
- fixP->fx_no_overflow = 1;
- if (fixP->fx_addsy == NULL)
- fixP->fx_done = 1;
break;
case BFD_RELOC_8:
- if (val > 255 || val < -128)
- as_warn_where (fixP->fx_file, fixP->fx_line, _("overflow"));
+ if (fixP->fx_done && is_overflow(val, 8))
+ as_warn_where (fixP->fx_file, fixP->fx_line,
+ _("8-bit overflow (%+ld)"), val);
*p_lit++ = val;
- fixP->fx_no_overflow = 1;
- if (fixP->fx_addsy == NULL)
- fixP->fx_done = 1;
break;
case BFD_RELOC_Z80_WORD1:
*p_lit++ = (val >> 16);
*p_lit++ = (val >> 24);
- fixP->fx_no_overflow = 1;
- if (fixP->fx_addsy == NULL)
- fixP->fx_done = 1;
break;
case BFD_RELOC_Z80_WORD0:
+ *p_lit++ = val;
+ *p_lit++ = (val >> 8);
+ break;
+
case BFD_RELOC_16:
+ if (fixP->fx_done && is_overflow(val, 16))
+ as_warn_where (fixP->fx_file, fixP->fx_line,
+ _("16-bit overflow (%+ld)"), val);
*p_lit++ = val;
*p_lit++ = (val >> 8);
- fixP->fx_no_overflow = 1;
- if (fixP->fx_addsy == NULL)
- fixP->fx_done = 1;
break;
case BFD_RELOC_24: /* Def24 may produce this. */
+ if (fixP->fx_done && is_overflow(val, 24))
+ as_warn_where (fixP->fx_file, fixP->fx_line,
+ _("24-bit overflow (%+ld)"), val);
*p_lit++ = val;
*p_lit++ = (val >> 8);
*p_lit++ = (val >> 16);
- fixP->fx_no_overflow = 1;
- if (fixP->fx_addsy == NULL)
- fixP->fx_done = 1;
break;
case BFD_RELOC_32: /* Def32 and .long may produce this. */
+ if (fixP->fx_done && is_overflow(val, 32))
+ as_warn_where (fixP->fx_file, fixP->fx_line,
+ _("32-bit overflow (%+ld)"), val);
*p_lit++ = val;
*p_lit++ = (val >> 8);
*p_lit++ = (val >> 16);
*p_lit++ = (val >> 24);
- if (fixP->fx_addsy == NULL)
- fixP->fx_done = 1;
+ break;
+
+ case BFD_RELOC_Z80_16_BE: /* Z80N PUSH nn instruction produce this. */
+ *p_lit++ = val >> 8;
+ *p_lit++ = val;
break;
default:
- printf (_("md_apply_fix: unknown r_type 0x%x\n"), fixP->fx_r_type);
+ printf (_("md_apply_fix: unknown reloc type 0x%x\n"), fixP->fx_r_type);
abort ();
}
}
@@ -3446,11 +3761,9 @@ tc_gen_reloc (asection *seg ATTRIBUTE_UNUSED , fixS *fixp)
{
arelent *reloc;
- if (! bfd_reloc_type_lookup (stdoutput, fixp->fx_r_type))
+ if (fixp->fx_subsy != NULL)
{
- as_bad_where (fixp->fx_file, fixp->fx_line,
- _("reloc %d not supported by object file format"),
- (int) fixp->fx_r_type);
+ as_bad_where (fixp->fx_file, fixp->fx_line, _("expression too complex"));
return NULL;
}
@@ -3458,8 +3771,19 @@ tc_gen_reloc (asection *seg ATTRIBUTE_UNUSED , fixS *fixp)
reloc->sym_ptr_ptr = XNEW (asymbol *);
*reloc->sym_ptr_ptr = symbol_get_bfdsym (fixp->fx_addsy);
reloc->address = fixp->fx_frag->fr_address + fixp->fx_where;
- reloc->howto = bfd_reloc_type_lookup (stdoutput, fixp->fx_r_type);
reloc->addend = fixp->fx_offset;
+ reloc->howto = bfd_reloc_type_lookup (stdoutput, fixp->fx_r_type);
+ if (reloc->howto == NULL)
+ {
+ as_bad_where (fixp->fx_file, fixp->fx_line,
+ _("reloc %d not supported by object file format"),
+ (int) fixp->fx_r_type);
+ return NULL;
+ }
+
+ if (fixp->fx_r_type == BFD_RELOC_VTABLE_INHERIT
+ || fixp->fx_r_type == BFD_RELOC_VTABLE_ENTRY)
+ reloc->address = fixp->fx_offset;
return reloc;
}
@@ -3712,3 +4036,49 @@ str_to_ieee754_d(char *litP, int *sizeP)
{
return ieee_md_atof ('d', litP, sizeP, FALSE);
}
+
+#ifdef TARGET_USE_CFIPOP
+/* Initialize the DWARF-2 unwind information for this procedure. */
+void
+z80_tc_frame_initial_instructions (void)
+{
+ static int sp_regno = -1;
+
+ if (sp_regno < 0)
+ sp_regno = z80_tc_regname_to_dw2regnum ("sp");
+
+ cfi_add_CFA_def_cfa (sp_regno, 0);
+}
+
+int
+z80_tc_regname_to_dw2regnum (const char *regname)
+{
+ static const char *regs[] =
+ { /* same registers as for GDB */
+ "af", "bc", "de", "hl",
+ "sp", "pc", "ix", "iy",
+ "af_", "bc_", "de_", "hl_",
+ "ir"
+ };
+ unsigned i;
+
+ for (i = 0; i < ARRAY_SIZE(regs); ++i)
+ if (!strcasecmp (regs[i], regname))
+ return i;
+
+ return -1;
+}
+#endif
+
+/* Implement DWARF2_ADDR_SIZE. */
+int
+z80_dwarf2_addr_size (const bfd *abfd)
+{
+ switch (bfd_get_mach (abfd))
+ {
+ case bfd_mach_ez80_adl:
+ return 3;
+ default:
+ return 2;
+ }
+}
diff --git a/gas/config/tc-z80.h b/gas/config/tc-z80.h
index 5749027..d169d09 100644
--- a/gas/config/tc-z80.h
+++ b/gas/config/tc-z80.h
@@ -29,7 +29,6 @@
#endif
#define BFD_ARCH TARGET_ARCH
#define COFF_MAGIC 0x5A80
-#define TARGET_MACH 0
#define TARGET_BYTES_BIG_ENDIAN 0
/* If you define this macro, GAS will warn about the
@@ -116,4 +115,24 @@ extern int z80_tc_label_is_local (const char *name);
#define elf_tc_final_processing z80_elf_final_processing
extern void z80_elf_final_processing (void);
+/* Define the column that represents the PC. */
+#define DWARF2_DEFAULT_RETURN_COLUMN 5
+
+/* The stack grows down, and is only byte aligned. */
+#define DWARF2_CIE_DATA_ALIGNMENT -1
+
+/* Z80 instructions are 1 or 4 bytes long. */
+#define DWARF2_LINE_MIN_INSN_LENGTH 1
+
+/* 16 bits addresses are used on Z80. */
+#define DWARF2_ADDR_SIZE(bfd) z80_dwarf2_addr_size(bfd)
+extern int z80_dwarf2_addr_size (const bfd *abfd);
+
+/* CFI hooks. */
+#define tc_cfi_frame_initial_instructions z80_tc_frame_initial_instructions
+extern void z80_tc_frame_initial_instructions (void);
+
+#define tc_regname_to_dw2regnum z80_tc_regname_to_dw2regnum
+extern int z80_tc_regname_to_dw2regnum (const char *regname);
+
#endif
diff --git a/gas/doc/c-z80.texi b/gas/doc/c-z80.texi
index dd6332d..e768e38 100644
--- a/gas/doc/c-z80.texi
+++ b/gas/doc/c-z80.texi
@@ -31,19 +31,19 @@
@table @gcctabopt
@cindex @code{-z80} command-line option, Z80
@item -z80
-Produce code for the Z80 processor. By default accepted undocumented
-operations with halves of index registers (@code{IXL}, @code{IXH}, @code{IYL}, @code{IYH}) and
-instuction @code{IN F,(C)}. Other useful undocumented instructions produces
-warnings. Undocumented instructions may not work on some CPUs, use
-them on your own risk.
+Produce code for the Zilog Z80 processor. By default accepted undocumented
+operations with halves of index registers (@code{IXL}, @code{IXH}, @code{IYL},
+@code{IYH}) and instuction @code{IN F,(C)}. Other useful undocumented
+instructions produces warnings. Undocumented instructions may not work on some
+CPUs, use them on your own risk.
@cindex @code{-r800} command-line option, Z80
@item -r800
-Produce code for the R800 processor.
+Produce code for the Ascii R800 processor.
@cindex @code{-z180} command-line option, Z80
@item -z180
-Produce code for the Z180 processor.
+Produce code for the Zilog Z180 processor.
@cindex @code{-ez80} command-line option, Z80
@item -ez80
@@ -53,6 +53,14 @@ Produce code for the eZ80 processor in Z80 memory mode by default.
@item -ez80-adl
Produce code for the eZ80 processor in ADL memory mode by default.
+@cindex @code{-gbz80} command-line option, Z80
+@item -gbz80
+Produce code for the GameBoy Z80 processor.
+
+@cindex @code{-z80n} command-line option, Z80
+@item -z80n
+Produce code for the Z80N processor.
+
@cindex @code{-local-prefix} command-line option, Z80
@item -local-prefix=@var{prefix}
Mark all labels with specified prefix as local. But such label can be
diff --git a/gas/testsuite/gas/z80/gbz80_all.d b/gas/testsuite/gas/z80/gbz80_all.d
new file mode 100644
index 0000000..0bb5db0
--- /dev/null
+++ b/gas/testsuite/gas/z80/gbz80_all.d
@@ -0,0 +1,514 @@
+#as: -gbz80
+#objdump: -d
+#name: GBZ80 instruction set
+
+.*: .*
+
+Disassembly of section .text:
+
+0+ <.text>:
+\s+[0-9a-f]+:\s+00\s+nop
+\s+[0-9a-f]+:\s+01 af be\s+ld bc,0xbeaf
+\s+[0-9a-f]+:\s+02\s+ld \(bc\),a
+\s+[0-9a-f]+:\s+03\s+inc bc
+\s+[0-9a-f]+:\s+04\s+inc b
+\s+[0-9a-f]+:\s+05\s+dec b
+\s+[0-9a-f]+:\s+06 fd\s+ld b,0xfd
+\s+[0-9a-f]+:\s+07\s+rlca
+\s+[0-9a-f]+:\s+08 af be\s+ld \(0xbeaf\),sp
+\s+[0-9a-f]+:\s+09\s+add hl,bc
+\s+[0-9a-f]+:\s+0a\s+ld a,\(bc\)
+\s+[0-9a-f]+:\s+0b\s+dec bc
+\s+[0-9a-f]+:\s+0c\s+inc c
+\s+[0-9a-f]+:\s+0d\s+dec c
+\s+[0-9a-f]+:\s+0e fd\s+ld c,0xfd
+\s+[0-9a-f]+:\s+0f\s+rrca
+\s+[0-9a-f]+:\s+10\s+stop
+\s+[0-9a-f]+:\s+11 af be\s+ld de,0xbeaf
+\s+[0-9a-f]+:\s+12\s+ld \(de\),a
+\s+[0-9a-f]+:\s+13\s+inc de
+\s+[0-9a-f]+:\s+14\s+inc d
+\s+[0-9a-f]+:\s+15\s+dec d
+\s+[0-9a-f]+:\s+16 fd\s+ld d,0xfd
+\s+[0-9a-f]+:\s+17\s+rla
+\s+[0-9a-f]+:\s+18 0a\s+jr 0x002d
+\s+[0-9a-f]+:\s+19\s+add hl,de
+\s+[0-9a-f]+:\s+1a\s+ld a,\(de\)
+\s+[0-9a-f]+:\s+1b\s+dec de
+\s+[0-9a-f]+:\s+1c\s+inc e
+\s+[0-9a-f]+:\s+1d\s+dec e
+\s+[0-9a-f]+:\s+1e fd\s+ld e,0xfd
+\s+[0-9a-f]+:\s+1f\s+rra
+\s+[0-9a-f]+:\s+20 0a\s+jr nz,0x0037
+\s+[0-9a-f]+:\s+21 af be\s+ld hl,0xbeaf
+\s+[0-9a-f]+:\s+22\s+ld \(hl\+\),a
+\s+[0-9a-f]+:\s+22\s+ld \(hl\+\),a
+\s+[0-9a-f]+:\s+23\s+inc hl
+\s+[0-9a-f]+:\s+24\s+inc h
+\s+[0-9a-f]+:\s+25\s+dec h
+\s+[0-9a-f]+:\s+26 fd\s+ld h,0xfd
+\s+[0-9a-f]+:\s+27\s+daa
+\s+[0-9a-f]+:\s+28 0a\s+jr z,0x0044
+\s+[0-9a-f]+:\s+29\s+add hl,hl
+\s+[0-9a-f]+:\s+2a\s+ld a,\(hl\+\)
+\s+[0-9a-f]+:\s+2a\s+ld a,\(hl\+\)
+\s+[0-9a-f]+:\s+2b\s+dec hl
+\s+[0-9a-f]+:\s+2c\s+inc l
+\s+[0-9a-f]+:\s+2d\s+dec l
+\s+[0-9a-f]+:\s+2e fd\s+ld l,0xfd
+\s+[0-9a-f]+:\s+2f\s+cpl
+\s+[0-9a-f]+:\s+30 0a\s+jr nc,0x004f
+\s+[0-9a-f]+:\s+31 af be\s+ld sp,0xbeaf
+\s+[0-9a-f]+:\s+32\s+ld \(hl-\),a
+\s+[0-9a-f]+:\s+32\s+ld \(hl-\),a
+\s+[0-9a-f]+:\s+33\s+inc sp
+\s+[0-9a-f]+:\s+34\s+inc \(hl\)
+\s+[0-9a-f]+:\s+35\s+dec \(hl\)
+\s+[0-9a-f]+:\s+36 fd\s+ld \(hl\),0xfd
+\s+[0-9a-f]+:\s+37\s+scf
+\s+[0-9a-f]+:\s+38 0a\s+jr c,0x005c
+\s+[0-9a-f]+:\s+39\s+add hl,sp
+\s+[0-9a-f]+:\s+3a\s+ld a,\(hl-\)
+\s+[0-9a-f]+:\s+3a\s+ld a,\(hl-\)
+\s+[0-9a-f]+:\s+3b\s+dec sp
+\s+[0-9a-f]+:\s+3c\s+inc a
+\s+[0-9a-f]+:\s+3d\s+dec a
+\s+[0-9a-f]+:\s+3e fd\s+ld a,0xfd
+\s+[0-9a-f]+:\s+3f\s+ccf
+\s+[0-9a-f]+:\s+40\s+ld b,b
+\s+[0-9a-f]+:\s+41\s+ld b,c
+\s+[0-9a-f]+:\s+42\s+ld b,d
+\s+[0-9a-f]+:\s+43\s+ld b,e
+\s+[0-9a-f]+:\s+44\s+ld b,h
+\s+[0-9a-f]+:\s+45\s+ld b,l
+\s+[0-9a-f]+:\s+46\s+ld b,\(hl\)
+\s+[0-9a-f]+:\s+47\s+ld b,a
+\s+[0-9a-f]+:\s+48\s+ld c,b
+\s+[0-9a-f]+:\s+49\s+ld c,c
+\s+[0-9a-f]+:\s+4a\s+ld c,d
+\s+[0-9a-f]+:\s+4b\s+ld c,e
+\s+[0-9a-f]+:\s+4c\s+ld c,h
+\s+[0-9a-f]+:\s+4d\s+ld c,l
+\s+[0-9a-f]+:\s+4e\s+ld c,\(hl\)
+\s+[0-9a-f]+:\s+4f\s+ld c,a
+\s+[0-9a-f]+:\s+50\s+ld d,b
+\s+[0-9a-f]+:\s+51\s+ld d,c
+\s+[0-9a-f]+:\s+52\s+ld d,d
+\s+[0-9a-f]+:\s+53\s+ld d,e
+\s+[0-9a-f]+:\s+54\s+ld d,h
+\s+[0-9a-f]+:\s+55\s+ld d,l
+\s+[0-9a-f]+:\s+56\s+ld d,\(hl\)
+\s+[0-9a-f]+:\s+57\s+ld d,a
+\s+[0-9a-f]+:\s+58\s+ld e,b
+\s+[0-9a-f]+:\s+59\s+ld e,c
+\s+[0-9a-f]+:\s+5a\s+ld e,d
+\s+[0-9a-f]+:\s+5b\s+ld e,e
+\s+[0-9a-f]+:\s+5c\s+ld e,h
+\s+[0-9a-f]+:\s+5d\s+ld e,l
+\s+[0-9a-f]+:\s+5e\s+ld e,\(hl\)
+\s+[0-9a-f]+:\s+5f\s+ld e,a
+\s+[0-9a-f]+:\s+60\s+ld h,b
+\s+[0-9a-f]+:\s+61\s+ld h,c
+\s+[0-9a-f]+:\s+62\s+ld h,d
+\s+[0-9a-f]+:\s+63\s+ld h,e
+\s+[0-9a-f]+:\s+64\s+ld h,h
+\s+[0-9a-f]+:\s+65\s+ld h,l
+\s+[0-9a-f]+:\s+66\s+ld h,\(hl\)
+\s+[0-9a-f]+:\s+67\s+ld h,a
+\s+[0-9a-f]+:\s+68\s+ld l,b
+\s+[0-9a-f]+:\s+69\s+ld l,c
+\s+[0-9a-f]+:\s+6a\s+ld l,d
+\s+[0-9a-f]+:\s+6b\s+ld l,e
+\s+[0-9a-f]+:\s+6c\s+ld l,h
+\s+[0-9a-f]+:\s+6d\s+ld l,l
+\s+[0-9a-f]+:\s+6e\s+ld l,\(hl\)
+\s+[0-9a-f]+:\s+6f\s+ld l,a
+\s+[0-9a-f]+:\s+70\s+ld \(hl\),b
+\s+[0-9a-f]+:\s+71\s+ld \(hl\),c
+\s+[0-9a-f]+:\s+72\s+ld \(hl\),d
+\s+[0-9a-f]+:\s+73\s+ld \(hl\),e
+\s+[0-9a-f]+:\s+74\s+ld \(hl\),h
+\s+[0-9a-f]+:\s+75\s+ld \(hl\),l
+\s+[0-9a-f]+:\s+76\s+halt
+\s+[0-9a-f]+:\s+77\s+ld \(hl\),a
+\s+[0-9a-f]+:\s+78\s+ld a,b
+\s+[0-9a-f]+:\s+79\s+ld a,c
+\s+[0-9a-f]+:\s+7a\s+ld a,d
+\s+[0-9a-f]+:\s+7b\s+ld a,e
+\s+[0-9a-f]+:\s+7c\s+ld a,h
+\s+[0-9a-f]+:\s+7d\s+ld a,l
+\s+[0-9a-f]+:\s+7e\s+ld a,\(hl\)
+\s+[0-9a-f]+:\s+7f\s+ld a,a
+\s+[0-9a-f]+:\s+80\s+add a,b
+\s+[0-9a-f]+:\s+81\s+add a,c
+\s+[0-9a-f]+:\s+82\s+add a,d
+\s+[0-9a-f]+:\s+83\s+add a,e
+\s+[0-9a-f]+:\s+84\s+add a,h
+\s+[0-9a-f]+:\s+85\s+add a,l
+\s+[0-9a-f]+:\s+86\s+add a,\(hl\)
+\s+[0-9a-f]+:\s+87\s+add a,a
+\s+[0-9a-f]+:\s+88\s+adc a,b
+\s+[0-9a-f]+:\s+89\s+adc a,c
+\s+[0-9a-f]+:\s+8a\s+adc a,d
+\s+[0-9a-f]+:\s+8b\s+adc a,e
+\s+[0-9a-f]+:\s+8c\s+adc a,h
+\s+[0-9a-f]+:\s+8d\s+adc a,l
+\s+[0-9a-f]+:\s+8e\s+adc a,\(hl\)
+\s+[0-9a-f]+:\s+8f\s+adc a,a
+\s+[0-9a-f]+:\s+90\s+sub a,b
+\s+[0-9a-f]+:\s+91\s+sub a,c
+\s+[0-9a-f]+:\s+92\s+sub a,d
+\s+[0-9a-f]+:\s+93\s+sub a,e
+\s+[0-9a-f]+:\s+94\s+sub a,h
+\s+[0-9a-f]+:\s+95\s+sub a,l
+\s+[0-9a-f]+:\s+96\s+sub a,\(hl\)
+\s+[0-9a-f]+:\s+97\s+sub a,a
+\s+[0-9a-f]+:\s+98\s+sbc a,b
+\s+[0-9a-f]+:\s+99\s+sbc a,c
+\s+[0-9a-f]+:\s+9a\s+sbc a,d
+\s+[0-9a-f]+:\s+9b\s+sbc a,e
+\s+[0-9a-f]+:\s+9c\s+sbc a,h
+\s+[0-9a-f]+:\s+9d\s+sbc a,l
+\s+[0-9a-f]+:\s+9e\s+sbc a,\(hl\)
+\s+[0-9a-f]+:\s+9f\s+sbc a,a
+\s+[0-9a-f]+:\s+a0\s+and b
+\s+[0-9a-f]+:\s+a1\s+and c
+\s+[0-9a-f]+:\s+a2\s+and d
+\s+[0-9a-f]+:\s+a3\s+and e
+\s+[0-9a-f]+:\s+a4\s+and h
+\s+[0-9a-f]+:\s+a5\s+and l
+\s+[0-9a-f]+:\s+a6\s+and \(hl\)
+\s+[0-9a-f]+:\s+a7\s+and a
+\s+[0-9a-f]+:\s+a8\s+xor b
+\s+[0-9a-f]+:\s+a9\s+xor c
+\s+[0-9a-f]+:\s+aa\s+xor d
+\s+[0-9a-f]+:\s+ab\s+xor e
+\s+[0-9a-f]+:\s+ac\s+xor h
+\s+[0-9a-f]+:\s+ad\s+xor l
+\s+[0-9a-f]+:\s+ae\s+xor \(hl\)
+\s+[0-9a-f]+:\s+af\s+xor a
+\s+[0-9a-f]+:\s+b0\s+or b
+\s+[0-9a-f]+:\s+b1\s+or c
+\s+[0-9a-f]+:\s+b2\s+or d
+\s+[0-9a-f]+:\s+b3\s+or e
+\s+[0-9a-f]+:\s+b4\s+or h
+\s+[0-9a-f]+:\s+b5\s+or l
+\s+[0-9a-f]+:\s+b6\s+or \(hl\)
+\s+[0-9a-f]+:\s+b7\s+or a
+\s+[0-9a-f]+:\s+b8\s+cp b
+\s+[0-9a-f]+:\s+b9\s+cp c
+\s+[0-9a-f]+:\s+ba\s+cp d
+\s+[0-9a-f]+:\s+bb\s+cp e
+\s+[0-9a-f]+:\s+bc\s+cp h
+\s+[0-9a-f]+:\s+bd\s+cp l
+\s+[0-9a-f]+:\s+be\s+cp \(hl\)
+\s+[0-9a-f]+:\s+bf\s+cp a
+\s+[0-9a-f]+:\s+c0\s+ret nz
+\s+[0-9a-f]+:\s+c1\s+pop bc
+\s+[0-9a-f]+:\s+c2 af be\s+jp nz,0xbeaf
+\s+[0-9a-f]+:\s+c3 af be\s+jp 0xbeaf
+\s+[0-9a-f]+:\s+c4 af be\s+call nz,0xbeaf
+\s+[0-9a-f]+:\s+c5\s+push bc
+\s+[0-9a-f]+:\s+c6 fd\s+add a,0xfd
+\s+[0-9a-f]+:\s+c7\s+rst 0x00
+\s+[0-9a-f]+:\s+c8\s+ret z
+\s+[0-9a-f]+:\s+c9\s+ret
+\s+[0-9a-f]+:\s+ca af be\s+jp z,0xbeaf
+\s+[0-9a-f]+:\s+00\s+nop
+\s+[0-9a-f]+:\s+cc af be\s+call z,0xbeaf
+\s+[0-9a-f]+:\s+cd af be\s+call 0xbeaf
+\s+[0-9a-f]+:\s+ce fd\s+adc a,0xfd
+\s+[0-9a-f]+:\s+cf\s+rst 0x08
+\s+[0-9a-f]+:\s+d0\s+ret nc
+\s+[0-9a-f]+:\s+d1\s+pop de
+\s+[0-9a-f]+:\s+d2 af be\s+jp nc,0xbeaf
+\s+[0-9a-f]+:\s+d4 af be\s+call nc,0xbeaf
+\s+[0-9a-f]+:\s+d5\s+push de
+\s+[0-9a-f]+:\s+d6 fd\s+sub a,0xfd
+\s+[0-9a-f]+:\s+d7\s+rst 0x10
+\s+[0-9a-f]+:\s+d8\s+ret c
+\s+[0-9a-f]+:\s+d9\s+reti
+\s+[0-9a-f]+:\s+da af be\s+jp c,0xbeaf
+\s+[0-9a-f]+:\s+dc af be\s+call c,0xbeaf
+\s+[0-9a-f]+:\s+de fd\s+sbc a,0xfd
+\s+[0-9a-f]+:\s+df\s+rst 0x18
+\s+[0-9a-f]+:\s+e0 fd\s+ldh \(0xfd\),a
+\s+[0-9a-f]+:\s+e1\s+pop hl
+\s+[0-9a-f]+:\s+e2\s+ldh \(c\),a
+\s+[0-9a-f]+:\s+e5\s+push hl
+\s+[0-9a-f]+:\s+e6 fd\s+and 0xfd
+\s+[0-9a-f]+:\s+e7\s+rst 0x20
+\s+[0-9a-f]+:\s+e8 f4\s+add sp,-12
+\s+[0-9a-f]+:\s+e9\s+jp \(hl\)
+\s+[0-9a-f]+:\s+ea af be\s+ld \(0xbeaf\),a
+\s+[0-9a-f]+:\s+ee fd\s+xor 0xfd
+\s+[0-9a-f]+:\s+ef\s+rst 0x28
+\s+[0-9a-f]+:\s+f0 fd\s+ldh a,\(0xfd\)
+\s+[0-9a-f]+:\s+f1\s+pop af
+\s+[0-9a-f]+:\s+f2\s+ldh a,\(c\)
+\s+[0-9a-f]+:\s+f3\s+di
+\s+[0-9a-f]+:\s+f5\s+push af
+\s+[0-9a-f]+:\s+f6 fd\s+or 0xfd
+\s+[0-9a-f]+:\s+f7\s+rst 0x30
+\s+[0-9a-f]+:\s+f8 f4\s+ldhl sp,-12
+\s+[0-9a-f]+:\s+f9\s+ld sp,hl
+\s+[0-9a-f]+:\s+fa af be\s+ld a,\(0xbeaf\)
+\s+[0-9a-f]+:\s+fb\s+ei
+\s+[0-9a-f]+:\s+fe fd\s+cp 0xfd
+\s+[0-9a-f]+:\s+ff\s+rst 0x38
+\s+[0-9a-f]+:\s+cb 00\s+rlc b
+\s+[0-9a-f]+:\s+cb 01\s+rlc c
+\s+[0-9a-f]+:\s+cb 02\s+rlc d
+\s+[0-9a-f]+:\s+cb 03\s+rlc e
+\s+[0-9a-f]+:\s+cb 04\s+rlc h
+\s+[0-9a-f]+:\s+cb 05\s+rlc l
+\s+[0-9a-f]+:\s+cb 06\s+rlc \(hl\)
+\s+[0-9a-f]+:\s+cb 07\s+rlc a
+\s+[0-9a-f]+:\s+cb 08\s+rrc b
+\s+[0-9a-f]+:\s+cb 09\s+rrc c
+\s+[0-9a-f]+:\s+cb 0a\s+rrc d
+\s+[0-9a-f]+:\s+cb 0b\s+rrc e
+\s+[0-9a-f]+:\s+cb 0c\s+rrc h
+\s+[0-9a-f]+:\s+cb 0d\s+rrc l
+\s+[0-9a-f]+:\s+cb 0e\s+rrc \(hl\)
+\s+[0-9a-f]+:\s+cb 0f\s+rrc a
+\s+[0-9a-f]+:\s+cb 10\s+rl b
+\s+[0-9a-f]+:\s+cb 11\s+rl c
+\s+[0-9a-f]+:\s+cb 12\s+rl d
+\s+[0-9a-f]+:\s+cb 13\s+rl e
+\s+[0-9a-f]+:\s+cb 14\s+rl h
+\s+[0-9a-f]+:\s+cb 15\s+rl l
+\s+[0-9a-f]+:\s+cb 16\s+rl \(hl\)
+\s+[0-9a-f]+:\s+cb 17\s+rl a
+\s+[0-9a-f]+:\s+cb 18\s+rr b
+\s+[0-9a-f]+:\s+cb 19\s+rr c
+\s+[0-9a-f]+:\s+cb 1a\s+rr d
+\s+[0-9a-f]+:\s+cb 1b\s+rr e
+\s+[0-9a-f]+:\s+cb 1c\s+rr h
+\s+[0-9a-f]+:\s+cb 1d\s+rr l
+\s+[0-9a-f]+:\s+cb 1e\s+rr \(hl\)
+\s+[0-9a-f]+:\s+cb 1f\s+rr a
+\s+[0-9a-f]+:\s+cb 20\s+sla b
+\s+[0-9a-f]+:\s+cb 21\s+sla c
+\s+[0-9a-f]+:\s+cb 22\s+sla d
+\s+[0-9a-f]+:\s+cb 23\s+sla e
+\s+[0-9a-f]+:\s+cb 24\s+sla h
+\s+[0-9a-f]+:\s+cb 25\s+sla l
+\s+[0-9a-f]+:\s+cb 26\s+sla \(hl\)
+\s+[0-9a-f]+:\s+cb 27\s+sla a
+\s+[0-9a-f]+:\s+cb 28\s+sra b
+\s+[0-9a-f]+:\s+cb 29\s+sra c
+\s+[0-9a-f]+:\s+cb 2a\s+sra d
+\s+[0-9a-f]+:\s+cb 2b\s+sra e
+\s+[0-9a-f]+:\s+cb 2c\s+sra h
+\s+[0-9a-f]+:\s+cb 2d\s+sra l
+\s+[0-9a-f]+:\s+cb 2e\s+sra \(hl\)
+\s+[0-9a-f]+:\s+cb 2f\s+sra a
+\s+[0-9a-f]+:\s+cb 30\s+swap b
+\s+[0-9a-f]+:\s+cb 31\s+swap c
+\s+[0-9a-f]+:\s+cb 32\s+swap d
+\s+[0-9a-f]+:\s+cb 33\s+swap e
+\s+[0-9a-f]+:\s+cb 34\s+swap h
+\s+[0-9a-f]+:\s+cb 35\s+swap l
+\s+[0-9a-f]+:\s+cb 36\s+swap \(hl\)
+\s+[0-9a-f]+:\s+cb 37\s+swap a
+\s+[0-9a-f]+:\s+cb 38\s+srl b
+\s+[0-9a-f]+:\s+cb 39\s+srl c
+\s+[0-9a-f]+:\s+cb 3a\s+srl d
+\s+[0-9a-f]+:\s+cb 3b\s+srl e
+\s+[0-9a-f]+:\s+cb 3c\s+srl h
+\s+[0-9a-f]+:\s+cb 3d\s+srl l
+\s+[0-9a-f]+:\s+cb 3e\s+srl \(hl\)
+\s+[0-9a-f]+:\s+cb 3f\s+srl a
+\s+[0-9a-f]+:\s+cb 40\s+bit 0,b
+\s+[0-9a-f]+:\s+cb 41\s+bit 0,c
+\s+[0-9a-f]+:\s+cb 42\s+bit 0,d
+\s+[0-9a-f]+:\s+cb 43\s+bit 0,e
+\s+[0-9a-f]+:\s+cb 44\s+bit 0,h
+\s+[0-9a-f]+:\s+cb 45\s+bit 0,l
+\s+[0-9a-f]+:\s+cb 46\s+bit 0,\(hl\)
+\s+[0-9a-f]+:\s+cb 47\s+bit 0,a
+\s+[0-9a-f]+:\s+cb 48\s+bit 1,b
+\s+[0-9a-f]+:\s+cb 49\s+bit 1,c
+\s+[0-9a-f]+:\s+cb 4a\s+bit 1,d
+\s+[0-9a-f]+:\s+cb 4b\s+bit 1,e
+\s+[0-9a-f]+:\s+cb 4c\s+bit 1,h
+\s+[0-9a-f]+:\s+cb 4d\s+bit 1,l
+\s+[0-9a-f]+:\s+cb 4e\s+bit 1,\(hl\)
+\s+[0-9a-f]+:\s+cb 4f\s+bit 1,a
+\s+[0-9a-f]+:\s+cb 50\s+bit 2,b
+\s+[0-9a-f]+:\s+cb 51\s+bit 2,c
+\s+[0-9a-f]+:\s+cb 52\s+bit 2,d
+\s+[0-9a-f]+:\s+cb 53\s+bit 2,e
+\s+[0-9a-f]+:\s+cb 54\s+bit 2,h
+\s+[0-9a-f]+:\s+cb 55\s+bit 2,l
+\s+[0-9a-f]+:\s+cb 56\s+bit 2,\(hl\)
+\s+[0-9a-f]+:\s+cb 57\s+bit 2,a
+\s+[0-9a-f]+:\s+cb 58\s+bit 3,b
+\s+[0-9a-f]+:\s+cb 59\s+bit 3,c
+\s+[0-9a-f]+:\s+cb 5a\s+bit 3,d
+\s+[0-9a-f]+:\s+cb 5b\s+bit 3,e
+\s+[0-9a-f]+:\s+cb 5c\s+bit 3,h
+\s+[0-9a-f]+:\s+cb 5d\s+bit 3,l
+\s+[0-9a-f]+:\s+cb 5e\s+bit 3,\(hl\)
+\s+[0-9a-f]+:\s+cb 5f\s+bit 3,a
+\s+[0-9a-f]+:\s+cb 60\s+bit 4,b
+\s+[0-9a-f]+:\s+cb 61\s+bit 4,c
+\s+[0-9a-f]+:\s+cb 62\s+bit 4,d
+\s+[0-9a-f]+:\s+cb 63\s+bit 4,e
+\s+[0-9a-f]+:\s+cb 64\s+bit 4,h
+\s+[0-9a-f]+:\s+cb 65\s+bit 4,l
+\s+[0-9a-f]+:\s+cb 66\s+bit 4,\(hl\)
+\s+[0-9a-f]+:\s+cb 67\s+bit 4,a
+\s+[0-9a-f]+:\s+cb 68\s+bit 5,b
+\s+[0-9a-f]+:\s+cb 69\s+bit 5,c
+\s+[0-9a-f]+:\s+cb 6a\s+bit 5,d
+\s+[0-9a-f]+:\s+cb 6b\s+bit 5,e
+\s+[0-9a-f]+:\s+cb 6c\s+bit 5,h
+\s+[0-9a-f]+:\s+cb 6d\s+bit 5,l
+\s+[0-9a-f]+:\s+cb 6e\s+bit 5,\(hl\)
+\s+[0-9a-f]+:\s+cb 6f\s+bit 5,a
+\s+[0-9a-f]+:\s+cb 70\s+bit 6,b
+\s+[0-9a-f]+:\s+cb 71\s+bit 6,c
+\s+[0-9a-f]+:\s+cb 72\s+bit 6,d
+\s+[0-9a-f]+:\s+cb 73\s+bit 6,e
+\s+[0-9a-f]+:\s+cb 74\s+bit 6,h
+\s+[0-9a-f]+:\s+cb 75\s+bit 6,l
+\s+[0-9a-f]+:\s+cb 76\s+bit 6,\(hl\)
+\s+[0-9a-f]+:\s+cb 77\s+bit 6,a
+\s+[0-9a-f]+:\s+cb 78\s+bit 7,b
+\s+[0-9a-f]+:\s+cb 79\s+bit 7,c
+\s+[0-9a-f]+:\s+cb 7a\s+bit 7,d
+\s+[0-9a-f]+:\s+cb 7b\s+bit 7,e
+\s+[0-9a-f]+:\s+cb 7c\s+bit 7,h
+\s+[0-9a-f]+:\s+cb 7d\s+bit 7,l
+\s+[0-9a-f]+:\s+cb 7e\s+bit 7,\(hl\)
+\s+[0-9a-f]+:\s+cb 7f\s+bit 7,a
+\s+[0-9a-f]+:\s+cb 80\s+res 0,b
+\s+[0-9a-f]+:\s+cb 81\s+res 0,c
+\s+[0-9a-f]+:\s+cb 82\s+res 0,d
+\s+[0-9a-f]+:\s+cb 83\s+res 0,e
+\s+[0-9a-f]+:\s+cb 84\s+res 0,h
+\s+[0-9a-f]+:\s+cb 85\s+res 0,l
+\s+[0-9a-f]+:\s+cb 86\s+res 0,\(hl\)
+\s+[0-9a-f]+:\s+cb 87\s+res 0,a
+\s+[0-9a-f]+:\s+cb 88\s+res 1,b
+\s+[0-9a-f]+:\s+cb 89\s+res 1,c
+\s+[0-9a-f]+:\s+cb 8a\s+res 1,d
+\s+[0-9a-f]+:\s+cb 8b\s+res 1,e
+\s+[0-9a-f]+:\s+cb 8c\s+res 1,h
+\s+[0-9a-f]+:\s+cb 8d\s+res 1,l
+\s+[0-9a-f]+:\s+cb 8e\s+res 1,\(hl\)
+\s+[0-9a-f]+:\s+cb 8f\s+res 1,a
+\s+[0-9a-f]+:\s+cb 90\s+res 2,b
+\s+[0-9a-f]+:\s+cb 91\s+res 2,c
+\s+[0-9a-f]+:\s+cb 92\s+res 2,d
+\s+[0-9a-f]+:\s+cb 93\s+res 2,e
+\s+[0-9a-f]+:\s+cb 94\s+res 2,h
+\s+[0-9a-f]+:\s+cb 95\s+res 2,l
+\s+[0-9a-f]+:\s+cb 96\s+res 2,\(hl\)
+\s+[0-9a-f]+:\s+cb 97\s+res 2,a
+\s+[0-9a-f]+:\s+cb 98\s+res 3,b
+\s+[0-9a-f]+:\s+cb 99\s+res 3,c
+\s+[0-9a-f]+:\s+cb 9a\s+res 3,d
+\s+[0-9a-f]+:\s+cb 9b\s+res 3,e
+\s+[0-9a-f]+:\s+cb 9c\s+res 3,h
+\s+[0-9a-f]+:\s+cb 9d\s+res 3,l
+\s+[0-9a-f]+:\s+cb 9e\s+res 3,\(hl\)
+\s+[0-9a-f]+:\s+cb 9f\s+res 3,a
+\s+[0-9a-f]+:\s+cb a0\s+res 4,b
+\s+[0-9a-f]+:\s+cb a1\s+res 4,c
+\s+[0-9a-f]+:\s+cb a2\s+res 4,d
+\s+[0-9a-f]+:\s+cb a3\s+res 4,e
+\s+[0-9a-f]+:\s+cb a4\s+res 4,h
+\s+[0-9a-f]+:\s+cb a5\s+res 4,l
+\s+[0-9a-f]+:\s+cb a6\s+res 4,\(hl\)
+\s+[0-9a-f]+:\s+cb a7\s+res 4,a
+\s+[0-9a-f]+:\s+cb a8\s+res 5,b
+\s+[0-9a-f]+:\s+cb a9\s+res 5,c
+\s+[0-9a-f]+:\s+cb aa\s+res 5,d
+\s+[0-9a-f]+:\s+cb ab\s+res 5,e
+\s+[0-9a-f]+:\s+cb ac\s+res 5,h
+\s+[0-9a-f]+:\s+cb ad\s+res 5,l
+\s+[0-9a-f]+:\s+cb ae\s+res 5,\(hl\)
+\s+[0-9a-f]+:\s+cb af\s+res 5,a
+\s+[0-9a-f]+:\s+cb b0\s+res 6,b
+\s+[0-9a-f]+:\s+cb b1\s+res 6,c
+\s+[0-9a-f]+:\s+cb b2\s+res 6,d
+\s+[0-9a-f]+:\s+cb b3\s+res 6,e
+\s+[0-9a-f]+:\s+cb b4\s+res 6,h
+\s+[0-9a-f]+:\s+cb b5\s+res 6,l
+\s+[0-9a-f]+:\s+cb b6\s+res 6,\(hl\)
+\s+[0-9a-f]+:\s+cb b7\s+res 6,a
+\s+[0-9a-f]+:\s+cb b8\s+res 7,b
+\s+[0-9a-f]+:\s+cb b9\s+res 7,c
+\s+[0-9a-f]+:\s+cb ba\s+res 7,d
+\s+[0-9a-f]+:\s+cb bb\s+res 7,e
+\s+[0-9a-f]+:\s+cb bc\s+res 7,h
+\s+[0-9a-f]+:\s+cb bd\s+res 7,l
+\s+[0-9a-f]+:\s+cb be\s+res 7,\(hl\)
+\s+[0-9a-f]+:\s+cb bf\s+res 7,a
+\s+[0-9a-f]+:\s+cb c0\s+set 0,b
+\s+[0-9a-f]+:\s+cb c1\s+set 0,c
+\s+[0-9a-f]+:\s+cb c2\s+set 0,d
+\s+[0-9a-f]+:\s+cb c3\s+set 0,e
+\s+[0-9a-f]+:\s+cb c4\s+set 0,h
+\s+[0-9a-f]+:\s+cb c5\s+set 0,l
+\s+[0-9a-f]+:\s+cb c6\s+set 0,\(hl\)
+\s+[0-9a-f]+:\s+cb c7\s+set 0,a
+\s+[0-9a-f]+:\s+cb c8\s+set 1,b
+\s+[0-9a-f]+:\s+cb c9\s+set 1,c
+\s+[0-9a-f]+:\s+cb ca\s+set 1,d
+\s+[0-9a-f]+:\s+cb cb\s+set 1,e
+\s+[0-9a-f]+:\s+cb cc\s+set 1,h
+\s+[0-9a-f]+:\s+cb cd\s+set 1,l
+\s+[0-9a-f]+:\s+cb ce\s+set 1,\(hl\)
+\s+[0-9a-f]+:\s+cb cf\s+set 1,a
+\s+[0-9a-f]+:\s+cb d0\s+set 2,b
+\s+[0-9a-f]+:\s+cb d1\s+set 2,c
+\s+[0-9a-f]+:\s+cb d2\s+set 2,d
+\s+[0-9a-f]+:\s+cb d3\s+set 2,e
+\s+[0-9a-f]+:\s+cb d4\s+set 2,h
+\s+[0-9a-f]+:\s+cb d5\s+set 2,l
+\s+[0-9a-f]+:\s+cb d6\s+set 2,\(hl\)
+\s+[0-9a-f]+:\s+cb d7\s+set 2,a
+\s+[0-9a-f]+:\s+cb d8\s+set 3,b
+\s+[0-9a-f]+:\s+cb d9\s+set 3,c
+\s+[0-9a-f]+:\s+cb da\s+set 3,d
+\s+[0-9a-f]+:\s+cb db\s+set 3,e
+\s+[0-9a-f]+:\s+cb dc\s+set 3,h
+\s+[0-9a-f]+:\s+cb dd\s+set 3,l
+\s+[0-9a-f]+:\s+cb de\s+set 3,\(hl\)
+\s+[0-9a-f]+:\s+cb df\s+set 3,a
+\s+[0-9a-f]+:\s+cb e0\s+set 4,b
+\s+[0-9a-f]+:\s+cb e1\s+set 4,c
+\s+[0-9a-f]+:\s+cb e2\s+set 4,d
+\s+[0-9a-f]+:\s+cb e3\s+set 4,e
+\s+[0-9a-f]+:\s+cb e4\s+set 4,h
+\s+[0-9a-f]+:\s+cb e5\s+set 4,l
+\s+[0-9a-f]+:\s+cb e6\s+set 4,\(hl\)
+\s+[0-9a-f]+:\s+cb e7\s+set 4,a
+\s+[0-9a-f]+:\s+cb e8\s+set 5,b
+\s+[0-9a-f]+:\s+cb e9\s+set 5,c
+\s+[0-9a-f]+:\s+cb ea\s+set 5,d
+\s+[0-9a-f]+:\s+cb eb\s+set 5,e
+\s+[0-9a-f]+:\s+cb ec\s+set 5,h
+\s+[0-9a-f]+:\s+cb ed\s+set 5,l
+\s+[0-9a-f]+:\s+cb ee\s+set 5,\(hl\)
+\s+[0-9a-f]+:\s+cb ef\s+set 5,a
+\s+[0-9a-f]+:\s+cb f0\s+set 6,b
+\s+[0-9a-f]+:\s+cb f1\s+set 6,c
+\s+[0-9a-f]+:\s+cb f2\s+set 6,d
+\s+[0-9a-f]+:\s+cb f3\s+set 6,e
+\s+[0-9a-f]+:\s+cb f4\s+set 6,h
+\s+[0-9a-f]+:\s+cb f5\s+set 6,l
+\s+[0-9a-f]+:\s+cb f6\s+set 6,\(hl\)
+\s+[0-9a-f]+:\s+cb f7\s+set 6,a
+\s+[0-9a-f]+:\s+cb f8\s+set 7,b
+\s+[0-9a-f]+:\s+cb f9\s+set 7,c
+\s+[0-9a-f]+:\s+cb fa\s+set 7,d
+\s+[0-9a-f]+:\s+cb fb\s+set 7,e
+\s+[0-9a-f]+:\s+cb fc\s+set 7,h
+\s+[0-9a-f]+:\s+cb fd\s+set 7,l
+\s+[0-9a-f]+:\s+cb fe\s+set 7,\(hl\)
+\s+[0-9a-f]+:\s+cb ff\s+set 7,a
diff --git a/gas/testsuite/gas/z80/gbz80_all.s b/gas/testsuite/gas/z80/gbz80_all.s
new file mode 100644
index 0000000..8e9085e
--- /dev/null
+++ b/gas/testsuite/gas/z80/gbz80_all.s
@@ -0,0 +1,519 @@
+ .text
+ .org 0
+;; Game Boy Z80 opcode test
+ nop
+ ld bc,0xbeaf
+ ld (bc),a
+ inc bc
+ inc b
+ dec b
+ ld b,0xfd
+ rlca
+ ld (0xbeaf),sp
+ add hl,bc
+ ld a,(bc)
+ dec bc
+ inc c
+ dec c
+ ld c,0xfd
+ rrca
+ stop
+ ld de,0xbeaf
+ ld (de),a
+ inc de
+ inc d
+ dec d
+ ld d,0xfd
+ rla
+ jr .+12
+ add hl,de
+ ld a,(de)
+ dec de
+ inc e
+ dec e
+ ld e,0xfd
+ rra
+ jr nz,.+12
+ ld hl,0xbeaf
+ ldi (hl),a
+ ld (hl+),a
+ inc hl
+ inc h
+ dec h
+ ld h,0xfd
+ daa
+ jr z,.+12
+ add hl,hl
+ ldi a,(hl)
+ ld a,(hl+)
+ dec hl
+ inc l
+ dec l
+ ld l,0xfd
+ cpl
+ jr nc,.+12
+ ld sp,0xbeaf
+ ldd (hl),a
+ ld (hl-),a
+ inc sp
+ inc (hl)
+ dec (hl)
+ ld (hl),0xfd
+ scf
+ jr c,.+12
+ add hl,sp
+ ldd a,(hl)
+ ld a,(hl-)
+ dec sp
+ inc a
+ dec a
+ ld a,0xfd
+ ccf
+ ld b,b
+ ld b,c
+ ld b,d
+ ld b,e
+ ld b,h
+ ld b,l
+ ld b,(hl)
+ ld b,a
+ ld c,b
+ ld c,c
+ ld c,d
+ ld c,e
+ ld c,h
+ ld c,l
+ ld c,(hl)
+ ld c,a
+ ld d,b
+ ld d,c
+ ld d,d
+ ld d,e
+ ld d,h
+ ld d,l
+ ld d,(hl)
+ ld d,a
+ ld e,b
+ ld e,c
+ ld e,d
+ ld e,e
+ ld e,h
+ ld e,l
+ ld e,(hl)
+ ld e,a
+ ld h,b
+ ld h,c
+ ld h,d
+ ld h,e
+ ld h,h
+ ld h,l
+ ld h,(hl)
+ ld h,a
+ ld l,b
+ ld l,c
+ ld l,d
+ ld l,e
+ ld l,h
+ ld l,l
+ ld l,(hl)
+ ld l,a
+ ld (hl),b
+ ld (hl),c
+ ld (hl),d
+ ld (hl),e
+ ld (hl),h
+ ld (hl),l
+ halt
+ ld (hl),a
+ ld a,b
+ ld a,c
+ ld a,d
+ ld a,e
+ ld a,h
+ ld a,l
+ ld a,(hl)
+ ld a,a
+ add a,b
+ add a,c
+ add a,d
+ add a,e
+ add a,h
+ add a,l
+ add a,(hl)
+ add a,a
+ adc a,b
+ adc a,c
+ adc a,d
+ adc a,e
+ adc a,h
+ adc a,l
+ adc a,(hl)
+ adc a,a
+ sub a,b
+ sub a,c
+ sub a,d
+ sub a,e
+ sub a,h
+ sub a,l
+ sub a,(hl)
+ sub a,a
+ sbc a,b
+ sbc a,c
+ sbc a,d
+ sbc a,e
+ sbc a,h
+ sbc a,l
+ sbc a,(hl)
+ sbc a,a
+ and b
+ and c
+ and d
+ and e
+ and h
+ and l
+ and (hl)
+ and a
+ xor b
+ xor c
+ xor d
+ xor e
+ xor h
+ xor l
+ xor (hl)
+ xor a
+ or b
+ or c
+ or d
+ or e
+ or h
+ or l
+ or (hl)
+ or a
+ cp b
+ cp c
+ cp d
+ cp e
+ cp h
+ cp l
+ cp (hl)
+ cp a
+ ret nz
+ pop bc
+ jp nz,0xbeaf
+ jp 0xbeaf
+ call nz,0xbeaf
+ push bc
+ add a,0xfd
+ rst 0
+ ret z
+ ret
+ jp z,0xbeaf
+ nop ;CB prefix
+ call z,0xbeaf
+ call 0xbeaf
+ adc a,0xfd
+ rst 0x08
+ ret nc
+ pop de
+ jp nc,0xbeaf
+ ;xx
+ call nc,0xbeaf
+ push de
+ sub a,0xfd
+ rst 0x10
+ ret c
+ reti
+ jp c,0xbeaf
+ ;xx
+ call c,0xbeaf
+ ;xx
+ sbc a,0xfd
+ rst 0x18
+ ldh (0xfd),a
+ pop hl
+ ldh (c),a
+ ;xx
+ ;xx
+ push hl
+ and 0xfd
+ rst 0x20
+ add sp,-12
+ jp (hl)
+ ld (0xbeaf),a
+ ;xx
+ ;xx
+ ;xx
+ xor 0xfd
+ rst 0x28
+ ldh a,(0xfd)
+ pop af
+ ldh a,(c)
+ di
+ ;xx
+ push af
+ or 0xfd
+ rst 0x30
+ ldhl sp,-12
+ ld sp,hl
+ ld a,(0xbeaf)
+ ei
+ ;xx
+ ;xx
+ cp 0xfd
+ rst 0x38
+ rlc b
+ rlc c
+ rlc d
+ rlc e
+ rlc h
+ rlc l
+ rlc (hl)
+ rlc a
+ rrc b
+ rrc c
+ rrc d
+ rrc e
+ rrc h
+ rrc l
+ rrc (hl)
+ rrc a
+ rl b
+ rl c
+ rl d
+ rl e
+ rl h
+ rl l
+ rl (hl)
+ rl a
+ rr b
+ rr c
+ rr d
+ rr e
+ rr h
+ rr l
+ rr (hl)
+ rr a
+ sla b
+ sla c
+ sla d
+ sla e
+ sla h
+ sla l
+ sla (hl)
+ sla a
+ sra b
+ sra c
+ sra d
+ sra e
+ sra h
+ sra l
+ sra (hl)
+ sra a
+ swap b
+ swap c
+ swap d
+ swap e
+ swap h
+ swap l
+ swap (hl)
+ swap a
+ srl b
+ srl c
+ srl d
+ srl e
+ srl h
+ srl l
+ srl (hl)
+ srl a
+ bit 0,b
+ bit 0,c
+ bit 0,d
+ bit 0,e
+ bit 0,h
+ bit 0,l
+ bit 0,(hl)
+ bit 0,a
+ bit 1,b
+ bit 1,c
+ bit 1,d
+ bit 1,e
+ bit 1,h
+ bit 1,l
+ bit 1,(hl)
+ bit 1,a
+ bit 2,b
+ bit 2,c
+ bit 2,d
+ bit 2,e
+ bit 2,h
+ bit 2,l
+ bit 2,(hl)
+ bit 2,a
+ bit 3,b
+ bit 3,c
+ bit 3,d
+ bit 3,e
+ bit 3,h
+ bit 3,l
+ bit 3,(hl)
+ bit 3,a
+ bit 4,b
+ bit 4,c
+ bit 4,d
+ bit 4,e
+ bit 4,h
+ bit 4,l
+ bit 4,(hl)
+ bit 4,a
+ bit 5,b
+ bit 5,c
+ bit 5,d
+ bit 5,e
+ bit 5,h
+ bit 5,l
+ bit 5,(hl)
+ bit 5,a
+ bit 6,b
+ bit 6,c
+ bit 6,d
+ bit 6,e
+ bit 6,h
+ bit 6,l
+ bit 6,(hl)
+ bit 6,a
+ bit 7,b
+ bit 7,c
+ bit 7,d
+ bit 7,e
+ bit 7,h
+ bit 7,l
+ bit 7,(hl)
+ bit 7,a
+ res 0,b
+ res 0,c
+ res 0,d
+ res 0,e
+ res 0,h
+ res 0,l
+ res 0,(hl)
+ res 0,a
+ res 1,b
+ res 1,c
+ res 1,d
+ res 1,e
+ res 1,h
+ res 1,l
+ res 1,(hl)
+ res 1,a
+ res 2,b
+ res 2,c
+ res 2,d
+ res 2,e
+ res 2,h
+ res 2,l
+ res 2,(hl)
+ res 2,a
+ res 3,b
+ res 3,c
+ res 3,d
+ res 3,e
+ res 3,h
+ res 3,l
+ res 3,(hl)
+ res 3,a
+ res 4,b
+ res 4,c
+ res 4,d
+ res 4,e
+ res 4,h
+ res 4,l
+ res 4,(hl)
+ res 4,a
+ res 5,b
+ res 5,c
+ res 5,d
+ res 5,e
+ res 5,h
+ res 5,l
+ res 5,(hl)
+ res 5,a
+ res 6,b
+ res 6,c
+ res 6,d
+ res 6,e
+ res 6,h
+ res 6,l
+ res 6,(hl)
+ res 6,a
+ res 7,b
+ res 7,c
+ res 7,d
+ res 7,e
+ res 7,h
+ res 7,l
+ res 7,(hl)
+ res 7,a
+ set 0,b
+ set 0,c
+ set 0,d
+ set 0,e
+ set 0,h
+ set 0,l
+ set 0,(hl)
+ set 0,a
+ set 1,b
+ set 1,c
+ set 1,d
+ set 1,e
+ set 1,h
+ set 1,l
+ set 1,(hl)
+ set 1,a
+ set 2,b
+ set 2,c
+ set 2,d
+ set 2,e
+ set 2,h
+ set 2,l
+ set 2,(hl)
+ set 2,a
+ set 3,b
+ set 3,c
+ set 3,d
+ set 3,e
+ set 3,h
+ set 3,l
+ set 3,(hl)
+ set 3,a
+ set 4,b
+ set 4,c
+ set 4,d
+ set 4,e
+ set 4,h
+ set 4,l
+ set 4,(hl)
+ set 4,a
+ set 5,b
+ set 5,c
+ set 5,d
+ set 5,e
+ set 5,h
+ set 5,l
+ set 5,(hl)
+ set 5,a
+ set 6,b
+ set 6,c
+ set 6,d
+ set 6,e
+ set 6,h
+ set 6,l
+ set 6,(hl)
+ set 6,a
+ set 7,b
+ set 7,c
+ set 7,d
+ set 7,e
+ set 7,h
+ set 7,l
+ set 7,(hl)
+ set 7,a
diff --git a/gas/testsuite/gas/z80/z80.exp b/gas/testsuite/gas/z80/z80.exp
index 6ba13fc..31f6113 100644
--- a/gas/testsuite/gas/z80/z80.exp
+++ b/gas/testsuite/gas/z80/z80.exp
@@ -92,6 +92,12 @@ if [istarget z80-*-*] then {
run_dump_test "ez80_adl_suf"
#test for eZ80 opcode prefixes as multiple bytes before instruction
run_dump_test "ez80_pref_dis"
+#test for GBZ80 instruction set
+ run_dump_test "gbz80_all"
+#test for Z80N instruction set
+ run_dump_test "z80n_all"
+#test for Z80N push nn relocation test
+ run_dump_test "z80n_reloc"
# test for SDCC compatibility mode
run_dump_test "sdcc"
# test for colonless labels
diff --git a/gas/testsuite/gas/z80/z80n_all.d b/gas/testsuite/gas/z80/z80n_all.d
new file mode 100644
index 0000000..3412905
--- /dev/null
+++ b/gas/testsuite/gas/z80/z80n_all.d
@@ -0,0 +1,1208 @@
+#as: -z80n
+#objdump: -d
+
+.*:[ ]+file format (coff|elf32)\-z80
+
+
+Disassembly of section \.text:
+
+00000000 <\.text>:
+[ ]+0:[ ]+8e[ ]+adc a,\(hl\)
+[ ]+1:[ ]+dd 8e 09[ ]+adc a,\(ix\+9\)
+[ ]+4:[ ]+fd 8e 09[ ]+adc a,\(iy\+9\)
+[ ]+7:[ ]+ce 03[ ]+adc a,0x03
+[ ]+9:[ ]+8f[ ]+adc a,a
+[ ]+a:[ ]+88[ ]+adc a,b
+[ ]+b:[ ]+89[ ]+adc a,c
+[ ]+c:[ ]+8a[ ]+adc a,d
+[ ]+d:[ ]+8b[ ]+adc a,e
+[ ]+e:[ ]+8c[ ]+adc a,h
+[ ]+f:[ ]+8d[ ]+adc a,l
+[ ]+10:[ ]+ed 4a[ ]+adc hl,bc
+[ ]+12:[ ]+ed 5a[ ]+adc hl,de
+[ ]+14:[ ]+ed 6a[ ]+adc hl,hl
+[ ]+16:[ ]+ed 7a[ ]+adc hl,sp
+[ ]+18:[ ]+86[ ]+add a,\(hl\)
+[ ]+19:[ ]+dd 86 09[ ]+add a,\(ix\+9\)
+[ ]+1c:[ ]+fd 86 09[ ]+add a,\(iy\+9\)
+[ ]+1f:[ ]+c6 03[ ]+add a,0x03
+[ ]+21:[ ]+87[ ]+add a,a
+[ ]+22:[ ]+80[ ]+add a,b
+[ ]+23:[ ]+81[ ]+add a,c
+[ ]+24:[ ]+82[ ]+add a,d
+[ ]+25:[ ]+83[ ]+add a,e
+[ ]+26:[ ]+84[ ]+add a,h
+[ ]+27:[ ]+85[ ]+add a,l
+[ ]+28:[ ]+09[ ]+add hl,bc
+[ ]+29:[ ]+19[ ]+add hl,de
+[ ]+2a:[ ]+29[ ]+add hl,hl
+[ ]+2b:[ ]+39[ ]+add hl,sp
+[ ]+2c:[ ]+dd 09[ ]+add ix,bc
+[ ]+2e:[ ]+dd 19[ ]+add ix,de
+[ ]+30:[ ]+dd 29[ ]+add ix,ix
+[ ]+32:[ ]+dd 39[ ]+add ix,sp
+[ ]+34:[ ]+fd 09[ ]+add iy,bc
+[ ]+36:[ ]+fd 19[ ]+add iy,de
+[ ]+38:[ ]+fd 29[ ]+add iy,iy
+[ ]+3a:[ ]+fd 39[ ]+add iy,sp
+[ ]+3c:[ ]+a6[ ]+and \(hl\)
+[ ]+3d:[ ]+dd a6 09[ ]+and \(ix\+9\)
+[ ]+40:[ ]+fd a6 09[ ]+and \(iy\+9\)
+[ ]+43:[ ]+e6 03[ ]+and 0x03
+[ ]+45:[ ]+a7[ ]+and a
+[ ]+46:[ ]+a0[ ]+and b
+[ ]+47:[ ]+a1[ ]+and c
+[ ]+48:[ ]+a2[ ]+and d
+[ ]+49:[ ]+a3[ ]+and e
+[ ]+4a:[ ]+a4[ ]+and h
+[ ]+4b:[ ]+a5[ ]+and l
+[ ]+4c:[ ]+cb 46[ ]+bit 0,\(hl\)
+[ ]+4e:[ ]+dd cb 09 46[ ]+bit 0,\(ix\+9\)
+[ ]+52:[ ]+fd cb 09 46[ ]+bit 0,\(iy\+9\)
+[ ]+56:[ ]+cb 47[ ]+bit 0,a
+[ ]+58:[ ]+cb 40[ ]+bit 0,b
+[ ]+5a:[ ]+cb 41[ ]+bit 0,c
+[ ]+5c:[ ]+cb 42[ ]+bit 0,d
+[ ]+5e:[ ]+cb 43[ ]+bit 0,e
+[ ]+60:[ ]+cb 44[ ]+bit 0,h
+[ ]+62:[ ]+cb 45[ ]+bit 0,l
+[ ]+64:[ ]+cb 4e[ ]+bit 1,\(hl\)
+[ ]+66:[ ]+dd cb 09 4e[ ]+bit 1,\(ix\+9\)
+[ ]+6a:[ ]+fd cb 09 4e[ ]+bit 1,\(iy\+9\)
+[ ]+6e:[ ]+cb 4f[ ]+bit 1,a
+[ ]+70:[ ]+cb 48[ ]+bit 1,b
+[ ]+72:[ ]+cb 49[ ]+bit 1,c
+[ ]+74:[ ]+cb 4a[ ]+bit 1,d
+[ ]+76:[ ]+cb 4b[ ]+bit 1,e
+[ ]+78:[ ]+cb 4c[ ]+bit 1,h
+[ ]+7a:[ ]+cb 4d[ ]+bit 1,l
+[ ]+7c:[ ]+cb 56[ ]+bit 2,\(hl\)
+[ ]+7e:[ ]+dd cb 09 56[ ]+bit 2,\(ix\+9\)
+[ ]+82:[ ]+fd cb 09 56[ ]+bit 2,\(iy\+9\)
+[ ]+86:[ ]+cb 57[ ]+bit 2,a
+[ ]+88:[ ]+cb 50[ ]+bit 2,b
+[ ]+8a:[ ]+cb 51[ ]+bit 2,c
+[ ]+8c:[ ]+cb 52[ ]+bit 2,d
+[ ]+8e:[ ]+cb 53[ ]+bit 2,e
+[ ]+90:[ ]+cb 54[ ]+bit 2,h
+[ ]+92:[ ]+cb 55[ ]+bit 2,l
+[ ]+94:[ ]+cb 5e[ ]+bit 3,\(hl\)
+[ ]+96:[ ]+dd cb 09 5e[ ]+bit 3,\(ix\+9\)
+[ ]+9a:[ ]+fd cb 09 5e[ ]+bit 3,\(iy\+9\)
+[ ]+9e:[ ]+cb 5f[ ]+bit 3,a
+[ ]+a0:[ ]+cb 58[ ]+bit 3,b
+[ ]+a2:[ ]+cb 59[ ]+bit 3,c
+[ ]+a4:[ ]+cb 5a[ ]+bit 3,d
+[ ]+a6:[ ]+cb 5b[ ]+bit 3,e
+[ ]+a8:[ ]+cb 5c[ ]+bit 3,h
+[ ]+aa:[ ]+cb 5d[ ]+bit 3,l
+[ ]+ac:[ ]+cb 66[ ]+bit 4,\(hl\)
+[ ]+ae:[ ]+dd cb 09 66[ ]+bit 4,\(ix\+9\)
+[ ]+b2:[ ]+fd cb 09 66[ ]+bit 4,\(iy\+9\)
+[ ]+b6:[ ]+cb 67[ ]+bit 4,a
+[ ]+b8:[ ]+cb 60[ ]+bit 4,b
+[ ]+ba:[ ]+cb 61[ ]+bit 4,c
+[ ]+bc:[ ]+cb 62[ ]+bit 4,d
+[ ]+be:[ ]+cb 63[ ]+bit 4,e
+[ ]+c0:[ ]+cb 64[ ]+bit 4,h
+[ ]+c2:[ ]+cb 65[ ]+bit 4,l
+[ ]+c4:[ ]+cb 6e[ ]+bit 5,\(hl\)
+[ ]+c6:[ ]+dd cb 09 6e[ ]+bit 5,\(ix\+9\)
+[ ]+ca:[ ]+fd cb 09 6e[ ]+bit 5,\(iy\+9\)
+[ ]+ce:[ ]+cb 6f[ ]+bit 5,a
+[ ]+d0:[ ]+cb 68[ ]+bit 5,b
+[ ]+d2:[ ]+cb 69[ ]+bit 5,c
+[ ]+d4:[ ]+cb 6a[ ]+bit 5,d
+[ ]+d6:[ ]+cb 6b[ ]+bit 5,e
+[ ]+d8:[ ]+cb 6c[ ]+bit 5,h
+[ ]+da:[ ]+cb 6d[ ]+bit 5,l
+[ ]+dc:[ ]+cb 76[ ]+bit 6,\(hl\)
+[ ]+de:[ ]+dd cb 09 76[ ]+bit 6,\(ix\+9\)
+[ ]+e2:[ ]+fd cb 09 76[ ]+bit 6,\(iy\+9\)
+[ ]+e6:[ ]+cb 77[ ]+bit 6,a
+[ ]+e8:[ ]+cb 70[ ]+bit 6,b
+[ ]+ea:[ ]+cb 71[ ]+bit 6,c
+[ ]+ec:[ ]+cb 72[ ]+bit 6,d
+[ ]+ee:[ ]+cb 73[ ]+bit 6,e
+[ ]+f0:[ ]+cb 74[ ]+bit 6,h
+[ ]+f2:[ ]+cb 75[ ]+bit 6,l
+[ ]+f4:[ ]+cb 7e[ ]+bit 7,\(hl\)
+[ ]+f6:[ ]+dd cb 09 7e[ ]+bit 7,\(ix\+9\)
+[ ]+fa:[ ]+fd cb 09 7e[ ]+bit 7,\(iy\+9\)
+[ ]+fe:[ ]+cb 7f[ ]+bit 7,a
+[ ]+100:[ ]+cb 78[ ]+bit 7,b
+[ ]+102:[ ]+cb 79[ ]+bit 7,c
+[ ]+104:[ ]+cb 7a[ ]+bit 7,d
+[ ]+106:[ ]+cb 7b[ ]+bit 7,e
+[ ]+108:[ ]+cb 7c[ ]+bit 7,h
+[ ]+10a:[ ]+cb 7d[ ]+bit 7,l
+[ ]+10c:[ ]+cd 34 12[ ]+call 0x1234
+[ ]+10f:[ ]+dc 34 12[ ]+call c,0x1234
+[ ]+112:[ ]+fc 34 12[ ]+call m,0x1234
+[ ]+115:[ ]+d4 34 12[ ]+call nc,0x1234
+[ ]+118:[ ]+c4 34 12[ ]+call nz,0x1234
+[ ]+11b:[ ]+f4 34 12[ ]+call p,0x1234
+[ ]+11e:[ ]+ec 34 12[ ]+call pe,0x1234
+[ ]+121:[ ]+e4 34 12[ ]+call po,0x1234
+[ ]+124:[ ]+cc 34 12[ ]+call z,0x1234
+[ ]+127:[ ]+3f[ ]+ccf
+[ ]+128:[ ]+be[ ]+cp \(hl\)
+[ ]+129:[ ]+dd be 09[ ]+cp \(ix\+9\)
+[ ]+12c:[ ]+fd be 09[ ]+cp \(iy\+9\)
+[ ]+12f:[ ]+fe 03[ ]+cp 0x03
+[ ]+131:[ ]+bf[ ]+cp a
+[ ]+132:[ ]+b8[ ]+cp b
+[ ]+133:[ ]+b9[ ]+cp c
+[ ]+134:[ ]+ba[ ]+cp d
+[ ]+135:[ ]+bb[ ]+cp e
+[ ]+136:[ ]+bc[ ]+cp h
+[ ]+137:[ ]+bd[ ]+cp l
+[ ]+138:[ ]+ed a9[ ]+cpd
+[ ]+13a:[ ]+ed b9[ ]+cpdr
+[ ]+13c:[ ]+ed a1[ ]+cpi
+[ ]+13e:[ ]+ed b1[ ]+cpir
+[ ]+140:[ ]+2f[ ]+cpl
+[ ]+141:[ ]+27[ ]+daa
+[ ]+142:[ ]+35[ ]+dec \(hl\)
+[ ]+143:[ ]+dd 35 09[ ]+dec \(ix\+9\)
+[ ]+146:[ ]+fd 35 09[ ]+dec \(iy\+9\)
+[ ]+149:[ ]+3d[ ]+dec a
+[ ]+14a:[ ]+05[ ]+dec b
+[ ]+14b:[ ]+0b[ ]+dec bc
+[ ]+14c:[ ]+0d[ ]+dec c
+[ ]+14d:[ ]+15[ ]+dec d
+[ ]+14e:[ ]+1b[ ]+dec de
+[ ]+14f:[ ]+1d[ ]+dec e
+[ ]+150:[ ]+25[ ]+dec h
+[ ]+151:[ ]+2b[ ]+dec hl
+[ ]+152:[ ]+dd 2b[ ]+dec ix
+[ ]+154:[ ]+fd 2b[ ]+dec iy
+[ ]+156:[ ]+2d[ ]+dec l
+[ ]+157:[ ]+3b[ ]+dec sp
+[ ]+158:[ ]+f3[ ]+di
+[ ]+159:[ ]+10 05[ ]+djnz 0x0160
+[ ]+15b:[ ]+fb[ ]+ei
+[ ]+15c:[ ]+e3[ ]+ex \(sp\),hl
+[ ]+15d:[ ]+dd e3[ ]+ex \(sp\),ix
+[ ]+15f:[ ]+fd e3[ ]+ex \(sp\),iy
+[ ]+161:[ ]+08[ ]+ex af,af'
+[ ]+162:[ ]+eb[ ]+ex de,hl
+[ ]+163:[ ]+d9[ ]+exx
+[ ]+164:[ ]+76[ ]+halt
+[ ]+165:[ ]+ed 46[ ]+im 0
+[ ]+167:[ ]+ed 56[ ]+im 1
+[ ]+169:[ ]+ed 5e[ ]+im 2
+[ ]+16b:[ ]+ed 78[ ]+in a,\(c\)
+[ ]+16d:[ ]+db 03[ ]+in a,\(0x03\)
+[ ]+16f:[ ]+ed 40[ ]+in b,\(c\)
+[ ]+171:[ ]+ed 48[ ]+in c,\(c\)
+[ ]+173:[ ]+ed 50[ ]+in d,\(c\)
+[ ]+175:[ ]+ed 58[ ]+in e,\(c\)
+[ ]+177:[ ]+ed 60[ ]+in h,\(c\)
+[ ]+179:[ ]+ed 68[ ]+in l,\(c\)
+[ ]+17b:[ ]+34[ ]+inc \(hl\)
+[ ]+17c:[ ]+dd 34 09[ ]+inc \(ix\+9\)
+[ ]+17f:[ ]+fd 34 09[ ]+inc \(iy\+9\)
+[ ]+182:[ ]+3c[ ]+inc a
+[ ]+183:[ ]+04[ ]+inc b
+[ ]+184:[ ]+03[ ]+inc bc
+[ ]+185:[ ]+0c[ ]+inc c
+[ ]+186:[ ]+14[ ]+inc d
+[ ]+187:[ ]+13[ ]+inc de
+[ ]+188:[ ]+1c[ ]+inc e
+[ ]+189:[ ]+24[ ]+inc h
+[ ]+18a:[ ]+23[ ]+inc hl
+[ ]+18b:[ ]+dd 23[ ]+inc ix
+[ ]+18d:[ ]+fd 23[ ]+inc iy
+[ ]+18f:[ ]+2c[ ]+inc l
+[ ]+190:[ ]+33[ ]+inc sp
+[ ]+191:[ ]+ed aa[ ]+ind
+[ ]+193:[ ]+ed ba[ ]+indr
+[ ]+195:[ ]+ed a2[ ]+ini
+[ ]+197:[ ]+ed b2[ ]+inir
+[ ]+199:[ ]+e9[ ]+jp \(hl\)
+[ ]+19a:[ ]+dd e9[ ]+jp \(ix\)
+[ ]+19c:[ ]+fd e9[ ]+jp \(iy\)
+[ ]+19e:[ ]+c3 34 12[ ]+jp 0x1234
+[ ]+1a1:[ ]+da 34 12[ ]+jp c,0x1234
+[ ]+1a4:[ ]+fa 34 12[ ]+jp m,0x1234
+[ ]+1a7:[ ]+d2 34 12[ ]+jp nc,0x1234
+[ ]+1aa:[ ]+c2 34 12[ ]+jp nz,0x1234
+[ ]+1ad:[ ]+f2 34 12[ ]+jp p,0x1234
+[ ]+1b0:[ ]+ea 34 12[ ]+jp pe,0x1234
+[ ]+1b3:[ ]+e2 34 12[ ]+jp po,0x1234
+[ ]+1b6:[ ]+ca 34 12[ ]+jp z,0x1234
+[ ]+1b9:[ ]+18 05[ ]+jr 0x01c0
+[ ]+1bb:[ ]+38 05[ ]+jr c,0x01c2
+[ ]+1bd:[ ]+30 05[ ]+jr nc,0x01c4
+[ ]+1bf:[ ]+20 05[ ]+jr nz,0x01c6
+[ ]+1c1:[ ]+28 05[ ]+jr z,0x01c8
+[ ]+1c3:[ ]+32 34 12[ ]+ld \(0x1234\),a
+[ ]+1c6:[ ]+ed 43 34 12[ ]+ld \(0x1234\),bc
+[ ]+1ca:[ ]+ed 53 34 12[ ]+ld \(0x1234\),de
+[ ]+1ce:[ ]+22 34 12[ ]+ld \(0x1234\),hl
+[ ]+1d1:[ ]+dd 22 34 12[ ]+ld \(0x1234\),ix
+[ ]+1d5:[ ]+fd 22 34 12[ ]+ld \(0x1234\),iy
+[ ]+1d9:[ ]+ed 73 34 12[ ]+ld \(0x1234\),sp
+[ ]+1dd:[ ]+02[ ]+ld \(bc\),a
+[ ]+1de:[ ]+12[ ]+ld \(de\),a
+[ ]+1df:[ ]+36 03[ ]+ld \(hl\),0x03
+[ ]+1e1:[ ]+77[ ]+ld \(hl\),a
+[ ]+1e2:[ ]+70[ ]+ld \(hl\),b
+[ ]+1e3:[ ]+71[ ]+ld \(hl\),c
+[ ]+1e4:[ ]+72[ ]+ld \(hl\),d
+[ ]+1e5:[ ]+73[ ]+ld \(hl\),e
+[ ]+1e6:[ ]+74[ ]+ld \(hl\),h
+[ ]+1e7:[ ]+75[ ]+ld \(hl\),l
+[ ]+1e8:[ ]+dd 36 09 03[ ]+ld \(ix\+9\),0x03
+[ ]+1ec:[ ]+dd 77 09[ ]+ld \(ix\+9\),a
+[ ]+1ef:[ ]+dd 70 09[ ]+ld \(ix\+9\),b
+[ ]+1f2:[ ]+dd 71 09[ ]+ld \(ix\+9\),c
+[ ]+1f5:[ ]+dd 72 09[ ]+ld \(ix\+9\),d
+[ ]+1f8:[ ]+dd 73 09[ ]+ld \(ix\+9\),e
+[ ]+1fb:[ ]+dd 74 09[ ]+ld \(ix\+9\),h
+[ ]+1fe:[ ]+dd 75 09[ ]+ld \(ix\+9\),l
+[ ]+201:[ ]+fd 36 09 03[ ]+ld \(iy\+9\),0x03
+[ ]+205:[ ]+fd 77 09[ ]+ld \(iy\+9\),a
+[ ]+208:[ ]+fd 70 09[ ]+ld \(iy\+9\),b
+[ ]+20b:[ ]+fd 71 09[ ]+ld \(iy\+9\),c
+[ ]+20e:[ ]+fd 72 09[ ]+ld \(iy\+9\),d
+[ ]+211:[ ]+fd 73 09[ ]+ld \(iy\+9\),e
+[ ]+214:[ ]+fd 74 09[ ]+ld \(iy\+9\),h
+[ ]+217:[ ]+fd 75 09[ ]+ld \(iy\+9\),l
+[ ]+21a:[ ]+3a 34 12[ ]+ld a,\(0x1234\)
+[ ]+21d:[ ]+0a[ ]+ld a,\(bc\)
+[ ]+21e:[ ]+1a[ ]+ld a,\(de\)
+[ ]+21f:[ ]+7e[ ]+ld a,\(hl\)
+[ ]+220:[ ]+dd 7e 09[ ]+ld a,\(ix\+9\)
+[ ]+223:[ ]+fd 7e 09[ ]+ld a,\(iy\+9\)
+[ ]+226:[ ]+3e 03[ ]+ld a,0x03
+[ ]+228:[ ]+7f[ ]+ld a,a
+[ ]+229:[ ]+78[ ]+ld a,b
+[ ]+22a:[ ]+79[ ]+ld a,c
+[ ]+22b:[ ]+7a[ ]+ld a,d
+[ ]+22c:[ ]+7b[ ]+ld a,e
+[ ]+22d:[ ]+7c[ ]+ld a,h
+[ ]+22e:[ ]+ed 57[ ]+ld a,i
+[ ]+230:[ ]+7d[ ]+ld a,l
+[ ]+231:[ ]+ed 5f[ ]+ld a,r
+[ ]+233:[ ]+46[ ]+ld b,\(hl\)
+[ ]+234:[ ]+dd 46 09[ ]+ld b,\(ix\+9\)
+[ ]+237:[ ]+fd 46 09[ ]+ld b,\(iy\+9\)
+[ ]+23a:[ ]+06 03[ ]+ld b,0x03
+[ ]+23c:[ ]+47[ ]+ld b,a
+[ ]+23d:[ ]+40[ ]+ld b,b
+[ ]+23e:[ ]+41[ ]+ld b,c
+[ ]+23f:[ ]+42[ ]+ld b,d
+[ ]+240:[ ]+43[ ]+ld b,e
+[ ]+241:[ ]+44[ ]+ld b,h
+[ ]+242:[ ]+45[ ]+ld b,l
+[ ]+243:[ ]+ed 4b 34 12[ ]+ld bc,\(0x1234\)
+[ ]+247:[ ]+01 34 12[ ]+ld bc,0x1234
+[ ]+24a:[ ]+4e[ ]+ld c,\(hl\)
+[ ]+24b:[ ]+dd 4e 09[ ]+ld c,\(ix\+9\)
+[ ]+24e:[ ]+fd 4e 09[ ]+ld c,\(iy\+9\)
+[ ]+251:[ ]+0e 03[ ]+ld c,0x03
+[ ]+253:[ ]+4f[ ]+ld c,a
+[ ]+254:[ ]+48[ ]+ld c,b
+[ ]+255:[ ]+49[ ]+ld c,c
+[ ]+256:[ ]+4a[ ]+ld c,d
+[ ]+257:[ ]+4b[ ]+ld c,e
+[ ]+258:[ ]+4c[ ]+ld c,h
+[ ]+259:[ ]+4d[ ]+ld c,l
+[ ]+25a:[ ]+56[ ]+ld d,\(hl\)
+[ ]+25b:[ ]+dd 56 09[ ]+ld d,\(ix\+9\)
+[ ]+25e:[ ]+fd 56 09[ ]+ld d,\(iy\+9\)
+[ ]+261:[ ]+16 03[ ]+ld d,0x03
+[ ]+263:[ ]+57[ ]+ld d,a
+[ ]+264:[ ]+50[ ]+ld d,b
+[ ]+265:[ ]+51[ ]+ld d,c
+[ ]+266:[ ]+52[ ]+ld d,d
+[ ]+267:[ ]+53[ ]+ld d,e
+[ ]+268:[ ]+54[ ]+ld d,h
+[ ]+269:[ ]+55[ ]+ld d,l
+[ ]+26a:[ ]+ed 5b 34 12[ ]+ld de,\(0x1234\)
+[ ]+26e:[ ]+11 34 12[ ]+ld de,0x1234
+[ ]+271:[ ]+5e[ ]+ld e,\(hl\)
+[ ]+272:[ ]+dd 5e 09[ ]+ld e,\(ix\+9\)
+[ ]+275:[ ]+fd 5e 09[ ]+ld e,\(iy\+9\)
+[ ]+278:[ ]+1e 03[ ]+ld e,0x03
+[ ]+27a:[ ]+5f[ ]+ld e,a
+[ ]+27b:[ ]+58[ ]+ld e,b
+[ ]+27c:[ ]+59[ ]+ld e,c
+[ ]+27d:[ ]+5a[ ]+ld e,d
+[ ]+27e:[ ]+5b[ ]+ld e,e
+[ ]+27f:[ ]+5c[ ]+ld e,h
+[ ]+280:[ ]+5d[ ]+ld e,l
+[ ]+281:[ ]+66[ ]+ld h,\(hl\)
+[ ]+282:[ ]+dd 66 09[ ]+ld h,\(ix\+9\)
+[ ]+285:[ ]+fd 66 09[ ]+ld h,\(iy\+9\)
+[ ]+288:[ ]+26 03[ ]+ld h,0x03
+[ ]+28a:[ ]+67[ ]+ld h,a
+[ ]+28b:[ ]+60[ ]+ld h,b
+[ ]+28c:[ ]+61[ ]+ld h,c
+[ ]+28d:[ ]+62[ ]+ld h,d
+[ ]+28e:[ ]+63[ ]+ld h,e
+[ ]+28f:[ ]+64[ ]+ld h,h
+[ ]+290:[ ]+65[ ]+ld h,l
+[ ]+291:[ ]+2a 34 12[ ]+ld hl,\(0x1234\)
+[ ]+294:[ ]+21 34 12[ ]+ld hl,0x1234
+[ ]+297:[ ]+ed 47[ ]+ld i,a
+[ ]+299:[ ]+dd 2a 34 12[ ]+ld ix,\(0x1234\)
+[ ]+29d:[ ]+dd 21 34 12[ ]+ld ix,0x1234
+[ ]+2a1:[ ]+fd 2a 34 12[ ]+ld iy,\(0x1234\)
+[ ]+2a5:[ ]+fd 21 34 12[ ]+ld iy,0x1234
+[ ]+2a9:[ ]+6e[ ]+ld l,\(hl\)
+[ ]+2aa:[ ]+dd 6e 09[ ]+ld l,\(ix\+9\)
+[ ]+2ad:[ ]+fd 6e 09[ ]+ld l,\(iy\+9\)
+[ ]+2b0:[ ]+2e 03[ ]+ld l,0x03
+[ ]+2b2:[ ]+6f[ ]+ld l,a
+[ ]+2b3:[ ]+68[ ]+ld l,b
+[ ]+2b4:[ ]+69[ ]+ld l,c
+[ ]+2b5:[ ]+6a[ ]+ld l,d
+[ ]+2b6:[ ]+6b[ ]+ld l,e
+[ ]+2b7:[ ]+6c[ ]+ld l,h
+[ ]+2b8:[ ]+6d[ ]+ld l,l
+[ ]+2b9:[ ]+ed 4f[ ]+ld r,a
+[ ]+2bb:[ ]+ed 7b 34 12[ ]+ld sp,\(0x1234\)
+[ ]+2bf:[ ]+31 34 12[ ]+ld sp,0x1234
+[ ]+2c2:[ ]+f9[ ]+ld sp,hl
+[ ]+2c3:[ ]+dd f9[ ]+ld sp,ix
+[ ]+2c5:[ ]+fd f9[ ]+ld sp,iy
+[ ]+2c7:[ ]+ed a8[ ]+ldd
+[ ]+2c9:[ ]+ed b8[ ]+lddr
+[ ]+2cb:[ ]+ed a0[ ]+ldi
+[ ]+2cd:[ ]+ed b0[ ]+ldir
+[ ]+2cf:[ ]+ed 44[ ]+neg
+[ ]+2d1:[ ]+00[ ]+nop
+[ ]+2d2:[ ]+b6[ ]+or \(hl\)
+[ ]+2d3:[ ]+dd b6 09[ ]+or \(ix\+9\)
+[ ]+2d6:[ ]+fd b6 09[ ]+or \(iy\+9\)
+[ ]+2d9:[ ]+f6 03[ ]+or 0x03
+[ ]+2db:[ ]+b7[ ]+or a
+[ ]+2dc:[ ]+b0[ ]+or b
+[ ]+2dd:[ ]+b1[ ]+or c
+[ ]+2de:[ ]+b2[ ]+or d
+[ ]+2df:[ ]+b3[ ]+or e
+[ ]+2e0:[ ]+b4[ ]+or h
+[ ]+2e1:[ ]+b5[ ]+or l
+[ ]+2e2:[ ]+ed bb[ ]+otdr
+[ ]+2e4:[ ]+ed b3[ ]+otir
+[ ]+2e6:[ ]+ed 79[ ]+out \(c\),a
+[ ]+2e8:[ ]+ed 41[ ]+out \(c\),b
+[ ]+2ea:[ ]+ed 49[ ]+out \(c\),c
+[ ]+2ec:[ ]+ed 51[ ]+out \(c\),d
+[ ]+2ee:[ ]+ed 59[ ]+out \(c\),e
+[ ]+2f0:[ ]+ed 61[ ]+out \(c\),h
+[ ]+2f2:[ ]+ed 69[ ]+out \(c\),l
+[ ]+2f4:[ ]+d3 03[ ]+out \(0x03\),a
+[ ]+2f6:[ ]+ed ab[ ]+outd
+[ ]+2f8:[ ]+ed a3[ ]+outi
+[ ]+2fa:[ ]+f1[ ]+pop af
+[ ]+2fb:[ ]+c1[ ]+pop bc
+[ ]+2fc:[ ]+d1[ ]+pop de
+[ ]+2fd:[ ]+e1[ ]+pop hl
+[ ]+2fe:[ ]+dd e1[ ]+pop ix
+[ ]+300:[ ]+fd e1[ ]+pop iy
+[ ]+302:[ ]+f5[ ]+push af
+[ ]+303:[ ]+c5[ ]+push bc
+[ ]+304:[ ]+d5[ ]+push de
+[ ]+305:[ ]+e5[ ]+push hl
+[ ]+306:[ ]+dd e5[ ]+push ix
+[ ]+308:[ ]+fd e5[ ]+push iy
+[ ]+30a:[ ]+cb 86[ ]+res 0,\(hl\)
+[ ]+30c:[ ]+dd cb 09 86[ ]+res 0,\(ix\+9\)
+[ ]+310:[ ]+fd cb 09 86[ ]+res 0,\(iy\+9\)
+[ ]+314:[ ]+cb 87[ ]+res 0,a
+[ ]+316:[ ]+cb 80[ ]+res 0,b
+[ ]+318:[ ]+cb 81[ ]+res 0,c
+[ ]+31a:[ ]+cb 82[ ]+res 0,d
+[ ]+31c:[ ]+cb 83[ ]+res 0,e
+[ ]+31e:[ ]+cb 84[ ]+res 0,h
+[ ]+320:[ ]+cb 85[ ]+res 0,l
+[ ]+322:[ ]+cb 8e[ ]+res 1,\(hl\)
+[ ]+324:[ ]+dd cb 09 8e[ ]+res 1,\(ix\+9\)
+[ ]+328:[ ]+fd cb 09 8e[ ]+res 1,\(iy\+9\)
+[ ]+32c:[ ]+cb 8f[ ]+res 1,a
+[ ]+32e:[ ]+cb 88[ ]+res 1,b
+[ ]+330:[ ]+cb 89[ ]+res 1,c
+[ ]+332:[ ]+cb 8a[ ]+res 1,d
+[ ]+334:[ ]+cb 8b[ ]+res 1,e
+[ ]+336:[ ]+cb 8c[ ]+res 1,h
+[ ]+338:[ ]+cb 8d[ ]+res 1,l
+[ ]+33a:[ ]+cb 96[ ]+res 2,\(hl\)
+[ ]+33c:[ ]+dd cb 09 96[ ]+res 2,\(ix\+9\)
+[ ]+340:[ ]+fd cb 09 96[ ]+res 2,\(iy\+9\)
+[ ]+344:[ ]+cb 97[ ]+res 2,a
+[ ]+346:[ ]+cb 90[ ]+res 2,b
+[ ]+348:[ ]+cb 91[ ]+res 2,c
+[ ]+34a:[ ]+cb 92[ ]+res 2,d
+[ ]+34c:[ ]+cb 93[ ]+res 2,e
+[ ]+34e:[ ]+cb 94[ ]+res 2,h
+[ ]+350:[ ]+cb 95[ ]+res 2,l
+[ ]+352:[ ]+cb 9e[ ]+res 3,\(hl\)
+[ ]+354:[ ]+dd cb 09 9e[ ]+res 3,\(ix\+9\)
+[ ]+358:[ ]+fd cb 09 9e[ ]+res 3,\(iy\+9\)
+[ ]+35c:[ ]+cb 9f[ ]+res 3,a
+[ ]+35e:[ ]+cb 98[ ]+res 3,b
+[ ]+360:[ ]+cb 99[ ]+res 3,c
+[ ]+362:[ ]+cb 9a[ ]+res 3,d
+[ ]+364:[ ]+cb 9b[ ]+res 3,e
+[ ]+366:[ ]+cb 9c[ ]+res 3,h
+[ ]+368:[ ]+cb 9d[ ]+res 3,l
+[ ]+36a:[ ]+cb a6[ ]+res 4,\(hl\)
+[ ]+36c:[ ]+dd cb 09 a6[ ]+res 4,\(ix\+9\)
+[ ]+370:[ ]+fd cb 09 a6[ ]+res 4,\(iy\+9\)
+[ ]+374:[ ]+cb a7[ ]+res 4,a
+[ ]+376:[ ]+cb a0[ ]+res 4,b
+[ ]+378:[ ]+cb a1[ ]+res 4,c
+[ ]+37a:[ ]+cb a2[ ]+res 4,d
+[ ]+37c:[ ]+cb a3[ ]+res 4,e
+[ ]+37e:[ ]+cb a4[ ]+res 4,h
+[ ]+380:[ ]+cb a5[ ]+res 4,l
+[ ]+382:[ ]+cb ae[ ]+res 5,\(hl\)
+[ ]+384:[ ]+dd cb 09 ae[ ]+res 5,\(ix\+9\)
+[ ]+388:[ ]+fd cb 09 ae[ ]+res 5,\(iy\+9\)
+[ ]+38c:[ ]+cb af[ ]+res 5,a
+[ ]+38e:[ ]+cb a8[ ]+res 5,b
+[ ]+390:[ ]+cb a9[ ]+res 5,c
+[ ]+392:[ ]+cb aa[ ]+res 5,d
+[ ]+394:[ ]+cb ab[ ]+res 5,e
+[ ]+396:[ ]+cb ac[ ]+res 5,h
+[ ]+398:[ ]+cb ad[ ]+res 5,l
+[ ]+39a:[ ]+cb b6[ ]+res 6,\(hl\)
+[ ]+39c:[ ]+dd cb 09 b6[ ]+res 6,\(ix\+9\)
+[ ]+3a0:[ ]+fd cb 09 b6[ ]+res 6,\(iy\+9\)
+[ ]+3a4:[ ]+cb b7[ ]+res 6,a
+[ ]+3a6:[ ]+cb b0[ ]+res 6,b
+[ ]+3a8:[ ]+cb b1[ ]+res 6,c
+[ ]+3aa:[ ]+cb b2[ ]+res 6,d
+[ ]+3ac:[ ]+cb b3[ ]+res 6,e
+[ ]+3ae:[ ]+cb b4[ ]+res 6,h
+[ ]+3b0:[ ]+cb b5[ ]+res 6,l
+[ ]+3b2:[ ]+cb be[ ]+res 7,\(hl\)
+[ ]+3b4:[ ]+dd cb 09 be[ ]+res 7,\(ix\+9\)
+[ ]+3b8:[ ]+fd cb 09 be[ ]+res 7,\(iy\+9\)
+[ ]+3bc:[ ]+cb bf[ ]+res 7,a
+[ ]+3be:[ ]+cb b8[ ]+res 7,b
+[ ]+3c0:[ ]+cb b9[ ]+res 7,c
+[ ]+3c2:[ ]+cb ba[ ]+res 7,d
+[ ]+3c4:[ ]+cb bb[ ]+res 7,e
+[ ]+3c6:[ ]+cb bc[ ]+res 7,h
+[ ]+3c8:[ ]+cb bd[ ]+res 7,l
+[ ]+3ca:[ ]+c9[ ]+ret
+[ ]+3cb:[ ]+d8[ ]+ret c
+[ ]+3cc:[ ]+f8[ ]+ret m
+[ ]+3cd:[ ]+d0[ ]+ret nc
+[ ]+3ce:[ ]+c0[ ]+ret nz
+[ ]+3cf:[ ]+f0[ ]+ret p
+[ ]+3d0:[ ]+e8[ ]+ret pe
+[ ]+3d1:[ ]+e0[ ]+ret po
+[ ]+3d2:[ ]+c8[ ]+ret z
+[ ]+3d3:[ ]+ed 4d[ ]+reti
+[ ]+3d5:[ ]+ed 45[ ]+retn
+[ ]+3d7:[ ]+cb 16[ ]+rl \(hl\)
+[ ]+3d9:[ ]+dd cb 09 16[ ]+rl \(ix\+9\)
+[ ]+3dd:[ ]+fd cb 09 16[ ]+rl \(iy\+9\)
+[ ]+3e1:[ ]+cb 17[ ]+rl a
+[ ]+3e3:[ ]+cb 10[ ]+rl b
+[ ]+3e5:[ ]+cb 11[ ]+rl c
+[ ]+3e7:[ ]+cb 12[ ]+rl d
+[ ]+3e9:[ ]+cb 13[ ]+rl e
+[ ]+3eb:[ ]+cb 14[ ]+rl h
+[ ]+3ed:[ ]+cb 15[ ]+rl l
+[ ]+3ef:[ ]+17[ ]+rla
+[ ]+3f0:[ ]+cb 06[ ]+rlc \(hl\)
+[ ]+3f2:[ ]+dd cb 09 06[ ]+rlc \(ix\+9\)
+[ ]+3f6:[ ]+fd cb 09 06[ ]+rlc \(iy\+9\)
+[ ]+3fa:[ ]+cb 07[ ]+rlc a
+[ ]+3fc:[ ]+cb 00[ ]+rlc b
+[ ]+3fe:[ ]+cb 01[ ]+rlc c
+[ ]+400:[ ]+cb 02[ ]+rlc d
+[ ]+402:[ ]+cb 03[ ]+rlc e
+[ ]+404:[ ]+cb 04[ ]+rlc h
+[ ]+406:[ ]+cb 05[ ]+rlc l
+[ ]+408:[ ]+07[ ]+rlca
+[ ]+409:[ ]+ed 6f[ ]+rld
+[ ]+40b:[ ]+cb 1e[ ]+rr \(hl\)
+[ ]+40d:[ ]+dd cb 09 1e[ ]+rr \(ix\+9\)
+[ ]+411:[ ]+fd cb 09 1e[ ]+rr \(iy\+9\)
+[ ]+415:[ ]+cb 1f[ ]+rr a
+[ ]+417:[ ]+cb 18[ ]+rr b
+[ ]+419:[ ]+cb 19[ ]+rr c
+[ ]+41b:[ ]+cb 1a[ ]+rr d
+[ ]+41d:[ ]+cb 1b[ ]+rr e
+[ ]+41f:[ ]+cb 1c[ ]+rr h
+[ ]+421:[ ]+cb 1d[ ]+rr l
+[ ]+423:[ ]+1f[ ]+rra
+[ ]+424:[ ]+cb 0e[ ]+rrc \(hl\)
+[ ]+426:[ ]+dd cb 09 0e[ ]+rrc \(ix\+9\)
+[ ]+42a:[ ]+fd cb 09 0e[ ]+rrc \(iy\+9\)
+[ ]+42e:[ ]+cb 0f[ ]+rrc a
+[ ]+430:[ ]+cb 08[ ]+rrc b
+[ ]+432:[ ]+cb 09[ ]+rrc c
+[ ]+434:[ ]+cb 0a[ ]+rrc d
+[ ]+436:[ ]+cb 0b[ ]+rrc e
+[ ]+438:[ ]+cb 0c[ ]+rrc h
+[ ]+43a:[ ]+cb 0d[ ]+rrc l
+[ ]+43c:[ ]+0f[ ]+rrca
+[ ]+43d:[ ]+ed 67[ ]+rrd
+[ ]+43f:[ ]+c7[ ]+rst 0x00
+[ ]+440:[ ]+cf[ ]+rst 0x08
+[ ]+441:[ ]+d7[ ]+rst 0x10
+[ ]+442:[ ]+df[ ]+rst 0x18
+[ ]+443:[ ]+e7[ ]+rst 0x20
+[ ]+444:[ ]+ef[ ]+rst 0x28
+[ ]+445:[ ]+f7[ ]+rst 0x30
+[ ]+446:[ ]+ff[ ]+rst 0x38
+[ ]+447:[ ]+9e[ ]+sbc a,\(hl\)
+[ ]+448:[ ]+dd 9e 09[ ]+sbc a,\(ix\+9\)
+[ ]+44b:[ ]+fd 9e 09[ ]+sbc a,\(iy\+9\)
+[ ]+44e:[ ]+de 03[ ]+sbc a,0x03
+[ ]+450:[ ]+9f[ ]+sbc a,a
+[ ]+451:[ ]+98[ ]+sbc a,b
+[ ]+452:[ ]+99[ ]+sbc a,c
+[ ]+453:[ ]+9a[ ]+sbc a,d
+[ ]+454:[ ]+9b[ ]+sbc a,e
+[ ]+455:[ ]+9c[ ]+sbc a,h
+[ ]+456:[ ]+9d[ ]+sbc a,l
+[ ]+457:[ ]+ed 42[ ]+sbc hl,bc
+[ ]+459:[ ]+ed 52[ ]+sbc hl,de
+[ ]+45b:[ ]+ed 62[ ]+sbc hl,hl
+[ ]+45d:[ ]+ed 72[ ]+sbc hl,sp
+[ ]+45f:[ ]+37[ ]+scf
+[ ]+460:[ ]+cb c6[ ]+set 0,\(hl\)
+[ ]+462:[ ]+dd cb 09 c6[ ]+set 0,\(ix\+9\)
+[ ]+466:[ ]+fd cb 09 c6[ ]+set 0,\(iy\+9\)
+[ ]+46a:[ ]+cb c7[ ]+set 0,a
+[ ]+46c:[ ]+cb c0[ ]+set 0,b
+[ ]+46e:[ ]+cb c1[ ]+set 0,c
+[ ]+470:[ ]+cb c2[ ]+set 0,d
+[ ]+472:[ ]+cb c3[ ]+set 0,e
+[ ]+474:[ ]+cb c4[ ]+set 0,h
+[ ]+476:[ ]+cb c5[ ]+set 0,l
+[ ]+478:[ ]+cb ce[ ]+set 1,\(hl\)
+[ ]+47a:[ ]+dd cb 09 ce[ ]+set 1,\(ix\+9\)
+[ ]+47e:[ ]+fd cb 09 ce[ ]+set 1,\(iy\+9\)
+[ ]+482:[ ]+cb cf[ ]+set 1,a
+[ ]+484:[ ]+cb c8[ ]+set 1,b
+[ ]+486:[ ]+cb c9[ ]+set 1,c
+[ ]+488:[ ]+cb ca[ ]+set 1,d
+[ ]+48a:[ ]+cb cb[ ]+set 1,e
+[ ]+48c:[ ]+cb cc[ ]+set 1,h
+[ ]+48e:[ ]+cb cd[ ]+set 1,l
+[ ]+490:[ ]+cb d6[ ]+set 2,\(hl\)
+[ ]+492:[ ]+dd cb 09 d6[ ]+set 2,\(ix\+9\)
+[ ]+496:[ ]+fd cb 09 d6[ ]+set 2,\(iy\+9\)
+[ ]+49a:[ ]+cb d7[ ]+set 2,a
+[ ]+49c:[ ]+cb d0[ ]+set 2,b
+[ ]+49e:[ ]+cb d1[ ]+set 2,c
+[ ]+4a0:[ ]+cb d2[ ]+set 2,d
+[ ]+4a2:[ ]+cb d3[ ]+set 2,e
+[ ]+4a4:[ ]+cb d4[ ]+set 2,h
+[ ]+4a6:[ ]+cb d5[ ]+set 2,l
+[ ]+4a8:[ ]+cb de[ ]+set 3,\(hl\)
+[ ]+4aa:[ ]+dd cb 09 de[ ]+set 3,\(ix\+9\)
+[ ]+4ae:[ ]+fd cb 09 de[ ]+set 3,\(iy\+9\)
+[ ]+4b2:[ ]+cb df[ ]+set 3,a
+[ ]+4b4:[ ]+cb d8[ ]+set 3,b
+[ ]+4b6:[ ]+cb d9[ ]+set 3,c
+[ ]+4b8:[ ]+cb da[ ]+set 3,d
+[ ]+4ba:[ ]+cb db[ ]+set 3,e
+[ ]+4bc:[ ]+cb dc[ ]+set 3,h
+[ ]+4be:[ ]+cb dd[ ]+set 3,l
+[ ]+4c0:[ ]+cb e6[ ]+set 4,\(hl\)
+[ ]+4c2:[ ]+dd cb 09 e6[ ]+set 4,\(ix\+9\)
+[ ]+4c6:[ ]+fd cb 09 e6[ ]+set 4,\(iy\+9\)
+[ ]+4ca:[ ]+cb e7[ ]+set 4,a
+[ ]+4cc:[ ]+cb e0[ ]+set 4,b
+[ ]+4ce:[ ]+cb e1[ ]+set 4,c
+[ ]+4d0:[ ]+cb e2[ ]+set 4,d
+[ ]+4d2:[ ]+cb e3[ ]+set 4,e
+[ ]+4d4:[ ]+cb e4[ ]+set 4,h
+[ ]+4d6:[ ]+cb e5[ ]+set 4,l
+[ ]+4d8:[ ]+cb ee[ ]+set 5,\(hl\)
+[ ]+4da:[ ]+dd cb 09 ee[ ]+set 5,\(ix\+9\)
+[ ]+4de:[ ]+fd cb 09 ee[ ]+set 5,\(iy\+9\)
+[ ]+4e2:[ ]+cb ef[ ]+set 5,a
+[ ]+4e4:[ ]+cb e8[ ]+set 5,b
+[ ]+4e6:[ ]+cb e9[ ]+set 5,c
+[ ]+4e8:[ ]+cb ea[ ]+set 5,d
+[ ]+4ea:[ ]+cb eb[ ]+set 5,e
+[ ]+4ec:[ ]+cb ec[ ]+set 5,h
+[ ]+4ee:[ ]+cb ed[ ]+set 5,l
+[ ]+4f0:[ ]+cb f6[ ]+set 6,\(hl\)
+[ ]+4f2:[ ]+dd cb 09 f6[ ]+set 6,\(ix\+9\)
+[ ]+4f6:[ ]+fd cb 09 f6[ ]+set 6,\(iy\+9\)
+[ ]+4fa:[ ]+cb f7[ ]+set 6,a
+[ ]+4fc:[ ]+cb f0[ ]+set 6,b
+[ ]+4fe:[ ]+cb f1[ ]+set 6,c
+[ ]+500:[ ]+cb f2[ ]+set 6,d
+[ ]+502:[ ]+cb f3[ ]+set 6,e
+[ ]+504:[ ]+cb f4[ ]+set 6,h
+[ ]+506:[ ]+cb f5[ ]+set 6,l
+[ ]+508:[ ]+cb fe[ ]+set 7,\(hl\)
+[ ]+50a:[ ]+dd cb 09 fe[ ]+set 7,\(ix\+9\)
+[ ]+50e:[ ]+fd cb 09 fe[ ]+set 7,\(iy\+9\)
+[ ]+512:[ ]+cb ff[ ]+set 7,a
+[ ]+514:[ ]+cb f8[ ]+set 7,b
+[ ]+516:[ ]+cb f9[ ]+set 7,c
+[ ]+518:[ ]+cb fa[ ]+set 7,d
+[ ]+51a:[ ]+cb fb[ ]+set 7,e
+[ ]+51c:[ ]+cb fc[ ]+set 7,h
+[ ]+51e:[ ]+cb fd[ ]+set 7,l
+[ ]+520:[ ]+cb 26[ ]+sla \(hl\)
+[ ]+522:[ ]+dd cb 09 26[ ]+sla \(ix\+9\)
+[ ]+526:[ ]+fd cb 09 26[ ]+sla \(iy\+9\)
+[ ]+52a:[ ]+cb 27[ ]+sla a
+[ ]+52c:[ ]+cb 20[ ]+sla b
+[ ]+52e:[ ]+cb 21[ ]+sla c
+[ ]+530:[ ]+cb 22[ ]+sla d
+[ ]+532:[ ]+cb 23[ ]+sla e
+[ ]+534:[ ]+cb 24[ ]+sla h
+[ ]+536:[ ]+cb 25[ ]+sla l
+[ ]+538:[ ]+cb 2e[ ]+sra \(hl\)
+[ ]+53a:[ ]+dd cb 09 2e[ ]+sra \(ix\+9\)
+[ ]+53e:[ ]+fd cb 09 2e[ ]+sra \(iy\+9\)
+[ ]+542:[ ]+cb 2f[ ]+sra a
+[ ]+544:[ ]+cb 28[ ]+sra b
+[ ]+546:[ ]+cb 29[ ]+sra c
+[ ]+548:[ ]+cb 2a[ ]+sra d
+[ ]+54a:[ ]+cb 2b[ ]+sra e
+[ ]+54c:[ ]+cb 2c[ ]+sra h
+[ ]+54e:[ ]+cb 2d[ ]+sra l
+[ ]+550:[ ]+cb 3e[ ]+srl \(hl\)
+[ ]+552:[ ]+dd cb 09 3e[ ]+srl \(ix\+9\)
+[ ]+556:[ ]+fd cb 09 3e[ ]+srl \(iy\+9\)
+[ ]+55a:[ ]+cb 3f[ ]+srl a
+[ ]+55c:[ ]+cb 38[ ]+srl b
+[ ]+55e:[ ]+cb 39[ ]+srl c
+[ ]+560:[ ]+cb 3a[ ]+srl d
+[ ]+562:[ ]+cb 3b[ ]+srl e
+[ ]+564:[ ]+cb 3c[ ]+srl h
+[ ]+566:[ ]+cb 3d[ ]+srl l
+[ ]+568:[ ]+96[ ]+sub \(hl\)
+[ ]+569:[ ]+dd 96 09[ ]+sub \(ix\+9\)
+[ ]+56c:[ ]+fd 96 09[ ]+sub \(iy\+9\)
+[ ]+56f:[ ]+d6 03[ ]+sub 0x03
+[ ]+571:[ ]+97[ ]+sub a
+[ ]+572:[ ]+90[ ]+sub b
+[ ]+573:[ ]+91[ ]+sub c
+[ ]+574:[ ]+92[ ]+sub d
+[ ]+575:[ ]+93[ ]+sub e
+[ ]+576:[ ]+94[ ]+sub h
+[ ]+577:[ ]+95[ ]+sub l
+[ ]+578:[ ]+ae[ ]+xor \(hl\)
+[ ]+579:[ ]+dd ae 09[ ]+xor \(ix\+9\)
+[ ]+57c:[ ]+fd ae 09[ ]+xor \(iy\+9\)
+[ ]+57f:[ ]+ee 03[ ]+xor 0x03
+[ ]+581:[ ]+af[ ]+xor a
+[ ]+582:[ ]+a8[ ]+xor b
+[ ]+583:[ ]+a9[ ]+xor c
+[ ]+584:[ ]+aa[ ]+xor d
+[ ]+585:[ ]+ab[ ]+xor e
+[ ]+586:[ ]+ac[ ]+xor h
+[ ]+587:[ ]+ad[ ]+xor l
+[ ]+588:[ ]+dd 7c[ ]+ld a,ixh
+[ ]+58a:[ ]+dd 44[ ]+ld b,ixh
+[ ]+58c:[ ]+dd 4c[ ]+ld c,ixh
+[ ]+58e:[ ]+dd 54[ ]+ld d,ixh
+[ ]+590:[ ]+dd 5c[ ]+ld e,ixh
+[ ]+592:[ ]+dd 64[ ]+ld ixh,ixh
+[ ]+594:[ ]+dd 6c[ ]+ld ixl,ixh
+[ ]+596:[ ]+dd 7d[ ]+ld a,ixl
+[ ]+598:[ ]+dd 45[ ]+ld b,ixl
+[ ]+59a:[ ]+dd 4d[ ]+ld c,ixl
+[ ]+59c:[ ]+dd 55[ ]+ld d,ixl
+[ ]+59e:[ ]+dd 5d[ ]+ld e,ixl
+[ ]+5a0:[ ]+dd 65[ ]+ld ixh,ixl
+[ ]+5a2:[ ]+dd 6d[ ]+ld ixl,ixl
+[ ]+5a4:[ ]+fd 7c[ ]+ld a,iyh
+[ ]+5a6:[ ]+fd 44[ ]+ld b,iyh
+[ ]+5a8:[ ]+fd 4c[ ]+ld c,iyh
+[ ]+5aa:[ ]+fd 54[ ]+ld d,iyh
+[ ]+5ac:[ ]+fd 5c[ ]+ld e,iyh
+[ ]+5ae:[ ]+fd 64[ ]+ld iyh,iyh
+[ ]+5b0:[ ]+fd 6c[ ]+ld iyl,iyh
+[ ]+5b2:[ ]+fd 7d[ ]+ld a,iyl
+[ ]+5b4:[ ]+fd 45[ ]+ld b,iyl
+[ ]+5b6:[ ]+fd 4d[ ]+ld c,iyl
+[ ]+5b8:[ ]+fd 55[ ]+ld d,iyl
+[ ]+5ba:[ ]+fd 5d[ ]+ld e,iyl
+[ ]+5bc:[ ]+fd 65[ ]+ld iyh,iyl
+[ ]+5be:[ ]+fd 6d[ ]+ld iyl,iyl
+[ ]+5c0:[ ]+dd 67[ ]+ld ixh,a
+[ ]+5c2:[ ]+dd 60[ ]+ld ixh,b
+[ ]+5c4:[ ]+dd 61[ ]+ld ixh,c
+[ ]+5c6:[ ]+dd 62[ ]+ld ixh,d
+[ ]+5c8:[ ]+dd 63[ ]+ld ixh,e
+[ ]+5ca:[ ]+dd 64[ ]+ld ixh,ixh
+[ ]+5cc:[ ]+dd 65[ ]+ld ixh,ixl
+[ ]+5ce:[ ]+dd 26 19[ ]+ld ixh,0x19
+[ ]+5d1:[ ]+dd 6f[ ]+ld ixl,a
+[ ]+5d3:[ ]+dd 68[ ]+ld ixl,b
+[ ]+5d5:[ ]+dd 69[ ]+ld ixl,c
+[ ]+5d7:[ ]+dd 6a[ ]+ld ixl,d
+[ ]+5d9:[ ]+dd 6b[ ]+ld ixl,e
+[ ]+5db:[ ]+dd 6c[ ]+ld ixl,ixh
+[ ]+5dd:[ ]+dd 6d[ ]+ld ixl,ixl
+[ ]+5df:[ ]+dd 2e 19[ ]+ld ixl,0x19
+[ ]+5e2:[ ]+fd 67[ ]+ld iyh,a
+[ ]+5e4:[ ]+fd 60[ ]+ld iyh,b
+[ ]+5e6:[ ]+fd 61[ ]+ld iyh,c
+[ ]+5e8:[ ]+fd 62[ ]+ld iyh,d
+[ ]+5ea:[ ]+fd 63[ ]+ld iyh,e
+[ ]+5ec:[ ]+fd 64[ ]+ld iyh,iyh
+[ ]+5ee:[ ]+fd 65[ ]+ld iyh,iyl
+[ ]+5f0:[ ]+fd 26 19[ ]+ld iyh,0x19
+[ ]+5f3:[ ]+fd 6f[ ]+ld iyl,a
+[ ]+5f5:[ ]+fd 68[ ]+ld iyl,b
+[ ]+5f7:[ ]+fd 69[ ]+ld iyl,c
+[ ]+5f9:[ ]+fd 6a[ ]+ld iyl,d
+[ ]+5fb:[ ]+fd 6b[ ]+ld iyl,e
+[ ]+5fd:[ ]+fd 6c[ ]+ld iyl,iyh
+[ ]+5ff:[ ]+fd 6d[ ]+ld iyl,iyl
+[ ]+601:[ ]+fd 2e 19[ ]+ld iyl,0x19
+[ ]+604:[ ]+dd 84[ ]+add a,ixh
+[ ]+606:[ ]+dd 85[ ]+add a,ixl
+[ ]+608:[ ]+fd 84[ ]+add a,iyh
+[ ]+60a:[ ]+fd 85[ ]+add a,iyl
+[ ]+60c:[ ]+dd 8c[ ]+adc a,ixh
+[ ]+60e:[ ]+dd 8d[ ]+adc a,ixl
+[ ]+610:[ ]+fd 8c[ ]+adc a,iyh
+[ ]+612:[ ]+fd 8d[ ]+adc a,iyl
+[ ]+614:[ ]+dd bc[ ]+cp ixh
+[ ]+616:[ ]+dd bd[ ]+cp ixl
+[ ]+618:[ ]+fd bc[ ]+cp iyh
+[ ]+61a:[ ]+fd bd[ ]+cp iyl
+[ ]+61c:[ ]+dd 25[ ]+dec ixh
+[ ]+61e:[ ]+dd 2d[ ]+dec ixl
+[ ]+620:[ ]+fd 25[ ]+dec iyh
+[ ]+622:[ ]+fd 2d[ ]+dec iyl
+[ ]+624:[ ]+dd 24[ ]+inc ixh
+[ ]+626:[ ]+dd 2c[ ]+inc ixl
+[ ]+628:[ ]+fd 24[ ]+inc iyh
+[ ]+62a:[ ]+fd 2c[ ]+inc iyl
+[ ]+62c:[ ]+dd 9c[ ]+sbc a,ixh
+[ ]+62e:[ ]+dd 9d[ ]+sbc a,ixl
+[ ]+630:[ ]+fd 9c[ ]+sbc a,iyh
+[ ]+632:[ ]+fd 9d[ ]+sbc a,iyl
+[ ]+634:[ ]+dd 94[ ]+sub ixh
+[ ]+636:[ ]+dd 95[ ]+sub ixl
+[ ]+638:[ ]+fd 94[ ]+sub iyh
+[ ]+63a:[ ]+fd 95[ ]+sub iyl
+[ ]+63c:[ ]+dd a4[ ]+and ixh
+[ ]+63e:[ ]+dd a5[ ]+and ixl
+[ ]+640:[ ]+fd a4[ ]+and iyh
+[ ]+642:[ ]+fd a5[ ]+and iyl
+[ ]+644:[ ]+dd b4[ ]+or ixh
+[ ]+646:[ ]+dd b5[ ]+or ixl
+[ ]+648:[ ]+fd b4[ ]+or iyh
+[ ]+64a:[ ]+fd b5[ ]+or iyl
+[ ]+64c:[ ]+dd ac[ ]+xor ixh
+[ ]+64e:[ ]+dd ad[ ]+xor ixl
+[ ]+650:[ ]+fd ac[ ]+xor iyh
+[ ]+652:[ ]+fd ad[ ]+xor iyl
+[ ]+654:[ ]+ed 70[ ]+in f,\(c\)
+[ ]+656:[ ]+ed 70[ ]+in f,\(c\)
+[ ]+658:[ ]+ed 71[ ]+out \(c\),0
+[ ]+65a:[ ]+dd cb 08 07[ ]+rlc \(ix\+8\),a
+[ ]+65e:[ ]+dd cb 08 00[ ]+rlc \(ix\+8\),b
+[ ]+662:[ ]+dd cb 08 01[ ]+rlc \(ix\+8\),c
+[ ]+666:[ ]+dd cb 08 02[ ]+rlc \(ix\+8\),d
+[ ]+66a:[ ]+dd cb 08 03[ ]+rlc \(ix\+8\),e
+[ ]+66e:[ ]+dd cb 08 04[ ]+rlc \(ix\+8\),h
+[ ]+672:[ ]+dd cb 08 05[ ]+rlc \(ix\+8\),l
+[ ]+676:[ ]+fd cb 08 07[ ]+rlc \(iy\+8\),a
+[ ]+67a:[ ]+fd cb 08 00[ ]+rlc \(iy\+8\),b
+[ ]+67e:[ ]+fd cb 08 01[ ]+rlc \(iy\+8\),c
+[ ]+682:[ ]+fd cb 08 02[ ]+rlc \(iy\+8\),d
+[ ]+686:[ ]+fd cb 08 03[ ]+rlc \(iy\+8\),e
+[ ]+68a:[ ]+fd cb 08 04[ ]+rlc \(iy\+8\),h
+[ ]+68e:[ ]+fd cb 08 05[ ]+rlc \(iy\+8\),l
+[ ]+692:[ ]+dd cb 08 0f[ ]+rrc \(ix\+8\),a
+[ ]+696:[ ]+dd cb 08 08[ ]+rrc \(ix\+8\),b
+[ ]+69a:[ ]+dd cb 08 09[ ]+rrc \(ix\+8\),c
+[ ]+69e:[ ]+dd cb 08 0a[ ]+rrc \(ix\+8\),d
+[ ]+6a2:[ ]+dd cb 08 0b[ ]+rrc \(ix\+8\),e
+[ ]+6a6:[ ]+dd cb 08 0c[ ]+rrc \(ix\+8\),h
+[ ]+6aa:[ ]+dd cb 08 0d[ ]+rrc \(ix\+8\),l
+[ ]+6ae:[ ]+fd cb 08 0f[ ]+rrc \(iy\+8\),a
+[ ]+6b2:[ ]+fd cb 08 08[ ]+rrc \(iy\+8\),b
+[ ]+6b6:[ ]+fd cb 08 09[ ]+rrc \(iy\+8\),c
+[ ]+6ba:[ ]+fd cb 08 0a[ ]+rrc \(iy\+8\),d
+[ ]+6be:[ ]+fd cb 08 0b[ ]+rrc \(iy\+8\),e
+[ ]+6c2:[ ]+fd cb 08 0c[ ]+rrc \(iy\+8\),h
+[ ]+6c6:[ ]+fd cb 08 0d[ ]+rrc \(iy\+8\),l
+[ ]+6ca:[ ]+dd cb 08 17[ ]+rl \(ix\+8\),a
+[ ]+6ce:[ ]+dd cb 08 10[ ]+rl \(ix\+8\),b
+[ ]+6d2:[ ]+dd cb 08 11[ ]+rl \(ix\+8\),c
+[ ]+6d6:[ ]+dd cb 08 12[ ]+rl \(ix\+8\),d
+[ ]+6da:[ ]+dd cb 08 13[ ]+rl \(ix\+8\),e
+[ ]+6de:[ ]+dd cb 08 14[ ]+rl \(ix\+8\),h
+[ ]+6e2:[ ]+dd cb 08 15[ ]+rl \(ix\+8\),l
+[ ]+6e6:[ ]+fd cb 08 17[ ]+rl \(iy\+8\),a
+[ ]+6ea:[ ]+fd cb 08 10[ ]+rl \(iy\+8\),b
+[ ]+6ee:[ ]+fd cb 08 11[ ]+rl \(iy\+8\),c
+[ ]+6f2:[ ]+fd cb 08 12[ ]+rl \(iy\+8\),d
+[ ]+6f6:[ ]+fd cb 08 13[ ]+rl \(iy\+8\),e
+[ ]+6fa:[ ]+fd cb 08 14[ ]+rl \(iy\+8\),h
+[ ]+6fe:[ ]+fd cb 08 15[ ]+rl \(iy\+8\),l
+[ ]+702:[ ]+dd cb 08 1f[ ]+rr \(ix\+8\),a
+[ ]+706:[ ]+dd cb 08 18[ ]+rr \(ix\+8\),b
+[ ]+70a:[ ]+dd cb 08 19[ ]+rr \(ix\+8\),c
+[ ]+70e:[ ]+dd cb 08 1a[ ]+rr \(ix\+8\),d
+[ ]+712:[ ]+dd cb 08 1b[ ]+rr \(ix\+8\),e
+[ ]+716:[ ]+dd cb 08 1c[ ]+rr \(ix\+8\),h
+[ ]+71a:[ ]+dd cb 08 1d[ ]+rr \(ix\+8\),l
+[ ]+71e:[ ]+fd cb 08 1f[ ]+rr \(iy\+8\),a
+[ ]+722:[ ]+fd cb 08 18[ ]+rr \(iy\+8\),b
+[ ]+726:[ ]+fd cb 08 19[ ]+rr \(iy\+8\),c
+[ ]+72a:[ ]+fd cb 08 1a[ ]+rr \(iy\+8\),d
+[ ]+72e:[ ]+fd cb 08 1b[ ]+rr \(iy\+8\),e
+[ ]+732:[ ]+fd cb 08 1c[ ]+rr \(iy\+8\),h
+[ ]+736:[ ]+fd cb 08 1d[ ]+rr \(iy\+8\),l
+[ ]+73a:[ ]+dd cb 08 27[ ]+sla \(ix\+8\),a
+[ ]+73e:[ ]+dd cb 08 20[ ]+sla \(ix\+8\),b
+[ ]+742:[ ]+dd cb 08 21[ ]+sla \(ix\+8\),c
+[ ]+746:[ ]+dd cb 08 22[ ]+sla \(ix\+8\),d
+[ ]+74a:[ ]+dd cb 08 23[ ]+sla \(ix\+8\),e
+[ ]+74e:[ ]+dd cb 08 24[ ]+sla \(ix\+8\),h
+[ ]+752:[ ]+dd cb 08 25[ ]+sla \(ix\+8\),l
+[ ]+756:[ ]+fd cb 08 27[ ]+sla \(iy\+8\),a
+[ ]+75a:[ ]+fd cb 08 20[ ]+sla \(iy\+8\),b
+[ ]+75e:[ ]+fd cb 08 21[ ]+sla \(iy\+8\),c
+[ ]+762:[ ]+fd cb 08 22[ ]+sla \(iy\+8\),d
+[ ]+766:[ ]+fd cb 08 23[ ]+sla \(iy\+8\),e
+[ ]+76a:[ ]+fd cb 08 24[ ]+sla \(iy\+8\),h
+[ ]+76e:[ ]+fd cb 08 25[ ]+sla \(iy\+8\),l
+[ ]+772:[ ]+dd cb 08 2f[ ]+sra \(ix\+8\),a
+[ ]+776:[ ]+dd cb 08 28[ ]+sra \(ix\+8\),b
+[ ]+77a:[ ]+dd cb 08 29[ ]+sra \(ix\+8\),c
+[ ]+77e:[ ]+dd cb 08 2a[ ]+sra \(ix\+8\),d
+[ ]+782:[ ]+dd cb 08 2b[ ]+sra \(ix\+8\),e
+[ ]+786:[ ]+dd cb 08 2c[ ]+sra \(ix\+8\),h
+[ ]+78a:[ ]+dd cb 08 2d[ ]+sra \(ix\+8\),l
+[ ]+78e:[ ]+fd cb 08 2f[ ]+sra \(iy\+8\),a
+[ ]+792:[ ]+fd cb 08 28[ ]+sra \(iy\+8\),b
+[ ]+796:[ ]+fd cb 08 29[ ]+sra \(iy\+8\),c
+[ ]+79a:[ ]+fd cb 08 2a[ ]+sra \(iy\+8\),d
+[ ]+79e:[ ]+fd cb 08 2b[ ]+sra \(iy\+8\),e
+[ ]+7a2:[ ]+fd cb 08 2c[ ]+sra \(iy\+8\),h
+[ ]+7a6:[ ]+fd cb 08 2d[ ]+sra \(iy\+8\),l
+[ ]+7aa:[ ]+dd cb 08 37[ ]+sli \(ix\+8\),a
+[ ]+7ae:[ ]+dd cb 08 30[ ]+sli \(ix\+8\),b
+[ ]+7b2:[ ]+dd cb 08 31[ ]+sli \(ix\+8\),c
+[ ]+7b6:[ ]+dd cb 08 32[ ]+sli \(ix\+8\),d
+[ ]+7ba:[ ]+dd cb 08 33[ ]+sli \(ix\+8\),e
+[ ]+7be:[ ]+dd cb 08 34[ ]+sli \(ix\+8\),h
+[ ]+7c2:[ ]+dd cb 08 35[ ]+sli \(ix\+8\),l
+[ ]+7c6:[ ]+fd cb 08 37[ ]+sli \(iy\+8\),a
+[ ]+7ca:[ ]+fd cb 08 30[ ]+sli \(iy\+8\),b
+[ ]+7ce:[ ]+fd cb 08 31[ ]+sli \(iy\+8\),c
+[ ]+7d2:[ ]+fd cb 08 32[ ]+sli \(iy\+8\),d
+[ ]+7d6:[ ]+fd cb 08 33[ ]+sli \(iy\+8\),e
+[ ]+7da:[ ]+fd cb 08 34[ ]+sli \(iy\+8\),h
+[ ]+7de:[ ]+fd cb 08 35[ ]+sli \(iy\+8\),l
+[ ]+7e2:[ ]+dd cb 08 3f[ ]+srl \(ix\+8\),a
+[ ]+7e6:[ ]+dd cb 08 38[ ]+srl \(ix\+8\),b
+[ ]+7ea:[ ]+dd cb 08 39[ ]+srl \(ix\+8\),c
+[ ]+7ee:[ ]+dd cb 08 3a[ ]+srl \(ix\+8\),d
+[ ]+7f2:[ ]+dd cb 08 3b[ ]+srl \(ix\+8\),e
+[ ]+7f6:[ ]+dd cb 08 3c[ ]+srl \(ix\+8\),h
+[ ]+7fa:[ ]+dd cb 08 3d[ ]+srl \(ix\+8\),l
+[ ]+7fe:[ ]+fd cb 08 3f[ ]+srl \(iy\+8\),a
+[ ]+802:[ ]+fd cb 08 38[ ]+srl \(iy\+8\),b
+[ ]+806:[ ]+fd cb 08 39[ ]+srl \(iy\+8\),c
+[ ]+80a:[ ]+fd cb 08 3a[ ]+srl \(iy\+8\),d
+[ ]+80e:[ ]+fd cb 08 3b[ ]+srl \(iy\+8\),e
+[ ]+812:[ ]+fd cb 08 3c[ ]+srl \(iy\+8\),h
+[ ]+816:[ ]+fd cb 08 3d[ ]+srl \(iy\+8\),l
+[ ]+81a:[ ]+dd cb 08 87[ ]+res 0,\(ix\+8\),a
+[ ]+81e:[ ]+dd cb 08 80[ ]+res 0,\(ix\+8\),b
+[ ]+822:[ ]+dd cb 08 81[ ]+res 0,\(ix\+8\),c
+[ ]+826:[ ]+dd cb 08 82[ ]+res 0,\(ix\+8\),d
+[ ]+82a:[ ]+dd cb 08 83[ ]+res 0,\(ix\+8\),e
+[ ]+82e:[ ]+dd cb 08 84[ ]+res 0,\(ix\+8\),h
+[ ]+832:[ ]+dd cb 08 85[ ]+res 0,\(ix\+8\),l
+[ ]+836:[ ]+fd cb 08 87[ ]+res 0,\(iy\+8\),a
+[ ]+83a:[ ]+fd cb 08 80[ ]+res 0,\(iy\+8\),b
+[ ]+83e:[ ]+fd cb 08 81[ ]+res 0,\(iy\+8\),c
+[ ]+842:[ ]+fd cb 08 82[ ]+res 0,\(iy\+8\),d
+[ ]+846:[ ]+fd cb 08 83[ ]+res 0,\(iy\+8\),e
+[ ]+84a:[ ]+fd cb 08 84[ ]+res 0,\(iy\+8\),h
+[ ]+84e:[ ]+fd cb 08 85[ ]+res 0,\(iy\+8\),l
+[ ]+852:[ ]+dd cb 08 8f[ ]+res 1,\(ix\+8\),a
+[ ]+856:[ ]+dd cb 08 88[ ]+res 1,\(ix\+8\),b
+[ ]+85a:[ ]+dd cb 08 89[ ]+res 1,\(ix\+8\),c
+[ ]+85e:[ ]+dd cb 08 8a[ ]+res 1,\(ix\+8\),d
+[ ]+862:[ ]+dd cb 08 8b[ ]+res 1,\(ix\+8\),e
+[ ]+866:[ ]+dd cb 08 8c[ ]+res 1,\(ix\+8\),h
+[ ]+86a:[ ]+dd cb 08 8d[ ]+res 1,\(ix\+8\),l
+[ ]+86e:[ ]+fd cb 08 8f[ ]+res 1,\(iy\+8\),a
+[ ]+872:[ ]+fd cb 08 88[ ]+res 1,\(iy\+8\),b
+[ ]+876:[ ]+fd cb 08 89[ ]+res 1,\(iy\+8\),c
+[ ]+87a:[ ]+fd cb 08 8a[ ]+res 1,\(iy\+8\),d
+[ ]+87e:[ ]+fd cb 08 8b[ ]+res 1,\(iy\+8\),e
+[ ]+882:[ ]+fd cb 08 8c[ ]+res 1,\(iy\+8\),h
+[ ]+886:[ ]+fd cb 08 8d[ ]+res 1,\(iy\+8\),l
+[ ]+88a:[ ]+dd cb 08 97[ ]+res 2,\(ix\+8\),a
+[ ]+88e:[ ]+dd cb 08 90[ ]+res 2,\(ix\+8\),b
+[ ]+892:[ ]+dd cb 08 91[ ]+res 2,\(ix\+8\),c
+[ ]+896:[ ]+dd cb 08 92[ ]+res 2,\(ix\+8\),d
+[ ]+89a:[ ]+dd cb 08 93[ ]+res 2,\(ix\+8\),e
+[ ]+89e:[ ]+dd cb 08 94[ ]+res 2,\(ix\+8\),h
+[ ]+8a2:[ ]+dd cb 08 95[ ]+res 2,\(ix\+8\),l
+[ ]+8a6:[ ]+fd cb 08 97[ ]+res 2,\(iy\+8\),a
+[ ]+8aa:[ ]+fd cb 08 90[ ]+res 2,\(iy\+8\),b
+[ ]+8ae:[ ]+fd cb 08 91[ ]+res 2,\(iy\+8\),c
+[ ]+8b2:[ ]+fd cb 08 92[ ]+res 2,\(iy\+8\),d
+[ ]+8b6:[ ]+fd cb 08 93[ ]+res 2,\(iy\+8\),e
+[ ]+8ba:[ ]+fd cb 08 94[ ]+res 2,\(iy\+8\),h
+[ ]+8be:[ ]+fd cb 08 95[ ]+res 2,\(iy\+8\),l
+[ ]+8c2:[ ]+dd cb 08 9f[ ]+res 3,\(ix\+8\),a
+[ ]+8c6:[ ]+dd cb 08 98[ ]+res 3,\(ix\+8\),b
+[ ]+8ca:[ ]+dd cb 08 99[ ]+res 3,\(ix\+8\),c
+[ ]+8ce:[ ]+dd cb 08 9a[ ]+res 3,\(ix\+8\),d
+[ ]+8d2:[ ]+dd cb 08 9b[ ]+res 3,\(ix\+8\),e
+[ ]+8d6:[ ]+dd cb 08 9c[ ]+res 3,\(ix\+8\),h
+[ ]+8da:[ ]+dd cb 08 9d[ ]+res 3,\(ix\+8\),l
+[ ]+8de:[ ]+fd cb 08 9f[ ]+res 3,\(iy\+8\),a
+[ ]+8e2:[ ]+fd cb 08 98[ ]+res 3,\(iy\+8\),b
+[ ]+8e6:[ ]+fd cb 08 99[ ]+res 3,\(iy\+8\),c
+[ ]+8ea:[ ]+fd cb 08 9a[ ]+res 3,\(iy\+8\),d
+[ ]+8ee:[ ]+fd cb 08 9b[ ]+res 3,\(iy\+8\),e
+[ ]+8f2:[ ]+fd cb 08 9c[ ]+res 3,\(iy\+8\),h
+[ ]+8f6:[ ]+fd cb 08 9d[ ]+res 3,\(iy\+8\),l
+[ ]+8fa:[ ]+dd cb 08 a7[ ]+res 4,\(ix\+8\),a
+[ ]+8fe:[ ]+dd cb 08 a0[ ]+res 4,\(ix\+8\),b
+[ ]+902:[ ]+dd cb 08 a1[ ]+res 4,\(ix\+8\),c
+[ ]+906:[ ]+dd cb 08 a2[ ]+res 4,\(ix\+8\),d
+[ ]+90a:[ ]+dd cb 08 a3[ ]+res 4,\(ix\+8\),e
+[ ]+90e:[ ]+dd cb 08 a4[ ]+res 4,\(ix\+8\),h
+[ ]+912:[ ]+dd cb 08 a5[ ]+res 4,\(ix\+8\),l
+[ ]+916:[ ]+fd cb 08 a7[ ]+res 4,\(iy\+8\),a
+[ ]+91a:[ ]+fd cb 08 a0[ ]+res 4,\(iy\+8\),b
+[ ]+91e:[ ]+fd cb 08 a1[ ]+res 4,\(iy\+8\),c
+[ ]+922:[ ]+fd cb 08 a2[ ]+res 4,\(iy\+8\),d
+[ ]+926:[ ]+fd cb 08 a3[ ]+res 4,\(iy\+8\),e
+[ ]+92a:[ ]+fd cb 08 a4[ ]+res 4,\(iy\+8\),h
+[ ]+92e:[ ]+fd cb 08 a5[ ]+res 4,\(iy\+8\),l
+[ ]+932:[ ]+dd cb 08 af[ ]+res 5,\(ix\+8\),a
+[ ]+936:[ ]+dd cb 08 a8[ ]+res 5,\(ix\+8\),b
+[ ]+93a:[ ]+dd cb 08 a9[ ]+res 5,\(ix\+8\),c
+[ ]+93e:[ ]+dd cb 08 aa[ ]+res 5,\(ix\+8\),d
+[ ]+942:[ ]+dd cb 08 ab[ ]+res 5,\(ix\+8\),e
+[ ]+946:[ ]+dd cb 08 ac[ ]+res 5,\(ix\+8\),h
+[ ]+94a:[ ]+dd cb 08 ad[ ]+res 5,\(ix\+8\),l
+[ ]+94e:[ ]+fd cb 08 af[ ]+res 5,\(iy\+8\),a
+[ ]+952:[ ]+fd cb 08 a8[ ]+res 5,\(iy\+8\),b
+[ ]+956:[ ]+fd cb 08 a9[ ]+res 5,\(iy\+8\),c
+[ ]+95a:[ ]+fd cb 08 aa[ ]+res 5,\(iy\+8\),d
+[ ]+95e:[ ]+fd cb 08 ab[ ]+res 5,\(iy\+8\),e
+[ ]+962:[ ]+fd cb 08 ac[ ]+res 5,\(iy\+8\),h
+[ ]+966:[ ]+fd cb 08 ad[ ]+res 5,\(iy\+8\),l
+[ ]+96a:[ ]+dd cb 08 b7[ ]+res 6,\(ix\+8\),a
+[ ]+96e:[ ]+dd cb 08 b0[ ]+res 6,\(ix\+8\),b
+[ ]+972:[ ]+dd cb 08 b1[ ]+res 6,\(ix\+8\),c
+[ ]+976:[ ]+dd cb 08 b2[ ]+res 6,\(ix\+8\),d
+[ ]+97a:[ ]+dd cb 08 b3[ ]+res 6,\(ix\+8\),e
+[ ]+97e:[ ]+dd cb 08 b4[ ]+res 6,\(ix\+8\),h
+[ ]+982:[ ]+dd cb 08 b5[ ]+res 6,\(ix\+8\),l
+[ ]+986:[ ]+fd cb 08 b7[ ]+res 6,\(iy\+8\),a
+[ ]+98a:[ ]+fd cb 08 b0[ ]+res 6,\(iy\+8\),b
+[ ]+98e:[ ]+fd cb 08 b1[ ]+res 6,\(iy\+8\),c
+[ ]+992:[ ]+fd cb 08 b2[ ]+res 6,\(iy\+8\),d
+[ ]+996:[ ]+fd cb 08 b3[ ]+res 6,\(iy\+8\),e
+[ ]+99a:[ ]+fd cb 08 b4[ ]+res 6,\(iy\+8\),h
+[ ]+99e:[ ]+fd cb 08 b5[ ]+res 6,\(iy\+8\),l
+[ ]+9a2:[ ]+dd cb 08 bf[ ]+res 7,\(ix\+8\),a
+[ ]+9a6:[ ]+dd cb 08 b8[ ]+res 7,\(ix\+8\),b
+[ ]+9aa:[ ]+dd cb 08 b9[ ]+res 7,\(ix\+8\),c
+[ ]+9ae:[ ]+dd cb 08 ba[ ]+res 7,\(ix\+8\),d
+[ ]+9b2:[ ]+dd cb 08 bb[ ]+res 7,\(ix\+8\),e
+[ ]+9b6:[ ]+dd cb 08 bc[ ]+res 7,\(ix\+8\),h
+[ ]+9ba:[ ]+dd cb 08 bd[ ]+res 7,\(ix\+8\),l
+[ ]+9be:[ ]+fd cb 08 bf[ ]+res 7,\(iy\+8\),a
+[ ]+9c2:[ ]+fd cb 08 b8[ ]+res 7,\(iy\+8\),b
+[ ]+9c6:[ ]+fd cb 08 b9[ ]+res 7,\(iy\+8\),c
+[ ]+9ca:[ ]+fd cb 08 ba[ ]+res 7,\(iy\+8\),d
+[ ]+9ce:[ ]+fd cb 08 bb[ ]+res 7,\(iy\+8\),e
+[ ]+9d2:[ ]+fd cb 08 bc[ ]+res 7,\(iy\+8\),h
+[ ]+9d6:[ ]+fd cb 08 bd[ ]+res 7,\(iy\+8\),l
+[ ]+9da:[ ]+dd cb 08 c7[ ]+set 0,\(ix\+8\),a
+[ ]+9de:[ ]+dd cb 08 c0[ ]+set 0,\(ix\+8\),b
+[ ]+9e2:[ ]+dd cb 08 c1[ ]+set 0,\(ix\+8\),c
+[ ]+9e6:[ ]+dd cb 08 c2[ ]+set 0,\(ix\+8\),d
+[ ]+9ea:[ ]+dd cb 08 c3[ ]+set 0,\(ix\+8\),e
+[ ]+9ee:[ ]+dd cb 08 c4[ ]+set 0,\(ix\+8\),h
+[ ]+9f2:[ ]+dd cb 08 c5[ ]+set 0,\(ix\+8\),l
+[ ]+9f6:[ ]+fd cb 08 c7[ ]+set 0,\(iy\+8\),a
+[ ]+9fa:[ ]+fd cb 08 c0[ ]+set 0,\(iy\+8\),b
+[ ]+9fe:[ ]+fd cb 08 c1[ ]+set 0,\(iy\+8\),c
+[ ]+a02:[ ]+fd cb 08 c2[ ]+set 0,\(iy\+8\),d
+[ ]+a06:[ ]+fd cb 08 c3[ ]+set 0,\(iy\+8\),e
+[ ]+a0a:[ ]+fd cb 08 c4[ ]+set 0,\(iy\+8\),h
+[ ]+a0e:[ ]+fd cb 08 c5[ ]+set 0,\(iy\+8\),l
+[ ]+a12:[ ]+dd cb 08 cf[ ]+set 1,\(ix\+8\),a
+[ ]+a16:[ ]+dd cb 08 c8[ ]+set 1,\(ix\+8\),b
+[ ]+a1a:[ ]+dd cb 08 c9[ ]+set 1,\(ix\+8\),c
+[ ]+a1e:[ ]+dd cb 08 ca[ ]+set 1,\(ix\+8\),d
+[ ]+a22:[ ]+dd cb 08 cb[ ]+set 1,\(ix\+8\),e
+[ ]+a26:[ ]+dd cb 08 cc[ ]+set 1,\(ix\+8\),h
+[ ]+a2a:[ ]+dd cb 08 cd[ ]+set 1,\(ix\+8\),l
+[ ]+a2e:[ ]+fd cb 08 cf[ ]+set 1,\(iy\+8\),a
+[ ]+a32:[ ]+fd cb 08 c8[ ]+set 1,\(iy\+8\),b
+[ ]+a36:[ ]+fd cb 08 c9[ ]+set 1,\(iy\+8\),c
+[ ]+a3a:[ ]+fd cb 08 ca[ ]+set 1,\(iy\+8\),d
+[ ]+a3e:[ ]+fd cb 08 cb[ ]+set 1,\(iy\+8\),e
+[ ]+a42:[ ]+fd cb 08 cc[ ]+set 1,\(iy\+8\),h
+[ ]+a46:[ ]+fd cb 08 cd[ ]+set 1,\(iy\+8\),l
+[ ]+a4a:[ ]+dd cb 08 d7[ ]+set 2,\(ix\+8\),a
+[ ]+a4e:[ ]+dd cb 08 d0[ ]+set 2,\(ix\+8\),b
+[ ]+a52:[ ]+dd cb 08 d1[ ]+set 2,\(ix\+8\),c
+[ ]+a56:[ ]+dd cb 08 d2[ ]+set 2,\(ix\+8\),d
+[ ]+a5a:[ ]+dd cb 08 d3[ ]+set 2,\(ix\+8\),e
+[ ]+a5e:[ ]+dd cb 08 d4[ ]+set 2,\(ix\+8\),h
+[ ]+a62:[ ]+dd cb 08 d5[ ]+set 2,\(ix\+8\),l
+[ ]+a66:[ ]+fd cb 08 d7[ ]+set 2,\(iy\+8\),a
+[ ]+a6a:[ ]+fd cb 08 d0[ ]+set 2,\(iy\+8\),b
+[ ]+a6e:[ ]+fd cb 08 d1[ ]+set 2,\(iy\+8\),c
+[ ]+a72:[ ]+fd cb 08 d2[ ]+set 2,\(iy\+8\),d
+[ ]+a76:[ ]+fd cb 08 d3[ ]+set 2,\(iy\+8\),e
+[ ]+a7a:[ ]+fd cb 08 d4[ ]+set 2,\(iy\+8\),h
+[ ]+a7e:[ ]+fd cb 08 d5[ ]+set 2,\(iy\+8\),l
+[ ]+a82:[ ]+dd cb 08 df[ ]+set 3,\(ix\+8\),a
+[ ]+a86:[ ]+dd cb 08 d8[ ]+set 3,\(ix\+8\),b
+[ ]+a8a:[ ]+dd cb 08 d9[ ]+set 3,\(ix\+8\),c
+[ ]+a8e:[ ]+dd cb 08 da[ ]+set 3,\(ix\+8\),d
+[ ]+a92:[ ]+dd cb 08 db[ ]+set 3,\(ix\+8\),e
+[ ]+a96:[ ]+dd cb 08 dc[ ]+set 3,\(ix\+8\),h
+[ ]+a9a:[ ]+dd cb 08 dd[ ]+set 3,\(ix\+8\),l
+[ ]+a9e:[ ]+fd cb 08 df[ ]+set 3,\(iy\+8\),a
+[ ]+aa2:[ ]+fd cb 08 d8[ ]+set 3,\(iy\+8\),b
+[ ]+aa6:[ ]+fd cb 08 d9[ ]+set 3,\(iy\+8\),c
+[ ]+aaa:[ ]+fd cb 08 da[ ]+set 3,\(iy\+8\),d
+[ ]+aae:[ ]+fd cb 08 db[ ]+set 3,\(iy\+8\),e
+[ ]+ab2:[ ]+fd cb 08 dc[ ]+set 3,\(iy\+8\),h
+[ ]+ab6:[ ]+fd cb 08 dd[ ]+set 3,\(iy\+8\),l
+[ ]+aba:[ ]+dd cb 08 e7[ ]+set 4,\(ix\+8\),a
+[ ]+abe:[ ]+dd cb 08 e0[ ]+set 4,\(ix\+8\),b
+[ ]+ac2:[ ]+dd cb 08 e1[ ]+set 4,\(ix\+8\),c
+[ ]+ac6:[ ]+dd cb 08 e2[ ]+set 4,\(ix\+8\),d
+[ ]+aca:[ ]+dd cb 08 e3[ ]+set 4,\(ix\+8\),e
+[ ]+ace:[ ]+dd cb 08 e4[ ]+set 4,\(ix\+8\),h
+[ ]+ad2:[ ]+dd cb 08 e5[ ]+set 4,\(ix\+8\),l
+[ ]+ad6:[ ]+fd cb 08 e7[ ]+set 4,\(iy\+8\),a
+[ ]+ada:[ ]+fd cb 08 e0[ ]+set 4,\(iy\+8\),b
+[ ]+ade:[ ]+fd cb 08 e1[ ]+set 4,\(iy\+8\),c
+[ ]+ae2:[ ]+fd cb 08 e2[ ]+set 4,\(iy\+8\),d
+[ ]+ae6:[ ]+fd cb 08 e3[ ]+set 4,\(iy\+8\),e
+[ ]+aea:[ ]+fd cb 08 e4[ ]+set 4,\(iy\+8\),h
+[ ]+aee:[ ]+fd cb 08 e5[ ]+set 4,\(iy\+8\),l
+[ ]+af2:[ ]+dd cb 08 ef[ ]+set 5,\(ix\+8\),a
+[ ]+af6:[ ]+dd cb 08 e8[ ]+set 5,\(ix\+8\),b
+[ ]+afa:[ ]+dd cb 08 e9[ ]+set 5,\(ix\+8\),c
+[ ]+afe:[ ]+dd cb 08 ea[ ]+set 5,\(ix\+8\),d
+[ ]+b02:[ ]+dd cb 08 eb[ ]+set 5,\(ix\+8\),e
+[ ]+b06:[ ]+dd cb 08 ec[ ]+set 5,\(ix\+8\),h
+[ ]+b0a:[ ]+dd cb 08 ed[ ]+set 5,\(ix\+8\),l
+[ ]+b0e:[ ]+fd cb 08 ef[ ]+set 5,\(iy\+8\),a
+[ ]+b12:[ ]+fd cb 08 e8[ ]+set 5,\(iy\+8\),b
+[ ]+b16:[ ]+fd cb 08 e9[ ]+set 5,\(iy\+8\),c
+[ ]+b1a:[ ]+fd cb 08 ea[ ]+set 5,\(iy\+8\),d
+[ ]+b1e:[ ]+fd cb 08 eb[ ]+set 5,\(iy\+8\),e
+[ ]+b22:[ ]+fd cb 08 ec[ ]+set 5,\(iy\+8\),h
+[ ]+b26:[ ]+fd cb 08 ed[ ]+set 5,\(iy\+8\),l
+[ ]+b2a:[ ]+dd cb 08 f7[ ]+set 6,\(ix\+8\),a
+[ ]+b2e:[ ]+dd cb 08 f0[ ]+set 6,\(ix\+8\),b
+[ ]+b32:[ ]+dd cb 08 f1[ ]+set 6,\(ix\+8\),c
+[ ]+b36:[ ]+dd cb 08 f2[ ]+set 6,\(ix\+8\),d
+[ ]+b3a:[ ]+dd cb 08 f3[ ]+set 6,\(ix\+8\),e
+[ ]+b3e:[ ]+dd cb 08 f4[ ]+set 6,\(ix\+8\),h
+[ ]+b42:[ ]+dd cb 08 f5[ ]+set 6,\(ix\+8\),l
+[ ]+b46:[ ]+fd cb 08 f7[ ]+set 6,\(iy\+8\),a
+[ ]+b4a:[ ]+fd cb 08 f0[ ]+set 6,\(iy\+8\),b
+[ ]+b4e:[ ]+fd cb 08 f1[ ]+set 6,\(iy\+8\),c
+[ ]+b52:[ ]+fd cb 08 f2[ ]+set 6,\(iy\+8\),d
+[ ]+b56:[ ]+fd cb 08 f3[ ]+set 6,\(iy\+8\),e
+[ ]+b5a:[ ]+fd cb 08 f4[ ]+set 6,\(iy\+8\),h
+[ ]+b5e:[ ]+fd cb 08 f5[ ]+set 6,\(iy\+8\),l
+[ ]+b62:[ ]+dd cb 08 ff[ ]+set 7,\(ix\+8\),a
+[ ]+b66:[ ]+dd cb 08 f8[ ]+set 7,\(ix\+8\),b
+[ ]+b6a:[ ]+dd cb 08 f9[ ]+set 7,\(ix\+8\),c
+[ ]+b6e:[ ]+dd cb 08 fa[ ]+set 7,\(ix\+8\),d
+[ ]+b72:[ ]+dd cb 08 fb[ ]+set 7,\(ix\+8\),e
+[ ]+b76:[ ]+dd cb 08 fc[ ]+set 7,\(ix\+8\),h
+[ ]+b7a:[ ]+dd cb 08 fd[ ]+set 7,\(ix\+8\),l
+[ ]+b7e:[ ]+fd cb 08 ff[ ]+set 7,\(iy\+8\),a
+[ ]+b82:[ ]+fd cb 08 f8[ ]+set 7,\(iy\+8\),b
+[ ]+b86:[ ]+fd cb 08 f9[ ]+set 7,\(iy\+8\),c
+[ ]+b8a:[ ]+fd cb 08 fa[ ]+set 7,\(iy\+8\),d
+[ ]+b8e:[ ]+fd cb 08 fb[ ]+set 7,\(iy\+8\),e
+[ ]+b92:[ ]+fd cb 08 fc[ ]+set 7,\(iy\+8\),h
+[ ]+b96:[ ]+fd cb 08 fd[ ]+set 7,\(iy\+8\),l
+[ ]+b9a:[ ]+cb 37[ ]+sli a
+[ ]+b9c:[ ]+cb 30[ ]+sli b
+[ ]+b9e:[ ]+cb 31[ ]+sli c
+[ ]+ba0:[ ]+cb 32[ ]+sli d
+[ ]+ba2:[ ]+cb 33[ ]+sli e
+[ ]+ba4:[ ]+cb 34[ ]+sli h
+[ ]+ba6:[ ]+cb 35[ ]+sli l
+[ ]+ba8:[ ]+cb 36[ ]+sli \(hl\)
+[ ]+baa:[ ]+dd cb 07 36[ ]+sli \(ix\+7\)
+[ ]+bae:[ ]+fd cb f7 36[ ]+sli \(iy\-9\)
+[ ]+bb2:[ ]+cb 37[ ]+sli a
+[ ]+bb4:[ ]+cb 30[ ]+sli b
+[ ]+bb6:[ ]+cb 31[ ]+sli c
+[ ]+bb8:[ ]+cb 32[ ]+sli d
+[ ]+bba:[ ]+cb 33[ ]+sli e
+[ ]+bbc:[ ]+cb 34[ ]+sli h
+[ ]+bbe:[ ]+cb 35[ ]+sli l
+[ ]+bc0:[ ]+cb 36[ ]+sli \(hl\)
+[ ]+bc2:[ ]+dd cb 07 36[ ]+sli \(ix\+7\)
+[ ]+bc6:[ ]+fd cb f7 36[ ]+sli \(iy\-9\)
+[ ]+bca:[ ]+cb 37[ ]+sli a
+[ ]+bcc:[ ]+cb 30[ ]+sli b
+[ ]+bce:[ ]+cb 31[ ]+sli c
+[ ]+bd0:[ ]+cb 32[ ]+sli d
+[ ]+bd2:[ ]+cb 33[ ]+sli e
+[ ]+bd4:[ ]+cb 34[ ]+sli h
+[ ]+bd6:[ ]+cb 35[ ]+sli l
+[ ]+bd8:[ ]+cb 36[ ]+sli \(hl\)
+[ ]+bda:[ ]+dd cb 07 36[ ]+sli \(ix\+7\)
+[ ]+bde:[ ]+fd cb f7 36[ ]+sli \(iy\-9\)
+[ ]+be2:[ ]+ed a4[ ]+ldix
+[ ]+be4:[ ]+ed a5[ ]+ldws
+[ ]+be6:[ ]+ed b4[ ]+ldirx
+[ ]+be8:[ ]+ed ac[ ]+lddx
+[ ]+bea:[ ]+ed bc[ ]+lddrx
+[ ]+bec:[ ]+ed b7[ ]+ldpirx
+[ ]+bee:[ ]+ed 90[ ]+outinb
+[ ]+bf0:[ ]+ed 30[ ]+mul d,e
+[ ]+bf2:[ ]+ed 31[ ]+add hl,a
+[ ]+bf4:[ ]+ed 32[ ]+add de,a
+[ ]+bf6:[ ]+ed 33[ ]+add bc,a
+[ ]+bf8:[ ]+ed 34 af be[ ]+add hl,0xbeaf
+[ ]+bfc:[ ]+ed 35 ad de[ ]+add de,0xdead
+[ ]+c00:[ ]+ed 36 34 12[ ]+add bc,0x1234
+[ ]+c04:[ ]+ed 23[ ]+swapnib
+[ ]+c06:[ ]+ed 24[ ]+mirror
+[ ]+c08:[ ]+ed 8a 12 34[ ]+push 0x1234
+[ ]+c0c:[ ]+ed 91 12 34[ ]+nextreg 0x12,0x34
+[ ]+c10:[ ]+ed 92 56[ ]+nextreg 0x56,a
+[ ]+c13:[ ]+ed 93[ ]+pixeldn
+[ ]+c15:[ ]+ed 94[ ]+pixelad
+[ ]+c17:[ ]+ed 95[ ]+setae
+[ ]+c19:[ ]+ed 27 78[ ]+test 0x78
+[ ]+c1c:[ ]+ed 28[ ]+bsla de,b
+[ ]+c1e:[ ]+ed 29[ ]+bsra de,b
+[ ]+c20:[ ]+ed 2a[ ]+bsrl de,b
+[ ]+c22:[ ]+ed 2b[ ]+bsrf de,b
+[ ]+c24:[ ]+ed 2c[ ]+bslc de,b
+[ ]+c26:[ ]+ed 98[ ]+jp \(c\)
+[ ]+c28:[ ]+ed 8a 00 00[ ]+push 0x0000
+[ ]+c2c:[ ]+ed 30[ ]+mul d,e
+[ ]+c2e:[ ]+ed 23[ ]+swapnib
+[ ]+c30:[ ]+ed 27 ab[ ]+test 0xab
+#pass
diff --git a/gas/testsuite/gas/z80/z80n_all.s b/gas/testsuite/gas/z80/z80n_all.s
new file mode 100644
index 0000000..3d0e341
--- /dev/null
+++ b/gas/testsuite/gas/z80/z80n_all.s
@@ -0,0 +1,1242 @@
+ .text
+ .org 0
+
+ adc a,(hl)
+ adc a,(ix+9)
+ adc a,(iy+9)
+ adc a,3
+ adc a,a
+ adc a,b
+ adc a,c
+ adc a,d
+ adc a,e
+ adc a,h
+ adc a,l
+ adc hl,bc
+ adc hl,de
+ adc hl,hl
+ adc hl,sp
+ add a,(hl)
+ add a,(ix+9)
+ add a,(iy+9)
+ add a,3
+ add a,a
+ add a,b
+ add a,c
+ add a,d
+ add a,e
+ add a,h
+ add a,l
+ add hl,bc
+ add hl,de
+ add hl,hl
+ add hl,sp
+ add ix,bc
+ add ix,de
+ add ix,ix
+ add ix,sp
+ add iy,bc
+ add iy,de
+ add iy,iy
+ add iy,sp
+ and (hl)
+ and (ix+9)
+ and (iy+9)
+ and 3
+ and a
+ and b
+ and c
+ and d
+ and e
+ and h
+ and l
+ bit 0,(hl)
+ bit 0,(ix+9)
+ bit 0,(iy+9)
+ bit 0,a
+ bit 0,b
+ bit 0,c
+ bit 0,d
+ bit 0,e
+ bit 0,h
+ bit 0,l
+ bit 1,(hl)
+ bit 1,(ix+9)
+ bit 1,(iy+9)
+ bit 1,a
+ bit 1,b
+ bit 1,c
+ bit 1,d
+ bit 1,e
+ bit 1,h
+ bit 1,l
+ bit 2,(hl)
+ bit 2,(ix+9)
+ bit 2,(iy+9)
+ bit 2,a
+ bit 2,b
+ bit 2,c
+ bit 2,d
+ bit 2,e
+ bit 2,h
+ bit 2,l
+ bit 3,(hl)
+ bit 3,(ix+9)
+ bit 3,(iy+9)
+ bit 3,a
+ bit 3,b
+ bit 3,c
+ bit 3,d
+ bit 3,e
+ bit 3,h
+ bit 3,l
+ bit 4,(hl)
+ bit 4,(ix+9)
+ bit 4,(iy+9)
+ bit 4,a
+ bit 4,b
+ bit 4,c
+ bit 4,d
+ bit 4,e
+ bit 4,h
+ bit 4,l
+ bit 5,(hl)
+ bit 5,(ix+9)
+ bit 5,(iy+9)
+ bit 5,a
+ bit 5,b
+ bit 5,c
+ bit 5,d
+ bit 5,e
+ bit 5,h
+ bit 5,l
+ bit 6,(hl)
+ bit 6,(ix+9)
+ bit 6,(iy+9)
+ bit 6,a
+ bit 6,b
+ bit 6,c
+ bit 6,d
+ bit 6,e
+ bit 6,h
+ bit 6,l
+ bit 7,(hl)
+ bit 7,(ix+9)
+ bit 7,(iy+9)
+ bit 7,a
+ bit 7,b
+ bit 7,c
+ bit 7,d
+ bit 7,e
+ bit 7,h
+ bit 7,l
+ call 0x1234
+ call c,0x1234
+ call m,0x1234
+ call nc,0x1234
+ call nz,0x1234
+ call p,0x1234
+ call pe,0x1234
+ call po,0x1234
+ call z,0x1234
+ ccf
+ cp (hl)
+ cp (ix+9)
+ cp (iy+9)
+ cp 03
+ cp a
+ cp b
+ cp c
+ cp d
+ cp e
+ cp h
+ cp l
+ cpd
+ cpdr
+ cpi
+ cpir
+ cpl
+ daa
+ dec (hl)
+ dec (ix+9)
+ dec (iy+9)
+ dec a
+ dec b
+ dec bc
+ dec c
+ dec d
+ dec de
+ dec e
+ dec h
+ dec hl
+ dec ix
+ dec iy
+ dec l
+ dec sp
+ di
+ djnz .+7
+ ei
+ ex (sp),hl
+ ex (sp),ix
+ ex (sp),iy
+ ex af,af' ;'
+ ex de,hl
+ exx
+ halt
+ im 0
+ im 1
+ im 2
+ in a,(c)
+ in a,(3)
+ in b,(c)
+ in c,(c)
+ in d,(c)
+ in e,(c)
+ in h,(c)
+ in l,(c)
+ inc (hl)
+ inc (ix+9)
+ inc (iy+9)
+ inc a
+ inc b
+ inc bc
+ inc c
+ inc d
+ inc de
+ inc e
+ inc h
+ inc hl
+ inc ix
+ inc iy
+ inc l
+ inc sp
+ ind
+ indr
+ ini
+ inir
+ jp (hl)
+ jp (ix)
+ jp (iy)
+ jp 0x1234
+ jp c,0x1234
+ jp m,0x1234
+ jp nc,0x1234
+ jp nz,0x1234
+ jp p,0x1234
+ jp pe,0x1234
+ jp po,0x1234
+ jp z,0x1234
+ jr .+7
+ jr c,.+7
+ jr nc,.+7
+ jr nz,.+7
+ jr z,.+7
+ ld (0x1234),a
+ ld (0x1234),bc
+ ld (0x1234),de
+ ld (0x1234),hl
+ ld (0x1234),ix
+ ld (0x1234),iy
+ ld (0x1234),sp
+ ld (bc),a
+ ld (de),a
+ ld (hl),3
+ ld (hl),a
+ ld (hl),b
+ ld (hl),c
+ ld (hl),d
+ ld (hl),e
+ ld (hl),h
+ ld (hl),l
+ ld (ix+9),3
+ ld (ix+9),a
+ ld (ix+9),b
+ ld (ix+9),c
+ ld (ix+9),d
+ ld (ix+9),e
+ ld (ix+9),h
+ ld (ix+9),l
+ ld (iy+9),3
+ ld (iy+9),a
+ ld (iy+9),b
+ ld (iy+9),c
+ ld (iy+9),d
+ ld (iy+9),e
+ ld (iy+9),h
+ ld (iy+9),l
+ ld a,(0x1234)
+ ld a,(bc)
+ ld a,(de)
+ ld a,(hl)
+ ld a,(ix+9)
+ ld a,(iy+9)
+ ld a,3
+ ld a,a
+ ld a,b
+ ld a,c
+ ld a,d
+ ld a,e
+ ld a,h
+ ld a,i
+ ld a,l
+ ld a,r
+ ld b,(hl)
+ ld b,(ix+9)
+ ld b,(iy+9)
+ ld b,3
+ ld b,a
+ ld b,b
+ ld b,c
+ ld b,d
+ ld b,e
+ ld b,h
+ ld b,l
+ ld bc,(0x1234)
+ ld bc,0x1234
+ ld c,(hl)
+ ld c,(ix+9)
+ ld c,(iy+9)
+ ld c,3
+ ld c,a
+ ld c,b
+ ld c,c
+ ld c,d
+ ld c,e
+ ld c,h
+ ld c,l
+ ld d,(hl)
+ ld d,(ix+9)
+ ld d,(iy+9)
+ ld d,3
+ ld d,a
+ ld d,b
+ ld d,c
+ ld d,d
+ ld d,e
+ ld d,h
+ ld d,l
+ ld de,(0x1234)
+ ld de,0x1234
+ ld e,(hl)
+ ld e,(ix+9)
+ ld e,(iy+9)
+ ld e,3
+ ld e,a
+ ld e,b
+ ld e,c
+ ld e,d
+ ld e,e
+ ld e,h
+ ld e,l
+ ld h,(hl)
+ ld h,(ix+9)
+ ld h,(iy+9)
+ ld h,3
+ ld h,a
+ ld h,b
+ ld h,c
+ ld h,d
+ ld h,e
+ ld h,h
+ ld h,l
+ ld hl,(0x1234)
+ ld hl,0x1234
+ ld i,a
+ ld ix,(0x1234)
+ ld ix,0x1234
+ ld iy,(0x1234)
+ ld iy,0x1234
+ ld l,(hl)
+ ld l,(ix+9)
+ ld l,(iy+9)
+ ld l,3
+ ld l,a
+ ld l,b
+ ld l,c
+ ld l,d
+ ld l,e
+ ld l,h
+ ld l,l
+ ld r,a
+ ld sp,(0x1234)
+ ld sp,0x1234
+ ld sp,hl
+ ld sp,ix
+ ld sp,iy
+ ldd
+ lddr
+ ldi
+ ldir
+ neg
+ nop
+ or (hl)
+ or (ix+9)
+ or (iy+9)
+ or 3
+ or a
+ or b
+ or c
+ or d
+ or e
+ or h
+ or l
+ otdr
+ otir
+ out (c),a
+ out (c),b
+ out (c),c
+ out (c),d
+ out (c),e
+ out (c),h
+ out (c),l
+ out (3),a
+ outd
+ outi
+ pop af
+ pop bc
+ pop de
+ pop hl
+ pop ix
+ pop iy
+ push af
+ push bc
+ push de
+ push hl
+ push ix
+ push iy
+ res 0,(hl)
+ res 0,(ix+9)
+ res 0,(iy+9)
+ res 0,a
+ res 0,b
+ res 0,c
+ res 0,d
+ res 0,e
+ res 0,h
+ res 0,l
+ res 1,(hl)
+ res 1,(ix+9)
+ res 1,(iy+9)
+ res 1,a
+ res 1,b
+ res 1,c
+ res 1,d
+ res 1,e
+ res 1,h
+ res 1,l
+ res 2,(hl)
+ res 2,(ix+9)
+ res 2,(iy+9)
+ res 2,a
+ res 2,b
+ res 2,c
+ res 2,d
+ res 2,e
+ res 2,h
+ res 2,l
+ res 3,(hl)
+ res 3,(ix+9)
+ res 3,(iy+9)
+ res 3,a
+ res 3,b
+ res 3,c
+ res 3,d
+ res 3,e
+ res 3,h
+ res 3,l
+ res 4,(hl)
+ res 4,(ix+9)
+ res 4,(iy+9)
+ res 4,a
+ res 4,b
+ res 4,c
+ res 4,d
+ res 4,e
+ res 4,h
+ res 4,l
+ res 5,(hl)
+ res 5,(ix+9)
+ res 5,(iy+9)
+ res 5,a
+ res 5,b
+ res 5,c
+ res 5,d
+ res 5,e
+ res 5,h
+ res 5,l
+ res 6,(hl)
+ res 6,(ix+9)
+ res 6,(iy+9)
+ res 6,a
+ res 6,b
+ res 6,c
+ res 6,d
+ res 6,e
+ res 6,h
+ res 6,l
+ res 7,(hl)
+ res 7,(ix+9)
+ res 7,(iy+9)
+ res 7,a
+ res 7,b
+ res 7,c
+ res 7,d
+ res 7,e
+ res 7,h
+ res 7,l
+ ret
+ ret c
+ ret m
+ ret nc
+ ret nz
+ ret p
+ ret pe
+ ret po
+ ret z
+ reti
+ retn
+ rl (hl)
+ rl (ix+9)
+ rl (iy+9)
+ rl a
+ rl b
+ rl c
+ rl d
+ rl e
+ rl h
+ rl l
+ rla
+ rlc (hl)
+ rlc (ix+9)
+ rlc (iy+9)
+ rlc a
+ rlc b
+ rlc c
+ rlc d
+ rlc e
+ rlc h
+ rlc l
+ rlca
+ rld
+ rr (hl)
+ rr (ix+9)
+ rr (iy+9)
+ rr a
+ rr b
+ rr c
+ rr d
+ rr e
+ rr h
+ rr l
+ rra
+ rrc (hl)
+ rrc (ix+9)
+ rrc (iy+9)
+ rrc a
+ rrc b
+ rrc c
+ rrc d
+ rrc e
+ rrc h
+ rrc l
+ rrca
+ rrd
+ rst 0x00
+ rst 0x08
+ rst 0x10
+ rst 0x18
+ rst 0x20
+ rst 0x28
+ rst 0x30
+ rst 0x38
+ sbc a,(hl)
+ sbc a,(ix+9)
+ sbc a,(iy+9)
+ sbc a,3
+ sbc a,a
+ sbc a,b
+ sbc a,c
+ sbc a,d
+ sbc a,e
+ sbc a,h
+ sbc a,l
+ sbc hl,bc
+ sbc hl,de
+ sbc hl,hl
+ sbc hl,sp
+ scf
+ set 0,(hl)
+ set 0,(ix+9)
+ set 0,(iy+9)
+ set 0,a
+ set 0,b
+ set 0,c
+ set 0,d
+ set 0,e
+ set 0,h
+ set 0,l
+ set 1,(hl)
+ set 1,(ix+9)
+ set 1,(iy+9)
+ set 1,a
+ set 1,b
+ set 1,c
+ set 1,d
+ set 1,e
+ set 1,h
+ set 1,l
+ set 2,(hl)
+ set 2,(ix+9)
+ set 2,(iy+9)
+ set 2,a
+ set 2,b
+ set 2,c
+ set 2,d
+ set 2,e
+ set 2,h
+ set 2,l
+ set 3,(hl)
+ set 3,(ix+9)
+ set 3,(iy+9)
+ set 3,a
+ set 3,b
+ set 3,c
+ set 3,d
+ set 3,e
+ set 3,h
+ set 3,l
+ set 4,(hl)
+ set 4,(ix+9)
+ set 4,(iy+9)
+ set 4,a
+ set 4,b
+ set 4,c
+ set 4,d
+ set 4,e
+ set 4,h
+ set 4,l
+ set 5,(hl)
+ set 5,(ix+9)
+ set 5,(iy+9)
+ set 5,a
+ set 5,b
+ set 5,c
+ set 5,d
+ set 5,e
+ set 5,h
+ set 5,l
+ set 6,(hl)
+ set 6,(ix+9)
+ set 6,(iy+9)
+ set 6,a
+ set 6,b
+ set 6,c
+ set 6,d
+ set 6,e
+ set 6,h
+ set 6,l
+ set 7,(hl)
+ set 7,(ix+9)
+ set 7,(iy+9)
+ set 7,a
+ set 7,b
+ set 7,c
+ set 7,d
+ set 7,e
+ set 7,h
+ set 7,l
+ sla (hl)
+ sla (ix+9)
+ sla (iy+9)
+ sla a
+ sla b
+ sla c
+ sla d
+ sla e
+ sla h
+ sla l
+ sra (hl)
+ sra (ix+9)
+ sra (iy+9)
+ sra a
+ sra b
+ sra c
+ sra d
+ sra e
+ sra h
+ sra l
+ srl (hl)
+ srl (ix+9)
+ srl (iy+9)
+ srl a
+ srl b
+ srl c
+ srl d
+ srl e
+ srl h
+ srl l
+ sub (hl)
+ sub (ix+9)
+ sub (iy+9)
+ sub 3
+ sub a
+ sub b
+ sub c
+ sub d
+ sub e
+ sub h
+ sub l
+ xor (hl)
+ xor (ix+9)
+ xor (iy+9)
+ xor 3
+ xor a
+ xor b
+ xor c
+ xor d
+ xor e
+ xor h
+ xor l
+
+ ld a,ixh
+ ld b,ixh
+ ld c,ixh
+ ld d,ixh
+ ld e,ixh
+ ld ixh,ixh
+ ld ixl,ixh
+
+ ld a,ixl
+ ld b,ixl
+ ld c,ixl
+ ld d,ixl
+ ld e,ixl
+ ld ixh,ixl
+ ld ixl,ixl
+
+ ld a,iyh
+ ld b,iyh
+ ld c,iyh
+ ld d,iyh
+ ld e,iyh
+ ld iyh,iyh
+ ld iyl,iyh
+
+ ld a,iyl
+ ld b,iyl
+ ld c,iyl
+ ld d,iyl
+ ld e,iyl
+ ld iyh,iyl
+ ld iyl,iyl
+
+ ld ixh,a
+ ld ixh,b
+ ld ixh,c
+ ld ixh,d
+ ld ixh,e
+ ld ixh,ixh
+ ld ixh,ixl
+ ld ixh,25
+
+ ld ixl,a
+ ld ixl,b
+ ld ixl,c
+ ld ixl,d
+ ld ixl,e
+ ld ixl,ixh
+ ld ixl,ixl
+ ld ixl,25
+
+ ld iyh,a
+ ld iyh,b
+ ld iyh,c
+ ld iyh,d
+ ld iyh,e
+ ld iyh,iyh
+ ld iyh,iyl
+ ld iyh,25
+
+ ld iyl,a
+ ld iyl,b
+ ld iyl,c
+ ld iyl,d
+ ld iyl,e
+ ld iyl,iyh
+ ld iyl,iyl
+ ld iyl,25
+
+ add a,ixh
+ add a,ixl
+ add a,iyh
+ add a,iyl
+
+ adc a,ixh
+ adc a,ixl
+ adc a,iyh
+ adc a,iyl
+
+ cp ixh
+ cp ixl
+ cp iyh
+ cp iyl
+
+ dec ixh
+ dec ixl
+ dec iyh
+ dec iyl
+
+ inc ixh
+ inc ixl
+ inc iyh
+ inc iyl
+
+ sbc a,ixh
+ sbc a,ixl
+ sbc a,iyh
+ sbc a,iyl
+
+ sub ixh
+ sub ixl
+ sub iyh
+ sub iyl
+
+ and ixh
+ and ixl
+ and iyh
+ and iyl
+
+ or ixh
+ or ixl
+ or iyh
+ or iyl
+
+ xor ixh
+ xor ixl
+ xor iyh
+ xor iyl
+
+ in f,(c)
+ in (c)
+ out (c),0
+
+ RLC (ix+8),a
+ RLC (ix+8),b
+ RLC (ix+8),c
+ RLC (ix+8),d
+ RLC (ix+8),e
+ RLC (ix+8),h
+ RLC (ix+8),l
+ RLC (iy+8),a
+ RLC (iy+8),b
+ RLC (iy+8),c
+ RLC (iy+8),d
+ RLC (iy+8),e
+ RLC (iy+8),h
+ RLC (iy+8),l
+
+ RRC (ix+8),a
+ RRC (ix+8),b
+ RRC (ix+8),c
+ RRC (ix+8),d
+ RRC (ix+8),e
+ RRC (ix+8),h
+ RRC (ix+8),l
+ RRC (iy+8),a
+ RRC (iy+8),b
+ RRC (iy+8),c
+ RRC (iy+8),d
+ RRC (iy+8),e
+ RRC (iy+8),h
+ RRC (iy+8),l
+
+ RL (ix+8),a
+ RL (ix+8),b
+ RL (ix+8),c
+ RL (ix+8),d
+ RL (ix+8),e
+ RL (ix+8),h
+ RL (ix+8),l
+ RL (iy+8),a
+ RL (iy+8),b
+ RL (iy+8),c
+ RL (iy+8),d
+ RL (iy+8),e
+ RL (iy+8),h
+ RL (iy+8),l
+
+ RR (ix+8),a
+ RR (ix+8),b
+ RR (ix+8),c
+ RR (ix+8),d
+ RR (ix+8),e
+ RR (ix+8),h
+ RR (ix+8),l
+ RR (iy+8),a
+ RR (iy+8),b
+ RR (iy+8),c
+ RR (iy+8),d
+ RR (iy+8),e
+ RR (iy+8),h
+ RR (iy+8),l
+
+ SLA (ix+8),a
+ SLA (ix+8),b
+ SLA (ix+8),c
+ SLA (ix+8),d
+ SLA (ix+8),e
+ SLA (ix+8),h
+ SLA (ix+8),l
+ SLA (iy+8),a
+ SLA (iy+8),b
+ SLA (iy+8),c
+ SLA (iy+8),d
+ SLA (iy+8),e
+ SLA (iy+8),h
+ SLA (iy+8),l
+
+ SRA (ix+8),a
+ SRA (ix+8),b
+ SRA (ix+8),c
+ SRA (ix+8),d
+ SRA (ix+8),e
+ SRA (ix+8),h
+ SRA (ix+8),l
+ SRA (iy+8),a
+ SRA (iy+8),b
+ SRA (iy+8),c
+ SRA (iy+8),d
+ SRA (iy+8),e
+ SRA (iy+8),h
+ SRA (iy+8),l
+
+ SLI (ix+8),a
+ SLI (ix+8),b
+ SLI (ix+8),c
+ SLI (ix+8),d
+ SLI (ix+8),e
+ SLI (ix+8),h
+ SLI (ix+8),l
+ SLI (iy+8),a
+ SLI (iy+8),b
+ SLI (iy+8),c
+ SLI (iy+8),d
+ SLI (iy+8),e
+ SLI (iy+8),h
+ SLI (iy+8),l
+
+ SRL (ix+8),a
+ SRL (ix+8),b
+ SRL (ix+8),c
+ SRL (ix+8),d
+ SRL (ix+8),e
+ SRL (ix+8),h
+ SRL (ix+8),l
+ SRL (iy+8),a
+ SRL (iy+8),b
+ SRL (iy+8),c
+ SRL (iy+8),d
+ SRL (iy+8),e
+ SRL (iy+8),h
+ SRL (iy+8),l
+
+ RES 0,(ix+8),a
+ RES 0,(ix+8),b
+ RES 0,(ix+8),c
+ RES 0,(ix+8),d
+ RES 0,(ix+8),e
+ RES 0,(ix+8),h
+ RES 0,(ix+8),l
+ RES 0,(iy+8),a
+ RES 0,(iy+8),b
+ RES 0,(iy+8),c
+ RES 0,(iy+8),d
+ RES 0,(iy+8),e
+ RES 0,(iy+8),h
+ RES 0,(iy+8),l
+ RES 1,(ix+8),a
+ RES 1,(ix+8),b
+ RES 1,(ix+8),c
+ RES 1,(ix+8),d
+ RES 1,(ix+8),e
+ RES 1,(ix+8),h
+ RES 1,(ix+8),l
+ RES 1,(iy+8),a
+ RES 1,(iy+8),b
+ RES 1,(iy+8),c
+ RES 1,(iy+8),d
+ RES 1,(iy+8),e
+ RES 1,(iy+8),h
+ RES 1,(iy+8),l
+ RES 2,(ix+8),a
+ RES 2,(ix+8),b
+ RES 2,(ix+8),c
+ RES 2,(ix+8),d
+ RES 2,(ix+8),e
+ RES 2,(ix+8),h
+ RES 2,(ix+8),l
+ RES 2,(iy+8),a
+ RES 2,(iy+8),b
+ RES 2,(iy+8),c
+ RES 2,(iy+8),d
+ RES 2,(iy+8),e
+ RES 2,(iy+8),h
+ RES 2,(iy+8),l
+ RES 3,(ix+8),a
+ RES 3,(ix+8),b
+ RES 3,(ix+8),c
+ RES 3,(ix+8),d
+ RES 3,(ix+8),e
+ RES 3,(ix+8),h
+ RES 3,(ix+8),l
+ RES 3,(iy+8),a
+ RES 3,(iy+8),b
+ RES 3,(iy+8),c
+ RES 3,(iy+8),d
+ RES 3,(iy+8),e
+ RES 3,(iy+8),h
+ RES 3,(iy+8),l
+ RES 4,(ix+8),a
+ RES 4,(ix+8),b
+ RES 4,(ix+8),c
+ RES 4,(ix+8),d
+ RES 4,(ix+8),e
+ RES 4,(ix+8),h
+ RES 4,(ix+8),l
+ RES 4,(iy+8),a
+ RES 4,(iy+8),b
+ RES 4,(iy+8),c
+ RES 4,(iy+8),d
+ RES 4,(iy+8),e
+ RES 4,(iy+8),h
+ RES 4,(iy+8),l
+ RES 5,(ix+8),a
+ RES 5,(ix+8),b
+ RES 5,(ix+8),c
+ RES 5,(ix+8),d
+ RES 5,(ix+8),e
+ RES 5,(ix+8),h
+ RES 5,(ix+8),l
+ RES 5,(iy+8),a
+ RES 5,(iy+8),b
+ RES 5,(iy+8),c
+ RES 5,(iy+8),d
+ RES 5,(iy+8),e
+ RES 5,(iy+8),h
+ RES 5,(iy+8),l
+ RES 6,(ix+8),a
+ RES 6,(ix+8),b
+ RES 6,(ix+8),c
+ RES 6,(ix+8),d
+ RES 6,(ix+8),e
+ RES 6,(ix+8),h
+ RES 6,(ix+8),l
+ RES 6,(iy+8),a
+ RES 6,(iy+8),b
+ RES 6,(iy+8),c
+ RES 6,(iy+8),d
+ RES 6,(iy+8),e
+ RES 6,(iy+8),h
+ RES 6,(iy+8),l
+ RES 7,(ix+8),a
+ RES 7,(ix+8),b
+ RES 7,(ix+8),c
+ RES 7,(ix+8),d
+ RES 7,(ix+8),e
+ RES 7,(ix+8),h
+ RES 7,(ix+8),l
+ RES 7,(iy+8),a
+ RES 7,(iy+8),b
+ RES 7,(iy+8),c
+ RES 7,(iy+8),d
+ RES 7,(iy+8),e
+ RES 7,(iy+8),h
+ RES 7,(iy+8),l
+
+ SET 0,(ix+8),a
+ SET 0,(ix+8),b
+ SET 0,(ix+8),c
+ SET 0,(ix+8),d
+ SET 0,(ix+8),e
+ SET 0,(ix+8),h
+ SET 0,(ix+8),l
+ SET 0,(iy+8),a
+ SET 0,(iy+8),b
+ SET 0,(iy+8),c
+ SET 0,(iy+8),d
+ SET 0,(iy+8),e
+ SET 0,(iy+8),h
+ SET 0,(iy+8),l
+ SET 1,(ix+8),a
+ SET 1,(ix+8),b
+ SET 1,(ix+8),c
+ SET 1,(ix+8),d
+ SET 1,(ix+8),e
+ SET 1,(ix+8),h
+ SET 1,(ix+8),l
+ SET 1,(iy+8),a
+ SET 1,(iy+8),b
+ SET 1,(iy+8),c
+ SET 1,(iy+8),d
+ SET 1,(iy+8),e
+ SET 1,(iy+8),h
+ SET 1,(iy+8),l
+ SET 2,(ix+8),a
+ SET 2,(ix+8),b
+ SET 2,(ix+8),c
+ SET 2,(ix+8),d
+ SET 2,(ix+8),e
+ SET 2,(ix+8),h
+ SET 2,(ix+8),l
+ SET 2,(iy+8),a
+ SET 2,(iy+8),b
+ SET 2,(iy+8),c
+ SET 2,(iy+8),d
+ SET 2,(iy+8),e
+ SET 2,(iy+8),h
+ SET 2,(iy+8),l
+ SET 3,(ix+8),a
+ SET 3,(ix+8),b
+ SET 3,(ix+8),c
+ SET 3,(ix+8),d
+ SET 3,(ix+8),e
+ SET 3,(ix+8),h
+ SET 3,(ix+8),l
+ SET 3,(iy+8),a
+ SET 3,(iy+8),b
+ SET 3,(iy+8),c
+ SET 3,(iy+8),d
+ SET 3,(iy+8),e
+ SET 3,(iy+8),h
+ SET 3,(iy+8),l
+ SET 4,(ix+8),a
+ SET 4,(ix+8),b
+ SET 4,(ix+8),c
+ SET 4,(ix+8),d
+ SET 4,(ix+8),e
+ SET 4,(ix+8),h
+ SET 4,(ix+8),l
+ SET 4,(iy+8),a
+ SET 4,(iy+8),b
+ SET 4,(iy+8),c
+ SET 4,(iy+8),d
+ SET 4,(iy+8),e
+ SET 4,(iy+8),h
+ SET 4,(iy+8),l
+ SET 5,(ix+8),a
+ SET 5,(ix+8),b
+ SET 5,(ix+8),c
+ SET 5,(ix+8),d
+ SET 5,(ix+8),e
+ SET 5,(ix+8),h
+ SET 5,(ix+8),l
+ SET 5,(iy+8),a
+ SET 5,(iy+8),b
+ SET 5,(iy+8),c
+ SET 5,(iy+8),d
+ SET 5,(iy+8),e
+ SET 5,(iy+8),h
+ SET 5,(iy+8),l
+ SET 6,(ix+8),a
+ SET 6,(ix+8),b
+ SET 6,(ix+8),c
+ SET 6,(ix+8),d
+ SET 6,(ix+8),e
+ SET 6,(ix+8),h
+ SET 6,(ix+8),l
+ SET 6,(iy+8),a
+ SET 6,(iy+8),b
+ SET 6,(iy+8),c
+ SET 6,(iy+8),d
+ SET 6,(iy+8),e
+ SET 6,(iy+8),h
+ SET 6,(iy+8),l
+ SET 7,(ix+8),a
+ SET 7,(ix+8),b
+ SET 7,(ix+8),c
+ SET 7,(ix+8),d
+ SET 7,(ix+8),e
+ SET 7,(ix+8),h
+ SET 7,(ix+8),l
+ SET 7,(iy+8),a
+ SET 7,(iy+8),b
+ SET 7,(iy+8),c
+ SET 7,(iy+8),d
+ SET 7,(iy+8),e
+ SET 7,(iy+8),h
+ SET 7,(iy+8),l
+
+;SLI
+ sli a
+ sli b
+ sli c
+ sli d
+ sli e
+ sli h
+ sli l
+ sli (hl)
+ sli (ix+7)
+ sli (iy-9)
+
+;SLL is an alias for SLI
+ sll a
+ sll b
+ sll c
+ sll d
+ sll e
+ sll h
+ sll l
+ sll (hl)
+ sll (ix+7)
+ sll (iy-9)
+
+;SL1 is an alias for SLI
+ sl1 a
+ sl1 b
+ sl1 c
+ sl1 d
+ sl1 e
+ sl1 h
+ sl1 l
+ sl1 (hl)
+ sl1 (ix+7)
+ sl1 (iy-9)
+
+;Z80N specific
+ ldix
+ ldws
+ ldirx
+ lddx
+ lddrx
+ ldpirx
+ outinb
+ mul d,e
+ add hl,a
+ add de,a
+ add bc,a
+ add hl,0xbeaf
+ add de,0xdead
+ add bc,0x1234
+ swapnib
+ mirror
+ push 0x1234
+ nextreg 0x12,0x34
+ nextreg 0x56,a
+ pixeldn
+ pixelad
+ setae
+ test 0x78
+ bsla de,b
+ bsra de,b
+ bsrl de,b
+ bsrf de,b
+ brlc de,b
+ jp (c)
+
+ .globl push_value
+ push push_value
+;Z80N aliases
+ mlt de
+ swap a
+ tst 0xab
+ .end
diff --git a/gas/testsuite/gas/z80/z80n_reloc.d b/gas/testsuite/gas/z80/z80n_reloc.d
new file mode 100644
index 0000000..8fa78e1
--- /dev/null
+++ b/gas/testsuite/gas/z80/z80n_reloc.d
@@ -0,0 +1,10 @@
+#as: -z80n
+#source: z80n_all.s
+#objdump: -r
+#name: Z80N big-endian relocation
+
+.*:[ ]+file format (coff|elf32)\-z80
+
+RELOCATION RECORDS FOR \[\.text\]:
+OFFSET[ ]+TYPE[ ]+VALUE\s*
+0*c2a[ ]+r_imm16be[ ]+push_value\s*