Coverage Report

Created: 2025-06-24 06:45

/src/binutils-gdb/opcodes/rl78-decode.c
Line
Count
Source (jump to first uncovered line)
1
/* DO NOT EDIT!  -*- buffer-read-only: t -*- vi:set ro:  */
2
#line 1 "rl78-decode.opc"
3
/* -*- c -*- */
4
/* Copyright (C) 2012-2025 Free Software Foundation, Inc.
5
   Contributed by Red Hat.
6
   Written by DJ Delorie.
7
8
   This file is part of the GNU opcodes library.
9
10
   This library is free software; you can redistribute it and/or modify
11
   it under the terms of the GNU General Public License as published by
12
   the Free Software Foundation; either version 3, or (at your option)
13
   any later version.
14
15
   It is distributed in the hope that it will be useful, but WITHOUT
16
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
17
   or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
18
   License for more details.
19
20
   You should have received a copy of the GNU General Public License
21
   along with this program; if not, write to the Free Software
22
   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
23
   MA 02110-1301, USA.  */
24
25
#include "sysdep.h"
26
#include <stdio.h>
27
#include <stdlib.h>
28
#include <string.h>
29
#include "bfd.h"
30
#include "opintl.h"
31
#include "opcode/rl78.h"
32
33
static int trace = 0;
34
35
typedef struct
36
{
37
  RL78_Opcode_Decoded * rl78;
38
  int (* getbyte)(void *);
39
  void * ptr;
40
  unsigned char * op;
41
} LocalData;
42
43
3.45M
#define ID(x) rl78->id = RLO_##x, rl78->lineno = __LINE__
44
4.59M
#define OP(n,t,r,a) (rl78->op[n].type = t, \
45
4.59M
         rl78->op[n].reg = r,      \
46
4.59M
         rl78->op[n].addend = a )
47
#define OPX(n,t,r1,r2,a) \
48
9.28k
  (rl78->op[n].type = t, \
49
9.28k
  rl78->op[n].reg = r1, \
50
9.28k
  rl78->op[n].reg2 = r2, \
51
9.28k
  rl78->op[n].addend = a )
52
53
735k
#define W() rl78->size = RL78_Word
54
55
#define AU ATTRIBUTE_UNUSED
56
57
5.96M
#define OP_BUF_LEN 20
58
5.96M
#define GETBYTE() (ld->rl78->n_bytes < (OP_BUF_LEN - 1) ? ld->op [ld->rl78->n_bytes++] = ld->getbyte (ld->ptr): 0)
59
1.78M
#define B ((unsigned long) GETBYTE())
60
61
3.82M
#define SYNTAX(x) rl78->syntax = x
62
63
#define UNSUPPORTED() \
64
6.56k
  rl78->syntax = "*unknown*"
65
66
#define RB(x) ((x)+RL78_Reg_X)
67
#define RW(x) ((x)+RL78_Reg_AX)
68
69
224k
#define Fz  rl78->flags = RL78_PSW_Z
70
152k
#define Fza rl78->flags = RL78_PSW_Z | RL78_PSW_AC
71
1.27k
#define Fzc rl78->flags = RL78_PSW_Z | RL78_PSW_CY
72
568k
#define Fzac  rl78->flags = RL78_PSW_Z | RL78_PSW_AC | RL78_PSW_CY
73
#define Fa  rl78->flags = RL78_PSW_AC
74
#define Fc  rl78->flags = RL78_PSW_CY
75
#define Fac rl78->flags = RL78_PSW_AC | RL78_PSW_CY
76
77
21.5k
#define IMMU(bytes)   immediate (bytes, 0, ld)
78
#define IMMS(bytes)   immediate (bytes, 1, ld)
79
80
static int
81
immediate (int bytes, int sign_extend, LocalData * ld)
82
1.33M
{
83
1.33M
  unsigned long i = 0;
84
85
1.33M
  switch (bytes)
86
1.33M
    {
87
890k
    case 1:
88
890k
      i |= B;
89
890k
      if (sign_extend && (i & 0x80))
90
20.9k
  i -= 0x100;
91
890k
      break;
92
424k
    case 2:
93
424k
      i |= B;
94
424k
      i |= B << 8;
95
424k
      if (sign_extend && (i & 0x8000))
96
9.59k
  i -= 0x10000;
97
424k
      break;
98
16.3k
    case 3:
99
16.3k
      i |= B;
100
16.3k
      i |= B << 8;
101
16.3k
      i |= B << 16;
102
16.3k
      if (sign_extend && (i & 0x800000))
103
0
  i -= 0x1000000;
104
16.3k
      break;
105
0
    default:
106
0
      opcodes_error_handler
107
  /* xgettext:c-format */
108
0
  (_("internal error: immediate() called with invalid byte count %d"),
109
0
     bytes);
110
0
      abort();
111
1.33M
    }
112
1.32M
  return i;
113
1.33M
}
114
115
102k
#define DC(c)   OP (0, RL78_Operand_Immediate, 0, c)
116
1.06M
#define DR(r)   OP (0, RL78_Operand_Register, RL78_Reg_##r, 0)
117
477k
#define DRB(r)    OP (0, RL78_Operand_Register, RB(r), 0)
118
217k
#define DRW(r)    OP (0, RL78_Operand_Register, RW(r), 0)
119
444k
#define DM(r,a)   OP (0, RL78_Operand_Indirect, RL78_Reg_##r, a)
120
596
#define DM2(r1,r2,a)  OPX (0, RL78_Operand_Indirect, RL78_Reg_##r1, RL78_Reg_##r2, a)
121
368k
#define DE()    rl78->op[0].use_es = 1
122
151k
#define DB(b)   set_bit (rl78->op, b)
123
54.3k
#define DCY()   DR(PSW); DB(0)
124
34.6k
#define DPUSH()   OP (0, RL78_Operand_PreDec, RL78_Reg_SP, 0);
125
126
826k
#define SC(c)   OP (1, RL78_Operand_Immediate, 0, c)
127
452k
#define SR(r)   OP (1, RL78_Operand_Register, RL78_Reg_##r, 0)
128
105k
#define SRB(r)    OP (1, RL78_Operand_Register, RB(r), 0)
129
235k
#define SRW(r)    OP (1, RL78_Operand_Register, RW(r), 0)
130
586k
#define SM(r,a)   OP (1, RL78_Operand_Indirect, RL78_Reg_##r, a)
131
8.68k
#define SM2(r1,r2,a)  OPX (1, RL78_Operand_Indirect, RL78_Reg_##r1, RL78_Reg_##r2, a)
132
368k
#define SE()    rl78->op[1].use_es = 1
133
132k
#define SB(b)   set_bit (rl78->op+1, b)
134
63.0k
#define SCY()   SR(PSW); SB(0)
135
42.3k
#define COND(c)   rl78->op[1].condition = RL78_Condition_##c
136
51.9k
#define SPOP()    OP (1, RL78_Operand_PostInc, RL78_Reg_SP, 0);
137
138
static void
139
set_bit (RL78_Opcode_Operand *op, int bit)
140
284k
{
141
284k
  op->bit_number = bit;
142
284k
  switch (op->type) {
143
139k
  case RL78_Operand_Register:
144
139k
    op->type = RL78_Operand_Bit;
145
139k
    break;
146
145k
  case RL78_Operand_Indirect:
147
145k
    op->type = RL78_Operand_BitIndirect;
148
145k
    break;
149
0
  default:
150
0
    break;
151
284k
  }
152
284k
}
153
154
static int
155
saddr (int x)
156
337k
{
157
337k
  if (x < 0x20)
158
81.9k
    return 0xfff00 + x;
159
256k
  return 0xffe00 + x;
160
337k
}
161
162
static int
163
sfr (int x)
164
75.6k
{
165
75.6k
  return 0xfff00 + x;
166
75.6k
}
167
168
#define SADDR saddr (IMMU (1))
169
13.3k
#define SFR sfr (IMMU (1))
170
171
int
172
rl78_decode_opcode (unsigned long pc AU,
173
      RL78_Opcode_Decoded * rl78,
174
      int (* getbyte)(void *),
175
      void * ptr,
176
      RL78_Dis_Isa isa)
177
3.45M
{
178
3.45M
  LocalData lds, * ld = &lds;
179
3.45M
  unsigned char op_buf[OP_BUF_LEN] = {0};
180
3.45M
  unsigned char *op = op_buf;
181
3.45M
  int op0, op1;
182
183
3.45M
  lds.rl78 = rl78;
184
3.45M
  lds.getbyte = getbyte;
185
3.45M
  lds.ptr = ptr;
186
3.45M
  lds.op = op;
187
188
3.45M
  memset (rl78, 0, sizeof (*rl78));
189
190
3.82M
 start_again:
191
192
/* Byte registers, not including A.  */
193
/* Word registers, not including AX.  */
194
195
/*----------------------------------------------------------------------*/
196
/* ES: prefix               */
197
198
3.82M
  GETBYTE ();
199
3.82M
  switch (op[0] & 0xff)
200
3.82M
  {
201
725k
    case 0x00:
202
725k
        {
203
          /** 0000 0000     nop         */
204
725k
          if (trace)
205
0
            {
206
0
              printf ("\033[33m%s\033[0m  %02x\n",
207
0
                     "/** 0000 0000     nop         */",
208
0
                     op[0]);
209
0
            }
210
725k
          SYNTAX("nop");
211
725k
#line 917 "rl78-decode.opc"
212
725k
          ID(nop);
213
214
        /*----------------------------------------------------------------------*/
215
216
725k
        }
217
725k
      break;
218
35.0k
    case 0x01:
219
52.8k
    case 0x03:
220
62.3k
    case 0x05:
221
79.4k
    case 0x07:
222
79.4k
        {
223
          /** 0000 0rw1     addw  %0, %1        */
224
79.4k
#line 280 "rl78-decode.opc"
225
79.4k
          int rw AU = (op[0] >> 1) & 0x03;
226
79.4k
          if (trace)
227
0
            {
228
0
              printf ("\033[33m%s\033[0m  %02x\n",
229
0
                     "/** 0000 0rw1     addw  %0, %1        */",
230
0
                     op[0]);
231
0
              printf ("  rw = 0x%x\n", rw);
232
0
            }
233
79.4k
          SYNTAX("addw  %0, %1");
234
79.4k
#line 280 "rl78-decode.opc"
235
79.4k
          ID(add); W(); DR(AX); SRW(rw); Fzac;
236
237
79.4k
        }
238
79.4k
      break;
239
11.7k
    case 0x02:
240
11.7k
        {
241
          /** 0000 0010     addw  %0, %e!1      */
242
11.7k
          if (trace)
243
0
            {
244
0
              printf ("\033[33m%s\033[0m  %02x\n",
245
0
                     "/** 0000 0010     addw  %0, %e!1      */",
246
0
                     op[0]);
247
0
            }
248
11.7k
          SYNTAX("addw  %0, %e!1");
249
11.7k
#line 271 "rl78-decode.opc"
250
11.7k
          ID(add); W(); DR(AX); SM(None, IMMU(2)); Fzac;
251
252
11.7k
        }
253
11.7k
      break;
254
15.6k
    case 0x04:
255
15.6k
        {
256
          /** 0000 0100     addw  %0, #%1       */
257
15.6k
          if (trace)
258
0
            {
259
0
              printf ("\033[33m%s\033[0m  %02x\n",
260
0
                     "/** 0000 0100     addw  %0, #%1       */",
261
0
                     op[0]);
262
0
            }
263
15.6k
          SYNTAX("addw  %0, #%1");
264
15.6k
#line 277 "rl78-decode.opc"
265
15.6k
          ID(add); W(); DR(AX); SC(IMMU(2)); Fzac;
266
267
15.6k
        }
268
15.6k
      break;
269
12.1k
    case 0x06:
270
12.1k
        {
271
          /** 0000 0110     addw  %0, %1        */
272
12.1k
          if (trace)
273
0
            {
274
0
              printf ("\033[33m%s\033[0m  %02x\n",
275
0
                     "/** 0000 0110     addw  %0, %1        */",
276
0
                     op[0]);
277
0
            }
278
12.1k
          SYNTAX("addw  %0, %1");
279
12.1k
#line 283 "rl78-decode.opc"
280
12.1k
          ID(add); W(); DR(AX); SM(None, SADDR); Fzac;
281
282
12.1k
        }
283
12.1k
      break;
284
11.4k
    case 0x08:
285
11.4k
        {
286
          /** 0000 1000     xch a, x        */
287
11.4k
          if (trace)
288
0
            {
289
0
              printf ("\033[33m%s\033[0m  %02x\n",
290
0
                     "/** 0000 1000     xch a, x        */",
291
0
                     op[0]);
292
0
            }
293
11.4k
          SYNTAX("xch a, x");
294
11.4k
#line 1240 "rl78-decode.opc"
295
11.4k
          ID(xch); DR(A); SR(X);
296
297
        /*----------------------------------------------------------------------*/
298
299
11.4k
        }
300
11.4k
      break;
301
9.17k
    case 0x09:
302
9.17k
        {
303
          /** 0000 1001     mov %0, %e1       */
304
9.17k
          if (trace)
305
0
            {
306
0
              printf ("\033[33m%s\033[0m  %02x\n",
307
0
                     "/** 0000 1001     mov %0, %e1       */",
308
0
                     op[0]);
309
0
            }
310
9.17k
          SYNTAX("mov %0, %e1");
311
9.17k
#line 684 "rl78-decode.opc"
312
9.17k
          ID(mov); DR(A); SM(B, IMMU(2));
313
314
9.17k
        }
315
9.17k
      break;
316
6.21k
    case 0x0a:
317
6.21k
        {
318
          /** 0000 1010     add %0, #%1       */
319
6.21k
          if (trace)
320
0
            {
321
0
              printf ("\033[33m%s\033[0m  %02x\n",
322
0
                     "/** 0000 1010     add %0, #%1       */",
323
0
                     op[0]);
324
0
            }
325
6.21k
          SYNTAX("add %0, #%1");
326
6.21k
#line 234 "rl78-decode.opc"
327
6.21k
          ID(add); DM(None, SADDR); SC(IMMU(1)); Fzac;
328
329
        /*----------------------------------------------------------------------*/
330
331
6.21k
        }
332
6.21k
      break;
333
6.70k
    case 0x0b:
334
6.70k
        {
335
          /** 0000 1011     add %0, %1        */
336
6.70k
          if (trace)
337
0
            {
338
0
              printf ("\033[33m%s\033[0m  %02x\n",
339
0
                     "/** 0000 1011     add %0, %1        */",
340
0
                     op[0]);
341
0
            }
342
6.70k
          SYNTAX("add %0, %1");
343
6.70k
#line 228 "rl78-decode.opc"
344
6.70k
          ID(add); DR(A); SM(None, SADDR); Fzac;
345
346
6.70k
        }
347
6.70k
      break;
348
7.62k
    case 0x0c:
349
7.62k
        {
350
          /** 0000 1100     add %0, #%1       */
351
7.62k
          if (trace)
352
0
            {
353
0
              printf ("\033[33m%s\033[0m  %02x\n",
354
0
                     "/** 0000 1100     add %0, #%1       */",
355
0
                     op[0]);
356
0
            }
357
7.62k
          SYNTAX("add %0, #%1");
358
7.62k
#line 222 "rl78-decode.opc"
359
7.62k
          ID(add); DR(A); SC(IMMU(1)); Fzac;
360
361
7.62k
        }
362
7.62k
      break;
363
11.0k
    case 0x0d:
364
11.0k
        {
365
          /** 0000 1101     add %0, %e1       */
366
11.0k
          if (trace)
367
0
            {
368
0
              printf ("\033[33m%s\033[0m  %02x\n",
369
0
                     "/** 0000 1101     add %0, %e1       */",
370
0
                     op[0]);
371
0
            }
372
11.0k
          SYNTAX("add %0, %e1");
373
11.0k
#line 210 "rl78-decode.opc"
374
11.0k
          ID(add); DR(A); SM(HL, 0); Fzac;
375
376
11.0k
        }
377
11.0k
      break;
378
13.2k
    case 0x0e:
379
13.2k
        {
380
          /** 0000 1110     add %0, %ea1      */
381
13.2k
          if (trace)
382
0
            {
383
0
              printf ("\033[33m%s\033[0m  %02x\n",
384
0
                     "/** 0000 1110     add %0, %ea1      */",
385
0
                     op[0]);
386
0
            }
387
13.2k
          SYNTAX("add %0, %ea1");
388
13.2k
#line 216 "rl78-decode.opc"
389
13.2k
          ID(add); DR(A); SM(HL, IMMU(1)); Fzac;
390
391
13.2k
        }
392
13.2k
      break;
393
8.41k
    case 0x0f:
394
8.41k
        {
395
          /** 0000 1111     add %0, %e!1      */
396
8.41k
          if (trace)
397
0
            {
398
0
              printf ("\033[33m%s\033[0m  %02x\n",
399
0
                     "/** 0000 1111     add %0, %e!1      */",
400
0
                     op[0]);
401
0
            }
402
8.41k
          SYNTAX("add %0, %e!1");
403
8.41k
#line 207 "rl78-decode.opc"
404
8.41k
          ID(add); DR(A); SM(None, IMMU(2)); Fzac;
405
406
8.41k
        }
407
8.41k
      break;
408
18.8k
    case 0x10:
409
18.8k
        {
410
          /** 0001 0000     addw  %0, #%1       */
411
18.8k
          if (trace)
412
0
            {
413
0
              printf ("\033[33m%s\033[0m  %02x\n",
414
0
                     "/** 0001 0000     addw  %0, #%1       */",
415
0
                     op[0]);
416
0
            }
417
18.8k
          SYNTAX("addw  %0, #%1");
418
18.8k
#line 286 "rl78-decode.opc"
419
18.8k
          ID(add); W(); DR(SP); SC(IMMU(1)); Fzac;
420
421
        /*----------------------------------------------------------------------*/
422
423
18.8k
        }
424
18.8k
      break;
425
368k
    case 0x11:
426
368k
        {
427
          /** 0001 0001     es:         */
428
368k
          if (trace)
429
0
            {
430
0
              printf ("\033[33m%s\033[0m  %02x\n",
431
0
                     "/** 0001 0001     es:         */",
432
0
                     op[0]);
433
0
            }
434
368k
          SYNTAX("es:");
435
368k
#line 199 "rl78-decode.opc"
436
368k
          DE(); SE();
437
368k
          op ++;
438
368k
          pc ++;
439
368k
          goto start_again;
440
441
        /*----------------------------------------------------------------------*/
442
443
62.3k
        }
444
0
      break;
445
8.56k
    case 0x12:
446
16.0k
    case 0x14:
447
20.5k
    case 0x16:
448
20.5k
        {
449
          /** 0001 0ra0     movw  %0, %1        */
450
20.5k
#line 865 "rl78-decode.opc"
451
20.5k
          int ra AU = (op[0] >> 1) & 0x03;
452
20.5k
          if (trace)
453
0
            {
454
0
              printf ("\033[33m%s\033[0m  %02x\n",
455
0
                     "/** 0001 0ra0     movw  %0, %1        */",
456
0
                     op[0]);
457
0
              printf ("  ra = 0x%x\n", ra);
458
0
            }
459
20.5k
          SYNTAX("movw  %0, %1");
460
20.5k
#line 865 "rl78-decode.opc"
461
20.5k
          ID(mov); W(); DRW(ra); SR(AX);
462
463
20.5k
        }
464
20.5k
      break;
465
7.93k
    case 0x13:
466
14.7k
    case 0x15:
467
22.8k
    case 0x17:
468
22.8k
        {
469
          /** 0001 0ra1     movw  %0, %1        */
470
22.8k
#line 862 "rl78-decode.opc"
471
22.8k
          int ra AU = (op[0] >> 1) & 0x03;
472
22.8k
          if (trace)
473
0
            {
474
0
              printf ("\033[33m%s\033[0m  %02x\n",
475
0
                     "/** 0001 0ra1     movw  %0, %1        */",
476
0
                     op[0]);
477
0
              printf ("  ra = 0x%x\n", ra);
478
0
            }
479
22.8k
          SYNTAX("movw  %0, %1");
480
22.8k
#line 862 "rl78-decode.opc"
481
22.8k
          ID(mov); W(); DR(AX); SRW(ra);
482
483
22.8k
        }
484
22.8k
      break;
485
4.88k
    case 0x18:
486
4.88k
        {
487
          /** 0001 1000     mov %e0, %1       */
488
4.88k
          if (trace)
489
0
            {
490
0
              printf ("\033[33m%s\033[0m  %02x\n",
491
0
                     "/** 0001 1000     mov %e0, %1       */",
492
0
                     op[0]);
493
0
            }
494
4.88k
          SYNTAX("mov %e0, %1");
495
4.88k
#line 735 "rl78-decode.opc"
496
4.88k
          ID(mov); DM(B, IMMU(2)); SR(A);
497
498
4.88k
        }
499
4.88k
      break;
500
2.04k
    case 0x19:
501
2.04k
        {
502
          /** 0001 1001     mov %e0, #%1      */
503
2.04k
          if (trace)
504
0
            {
505
0
              printf ("\033[33m%s\033[0m  %02x\n",
506
0
                     "/** 0001 1001     mov %e0, #%1      */",
507
0
                     op[0]);
508
0
            }
509
2.04k
          SYNTAX("mov %e0, #%1");
510
2.04k
#line 732 "rl78-decode.opc"
511
2.04k
          ID(mov); DM(B, IMMU(2)); SC(IMMU(1));
512
513
2.04k
        }
514
2.04k
      break;
515
4.42k
    case 0x1a:
516
4.42k
        {
517
          /** 0001 1010     addc  %0, #%1       */
518
4.42k
          if (trace)
519
0
            {
520
0
              printf ("\033[33m%s\033[0m  %02x\n",
521
0
                     "/** 0001 1010     addc  %0, #%1       */",
522
0
                     op[0]);
523
0
            }
524
4.42k
          SYNTAX("addc  %0, #%1");
525
4.42k
#line 266 "rl78-decode.opc"
526
4.42k
          ID(addc); DM(None, SADDR); SC(IMMU(1)); Fzac;
527
528
        /*----------------------------------------------------------------------*/
529
530
4.42k
        }
531
4.42k
      break;
532
7.19k
    case 0x1b:
533
7.19k
        {
534
          /** 0001 1011     addc  %0, %1        */
535
7.19k
          if (trace)
536
0
            {
537
0
              printf ("\033[33m%s\033[0m  %02x\n",
538
0
                     "/** 0001 1011     addc  %0, %1        */",
539
0
                     op[0]);
540
0
            }
541
7.19k
          SYNTAX("addc  %0, %1");
542
7.19k
#line 263 "rl78-decode.opc"
543
7.19k
          ID(addc); DR(A); SM(None, SADDR); Fzac;
544
545
7.19k
        }
546
7.19k
      break;
547
8.39k
    case 0x1c:
548
8.39k
        {
549
          /** 0001 1100     addc  %0, #%1       */
550
8.39k
          if (trace)
551
0
            {
552
0
              printf ("\033[33m%s\033[0m  %02x\n",
553
0
                     "/** 0001 1100     addc  %0, #%1       */",
554
0
                     op[0]);
555
0
            }
556
8.39k
          SYNTAX("addc  %0, #%1");
557
8.39k
#line 254 "rl78-decode.opc"
558
8.39k
          ID(addc); DR(A); SC(IMMU(1)); Fzac;
559
560
8.39k
        }
561
8.39k
      break;
562
5.05k
    case 0x1d:
563
5.05k
        {
564
          /** 0001 1101     addc  %0, %e1       */
565
5.05k
          if (trace)
566
0
            {
567
0
              printf ("\033[33m%s\033[0m  %02x\n",
568
0
                     "/** 0001 1101     addc  %0, %e1       */",
569
0
                     op[0]);
570
0
            }
571
5.05k
          SYNTAX("addc  %0, %e1");
572
5.05k
#line 242 "rl78-decode.opc"
573
5.05k
          ID(addc); DR(A); SM(HL, 0); Fzac;
574
575
5.05k
        }
576
5.05k
      break;
577
15.2k
    case 0x1e:
578
15.2k
        {
579
          /** 0001 1110     addc  %0, %ea1      */
580
15.2k
          if (trace)
581
0
            {
582
0
              printf ("\033[33m%s\033[0m  %02x\n",
583
0
                     "/** 0001 1110     addc  %0, %ea1      */",
584
0
                     op[0]);
585
0
            }
586
15.2k
          SYNTAX("addc  %0, %ea1");
587
15.2k
#line 251 "rl78-decode.opc"
588
15.2k
          ID(addc); DR(A); SM(HL, IMMU(1)); Fzac;
589
590
15.2k
        }
591
15.2k
      break;
592
5.04k
    case 0x1f:
593
5.04k
        {
594
          /** 0001 1111     addc  %0, %e!1      */
595
5.04k
          if (trace)
596
0
            {
597
0
              printf ("\033[33m%s\033[0m  %02x\n",
598
0
                     "/** 0001 1111     addc  %0, %e!1      */",
599
0
                     op[0]);
600
0
            }
601
5.04k
          SYNTAX("addc  %0, %e!1");
602
5.04k
#line 239 "rl78-decode.opc"
603
5.04k
          ID(addc); DR(A); SM(None, IMMU(2)); Fzac;
604
605
5.04k
        }
606
5.04k
      break;
607
14.8k
    case 0x20:
608
14.8k
        {
609
          /** 0010 0000     subw  %0, #%1       */
610
14.8k
          if (trace)
611
0
            {
612
0
              printf ("\033[33m%s\033[0m  %02x\n",
613
0
                     "/** 0010 0000     subw  %0, #%1       */",
614
0
                     op[0]);
615
0
            }
616
14.8k
          SYNTAX("subw  %0, #%1");
617
14.8k
#line 1204 "rl78-decode.opc"
618
14.8k
          ID(sub); W(); DR(SP); SC(IMMU(1)); Fzac;
619
620
        /*----------------------------------------------------------------------*/
621
622
14.8k
        }
623
14.8k
      break;
624
8.61k
    case 0x21:
625
18.5k
    case 0x23:
626
27.4k
    case 0x25:
627
35.0k
    case 0x27:
628
35.0k
        {
629
          /** 0010 0rw1     subw  %0, %1        */
630
35.0k
#line 1198 "rl78-decode.opc"
631
35.0k
          int rw AU = (op[0] >> 1) & 0x03;
632
35.0k
          if (trace)
633
0
            {
634
0
              printf ("\033[33m%s\033[0m  %02x\n",
635
0
                     "/** 0010 0rw1     subw  %0, %1        */",
636
0
                     op[0]);
637
0
              printf ("  rw = 0x%x\n", rw);
638
0
            }
639
35.0k
          SYNTAX("subw  %0, %1");
640
35.0k
#line 1198 "rl78-decode.opc"
641
35.0k
          ID(sub); W(); DR(AX); SRW(rw); Fzac;
642
643
35.0k
        }
644
35.0k
      break;
645
3.06k
    case 0x22:
646
3.06k
        {
647
          /** 0010 0010     subw  %0, %e!1      */
648
3.06k
          if (trace)
649
0
            {
650
0
              printf ("\033[33m%s\033[0m  %02x\n",
651
0
                     "/** 0010 0010     subw  %0, %e!1      */",
652
0
                     op[0]);
653
0
            }
654
3.06k
          SYNTAX("subw  %0, %e!1");
655
3.06k
#line 1189 "rl78-decode.opc"
656
3.06k
          ID(sub); W(); DR(AX); SM(None, IMMU(2)); Fzac;
657
658
3.06k
        }
659
3.06k
      break;
660
5.38k
    case 0x24:
661
5.38k
        {
662
          /** 0010 0100     subw  %0, #%1       */
663
5.38k
          if (trace)
664
0
            {
665
0
              printf ("\033[33m%s\033[0m  %02x\n",
666
0
                     "/** 0010 0100     subw  %0, #%1       */",
667
0
                     op[0]);
668
0
            }
669
5.38k
          SYNTAX("subw  %0, #%1");
670
5.38k
#line 1195 "rl78-decode.opc"
671
5.38k
          ID(sub); W(); DR(AX); SC(IMMU(2)); Fzac;
672
673
5.38k
        }
674
5.38k
      break;
675
6.87k
    case 0x26:
676
6.87k
        {
677
          /** 0010 0110     subw  %0, %1        */
678
6.87k
          if (trace)
679
0
            {
680
0
              printf ("\033[33m%s\033[0m  %02x\n",
681
0
                     "/** 0010 0110     subw  %0, %1        */",
682
0
                     op[0]);
683
0
            }
684
6.87k
          SYNTAX("subw  %0, %1");
685
6.87k
#line 1201 "rl78-decode.opc"
686
6.87k
          ID(sub); W(); DR(AX); SM(None, SADDR); Fzac;
687
688
6.87k
        }
689
6.87k
      break;
690
4.94k
    case 0x28:
691
4.94k
        {
692
          /** 0010 1000     mov %e0, %1       */
693
4.94k
          if (trace)
694
0
            {
695
0
              printf ("\033[33m%s\033[0m  %02x\n",
696
0
                     "/** 0010 1000     mov %e0, %1       */",
697
0
                     op[0]);
698
0
            }
699
4.94k
          SYNTAX("mov %e0, %1");
700
4.94k
#line 747 "rl78-decode.opc"
701
4.94k
          ID(mov); DM(C, IMMU(2)); SR(A);
702
703
4.94k
        }
704
4.94k
      break;
705
4.52k
    case 0x29:
706
4.52k
        {
707
          /** 0010 1001     mov %0, %e1       */
708
4.52k
          if (trace)
709
0
            {
710
0
              printf ("\033[33m%s\033[0m  %02x\n",
711
0
                     "/** 0010 1001     mov %0, %e1       */",
712
0
                     op[0]);
713
0
            }
714
4.52k
          SYNTAX("mov %0, %e1");
715
4.52k
#line 690 "rl78-decode.opc"
716
4.52k
          ID(mov); DR(A); SM(C, IMMU(2));
717
718
4.52k
        }
719
4.52k
      break;
720
5.23k
    case 0x2a:
721
5.23k
        {
722
          /** 0010 1010     sub %0, #%1       */
723
5.23k
          if (trace)
724
0
            {
725
0
              printf ("\033[33m%s\033[0m  %02x\n",
726
0
                     "/** 0010 1010     sub %0, #%1       */",
727
0
                     op[0]);
728
0
            }
729
5.23k
          SYNTAX("sub %0, #%1");
730
5.23k
#line 1152 "rl78-decode.opc"
731
5.23k
          ID(sub); DM(None, SADDR); SC(IMMU(1)); Fzac;
732
733
        /*----------------------------------------------------------------------*/
734
735
5.23k
        }
736
5.23k
      break;
737
11.9k
    case 0x2b:
738
11.9k
        {
739
          /** 0010 1011     sub %0, %1        */
740
11.9k
          if (trace)
741
0
            {
742
0
              printf ("\033[33m%s\033[0m  %02x\n",
743
0
                     "/** 0010 1011     sub %0, %1        */",
744
0
                     op[0]);
745
0
            }
746
11.9k
          SYNTAX("sub %0, %1");
747
11.9k
#line 1146 "rl78-decode.opc"
748
11.9k
          ID(sub); DR(A); SM(None, SADDR); Fzac;
749
750
11.9k
        }
751
11.9k
      break;
752
6.68k
    case 0x2c:
753
6.68k
        {
754
          /** 0010 1100     sub %0, #%1       */
755
6.68k
          if (trace)
756
0
            {
757
0
              printf ("\033[33m%s\033[0m  %02x\n",
758
0
                     "/** 0010 1100     sub %0, #%1       */",
759
0
                     op[0]);
760
0
            }
761
6.68k
          SYNTAX("sub %0, #%1");
762
6.68k
#line 1140 "rl78-decode.opc"
763
6.68k
          ID(sub); DR(A); SC(IMMU(1)); Fzac;
764
765
6.68k
        }
766
6.68k
      break;
767
6.21k
    case 0x2d:
768
6.21k
        {
769
          /** 0010 1101     sub %0, %e1       */
770
6.21k
          if (trace)
771
0
            {
772
0
              printf ("\033[33m%s\033[0m  %02x\n",
773
0
                     "/** 0010 1101     sub %0, %e1       */",
774
0
                     op[0]);
775
0
            }
776
6.21k
          SYNTAX("sub %0, %e1");
777
6.21k
#line 1128 "rl78-decode.opc"
778
6.21k
          ID(sub); DR(A); SM(HL, 0); Fzac;
779
780
6.21k
        }
781
6.21k
      break;
782
8.00k
    case 0x2e:
783
8.00k
        {
784
          /** 0010 1110     sub %0, %ea1      */
785
8.00k
          if (trace)
786
0
            {
787
0
              printf ("\033[33m%s\033[0m  %02x\n",
788
0
                     "/** 0010 1110     sub %0, %ea1      */",
789
0
                     op[0]);
790
0
            }
791
8.00k
          SYNTAX("sub %0, %ea1");
792
8.00k
#line 1134 "rl78-decode.opc"
793
8.00k
          ID(sub); DR(A); SM(HL, IMMU(1)); Fzac;
794
795
8.00k
        }
796
8.00k
      break;
797
6.32k
    case 0x2f:
798
6.32k
        {
799
          /** 0010 1111     sub %0, %e!1      */
800
6.32k
          if (trace)
801
0
            {
802
0
              printf ("\033[33m%s\033[0m  %02x\n",
803
0
                     "/** 0010 1111     sub %0, %e!1      */",
804
0
                     op[0]);
805
0
            }
806
6.32k
          SYNTAX("sub %0, %e!1");
807
6.32k
#line 1125 "rl78-decode.opc"
808
6.32k
          ID(sub); DR(A); SM(None, IMMU(2)); Fzac;
809
810
6.32k
        }
811
6.32k
      break;
812
20.8k
    case 0x30:
813
35.8k
    case 0x32:
814
46.0k
    case 0x34:
815
54.1k
    case 0x36:
816
54.1k
        {
817
          /** 0011 0rg0     movw  %0, #%1       */
818
54.1k
#line 859 "rl78-decode.opc"
819
54.1k
          int rg AU = (op[0] >> 1) & 0x03;
820
54.1k
          if (trace)
821
0
            {
822
0
              printf ("\033[33m%s\033[0m  %02x\n",
823
0
                     "/** 0011 0rg0     movw  %0, #%1       */",
824
0
                     op[0]);
825
0
              printf ("  rg = 0x%x\n", rg);
826
0
            }
827
54.1k
          SYNTAX("movw  %0, #%1");
828
54.1k
#line 859 "rl78-decode.opc"
829
54.1k
          ID(mov); W(); DRW(rg); SC(IMMU(2));
830
831
54.1k
        }
832
54.1k
      break;
833
27.8k
    case 0x31:
834
27.8k
        GETBYTE ();
835
27.8k
        switch (op[1] & 0x8f)
836
27.8k
        {
837
3.62k
          case 0x00:
838
3.62k
              {
839
                /** 0011 0001 0bit 0000   btclr %s1, $%a0     */
840
3.62k
#line 422 "rl78-decode.opc"
841
3.62k
                int bit AU = (op[1] >> 4) & 0x07;
842
3.62k
                if (trace)
843
0
                  {
844
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
845
0
                           "/** 0011 0001 0bit 0000   btclr %s1, $%a0     */",
846
0
                           op[0], op[1]);
847
0
                    printf ("  bit = 0x%x\n", bit);
848
0
                  }
849
3.62k
                SYNTAX("btclr %s1, $%a0");
850
3.62k
#line 422 "rl78-decode.opc"
851
3.62k
                ID(branch_cond_clear); SM(None, SADDR); SB(bit); DC(pc+IMMS(1)+4); COND(T);
852
853
              /*----------------------------------------------------------------------*/
854
855
3.62k
              }
856
3.62k
            break;
857
4.11k
          case 0x01:
858
4.11k
              {
859
                /** 0011 0001 0bit 0001   btclr %1, $%a0      */
860
4.11k
#line 416 "rl78-decode.opc"
861
4.11k
                int bit AU = (op[1] >> 4) & 0x07;
862
4.11k
                if (trace)
863
0
                  {
864
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
865
0
                           "/** 0011 0001 0bit 0001   btclr %1, $%a0      */",
866
0
                           op[0], op[1]);
867
0
                    printf ("  bit = 0x%x\n", bit);
868
0
                  }
869
4.11k
                SYNTAX("btclr %1, $%a0");
870
4.11k
#line 416 "rl78-decode.opc"
871
4.11k
                ID(branch_cond_clear); DC(pc+IMMS(1)+3); SR(A); SB(bit); COND(T);
872
873
4.11k
              }
874
4.11k
            break;
875
1.62k
          case 0x02:
876
1.62k
              {
877
                /** 0011 0001 0bit 0010   bt  %s1, $%a0     */
878
1.62k
#line 408 "rl78-decode.opc"
879
1.62k
                int bit AU = (op[1] >> 4) & 0x07;
880
1.62k
                if (trace)
881
0
                  {
882
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
883
0
                           "/** 0011 0001 0bit 0010   bt  %s1, $%a0     */",
884
0
                           op[0], op[1]);
885
0
                    printf ("  bit = 0x%x\n", bit);
886
0
                  }
887
1.62k
                SYNTAX("bt  %s1, $%a0");
888
1.62k
#line 408 "rl78-decode.opc"
889
1.62k
                ID(branch_cond); SM(None, SADDR); SB(bit); DC(pc+IMMS(1)+4); COND(T);
890
891
              /*----------------------------------------------------------------------*/
892
893
1.62k
              }
894
1.62k
            break;
895
858
          case 0x03:
896
858
              {
897
                /** 0011 0001 0bit 0011   bt  %1, $%a0      */
898
858
#line 402 "rl78-decode.opc"
899
858
                int bit AU = (op[1] >> 4) & 0x07;
900
858
                if (trace)
901
0
                  {
902
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
903
0
                           "/** 0011 0001 0bit 0011   bt  %1, $%a0      */",
904
0
                           op[0], op[1]);
905
0
                    printf ("  bit = 0x%x\n", bit);
906
0
                  }
907
858
                SYNTAX("bt  %1, $%a0");
908
858
#line 402 "rl78-decode.opc"
909
858
                ID(branch_cond); DC(pc+IMMS(1)+3); SR(A); SB(bit); COND(T);
910
911
858
              }
912
858
            break;
913
1.56k
          case 0x04:
914
1.56k
              {
915
                /** 0011 0001 0bit 0100   bf  %s1, $%a0     */
916
1.56k
#line 369 "rl78-decode.opc"
917
1.56k
                int bit AU = (op[1] >> 4) & 0x07;
918
1.56k
                if (trace)
919
0
                  {
920
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
921
0
                           "/** 0011 0001 0bit 0100   bf  %s1, $%a0     */",
922
0
                           op[0], op[1]);
923
0
                    printf ("  bit = 0x%x\n", bit);
924
0
                  }
925
1.56k
                SYNTAX("bf  %s1, $%a0");
926
1.56k
#line 369 "rl78-decode.opc"
927
1.56k
                ID(branch_cond); SM(None, SADDR); SB(bit); DC(pc+IMMS(1)+4); COND(F);
928
929
              /*----------------------------------------------------------------------*/
930
931
1.56k
              }
932
1.56k
            break;
933
1.32k
          case 0x05:
934
1.32k
              {
935
                /** 0011 0001 0bit 0101   bf  %1, $%a0      */
936
1.32k
#line 363 "rl78-decode.opc"
937
1.32k
                int bit AU = (op[1] >> 4) & 0x07;
938
1.32k
                if (trace)
939
0
                  {
940
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
941
0
                           "/** 0011 0001 0bit 0101   bf  %1, $%a0      */",
942
0
                           op[0], op[1]);
943
0
                    printf ("  bit = 0x%x\n", bit);
944
0
                  }
945
1.32k
                SYNTAX("bf  %1, $%a0");
946
1.32k
#line 363 "rl78-decode.opc"
947
1.32k
                ID(branch_cond); DC(pc+IMMS(1)+3); SR(A); SB(bit); COND(F);
948
949
1.32k
              }
950
1.32k
            break;
951
1.06k
          case 0x07:
952
1.06k
              {
953
                /** 0011 0001 0cnt 0111   shl %0, %1        */
954
1.06k
#line 1081 "rl78-decode.opc"
955
1.06k
                int cnt AU = (op[1] >> 4) & 0x07;
956
1.06k
                if (trace)
957
0
                  {
958
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
959
0
                           "/** 0011 0001 0cnt 0111   shl %0, %1        */",
960
0
                           op[0], op[1]);
961
0
                    printf ("  cnt = 0x%x\n", cnt);
962
0
                  }
963
1.06k
                SYNTAX("shl %0, %1");
964
1.06k
#line 1081 "rl78-decode.opc"
965
1.06k
                ID(shl); DR(C); SC(cnt);
966
967
1.06k
              }
968
1.06k
            break;
969
1.73k
          case 0x08:
970
1.73k
              {
971
                /** 0011 0001 0cnt 1000   shl %0, %1        */
972
1.73k
#line 1078 "rl78-decode.opc"
973
1.73k
                int cnt AU = (op[1] >> 4) & 0x07;
974
1.73k
                if (trace)
975
0
                  {
976
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
977
0
                           "/** 0011 0001 0cnt 1000   shl %0, %1        */",
978
0
                           op[0], op[1]);
979
0
                    printf ("  cnt = 0x%x\n", cnt);
980
0
                  }
981
1.73k
                SYNTAX("shl %0, %1");
982
1.73k
#line 1078 "rl78-decode.opc"
983
1.73k
                ID(shl); DR(B); SC(cnt);
984
985
1.73k
              }
986
1.73k
            break;
987
394
          case 0x09:
988
394
              {
989
                /** 0011 0001 0cnt 1001   shl %0, %1        */
990
394
#line 1075 "rl78-decode.opc"
991
394
                int cnt AU = (op[1] >> 4) & 0x07;
992
394
                if (trace)
993
0
                  {
994
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
995
0
                           "/** 0011 0001 0cnt 1001   shl %0, %1        */",
996
0
                           op[0], op[1]);
997
0
                    printf ("  cnt = 0x%x\n", cnt);
998
0
                  }
999
394
                SYNTAX("shl %0, %1");
1000
394
#line 1075 "rl78-decode.opc"
1001
394
                ID(shl); DR(A); SC(cnt);
1002
1003
394
              }
1004
394
            break;
1005
175
          case 0x0a:
1006
175
              {
1007
                /** 0011 0001 0cnt 1010   shr %0, %1        */
1008
175
#line 1092 "rl78-decode.opc"
1009
175
                int cnt AU = (op[1] >> 4) & 0x07;
1010
175
                if (trace)
1011
0
                  {
1012
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1013
0
                           "/** 0011 0001 0cnt 1010   shr %0, %1        */",
1014
0
                           op[0], op[1]);
1015
0
                    printf ("  cnt = 0x%x\n", cnt);
1016
0
                  }
1017
175
                SYNTAX("shr %0, %1");
1018
175
#line 1092 "rl78-decode.opc"
1019
175
                ID(shr); DR(A); SC(cnt);
1020
1021
175
              }
1022
175
            break;
1023
636
          case 0x0b:
1024
636
              {
1025
                /** 0011 0001 0cnt 1011   sar %0, %1        */
1026
636
#line 1039 "rl78-decode.opc"
1027
636
                int cnt AU = (op[1] >> 4) & 0x07;
1028
636
                if (trace)
1029
0
                  {
1030
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1031
0
                           "/** 0011 0001 0cnt 1011   sar %0, %1        */",
1032
0
                           op[0], op[1]);
1033
0
                    printf ("  cnt = 0x%x\n", cnt);
1034
0
                  }
1035
636
                SYNTAX("sar %0, %1");
1036
636
#line 1039 "rl78-decode.opc"
1037
636
                ID(sar); DR(A); SC(cnt);
1038
1039
636
              }
1040
636
            break;
1041
168
          case 0x0c:
1042
760
          case 0x8c:
1043
760
              {
1044
                /** 0011 0001 wcnt 1100   shlw  %0, %1        */
1045
760
#line 1087 "rl78-decode.opc"
1046
760
                int wcnt AU = (op[1] >> 4) & 0x0f;
1047
760
                if (trace)
1048
0
                  {
1049
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1050
0
                           "/** 0011 0001 wcnt 1100   shlw  %0, %1        */",
1051
0
                           op[0], op[1]);
1052
0
                    printf ("  wcnt = 0x%x\n", wcnt);
1053
0
                  }
1054
760
                SYNTAX("shlw  %0, %1");
1055
760
#line 1087 "rl78-decode.opc"
1056
760
                ID(shl); W(); DR(BC); SC(wcnt);
1057
1058
              /*----------------------------------------------------------------------*/
1059
1060
760
              }
1061
760
            break;
1062
436
          case 0x0d:
1063
825
          case 0x8d:
1064
825
              {
1065
                /** 0011 0001 wcnt 1101   shlw  %0, %1        */
1066
825
#line 1084 "rl78-decode.opc"
1067
825
                int wcnt AU = (op[1] >> 4) & 0x0f;
1068
825
                if (trace)
1069
0
                  {
1070
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1071
0
                           "/** 0011 0001 wcnt 1101   shlw  %0, %1        */",
1072
0
                           op[0], op[1]);
1073
0
                    printf ("  wcnt = 0x%x\n", wcnt);
1074
0
                  }
1075
825
                SYNTAX("shlw  %0, %1");
1076
825
#line 1084 "rl78-decode.opc"
1077
825
                ID(shl); W(); DR(AX); SC(wcnt);
1078
1079
825
              }
1080
825
            break;
1081
721
          case 0x0e:
1082
1.03k
          case 0x8e:
1083
1.03k
              {
1084
                /** 0011 0001 wcnt 1110   shrw  %0, %1        */
1085
1.03k
#line 1095 "rl78-decode.opc"
1086
1.03k
                int wcnt AU = (op[1] >> 4) & 0x0f;
1087
1.03k
                if (trace)
1088
0
                  {
1089
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1090
0
                           "/** 0011 0001 wcnt 1110   shrw  %0, %1        */",
1091
0
                           op[0], op[1]);
1092
0
                    printf ("  wcnt = 0x%x\n", wcnt);
1093
0
                  }
1094
1.03k
                SYNTAX("shrw  %0, %1");
1095
1.03k
#line 1095 "rl78-decode.opc"
1096
1.03k
                ID(shr); W(); DR(AX); SC(wcnt);
1097
1098
              /*----------------------------------------------------------------------*/
1099
1100
1.03k
              }
1101
1.03k
            break;
1102
320
          case 0x0f:
1103
1.20k
          case 0x8f:
1104
1.20k
              {
1105
                /** 0011 0001 wcnt 1111   sarw  %0, %1        */
1106
1.20k
#line 1042 "rl78-decode.opc"
1107
1.20k
                int wcnt AU = (op[1] >> 4) & 0x0f;
1108
1.20k
                if (trace)
1109
0
                  {
1110
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1111
0
                           "/** 0011 0001 wcnt 1111   sarw  %0, %1        */",
1112
0
                           op[0], op[1]);
1113
0
                    printf ("  wcnt = 0x%x\n", wcnt);
1114
0
                  }
1115
1.20k
                SYNTAX("sarw  %0, %1");
1116
1.20k
#line 1042 "rl78-decode.opc"
1117
1.20k
                ID(sar); W(); DR(AX); SC(wcnt);
1118
1119
              /*----------------------------------------------------------------------*/
1120
1121
1.20k
              }
1122
1.20k
            break;
1123
583
          case 0x80:
1124
583
              {
1125
                /** 0011 0001 1bit 0000   btclr %s1, $%a0     */
1126
583
#line 419 "rl78-decode.opc"
1127
583
                int bit AU = (op[1] >> 4) & 0x07;
1128
583
                if (trace)
1129
0
                  {
1130
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1131
0
                           "/** 0011 0001 1bit 0000   btclr %s1, $%a0     */",
1132
0
                           op[0], op[1]);
1133
0
                    printf ("  bit = 0x%x\n", bit);
1134
0
                  }
1135
583
                SYNTAX("btclr %s1, $%a0");
1136
583
#line 419 "rl78-decode.opc"
1137
583
                ID(branch_cond_clear); SM(None, SFR); SB(bit); DC(pc+IMMS(1)+4); COND(T);
1138
1139
583
              }
1140
583
            break;
1141
298
          case 0x81:
1142
298
              {
1143
                /** 0011 0001 1bit 0001   btclr %e1, $%a0     */
1144
298
#line 413 "rl78-decode.opc"
1145
298
                int bit AU = (op[1] >> 4) & 0x07;
1146
298
                if (trace)
1147
0
                  {
1148
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1149
0
                           "/** 0011 0001 1bit 0001   btclr %e1, $%a0     */",
1150
0
                           op[0], op[1]);
1151
0
                    printf ("  bit = 0x%x\n", bit);
1152
0
                  }
1153
298
                SYNTAX("btclr %e1, $%a0");
1154
298
#line 413 "rl78-decode.opc"
1155
298
                ID(branch_cond_clear); DC(pc+IMMS(1)+3); SM(HL,0); SB(bit); COND(T);
1156
1157
298
              }
1158
298
            break;
1159
1.31k
          case 0x82:
1160
1.31k
              {
1161
                /** 0011 0001 1bit 0010   bt  %s1, $%a0     */
1162
1.31k
#line 405 "rl78-decode.opc"
1163
1.31k
                int bit AU = (op[1] >> 4) & 0x07;
1164
1.31k
                if (trace)
1165
0
                  {
1166
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1167
0
                           "/** 0011 0001 1bit 0010   bt  %s1, $%a0     */",
1168
0
                           op[0], op[1]);
1169
0
                    printf ("  bit = 0x%x\n", bit);
1170
0
                  }
1171
1.31k
                SYNTAX("bt  %s1, $%a0");
1172
1.31k
#line 405 "rl78-decode.opc"
1173
1.31k
                ID(branch_cond); SM(None, SFR); SB(bit); DC(pc+IMMS(1)+4); COND(T);
1174
1175
1.31k
              }
1176
1.31k
            break;
1177
292
          case 0x83:
1178
292
              {
1179
                /** 0011 0001 1bit 0011   bt  %e1, $%a0     */
1180
292
#line 399 "rl78-decode.opc"
1181
292
                int bit AU = (op[1] >> 4) & 0x07;
1182
292
                if (trace)
1183
0
                  {
1184
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1185
0
                           "/** 0011 0001 1bit 0011   bt  %e1, $%a0     */",
1186
0
                           op[0], op[1]);
1187
0
                    printf ("  bit = 0x%x\n", bit);
1188
0
                  }
1189
292
                SYNTAX("bt  %e1, $%a0");
1190
292
#line 399 "rl78-decode.opc"
1191
292
                ID(branch_cond); DC(pc+IMMS(1)+3); SM(HL,0); SB(bit); COND(T);
1192
1193
292
              }
1194
292
            break;
1195
1.32k
          case 0x84:
1196
1.32k
              {
1197
                /** 0011 0001 1bit 0100   bf  %s1, $%a0     */
1198
1.32k
#line 366 "rl78-decode.opc"
1199
1.32k
                int bit AU = (op[1] >> 4) & 0x07;
1200
1.32k
                if (trace)
1201
0
                  {
1202
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1203
0
                           "/** 0011 0001 1bit 0100   bf  %s1, $%a0     */",
1204
0
                           op[0], op[1]);
1205
0
                    printf ("  bit = 0x%x\n", bit);
1206
0
                  }
1207
1.32k
                SYNTAX("bf  %s1, $%a0");
1208
1.32k
#line 366 "rl78-decode.opc"
1209
1.32k
                ID(branch_cond); SM(None, SFR); SB(bit); DC(pc+IMMS(1)+4); COND(F);
1210
1211
1.32k
              }
1212
1.32k
            break;
1213
349
          case 0x85:
1214
349
              {
1215
                /** 0011 0001 1bit 0101   bf  %e1, $%a0     */
1216
349
#line 360 "rl78-decode.opc"
1217
349
                int bit AU = (op[1] >> 4) & 0x07;
1218
349
                if (trace)
1219
0
                  {
1220
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1221
0
                           "/** 0011 0001 1bit 0101   bf  %e1, $%a0     */",
1222
0
                           op[0], op[1]);
1223
0
                    printf ("  bit = 0x%x\n", bit);
1224
0
                  }
1225
349
                SYNTAX("bf  %e1, $%a0");
1226
349
#line 360 "rl78-decode.opc"
1227
349
                ID(branch_cond); DC(pc+IMMS(1)+3); SM(HL,0); SB(bit); COND(F);
1228
1229
349
              }
1230
349
            break;
1231
2.67k
          default: UNSUPPORTED(); break;
1232
27.8k
        }
1233
27.7k
      break;
1234
27.7k
    case 0x33:
1235
22.5k
    case 0x35:
1236
34.7k
    case 0x37:
1237
34.7k
        {
1238
          /** 0011 0ra1     xchw  %0, %1        */
1239
34.7k
#line 1245 "rl78-decode.opc"
1240
34.7k
          int ra AU = (op[0] >> 1) & 0x03;
1241
34.7k
          if (trace)
1242
0
            {
1243
0
              printf ("\033[33m%s\033[0m  %02x\n",
1244
0
                     "/** 0011 0ra1     xchw  %0, %1        */",
1245
0
                     op[0]);
1246
0
              printf ("  ra = 0x%x\n", ra);
1247
0
            }
1248
34.7k
          SYNTAX("xchw  %0, %1");
1249
34.7k
#line 1245 "rl78-decode.opc"
1250
34.7k
          ID(xch); W(); DR(AX); SRW(ra);
1251
1252
        /*----------------------------------------------------------------------*/
1253
1254
34.7k
        }
1255
34.7k
      break;
1256
8.38k
    case 0x38:
1257
8.38k
        {
1258
          /** 0011 1000     mov %e0, #%1      */
1259
8.38k
          if (trace)
1260
0
            {
1261
0
              printf ("\033[33m%s\033[0m  %02x\n",
1262
0
                     "/** 0011 1000     mov %e0, #%1      */",
1263
0
                     op[0]);
1264
0
            }
1265
8.38k
          SYNTAX("mov %e0, #%1");
1266
8.38k
#line 744 "rl78-decode.opc"
1267
8.38k
          ID(mov); DM(C, IMMU(2)); SC(IMMU(1));
1268
1269
8.38k
        }
1270
8.38k
      break;
1271
5.23k
    case 0x39:
1272
5.23k
        {
1273
          /** 0011 1001     mov %e0, #%1      */
1274
5.23k
          if (trace)
1275
0
            {
1276
0
              printf ("\033[33m%s\033[0m  %02x\n",
1277
0
                     "/** 0011 1001     mov %e0, #%1      */",
1278
0
                     op[0]);
1279
0
            }
1280
5.23k
          SYNTAX("mov %e0, #%1");
1281
5.23k
#line 738 "rl78-decode.opc"
1282
5.23k
          ID(mov); DM(BC, IMMU(2)); SC(IMMU(1));
1283
1284
5.23k
        }
1285
5.23k
      break;
1286
9.38k
    case 0x3a:
1287
9.38k
        {
1288
          /** 0011 1010     subc  %0, #%1       */
1289
9.38k
          if (trace)
1290
0
            {
1291
0
              printf ("\033[33m%s\033[0m  %02x\n",
1292
0
                     "/** 0011 1010     subc  %0, #%1       */",
1293
0
                     op[0]);
1294
0
            }
1295
9.38k
          SYNTAX("subc  %0, #%1");
1296
9.38k
#line 1184 "rl78-decode.opc"
1297
9.38k
          ID(subc); DM(None, SADDR); SC(IMMU(1)); Fzac;
1298
1299
        /*----------------------------------------------------------------------*/
1300
1301
9.38k
        }
1302
9.38k
      break;
1303
11.2k
    case 0x3b:
1304
11.2k
        {
1305
          /** 0011 1011     subc  %0, %1        */
1306
11.2k
          if (trace)
1307
0
            {
1308
0
              printf ("\033[33m%s\033[0m  %02x\n",
1309
0
                     "/** 0011 1011     subc  %0, %1        */",
1310
0
                     op[0]);
1311
0
            }
1312
11.2k
          SYNTAX("subc  %0, %1");
1313
11.2k
#line 1181 "rl78-decode.opc"
1314
11.2k
          ID(subc); DR(A); SM(None, SADDR); Fzac;
1315
1316
11.2k
        }
1317
11.2k
      break;
1318
3.97k
    case 0x3c:
1319
3.97k
        {
1320
          /** 0011 1100     subc  %0, #%1       */
1321
3.97k
          if (trace)
1322
0
            {
1323
0
              printf ("\033[33m%s\033[0m  %02x\n",
1324
0
                     "/** 0011 1100     subc  %0, #%1       */",
1325
0
                     op[0]);
1326
0
            }
1327
3.97k
          SYNTAX("subc  %0, #%1");
1328
3.97k
#line 1172 "rl78-decode.opc"
1329
3.97k
          ID(subc); DR(A); SC(IMMU(1)); Fzac;
1330
1331
3.97k
        }
1332
3.97k
      break;
1333
11.5k
    case 0x3d:
1334
11.5k
        {
1335
          /** 0011 1101     subc  %0, %e1       */
1336
11.5k
          if (trace)
1337
0
            {
1338
0
              printf ("\033[33m%s\033[0m  %02x\n",
1339
0
                     "/** 0011 1101     subc  %0, %e1       */",
1340
0
                     op[0]);
1341
0
            }
1342
11.5k
          SYNTAX("subc  %0, %e1");
1343
11.5k
#line 1160 "rl78-decode.opc"
1344
11.5k
          ID(subc); DR(A); SM(HL, 0); Fzac;
1345
1346
11.5k
        }
1347
11.5k
      break;
1348
8.08k
    case 0x3e:
1349
8.08k
        {
1350
          /** 0011 1110     subc  %0, %ea1      */
1351
8.08k
          if (trace)
1352
0
            {
1353
0
              printf ("\033[33m%s\033[0m  %02x\n",
1354
0
                     "/** 0011 1110     subc  %0, %ea1      */",
1355
0
                     op[0]);
1356
0
            }
1357
8.08k
          SYNTAX("subc  %0, %ea1");
1358
8.08k
#line 1169 "rl78-decode.opc"
1359
8.08k
          ID(subc); DR(A); SM(HL, IMMU(1)); Fzac;
1360
1361
8.08k
        }
1362
8.08k
      break;
1363
5.22k
    case 0x3f:
1364
5.22k
        {
1365
          /** 0011 1111     subc  %0, %e!1      */
1366
5.22k
          if (trace)
1367
0
            {
1368
0
              printf ("\033[33m%s\033[0m  %02x\n",
1369
0
                     "/** 0011 1111     subc  %0, %e!1      */",
1370
0
                     op[0]);
1371
0
            }
1372
5.22k
          SYNTAX("subc  %0, %e!1");
1373
5.22k
#line 1157 "rl78-decode.opc"
1374
5.22k
          ID(subc); DR(A); SM(None, IMMU(2)); Fzac;
1375
1376
5.22k
        }
1377
5.22k
      break;
1378
12.1k
    case 0x40:
1379
12.1k
        {
1380
          /** 0100 0000     cmp %e!0, #%1     */
1381
12.1k
          if (trace)
1382
0
            {
1383
0
              printf ("\033[33m%s\033[0m  %02x\n",
1384
0
                     "/** 0100 0000     cmp %e!0, #%1     */",
1385
0
                     op[0]);
1386
0
            }
1387
12.1k
          SYNTAX("cmp %e!0, #%1");
1388
12.1k
#line 486 "rl78-decode.opc"
1389
12.1k
          ID(cmp); DM(None, IMMU(2)); SC(IMMU(1)); Fzac;
1390
1391
12.1k
        }
1392
12.1k
      break;
1393
11.7k
    case 0x41:
1394
11.7k
        {
1395
          /** 0100 0001     mov %0, #%1       */
1396
11.7k
          if (trace)
1397
0
            {
1398
0
              printf ("\033[33m%s\033[0m  %02x\n",
1399
0
                     "/** 0100 0001     mov %0, #%1       */",
1400
0
                     op[0]);
1401
0
            }
1402
11.7k
          SYNTAX("mov %0, #%1");
1403
11.7k
#line 723 "rl78-decode.opc"
1404
11.7k
          ID(mov); DR(ES); SC(IMMU(1));
1405
1406
11.7k
        }
1407
11.7k
      break;
1408
5.91k
    case 0x42:
1409
5.91k
        {
1410
          /** 0100 0010     cmpw  %0, %e!1      */
1411
5.91k
          if (trace)
1412
0
            {
1413
0
              printf ("\033[33m%s\033[0m  %02x\n",
1414
0
                     "/** 0100 0010     cmpw  %0, %e!1      */",
1415
0
                     op[0]);
1416
0
            }
1417
5.91k
          SYNTAX("cmpw  %0, %e!1");
1418
5.91k
#line 537 "rl78-decode.opc"
1419
5.91k
          ID(cmp); W(); DR(AX); SM(None, IMMU(2)); Fzac;
1420
1421
5.91k
        }
1422
5.91k
      break;
1423
3.97k
    case 0x43:
1424
9.87k
    case 0x45:
1425
28.7k
    case 0x47:
1426
28.7k
        {
1427
          /** 0100 0ra1     cmpw  %0, %1        */
1428
28.7k
#line 546 "rl78-decode.opc"
1429
28.7k
          int ra AU = (op[0] >> 1) & 0x03;
1430
28.7k
          if (trace)
1431
0
            {
1432
0
              printf ("\033[33m%s\033[0m  %02x\n",
1433
0
                     "/** 0100 0ra1     cmpw  %0, %1        */",
1434
0
                     op[0]);
1435
0
              printf ("  ra = 0x%x\n", ra);
1436
0
            }
1437
28.7k
          SYNTAX("cmpw  %0, %1");
1438
28.7k
#line 546 "rl78-decode.opc"
1439
28.7k
          ID(cmp); W(); DR(AX); SRW(ra); Fzac;
1440
1441
28.7k
        }
1442
28.7k
      break;
1443
7.29k
    case 0x44:
1444
7.29k
        {
1445
          /** 0100 0100     cmpw  %0, #%1       */
1446
7.29k
          if (trace)
1447
0
            {
1448
0
              printf ("\033[33m%s\033[0m  %02x\n",
1449
0
                     "/** 0100 0100     cmpw  %0, #%1       */",
1450
0
                     op[0]);
1451
0
            }
1452
7.29k
          SYNTAX("cmpw  %0, #%1");
1453
7.29k
#line 543 "rl78-decode.opc"
1454
7.29k
          ID(cmp); W(); DR(AX); SC(IMMU(2)); Fzac;
1455
1456
7.29k
        }
1457
7.29k
      break;
1458
4.37k
    case 0x46:
1459
4.37k
        {
1460
          /** 0100 0110     cmpw  %0, %1        */
1461
4.37k
          if (trace)
1462
0
            {
1463
0
              printf ("\033[33m%s\033[0m  %02x\n",
1464
0
                     "/** 0100 0110     cmpw  %0, %1        */",
1465
0
                     op[0]);
1466
0
            }
1467
4.37k
          SYNTAX("cmpw  %0, %1");
1468
4.37k
#line 549 "rl78-decode.opc"
1469
4.37k
          ID(cmp); W(); DR(AX); SM(None, SADDR); Fzac;
1470
1471
        /*----------------------------------------------------------------------*/
1472
1473
4.37k
        }
1474
4.37k
      break;
1475
6.24k
    case 0x48:
1476
6.24k
        {
1477
          /** 0100 1000     mov %e0, %1       */
1478
6.24k
          if (trace)
1479
0
            {
1480
0
              printf ("\033[33m%s\033[0m  %02x\n",
1481
0
                     "/** 0100 1000     mov %e0, %1       */",
1482
0
                     op[0]);
1483
0
            }
1484
6.24k
          SYNTAX("mov %e0, %1");
1485
6.24k
#line 741 "rl78-decode.opc"
1486
6.24k
          ID(mov); DM(BC, IMMU(2)); SR(A);
1487
1488
6.24k
        }
1489
6.24k
      break;
1490
3.81k
    case 0x49:
1491
3.81k
        {
1492
          /** 0100 1001     mov %0, %e1       */
1493
3.81k
          if (trace)
1494
0
            {
1495
0
              printf ("\033[33m%s\033[0m  %02x\n",
1496
0
                     "/** 0100 1001     mov %0, %e1       */",
1497
0
                     op[0]);
1498
0
            }
1499
3.81k
          SYNTAX("mov %0, %e1");
1500
3.81k
#line 687 "rl78-decode.opc"
1501
3.81k
          ID(mov); DR(A); SM(BC, IMMU(2));
1502
1503
3.81k
        }
1504
3.81k
      break;
1505
4.15k
    case 0x4a:
1506
4.15k
        {
1507
          /** 0100 1010     cmp %0, #%1       */
1508
4.15k
          if (trace)
1509
0
            {
1510
0
              printf ("\033[33m%s\033[0m  %02x\n",
1511
0
                     "/** 0100 1010     cmp %0, #%1       */",
1512
0
                     op[0]);
1513
0
            }
1514
4.15k
          SYNTAX("cmp %0, #%1");
1515
4.15k
#line 489 "rl78-decode.opc"
1516
4.15k
          ID(cmp); DM(None, SADDR); SC(IMMU(1)); Fzac;
1517
1518
4.15k
        }
1519
4.15k
      break;
1520
4.26k
    case 0x4b:
1521
4.26k
        {
1522
          /** 0100 1011     cmp %0, %1        */
1523
4.26k
          if (trace)
1524
0
            {
1525
0
              printf ("\033[33m%s\033[0m  %02x\n",
1526
0
                     "/** 0100 1011     cmp %0, %1        */",
1527
0
                     op[0]);
1528
0
            }
1529
4.26k
          SYNTAX("cmp %0, %1");
1530
4.26k
#line 516 "rl78-decode.opc"
1531
4.26k
          ID(cmp); DR(A); SM(None, SADDR); Fzac;
1532
1533
        /*----------------------------------------------------------------------*/
1534
1535
4.26k
        }
1536
4.26k
      break;
1537
6.93k
    case 0x4c:
1538
6.93k
        {
1539
          /** 0100 1100     cmp %0, #%1       */
1540
6.93k
          if (trace)
1541
0
            {
1542
0
              printf ("\033[33m%s\033[0m  %02x\n",
1543
0
                     "/** 0100 1100     cmp %0, #%1       */",
1544
0
                     op[0]);
1545
0
            }
1546
6.93k
          SYNTAX("cmp %0, #%1");
1547
6.93k
#line 507 "rl78-decode.opc"
1548
6.93k
          ID(cmp); DR(A); SC(IMMU(1)); Fzac;
1549
1550
6.93k
        }
1551
6.93k
      break;
1552
5.81k
    case 0x4d:
1553
5.81k
        {
1554
          /** 0100 1101     cmp %0, %e1       */
1555
5.81k
          if (trace)
1556
0
            {
1557
0
              printf ("\033[33m%s\033[0m  %02x\n",
1558
0
                     "/** 0100 1101     cmp %0, %e1       */",
1559
0
                     op[0]);
1560
0
            }
1561
5.81k
          SYNTAX("cmp %0, %e1");
1562
5.81k
#line 495 "rl78-decode.opc"
1563
5.81k
          ID(cmp); DR(A); SM(HL, 0); Fzac;
1564
1565
5.81k
        }
1566
5.81k
      break;
1567
7.41k
    case 0x4e:
1568
7.41k
        {
1569
          /** 0100 1110     cmp %0, %ea1      */
1570
7.41k
          if (trace)
1571
0
            {
1572
0
              printf ("\033[33m%s\033[0m  %02x\n",
1573
0
                     "/** 0100 1110     cmp %0, %ea1      */",
1574
0
                     op[0]);
1575
0
            }
1576
7.41k
          SYNTAX("cmp %0, %ea1");
1577
7.41k
#line 504 "rl78-decode.opc"
1578
7.41k
          ID(cmp); DR(A); SM(HL, IMMU(1)); Fzac;
1579
1580
7.41k
        }
1581
7.41k
      break;
1582
7.05k
    case 0x4f:
1583
7.05k
        {
1584
          /** 0100 1111     cmp %0, %e!1      */
1585
7.05k
          if (trace)
1586
0
            {
1587
0
              printf ("\033[33m%s\033[0m  %02x\n",
1588
0
                     "/** 0100 1111     cmp %0, %e!1      */",
1589
0
                     op[0]);
1590
0
            }
1591
7.05k
          SYNTAX("cmp %0, %e!1");
1592
7.05k
#line 492 "rl78-decode.opc"
1593
7.05k
          ID(cmp); DR(A); SM(None, IMMU(2)); Fzac;
1594
1595
7.05k
        }
1596
7.05k
      break;
1597
7.13k
    case 0x50:
1598
13.1k
    case 0x51:
1599
21.4k
    case 0x52:
1600
25.9k
    case 0x53:
1601
29.5k
    case 0x54:
1602
42.9k
    case 0x55:
1603
51.0k
    case 0x56:
1604
54.9k
    case 0x57:
1605
54.9k
        {
1606
          /** 0101 0reg     mov %0, #%1       */
1607
54.9k
#line 675 "rl78-decode.opc"
1608
54.9k
          int reg AU = op[0] & 0x07;
1609
54.9k
          if (trace)
1610
0
            {
1611
0
              printf ("\033[33m%s\033[0m  %02x\n",
1612
0
                     "/** 0101 0reg     mov %0, #%1       */",
1613
0
                     op[0]);
1614
0
              printf ("  reg = 0x%x\n", reg);
1615
0
            }
1616
54.9k
          SYNTAX("mov %0, #%1");
1617
54.9k
#line 675 "rl78-decode.opc"
1618
54.9k
          ID(mov); DRB(reg); SC(IMMU(1));
1619
1620
54.9k
        }
1621
54.9k
      break;
1622
4.95k
    case 0x58:
1623
4.95k
        {
1624
          /** 0101 1000     movw  %e0, %1       */
1625
4.95k
          if (trace)
1626
0
            {
1627
0
              printf ("\033[33m%s\033[0m  %02x\n",
1628
0
                     "/** 0101 1000     movw  %e0, %1       */",
1629
0
                     op[0]);
1630
0
            }
1631
4.95k
          SYNTAX("movw  %e0, %1");
1632
4.95k
#line 877 "rl78-decode.opc"
1633
4.95k
          ID(mov); W(); DM(B, IMMU(2)); SR(AX);
1634
1635
4.95k
        }
1636
4.95k
      break;
1637
2.69k
    case 0x59:
1638
2.69k
        {
1639
          /** 0101 1001     movw  %0, %e1       */
1640
2.69k
          if (trace)
1641
0
            {
1642
0
              printf ("\033[33m%s\033[0m  %02x\n",
1643
0
                     "/** 0101 1001     movw  %0, %e1       */",
1644
0
                     op[0]);
1645
0
            }
1646
2.69k
          SYNTAX("movw  %0, %e1");
1647
2.69k
#line 868 "rl78-decode.opc"
1648
2.69k
          ID(mov); W(); DR(AX); SM(B, IMMU(2));
1649
1650
2.69k
        }
1651
2.69k
      break;
1652
2.62k
    case 0x5a:
1653
2.62k
        {
1654
          /** 0101 1010           and %0, #%1       */
1655
2.62k
          if (trace)
1656
0
            {
1657
0
              printf ("\033[33m%s\033[0m  %02x\n",
1658
0
                     "/** 0101 1010           and %0, #%1       */",
1659
0
                     op[0]);
1660
0
            }
1661
2.62k
          SYNTAX("and %0, #%1");
1662
2.62k
#line 318 "rl78-decode.opc"
1663
2.62k
          ID(and); DM(None, SADDR); SC(IMMU(1)); Fz;
1664
1665
        /*----------------------------------------------------------------------*/
1666
1667
2.62k
        }
1668
2.62k
      break;
1669
9.67k
    case 0x5b:
1670
9.67k
        {
1671
          /** 0101 1011           and %0, %1        */
1672
9.67k
          if (trace)
1673
0
            {
1674
0
              printf ("\033[33m%s\033[0m  %02x\n",
1675
0
                     "/** 0101 1011           and %0, %1        */",
1676
0
                     op[0]);
1677
0
            }
1678
9.67k
          SYNTAX("and %0, %1");
1679
9.67k
#line 315 "rl78-decode.opc"
1680
9.67k
          ID(and); DR(A); SM(None, SADDR); Fz;
1681
1682
9.67k
        }
1683
9.67k
      break;
1684
2.84k
    case 0x5c:
1685
2.84k
        {
1686
          /** 0101 1100           and %0, #%1       */
1687
2.84k
          if (trace)
1688
0
            {
1689
0
              printf ("\033[33m%s\033[0m  %02x\n",
1690
0
                     "/** 0101 1100           and %0, #%1       */",
1691
0
                     op[0]);
1692
0
            }
1693
2.84k
          SYNTAX("and %0, #%1");
1694
2.84k
#line 306 "rl78-decode.opc"
1695
2.84k
          ID(and); DR(A); SC(IMMU(1)); Fz;
1696
1697
2.84k
        }
1698
2.84k
      break;
1699
7.25k
    case 0x5d:
1700
7.25k
        {
1701
          /** 0101 1101     and %0, %e1     */
1702
7.25k
          if (trace)
1703
0
            {
1704
0
              printf ("\033[33m%s\033[0m  %02x\n",
1705
0
                     "/** 0101 1101     and %0, %e1     */",
1706
0
                     op[0]);
1707
0
            }
1708
7.25k
          SYNTAX("and %0, %e1");
1709
7.25k
#line 294 "rl78-decode.opc"
1710
7.25k
          ID(and); DR(A); SM(HL, 0); Fz;
1711
1712
7.25k
        }
1713
7.25k
      break;
1714
4.57k
    case 0x5e:
1715
4.57k
        {
1716
          /** 0101 1110     and %0, %ea1      */
1717
4.57k
          if (trace)
1718
0
            {
1719
0
              printf ("\033[33m%s\033[0m  %02x\n",
1720
0
                     "/** 0101 1110     and %0, %ea1      */",
1721
0
                     op[0]);
1722
0
            }
1723
4.57k
          SYNTAX("and %0, %ea1");
1724
4.57k
#line 300 "rl78-decode.opc"
1725
4.57k
          ID(and); DR(A); SM(HL, IMMU(1)); Fz;
1726
1727
4.57k
        }
1728
4.57k
      break;
1729
4.69k
    case 0x5f:
1730
4.69k
        {
1731
          /** 0101 1111     and %0, %e!1      */
1732
4.69k
          if (trace)
1733
0
            {
1734
0
              printf ("\033[33m%s\033[0m  %02x\n",
1735
0
                     "/** 0101 1111     and %0, %e!1      */",
1736
0
                     op[0]);
1737
0
            }
1738
4.69k
          SYNTAX("and %0, %e!1");
1739
4.69k
#line 291 "rl78-decode.opc"
1740
4.69k
          ID(and); DR(A); SM(None, IMMU(2)); Fz;
1741
1742
4.69k
        }
1743
4.69k
      break;
1744
8.78k
    case 0x60:
1745
26.1k
    case 0x62:
1746
36.0k
    case 0x63:
1747
48.9k
    case 0x64:
1748
58.7k
    case 0x65:
1749
65.5k
    case 0x66:
1750
78.4k
    case 0x67:
1751
78.4k
        {
1752
          /** 0110 0rba     mov %0, %1        */
1753
78.4k
#line 678 "rl78-decode.opc"
1754
78.4k
          int rba AU = op[0] & 0x07;
1755
78.4k
          if (trace)
1756
0
            {
1757
0
              printf ("\033[33m%s\033[0m  %02x\n",
1758
0
                     "/** 0110 0rba     mov %0, %1        */",
1759
0
                     op[0]);
1760
0
              printf ("  rba = 0x%x\n", rba);
1761
0
            }
1762
78.4k
          SYNTAX("mov %0, %1");
1763
78.4k
#line 678 "rl78-decode.opc"
1764
78.4k
          ID(mov); DR(A); SRB(rba);
1765
1766
78.4k
        }
1767
78.4k
      break;
1768
164k
    case 0x61:
1769
164k
        GETBYTE ();
1770
164k
        switch (op[1] & 0xff)
1771
164k
        {
1772
3.63k
          case 0x00:
1773
4.27k
          case 0x01:
1774
4.56k
          case 0x02:
1775
4.77k
          case 0x03:
1776
5.36k
          case 0x04:
1777
5.46k
          case 0x05:
1778
6.42k
          case 0x06:
1779
6.54k
          case 0x07:
1780
6.54k
              {
1781
                /** 0110 0001 0000 0reg   add %0, %1        */
1782
6.54k
#line 231 "rl78-decode.opc"
1783
6.54k
                int reg AU = op[1] & 0x07;
1784
6.54k
                if (trace)
1785
0
                  {
1786
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1787
0
                           "/** 0110 0001 0000 0reg   add %0, %1        */",
1788
0
                           op[0], op[1]);
1789
0
                    printf ("  reg = 0x%x\n", reg);
1790
0
                  }
1791
6.54k
                SYNTAX("add %0, %1");
1792
6.54k
#line 231 "rl78-decode.opc"
1793
6.54k
                ID(add); DRB(reg); SR(A); Fzac;
1794
1795
6.54k
              }
1796
6.54k
            break;
1797
877
          case 0x08:
1798
1.02k
          case 0x0a:
1799
1.41k
          case 0x0b:
1800
1.53k
          case 0x0c:
1801
1.64k
          case 0x0d:
1802
1.98k
          case 0x0e:
1803
2.14k
          case 0x0f:
1804
2.14k
              {
1805
                /** 0110 0001 0000 1rba   add %0, %1        */
1806
2.14k
#line 225 "rl78-decode.opc"
1807
2.14k
                int rba AU = op[1] & 0x07;
1808
2.14k
                if (trace)
1809
0
                  {
1810
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1811
0
                           "/** 0110 0001 0000 1rba   add %0, %1        */",
1812
0
                           op[0], op[1]);
1813
0
                    printf ("  rba = 0x%x\n", rba);
1814
0
                  }
1815
2.14k
                SYNTAX("add %0, %1");
1816
2.14k
#line 225 "rl78-decode.opc"
1817
2.14k
                ID(add); DR(A); SRB(rba); Fzac;
1818
1819
2.14k
              }
1820
2.14k
            break;
1821
1.13k
          case 0x09:
1822
1.13k
              {
1823
                /** 0110 0001 0000 1001   addw  %0, %ea1      */
1824
1.13k
                if (trace)
1825
0
                  {
1826
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1827
0
                           "/** 0110 0001 0000 1001   addw  %0, %ea1      */",
1828
0
                           op[0], op[1]);
1829
0
                  }
1830
1.13k
                SYNTAX("addw  %0, %ea1");
1831
1.13k
#line 274 "rl78-decode.opc"
1832
1.13k
                ID(add); W(); DR(AX); SM(HL, IMMU(1)); Fzac;
1833
1834
1.13k
              }
1835
1.13k
            break;
1836
272
          case 0x10:
1837
566
          case 0x11:
1838
625
          case 0x12:
1839
812
          case 0x13:
1840
880
          case 0x14:
1841
1.66k
          case 0x15:
1842
2.06k
          case 0x16:
1843
2.81k
          case 0x17:
1844
2.81k
              {
1845
                /** 0110 0001 0001 0reg   addc  %0, %1        */
1846
2.81k
#line 260 "rl78-decode.opc"
1847
2.81k
                int reg AU = op[1] & 0x07;
1848
2.81k
                if (trace)
1849
0
                  {
1850
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1851
0
                           "/** 0110 0001 0001 0reg   addc  %0, %1        */",
1852
0
                           op[0], op[1]);
1853
0
                    printf ("  reg = 0x%x\n", reg);
1854
0
                  }
1855
2.81k
                SYNTAX("addc  %0, %1");
1856
2.81k
#line 260 "rl78-decode.opc"
1857
2.81k
                ID(addc); DRB(reg); SR(A); Fzac;
1858
1859
2.81k
              }
1860
2.81k
            break;
1861
107
          case 0x18:
1862
282
          case 0x1a:
1863
978
          case 0x1b:
1864
1.09k
          case 0x1c:
1865
1.18k
          case 0x1d:
1866
2.09k
          case 0x1e:
1867
2.19k
          case 0x1f:
1868
2.19k
              {
1869
                /** 0110 0001 0001 1rba   addc  %0, %1        */
1870
2.19k
#line 257 "rl78-decode.opc"
1871
2.19k
                int rba AU = op[1] & 0x07;
1872
2.19k
                if (trace)
1873
0
                  {
1874
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1875
0
                           "/** 0110 0001 0001 1rba   addc  %0, %1        */",
1876
0
                           op[0], op[1]);
1877
0
                    printf ("  rba = 0x%x\n", rba);
1878
0
                  }
1879
2.19k
                SYNTAX("addc  %0, %1");
1880
2.19k
#line 257 "rl78-decode.opc"
1881
2.19k
                ID(addc); DR(A); SRB(rba); Fzac;
1882
1883
2.19k
              }
1884
2.19k
            break;
1885
348
          case 0x20:
1886
845
          case 0x21:
1887
887
          case 0x22:
1888
1.45k
          case 0x23:
1889
1.60k
          case 0x24:
1890
2.11k
          case 0x25:
1891
2.46k
          case 0x26:
1892
2.59k
          case 0x27:
1893
2.59k
              {
1894
                /** 0110 0001 0010 0reg   sub %0, %1        */
1895
2.59k
#line 1149 "rl78-decode.opc"
1896
2.59k
                int reg AU = op[1] & 0x07;
1897
2.59k
                if (trace)
1898
0
                  {
1899
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1900
0
                           "/** 0110 0001 0010 0reg   sub %0, %1        */",
1901
0
                           op[0], op[1]);
1902
0
                    printf ("  reg = 0x%x\n", reg);
1903
0
                  }
1904
2.59k
                SYNTAX("sub %0, %1");
1905
2.59k
#line 1149 "rl78-decode.opc"
1906
2.59k
                ID(sub); DRB(reg); SR(A); Fzac;
1907
1908
2.59k
              }
1909
2.59k
            break;
1910
184
          case 0x28:
1911
335
          case 0x2a:
1912
709
          case 0x2b:
1913
964
          case 0x2c:
1914
1.25k
          case 0x2d:
1915
1.62k
          case 0x2e:
1916
1.79k
          case 0x2f:
1917
1.79k
              {
1918
                /** 0110 0001 0010 1rba   sub %0, %1        */
1919
1.79k
#line 1143 "rl78-decode.opc"
1920
1.79k
                int rba AU = op[1] & 0x07;
1921
1.79k
                if (trace)
1922
0
                  {
1923
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1924
0
                           "/** 0110 0001 0010 1rba   sub %0, %1        */",
1925
0
                           op[0], op[1]);
1926
0
                    printf ("  rba = 0x%x\n", rba);
1927
0
                  }
1928
1.79k
                SYNTAX("sub %0, %1");
1929
1.79k
#line 1143 "rl78-decode.opc"
1930
1.79k
                ID(sub); DR(A); SRB(rba); Fzac;
1931
1932
1.79k
              }
1933
1.79k
            break;
1934
902
          case 0x29:
1935
902
              {
1936
                /** 0110 0001 0010 1001   subw  %0, %ea1      */
1937
902
                if (trace)
1938
0
                  {
1939
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1940
0
                           "/** 0110 0001 0010 1001   subw  %0, %ea1      */",
1941
0
                           op[0], op[1]);
1942
0
                  }
1943
902
                SYNTAX("subw  %0, %ea1");
1944
902
#line 1192 "rl78-decode.opc"
1945
902
                ID(sub); W(); DR(AX); SM(HL, IMMU(1)); Fzac;
1946
1947
902
              }
1948
902
            break;
1949
475
          case 0x30:
1950
860
          case 0x31:
1951
1.07k
          case 0x32:
1952
1.20k
          case 0x33:
1953
1.35k
          case 0x34:
1954
1.99k
          case 0x35:
1955
2.20k
          case 0x36:
1956
2.42k
          case 0x37:
1957
2.42k
              {
1958
                /** 0110 0001 0011 0reg   subc  %0, %1        */
1959
2.42k
#line 1178 "rl78-decode.opc"
1960
2.42k
                int reg AU = op[1] & 0x07;
1961
2.42k
                if (trace)
1962
0
                  {
1963
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1964
0
                           "/** 0110 0001 0011 0reg   subc  %0, %1        */",
1965
0
                           op[0], op[1]);
1966
0
                    printf ("  reg = 0x%x\n", reg);
1967
0
                  }
1968
2.42k
                SYNTAX("subc  %0, %1");
1969
2.42k
#line 1178 "rl78-decode.opc"
1970
2.42k
                ID(subc); DRB(reg); SR(A); Fzac;
1971
1972
2.42k
              }
1973
2.42k
            break;
1974
121
          case 0x38:
1975
705
          case 0x3a:
1976
2.17k
          case 0x3b:
1977
2.33k
          case 0x3c:
1978
2.80k
          case 0x3d:
1979
3.24k
          case 0x3e:
1980
3.97k
          case 0x3f:
1981
3.97k
              {
1982
                /** 0110 0001 0011 1rba   subc  %0, %1        */
1983
3.97k
#line 1175 "rl78-decode.opc"
1984
3.97k
                int rba AU = op[1] & 0x07;
1985
3.97k
                if (trace)
1986
0
                  {
1987
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
1988
0
                           "/** 0110 0001 0011 1rba   subc  %0, %1        */",
1989
0
                           op[0], op[1]);
1990
0
                    printf ("  rba = 0x%x\n", rba);
1991
0
                  }
1992
3.97k
                SYNTAX("subc  %0, %1");
1993
3.97k
#line 1175 "rl78-decode.opc"
1994
3.97k
                ID(subc); DR(A); SRB(rba); Fzac;
1995
1996
3.97k
              }
1997
3.97k
            break;
1998
1.13k
          case 0x40:
1999
1.59k
          case 0x41:
2000
2.42k
          case 0x42:
2001
2.59k
          case 0x43:
2002
2.87k
          case 0x44:
2003
3.45k
          case 0x45:
2004
4.32k
          case 0x46:
2005
5.76k
          case 0x47:
2006
5.76k
              {
2007
                /** 0110 0001 0100 0reg   cmp %0, %1        */
2008
5.76k
#line 513 "rl78-decode.opc"
2009
5.76k
                int reg AU = op[1] & 0x07;
2010
5.76k
                if (trace)
2011
0
                  {
2012
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2013
0
                           "/** 0110 0001 0100 0reg   cmp %0, %1        */",
2014
0
                           op[0], op[1]);
2015
0
                    printf ("  reg = 0x%x\n", reg);
2016
0
                  }
2017
5.76k
                SYNTAX("cmp %0, %1");
2018
5.76k
#line 513 "rl78-decode.opc"
2019
5.76k
                ID(cmp); DRB(reg); SR(A); Fzac;
2020
2021
5.76k
              }
2022
5.76k
            break;
2023
321
          case 0x48:
2024
490
          case 0x4a:
2025
684
          case 0x4b:
2026
1.75k
          case 0x4c:
2027
2.01k
          case 0x4d:
2028
2.19k
          case 0x4e:
2029
2.49k
          case 0x4f:
2030
2.49k
              {
2031
                /** 0110 0001 0100 1rba   cmp %0, %1        */
2032
2.49k
#line 510 "rl78-decode.opc"
2033
2.49k
                int rba AU = op[1] & 0x07;
2034
2.49k
                if (trace)
2035
0
                  {
2036
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2037
0
                           "/** 0110 0001 0100 1rba   cmp %0, %1        */",
2038
0
                           op[0], op[1]);
2039
0
                    printf ("  rba = 0x%x\n", rba);
2040
0
                  }
2041
2.49k
                SYNTAX("cmp %0, %1");
2042
2.49k
#line 510 "rl78-decode.opc"
2043
2.49k
                ID(cmp); DR(A); SRB(rba); Fzac;
2044
2045
2.49k
              }
2046
2.49k
            break;
2047
309
          case 0x49:
2048
309
              {
2049
                /** 0110 0001 0100 1001   cmpw  %0, %ea1      */
2050
309
                if (trace)
2051
0
                  {
2052
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2053
0
                           "/** 0110 0001 0100 1001   cmpw  %0, %ea1      */",
2054
0
                           op[0], op[1]);
2055
0
                  }
2056
309
                SYNTAX("cmpw  %0, %ea1");
2057
309
#line 540 "rl78-decode.opc"
2058
309
                ID(cmp); W(); DR(AX); SM(HL, IMMU(1)); Fzac;
2059
2060
309
              }
2061
309
            break;
2062
482
          case 0x50:
2063
671
          case 0x51:
2064
730
          case 0x52:
2065
817
          case 0x53:
2066
869
          case 0x54:
2067
914
          case 0x55:
2068
1.28k
          case 0x56:
2069
1.51k
          case 0x57:
2070
1.51k
              {
2071
                /** 0110 0001 0101 0reg   and %0, %1        */
2072
1.51k
#line 312 "rl78-decode.opc"
2073
1.51k
                int reg AU = op[1] & 0x07;
2074
1.51k
                if (trace)
2075
0
                  {
2076
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2077
0
                           "/** 0110 0001 0101 0reg   and %0, %1        */",
2078
0
                           op[0], op[1]);
2079
0
                    printf ("  reg = 0x%x\n", reg);
2080
0
                  }
2081
1.51k
                SYNTAX("and %0, %1");
2082
1.51k
#line 312 "rl78-decode.opc"
2083
1.51k
                ID(and); DRB(reg); SR(A); Fz;
2084
2085
1.51k
              }
2086
1.51k
            break;
2087
636
          case 0x58:
2088
1.08k
          case 0x5a:
2089
1.70k
          case 0x5b:
2090
1.81k
          case 0x5c:
2091
2.22k
          case 0x5d:
2092
2.48k
          case 0x5e:
2093
2.63k
          case 0x5f:
2094
2.63k
              {
2095
                /** 0110 0001 0101 1rba   and %0, %1        */
2096
2.63k
#line 309 "rl78-decode.opc"
2097
2.63k
                int rba AU = op[1] & 0x07;
2098
2.63k
                if (trace)
2099
0
                  {
2100
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2101
0
                           "/** 0110 0001 0101 1rba   and %0, %1        */",
2102
0
                           op[0], op[1]);
2103
0
                    printf ("  rba = 0x%x\n", rba);
2104
0
                  }
2105
2.63k
                SYNTAX("and %0, %1");
2106
2.63k
#line 309 "rl78-decode.opc"
2107
2.63k
                ID(and); DR(A); SRB(rba); Fz;
2108
2109
2.63k
              }
2110
2.63k
            break;
2111
56
          case 0x59:
2112
56
              {
2113
                /** 0110 0001 0101 1001   inc %ea0        */
2114
56
                if (trace)
2115
0
                  {
2116
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2117
0
                           "/** 0110 0001 0101 1001   inc %ea0        */",
2118
0
                           op[0], op[1]);
2119
0
                  }
2120
56
                SYNTAX("inc %ea0");
2121
56
#line 590 "rl78-decode.opc"
2122
56
                ID(add); DM(HL, IMMU(1)); SC(1); Fza;
2123
2124
56
              }
2125
56
            break;
2126
1.76k
          case 0x60:
2127
58.6k
          case 0x61:
2128
59.7k
          case 0x62:
2129
60.5k
          case 0x63:
2130
61.8k
          case 0x64:
2131
62.0k
          case 0x65:
2132
63.0k
          case 0x66:
2133
63.1k
          case 0x67:
2134
63.1k
              {
2135
                /** 0110 0001 0110 0reg   or  %0, %1        */
2136
63.1k
#line 967 "rl78-decode.opc"
2137
63.1k
                int reg AU = op[1] & 0x07;
2138
63.1k
                if (trace)
2139
0
                  {
2140
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2141
0
                           "/** 0110 0001 0110 0reg   or  %0, %1        */",
2142
0
                           op[0], op[1]);
2143
0
                    printf ("  reg = 0x%x\n", reg);
2144
0
                  }
2145
63.1k
                SYNTAX("or  %0, %1");
2146
63.1k
#line 967 "rl78-decode.opc"
2147
63.1k
                ID(or); DRB(reg); SR(A); Fz;
2148
2149
63.1k
              }
2150
63.1k
            break;
2151
1.04k
          case 0x68:
2152
2.08k
          case 0x6a:
2153
2.30k
          case 0x6b:
2154
4.61k
          case 0x6c:
2155
4.91k
          case 0x6d:
2156
5.40k
          case 0x6e:
2157
7.04k
          case 0x6f:
2158
7.04k
              {
2159
                /** 0110 0001 0110 1rba   or  %0, %1        */
2160
7.04k
#line 964 "rl78-decode.opc"
2161
7.04k
                int rba AU = op[1] & 0x07;
2162
7.04k
                if (trace)
2163
0
                  {
2164
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2165
0
                           "/** 0110 0001 0110 1rba   or  %0, %1        */",
2166
0
                           op[0], op[1]);
2167
0
                    printf ("  rba = 0x%x\n", rba);
2168
0
                  }
2169
7.04k
                SYNTAX("or  %0, %1");
2170
7.04k
#line 964 "rl78-decode.opc"
2171
7.04k
                ID(or); DR(A); SRB(rba); Fz;
2172
2173
7.04k
              }
2174
7.04k
            break;
2175
1.26k
          case 0x69:
2176
1.26k
              {
2177
                /** 0110 0001 0110 1001   dec %ea0        */
2178
1.26k
                if (trace)
2179
0
                  {
2180
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2181
0
                           "/** 0110 0001 0110 1001   dec %ea0        */",
2182
0
                           op[0], op[1]);
2183
0
                  }
2184
1.26k
                SYNTAX("dec %ea0");
2185
1.26k
#line 557 "rl78-decode.opc"
2186
1.26k
                ID(sub); DM(HL, IMMU(1)); SC(1); Fza;
2187
2188
1.26k
              }
2189
1.26k
            break;
2190
154
          case 0x70:
2191
2.73k
          case 0x71:
2192
3.17k
          case 0x72:
2193
3.67k
          case 0x73:
2194
4.06k
          case 0x74:
2195
4.36k
          case 0x75:
2196
4.94k
          case 0x76:
2197
5.29k
          case 0x77:
2198
5.29k
              {
2199
                /** 0110 0001 0111 0reg   xor %0, %1        */
2200
5.29k
#line 1271 "rl78-decode.opc"
2201
5.29k
                int reg AU = op[1] & 0x07;
2202
5.29k
                if (trace)
2203
0
                  {
2204
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2205
0
                           "/** 0110 0001 0111 0reg   xor %0, %1        */",
2206
0
                           op[0], op[1]);
2207
0
                    printf ("  reg = 0x%x\n", reg);
2208
0
                  }
2209
5.29k
                SYNTAX("xor %0, %1");
2210
5.29k
#line 1271 "rl78-decode.opc"
2211
5.29k
                ID(xor); DRB(reg); SR(A); Fz;
2212
2213
5.29k
              }
2214
5.29k
            break;
2215
104
          case 0x78:
2216
576
          case 0x7a:
2217
688
          case 0x7b:
2218
853
          case 0x7c:
2219
1.41k
          case 0x7d:
2220
2.73k
          case 0x7e:
2221
3.34k
          case 0x7f:
2222
3.34k
              {
2223
                /** 0110 0001 0111 1rba   xor %0, %1        */
2224
3.34k
#line 1268 "rl78-decode.opc"
2225
3.34k
                int rba AU = op[1] & 0x07;
2226
3.34k
                if (trace)
2227
0
                  {
2228
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2229
0
                           "/** 0110 0001 0111 1rba   xor %0, %1        */",
2230
0
                           op[0], op[1]);
2231
0
                    printf ("  rba = 0x%x\n", rba);
2232
0
                  }
2233
3.34k
                SYNTAX("xor %0, %1");
2234
3.34k
#line 1268 "rl78-decode.opc"
2235
3.34k
                ID(xor); DR(A); SRB(rba); Fz;
2236
2237
3.34k
              }
2238
3.34k
            break;
2239
475
          case 0x79:
2240
475
              {
2241
                /** 0110 0001 0111 1001   incw  %ea0        */
2242
475
                if (trace)
2243
0
                  {
2244
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2245
0
                           "/** 0110 0001 0111 1001   incw  %ea0        */",
2246
0
                           op[0], op[1]);
2247
0
                  }
2248
475
                SYNTAX("incw  %ea0");
2249
475
#line 604 "rl78-decode.opc"
2250
475
                ID(add); W(); DM(HL, IMMU(1)); SC(1);
2251
2252
475
              }
2253
475
            break;
2254
550
          case 0x80:
2255
1.79k
          case 0x81:
2256
1.79k
              {
2257
                /** 0110 0001 1000 000    add %0, %e1       */
2258
1.79k
                if (trace)
2259
0
                  {
2260
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2261
0
                           "/** 0110 0001 1000 000    add %0, %e1       */",
2262
0
                           op[0], op[1]);
2263
0
                  }
2264
1.79k
                SYNTAX("add %0, %e1");
2265
1.79k
#line 213 "rl78-decode.opc"
2266
1.79k
                ID(add); DR(A); SM2(HL, B, 0); Fzac;
2267
2268
1.79k
              }
2269
1.79k
            break;
2270
119
          case 0x82:
2271
119
              {
2272
                /** 0110 0001 1000 0010   add %0, %e1       */
2273
119
                if (trace)
2274
0
                  {
2275
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2276
0
                           "/** 0110 0001 1000 0010   add %0, %e1       */",
2277
0
                           op[0], op[1]);
2278
0
                  }
2279
119
                SYNTAX("add %0, %e1");
2280
119
#line 219 "rl78-decode.opc"
2281
119
                ID(add); DR(A); SM2(HL, C, 0); Fzac;
2282
2283
119
              }
2284
119
            break;
2285
158
          case 0x84:
2286
465
          case 0x85:
2287
594
          case 0x86:
2288
1.02k
          case 0x87:
2289
1.27k
          case 0x94:
2290
1.70k
          case 0x95:
2291
1.85k
          case 0x96:
2292
2.20k
          case 0x97:
2293
3.18k
          case 0xa4:
2294
3.30k
          case 0xa5:
2295
3.38k
          case 0xa6:
2296
3.47k
          case 0xa7:
2297
3.78k
          case 0xb4:
2298
3.87k
          case 0xb5:
2299
5.47k
          case 0xb6:
2300
6.02k
          case 0xb7:
2301
7.08k
          case 0xc4:
2302
7.65k
          case 0xc5:
2303
8.19k
          case 0xc6:
2304
8.61k
          case 0xc7:
2305
8.95k
          case 0xd4:
2306
8.99k
          case 0xd5:
2307
9.36k
          case 0xd6:
2308
9.55k
          case 0xd7:
2309
9.75k
          case 0xe4:
2310
10.0k
          case 0xe5:
2311
10.6k
          case 0xe6:
2312
10.9k
          case 0xe7:
2313
11.4k
          case 0xf4:
2314
14.9k
          case 0xf5:
2315
15.0k
          case 0xf6:
2316
15.4k
          case 0xf7:
2317
15.4k
              {
2318
                /** 0110 0001 1nnn 01mm   callt [%x0]       */
2319
15.4k
#line 439 "rl78-decode.opc"
2320
15.4k
                int nnn AU = (op[1] >> 4) & 0x07;
2321
15.4k
#line 439 "rl78-decode.opc"
2322
15.4k
                int mm AU = op[1] & 0x03;
2323
15.4k
                if (trace)
2324
0
                  {
2325
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2326
0
                           "/** 0110 0001 1nnn 01mm   callt [%x0]       */",
2327
0
                           op[0], op[1]);
2328
0
                    printf ("  nnn = 0x%x,", nnn);
2329
0
                    printf ("  mm = 0x%x\n", mm);
2330
0
                  }
2331
15.4k
                SYNTAX("callt [%x0]");
2332
15.4k
#line 439 "rl78-decode.opc"
2333
15.4k
                ID(call); DM(None, 0x80 + mm*16 + nnn*2);
2334
2335
              /*----------------------------------------------------------------------*/
2336
2337
15.4k
              }
2338
15.4k
            break;
2339
108
          case 0x88:
2340
260
          case 0x8a:
2341
757
          case 0x8b:
2342
883
          case 0x8c:
2343
1.01k
          case 0x8d:
2344
1.08k
          case 0x8e:
2345
1.27k
          case 0x8f:
2346
1.27k
              {
2347
                /** 0110 0001 1000 1reg   xch %0, %1        */
2348
1.27k
#line 1230 "rl78-decode.opc"
2349
1.27k
                int reg AU = op[1] & 0x07;
2350
1.27k
                if (trace)
2351
0
                  {
2352
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2353
0
                           "/** 0110 0001 1000 1reg   xch %0, %1        */",
2354
0
                           op[0], op[1]);
2355
0
                    printf ("  reg = 0x%x\n", reg);
2356
0
                  }
2357
1.27k
                SYNTAX("xch %0, %1");
2358
1.27k
#line 1230 "rl78-decode.opc"
2359
                /* Note: DECW uses reg == X, so this must follow DECW */
2360
1.27k
                ID(xch); DR(A); SRB(reg);
2361
2362
1.27k
              }
2363
1.27k
            break;
2364
128
          case 0x89:
2365
128
              {
2366
                /** 0110 0001 1000 1001   decw  %ea0        */
2367
128
                if (trace)
2368
0
                  {
2369
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2370
0
                           "/** 0110 0001 1000 1001   decw  %ea0        */",
2371
0
                           op[0], op[1]);
2372
0
                  }
2373
128
                SYNTAX("decw  %ea0");
2374
128
#line 571 "rl78-decode.opc"
2375
128
                ID(sub); W(); DM(HL, IMMU(1)); SC(1);
2376
2377
128
              }
2378
128
            break;
2379
579
          case 0x90:
2380
579
              {
2381
                /** 0110 0001 1001 0000   addc  %0, %e1       */
2382
579
                if (trace)
2383
0
                  {
2384
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2385
0
                           "/** 0110 0001 1001 0000   addc  %0, %e1       */",
2386
0
                           op[0], op[1]);
2387
0
                  }
2388
579
                SYNTAX("addc  %0, %e1");
2389
579
#line 245 "rl78-decode.opc"
2390
579
                ID(addc); DR(A); SM2(HL, B, 0); Fzac;
2391
2392
579
              }
2393
579
            break;
2394
67
          case 0x92:
2395
67
              {
2396
                /** 0110 0001 1001 0010   addc  %0, %e1       */
2397
67
                if (trace)
2398
0
                  {
2399
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2400
0
                           "/** 0110 0001 1001 0010   addc  %0, %e1       */",
2401
0
                           op[0], op[1]);
2402
0
                  }
2403
67
                SYNTAX("addc  %0, %e1");
2404
67
#line 248 "rl78-decode.opc"
2405
67
                ID(addc); DR(A); SM2(HL, C, 0); Fzac;
2406
2407
67
              }
2408
67
            break;
2409
248
          case 0xa0:
2410
908
          case 0xa1:
2411
908
              {
2412
                /** 0110 0001 1010 000    sub %0, %e1       */
2413
908
                if (trace)
2414
0
                  {
2415
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2416
0
                           "/** 0110 0001 1010 000    sub %0, %e1       */",
2417
0
                           op[0], op[1]);
2418
0
                  }
2419
908
                SYNTAX("sub %0, %e1");
2420
908
#line 1131 "rl78-decode.opc"
2421
908
                ID(sub); DR(A); SM2(HL, B, 0); Fzac;
2422
2423
908
              }
2424
908
            break;
2425
818
          case 0xa2:
2426
818
              {
2427
                /** 0110 0001 1010 0010   sub %0, %e1       */
2428
818
                if (trace)
2429
0
                  {
2430
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2431
0
                           "/** 0110 0001 1010 0010   sub %0, %e1       */",
2432
0
                           op[0], op[1]);
2433
0
                  }
2434
818
                SYNTAX("sub %0, %e1");
2435
818
#line 1137 "rl78-decode.opc"
2436
818
                ID(sub); DR(A); SM2(HL, C, 0); Fzac;
2437
2438
818
              }
2439
818
            break;
2440
245
          case 0xa8:
2441
245
              {
2442
                /** 0110 0001 1010 1000         xch %0, %1        */
2443
245
                if (trace)
2444
0
                  {
2445
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2446
0
                           "/** 0110 0001 1010 1000         xch %0, %1        */",
2447
0
                           op[0], op[1]);
2448
0
                  }
2449
245
                SYNTAX("xch %0, %1");
2450
245
#line 1234 "rl78-decode.opc"
2451
245
                ID(xch); DR(A); SM(None, SADDR);
2452
2453
245
              }
2454
245
            break;
2455
91
          case 0xa9:
2456
91
              {
2457
                /** 0110 0001 1010 1001   xch %0, %e1       */
2458
91
                if (trace)
2459
0
                  {
2460
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2461
0
                           "/** 0110 0001 1010 1001   xch %0, %e1       */",
2462
0
                           op[0], op[1]);
2463
0
                  }
2464
91
                SYNTAX("xch %0, %e1");
2465
91
#line 1227 "rl78-decode.opc"
2466
91
                ID(xch); DR(A); SM2(HL, C, 0);
2467
2468
91
              }
2469
91
            break;
2470
1.58k
          case 0xaa:
2471
1.58k
              {
2472
                /** 0110 0001 1010 1010   xch %0, %e!1      */
2473
1.58k
                if (trace)
2474
0
                  {
2475
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2476
0
                           "/** 0110 0001 1010 1010   xch %0, %e!1      */",
2477
0
                           op[0], op[1]);
2478
0
                  }
2479
1.58k
                SYNTAX("xch %0, %e!1");
2480
1.58k
#line 1209 "rl78-decode.opc"
2481
1.58k
                ID(xch); DR(A); SM(None, IMMU(2));
2482
2483
1.58k
              }
2484
1.58k
            break;
2485
283
          case 0xab:
2486
283
              {
2487
                /** 0110 0001 1010 1011         xch %0, %s1       */
2488
283
                if (trace)
2489
0
                  {
2490
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2491
0
                           "/** 0110 0001 1010 1011         xch %0, %s1       */",
2492
0
                           op[0], op[1]);
2493
0
                  }
2494
283
                SYNTAX("xch %0, %s1");
2495
283
#line 1237 "rl78-decode.opc"
2496
283
                ID(xch); DR(A); SM(None, SFR);
2497
2498
283
              }
2499
283
            break;
2500
521
          case 0xac:
2501
521
              {
2502
                /** 0110 0001 1010 1100   xch %0, %e1       */
2503
521
                if (trace)
2504
0
                  {
2505
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2506
0
                           "/** 0110 0001 1010 1100   xch %0, %e1       */",
2507
0
                           op[0], op[1]);
2508
0
                  }
2509
521
                SYNTAX("xch %0, %e1");
2510
521
#line 1218 "rl78-decode.opc"
2511
521
                ID(xch); DR(A); SM(HL, 0);
2512
2513
521
              }
2514
521
            break;
2515
791
          case 0xad:
2516
791
              {
2517
                /** 0110 0001 1010 1101   xch %0, %ea1      */
2518
791
                if (trace)
2519
0
                  {
2520
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2521
0
                           "/** 0110 0001 1010 1101   xch %0, %ea1      */",
2522
0
                           op[0], op[1]);
2523
0
                  }
2524
791
                SYNTAX("xch %0, %ea1");
2525
791
#line 1224 "rl78-decode.opc"
2526
791
                ID(xch); DR(A); SM(HL, IMMU(1));
2527
2528
791
              }
2529
791
            break;
2530
86
          case 0xae:
2531
86
              {
2532
                /** 0110 0001 1010 1110   xch %0, %e1       */
2533
86
                if (trace)
2534
0
                  {
2535
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2536
0
                           "/** 0110 0001 1010 1110   xch %0, %e1       */",
2537
0
                           op[0], op[1]);
2538
0
                  }
2539
86
                SYNTAX("xch %0, %e1");
2540
86
#line 1212 "rl78-decode.opc"
2541
86
                ID(xch); DR(A); SM(DE, 0);
2542
2543
86
              }
2544
86
            break;
2545
102
          case 0xaf:
2546
102
              {
2547
                /** 0110 0001 1010 1111   xch %0, %ea1        */
2548
102
                if (trace)
2549
0
                  {
2550
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2551
0
                           "/** 0110 0001 1010 1111   xch %0, %ea1        */",
2552
0
                           op[0], op[1]);
2553
0
                  }
2554
102
                SYNTAX("xch %0, %ea1");
2555
102
#line 1215 "rl78-decode.opc"
2556
102
                ID(xch); DR(A); SM(DE, IMMU(1));
2557
2558
102
              }
2559
102
            break;
2560
256
          case 0xb0:
2561
256
              {
2562
                /** 0110 0001 1011 0000   subc  %0, %e1       */
2563
256
                if (trace)
2564
0
                  {
2565
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2566
0
                           "/** 0110 0001 1011 0000   subc  %0, %e1       */",
2567
0
                           op[0], op[1]);
2568
0
                  }
2569
256
                SYNTAX("subc  %0, %e1");
2570
256
#line 1163 "rl78-decode.opc"
2571
256
                ID(subc); DR(A); SM2(HL, B, 0); Fzac;
2572
2573
256
              }
2574
256
            break;
2575
147
          case 0xb2:
2576
147
              {
2577
                /** 0110 0001 1011 0010   subc  %0, %e1       */
2578
147
                if (trace)
2579
0
                  {
2580
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2581
0
                           "/** 0110 0001 1011 0010   subc  %0, %e1       */",
2582
0
                           op[0], op[1]);
2583
0
                  }
2584
147
                SYNTAX("subc  %0, %e1");
2585
147
#line 1166 "rl78-decode.opc"
2586
147
                ID(subc); DR(A); SM2(HL, C, 0); Fzac;
2587
2588
147
              }
2589
147
            break;
2590
293
          case 0xb8:
2591
293
              {
2592
                /** 0110 0001 1011 1000   mov %0, %1        */
2593
293
                if (trace)
2594
0
                  {
2595
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2596
0
                           "/** 0110 0001 1011 1000   mov %0, %1        */",
2597
0
                           op[0], op[1]);
2598
0
                  }
2599
293
                SYNTAX("mov %0, %1");
2600
293
#line 729 "rl78-decode.opc"
2601
293
                ID(mov); DR(ES); SM(None, SADDR);
2602
2603
293
              }
2604
293
            break;
2605
297
          case 0xb9:
2606
297
              {
2607
                /** 0110 0001 1011 1001   xch %0, %e1       */
2608
297
                if (trace)
2609
0
                  {
2610
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2611
0
                           "/** 0110 0001 1011 1001   xch %0, %e1       */",
2612
0
                           op[0], op[1]);
2613
0
                  }
2614
297
                SYNTAX("xch %0, %e1");
2615
297
#line 1221 "rl78-decode.opc"
2616
297
                ID(xch); DR(A); SM2(HL, B, 0);
2617
2618
297
              }
2619
297
            break;
2620
342
          case 0xc0:
2621
342
              {
2622
                /** 0110 0001 1100 0000   cmp %0, %e1       */
2623
342
                if (trace)
2624
0
                  {
2625
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2626
0
                           "/** 0110 0001 1100 0000   cmp %0, %e1       */",
2627
0
                           op[0], op[1]);
2628
0
                  }
2629
342
                SYNTAX("cmp %0, %e1");
2630
342
#line 498 "rl78-decode.opc"
2631
342
                ID(cmp); DR(A); SM2(HL, B, 0); Fzac;
2632
2633
342
              }
2634
342
            break;
2635
1.51k
          case 0xc2:
2636
1.51k
              {
2637
                /** 0110 0001 1100 0010   cmp %0, %e1       */
2638
1.51k
                if (trace)
2639
0
                  {
2640
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2641
0
                           "/** 0110 0001 1100 0010   cmp %0, %e1       */",
2642
0
                           op[0], op[1]);
2643
0
                  }
2644
1.51k
                SYNTAX("cmp %0, %e1");
2645
1.51k
#line 501 "rl78-decode.opc"
2646
1.51k
                ID(cmp); DR(A); SM2(HL, C, 0); Fzac;
2647
2648
1.51k
              }
2649
1.51k
            break;
2650
3.16k
          case 0xc3:
2651
3.16k
              {
2652
                /** 0110 0001 1100 0011   bh  $%a0        */
2653
3.16k
                if (trace)
2654
0
                  {
2655
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2656
0
                           "/** 0110 0001 1100 0011   bh  $%a0        */",
2657
0
                           op[0], op[1]);
2658
0
                  }
2659
3.16k
                SYNTAX("bh  $%a0");
2660
3.16k
#line 346 "rl78-decode.opc"
2661
3.16k
                ID(branch_cond); DC(pc+IMMS(1)+3); SR(None); COND(H);
2662
2663
3.16k
              }
2664
3.16k
            break;
2665
152
          case 0xc8:
2666
152
              {
2667
                /** 0110 0001 1100 1000   sk%c1         */
2668
152
                if (trace)
2669
0
                  {
2670
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2671
0
                           "/** 0110 0001 1100 1000   sk%c1         */",
2672
0
                           op[0], op[1]);
2673
0
                  }
2674
152
                SYNTAX("sk%c1");
2675
152
#line 1100 "rl78-decode.opc"
2676
152
                ID(skip); COND(C);
2677
2678
152
              }
2679
152
            break;
2680
99
          case 0xc9:
2681
99
              {
2682
                /** 0110 0001 1100 1001   mov %0, %e1       */
2683
99
                if (trace)
2684
0
                  {
2685
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2686
0
                           "/** 0110 0001 1100 1001   mov %0, %e1       */",
2687
0
                           op[0], op[1]);
2688
0
                  }
2689
99
                SYNTAX("mov %0, %e1");
2690
99
#line 666 "rl78-decode.opc"
2691
99
                ID(mov); DR(A); SM2(HL, B, 0);
2692
2693
99
              }
2694
99
            break;
2695
130
          case 0xca:
2696
244
          case 0xda:
2697
389
          case 0xea:
2698
642
          case 0xfa:
2699
642
              {
2700
                /** 0110 0001 11rg 1010   call  %0        */
2701
642
#line 436 "rl78-decode.opc"
2702
642
                int rg AU = (op[1] >> 4) & 0x03;
2703
642
                if (trace)
2704
0
                  {
2705
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2706
0
                           "/** 0110 0001 11rg 1010   call  %0        */",
2707
0
                           op[0], op[1]);
2708
0
                    printf ("  rg = 0x%x\n", rg);
2709
0
                  }
2710
642
                SYNTAX("call  %0");
2711
642
#line 436 "rl78-decode.opc"
2712
642
                ID(call); DRW(rg);
2713
2714
642
              }
2715
642
            break;
2716
95
          case 0xcb:
2717
95
              {
2718
                /** 0110 0001 1100 1011   br  ax        */
2719
95
                if (trace)
2720
0
                  {
2721
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2722
0
                           "/** 0110 0001 1100 1011   br  ax        */",
2723
0
                           op[0], op[1]);
2724
0
                  }
2725
95
                SYNTAX("br  ax");
2726
95
#line 386 "rl78-decode.opc"
2727
95
                ID(branch); DR(AX);
2728
2729
              /*----------------------------------------------------------------------*/
2730
2731
95
              }
2732
95
            break;
2733
164
          case 0xcc:
2734
164
              {
2735
                /** 0110 0001 1100 1100   brk         */
2736
164
                if (trace)
2737
0
                  {
2738
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2739
0
                           "/** 0110 0001 1100 1100   brk         */",
2740
0
                           op[0], op[1]);
2741
0
                  }
2742
164
                SYNTAX("brk");
2743
164
#line 394 "rl78-decode.opc"
2744
164
                ID(break);
2745
2746
              /*----------------------------------------------------------------------*/
2747
2748
164
              }
2749
164
            break;
2750
147
          case 0xcd:
2751
147
              {
2752
                /** 0110 0001 1100 1101   pop %s0       */
2753
147
                if (trace)
2754
0
                  {
2755
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2756
0
                           "/** 0110 0001 1100 1101   pop %s0       */",
2757
0
                           op[0], op[1]);
2758
0
                  }
2759
147
                SYNTAX("pop %s0");
2760
147
#line 995 "rl78-decode.opc"
2761
147
                ID(mov); W(); DR(PSW); SPOP();
2762
2763
              /*----------------------------------------------------------------------*/
2764
2765
147
              }
2766
147
            break;
2767
1.27k
          case 0xce:
2768
1.27k
              {
2769
                /** 0110 0001 1100 1110   movs  %ea0, %1      */
2770
1.27k
                if (trace)
2771
0
                  {
2772
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2773
0
                           "/** 0110 0001 1100 1110   movs  %ea0, %1      */",
2774
0
                           op[0], op[1]);
2775
0
                  }
2776
1.27k
                SYNTAX("movs  %ea0, %1");
2777
1.27k
#line 817 "rl78-decode.opc"
2778
1.27k
                ID(mov); DM(HL, IMMU(1)); SR(X); Fzc;
2779
2780
              /*----------------------------------------------------------------------*/
2781
2782
1.27k
              }
2783
1.27k
            break;
2784
249
          case 0xcf:
2785
716
          case 0xdf:
2786
803
          case 0xef:
2787
3.61k
          case 0xff:
2788
3.61k
              {
2789
                /** 0110 0001 11rb 1111   sel rb%1        */
2790
3.61k
#line 1047 "rl78-decode.opc"
2791
3.61k
                int rb AU = (op[1] >> 4) & 0x03;
2792
3.61k
                if (trace)
2793
0
                  {
2794
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2795
0
                           "/** 0110 0001 11rb 1111   sel rb%1        */",
2796
0
                           op[0], op[1]);
2797
0
                    printf ("  rb = 0x%x\n", rb);
2798
0
                  }
2799
3.61k
                SYNTAX("sel rb%1");
2800
3.61k
#line 1047 "rl78-decode.opc"
2801
3.61k
                ID(sel); SC(rb);
2802
2803
              /*----------------------------------------------------------------------*/
2804
2805
3.61k
              }
2806
3.61k
            break;
2807
344
          case 0xd0:
2808
344
              {
2809
                /** 0110 0001 1101 0000   and %0, %e1     */
2810
344
                if (trace)
2811
0
                  {
2812
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2813
0
                           "/** 0110 0001 1101 0000   and %0, %e1     */",
2814
0
                           op[0], op[1]);
2815
0
                  }
2816
344
                SYNTAX("and %0, %e1");
2817
344
#line 297 "rl78-decode.opc"
2818
344
                ID(and); DR(A); SM2(HL, B, 0); Fz;
2819
2820
344
              }
2821
344
            break;
2822
215
          case 0xd2:
2823
215
              {
2824
                /** 0110 0001 1101 0010   and %0, %e1     */
2825
215
                if (trace)
2826
0
                  {
2827
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2828
0
                           "/** 0110 0001 1101 0010   and %0, %e1     */",
2829
0
                           op[0], op[1]);
2830
0
                  }
2831
215
                SYNTAX("and %0, %e1");
2832
215
#line 303 "rl78-decode.opc"
2833
215
                ID(and); DR(A); SM2(HL, C, 0); Fz;
2834
2835
215
              }
2836
215
            break;
2837
709
          case 0xd3:
2838
709
              {
2839
                /** 0110 0001 1101 0011   bnh $%a0        */
2840
709
                if (trace)
2841
0
                  {
2842
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2843
0
                           "/** 0110 0001 1101 0011   bnh $%a0        */",
2844
0
                           op[0], op[1]);
2845
0
                  }
2846
709
                SYNTAX("bnh $%a0");
2847
709
#line 349 "rl78-decode.opc"
2848
709
                ID(branch_cond); DC(pc+IMMS(1)+3); SR(None); COND(NH);
2849
2850
709
              }
2851
709
            break;
2852
44
          case 0xd8:
2853
44
              {
2854
                /** 0110 0001 1101 1000   sk%c1         */
2855
44
                if (trace)
2856
0
                  {
2857
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2858
0
                           "/** 0110 0001 1101 1000   sk%c1         */",
2859
0
                           op[0], op[1]);
2860
0
                  }
2861
44
                SYNTAX("sk%c1");
2862
44
#line 1106 "rl78-decode.opc"
2863
44
                ID(skip); COND(NC);
2864
2865
44
              }
2866
44
            break;
2867
428
          case 0xd9:
2868
428
              {
2869
                /** 0110 0001 1101 1001   mov %e0, %1       */
2870
428
                if (trace)
2871
0
                  {
2872
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2873
0
                           "/** 0110 0001 1101 1001   mov %e0, %1       */",
2874
0
                           op[0], op[1]);
2875
0
                  }
2876
428
                SYNTAX("mov %e0, %1");
2877
428
#line 633 "rl78-decode.opc"
2878
428
                ID(mov); DM2(HL, B, 0); SR(A);
2879
2880
428
              }
2881
428
            break;
2882
214
          case 0xdb:
2883
214
              {
2884
                /** 0110 0001 1101 1011   ror %0, %1        */
2885
214
                if (trace)
2886
0
                  {
2887
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2888
0
                           "/** 0110 0001 1101 1011   ror %0, %1        */",
2889
0
                           op[0], op[1]);
2890
0
                  }
2891
214
                SYNTAX("ror %0, %1");
2892
214
#line 1028 "rl78-decode.opc"
2893
214
                ID(ror); DR(A); SC(1);
2894
2895
214
              }
2896
214
            break;
2897
292
          case 0xdc:
2898
292
              {
2899
                /** 0110 0001 1101 1100   rolc  %0, %1        */
2900
292
                if (trace)
2901
0
                  {
2902
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2903
0
                           "/** 0110 0001 1101 1100   rolc  %0, %1        */",
2904
0
                           op[0], op[1]);
2905
0
                  }
2906
292
                SYNTAX("rolc  %0, %1");
2907
292
#line 1022 "rl78-decode.opc"
2908
292
                ID(rolc); DR(A); SC(1);
2909
2910
292
              }
2911
292
            break;
2912
73
          case 0xdd:
2913
73
              {
2914
                /** 0110 0001 1101 1101   push  %s1       */
2915
73
                if (trace)
2916
0
                  {
2917
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2918
0
                           "/** 0110 0001 1101 1101   push  %s1       */",
2919
0
                           op[0], op[1]);
2920
0
                  }
2921
73
                SYNTAX("push  %s1");
2922
73
#line 1003 "rl78-decode.opc"
2923
73
                ID(mov); W(); DPUSH(); SR(PSW);
2924
2925
              /*----------------------------------------------------------------------*/
2926
2927
73
              }
2928
73
            break;
2929
173
          case 0xde:
2930
173
              {
2931
                /** 0110 0001 1101 1110   cmps  %0, %ea1      */
2932
173
                if (trace)
2933
0
                  {
2934
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2935
0
                           "/** 0110 0001 1101 1110   cmps  %0, %ea1      */",
2936
0
                           op[0], op[1]);
2937
0
                  }
2938
173
                SYNTAX("cmps  %0, %ea1");
2939
173
#line 532 "rl78-decode.opc"
2940
173
                ID(cmp); DR(X); SM(HL, IMMU(1)); Fzac;
2941
2942
              /*----------------------------------------------------------------------*/
2943
2944
173
              }
2945
173
            break;
2946
349
          case 0xe0:
2947
349
              {
2948
                /** 0110 0001 1110 0000   or  %0, %e1       */
2949
349
                if (trace)
2950
0
                  {
2951
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2952
0
                           "/** 0110 0001 1110 0000   or  %0, %e1       */",
2953
0
                           op[0], op[1]);
2954
0
                  }
2955
349
                SYNTAX("or  %0, %e1");
2956
349
#line 952 "rl78-decode.opc"
2957
349
                ID(or); DR(A); SM2(HL, B, 0); Fz;
2958
2959
349
              }
2960
349
            break;
2961
184
          case 0xe2:
2962
184
              {
2963
                /** 0110 0001 1110 0010   or  %0, %e1       */
2964
184
                if (trace)
2965
0
                  {
2966
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2967
0
                           "/** 0110 0001 1110 0010   or  %0, %e1       */",
2968
0
                           op[0], op[1]);
2969
0
                  }
2970
184
                SYNTAX("or  %0, %e1");
2971
184
#line 958 "rl78-decode.opc"
2972
184
                ID(or); DR(A); SM2(HL, C, 0); Fz;
2973
2974
184
              }
2975
184
            break;
2976
608
          case 0xe3:
2977
608
              {
2978
                /** 0110 0001 1110 0011   sk%c1         */
2979
608
                if (trace)
2980
0
                  {
2981
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2982
0
                           "/** 0110 0001 1110 0011   sk%c1         */",
2983
0
                           op[0], op[1]);
2984
0
                  }
2985
608
                SYNTAX("sk%c1");
2986
608
#line 1103 "rl78-decode.opc"
2987
608
                ID(skip); COND(H);
2988
2989
608
              }
2990
608
            break;
2991
54
          case 0xe8:
2992
54
              {
2993
                /** 0110 0001 1110 1000   sk%c1         */
2994
54
                if (trace)
2995
0
                  {
2996
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
2997
0
                           "/** 0110 0001 1110 1000   sk%c1         */",
2998
0
                           op[0], op[1]);
2999
0
                  }
3000
54
                SYNTAX("sk%c1");
3001
54
#line 1115 "rl78-decode.opc"
3002
54
                ID(skip); COND(Z);
3003
3004
              /*----------------------------------------------------------------------*/
3005
3006
54
              }
3007
54
            break;
3008
255
          case 0xe9:
3009
255
              {
3010
                /** 0110 0001 1110 1001   mov %0, %e1       */
3011
255
                if (trace)
3012
0
                  {
3013
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3014
0
                           "/** 0110 0001 1110 1001   mov %0, %e1       */",
3015
0
                           op[0], op[1]);
3016
0
                  }
3017
255
                SYNTAX("mov %0, %e1");
3018
255
#line 669 "rl78-decode.opc"
3019
255
                ID(mov); DR(A); SM2(HL, C, 0);
3020
3021
255
              }
3022
255
            break;
3023
88
          case 0xeb:
3024
88
              {
3025
                /** 0110 0001 1110 1011   rol %0, %1        */
3026
88
                if (trace)
3027
0
                  {
3028
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3029
0
                           "/** 0110 0001 1110 1011   rol %0, %1        */",
3030
0
                           op[0], op[1]);
3031
0
                  }
3032
88
                SYNTAX("rol %0, %1");
3033
88
#line 1019 "rl78-decode.opc"
3034
88
                ID(rol); DR(A); SC(1);
3035
3036
88
              }
3037
88
            break;
3038
139
          case 0xec:
3039
139
              {
3040
                /** 0110 0001 1110 1100   retb          */
3041
139
                if (trace)
3042
0
                  {
3043
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3044
0
                           "/** 0110 0001 1110 1100   retb          */",
3045
0
                           op[0], op[1]);
3046
0
                  }
3047
139
                SYNTAX("retb");
3048
139
#line 1014 "rl78-decode.opc"
3049
139
                ID(reti);
3050
3051
              /*----------------------------------------------------------------------*/
3052
3053
139
              }
3054
139
            break;
3055
182
          case 0xed:
3056
182
              {
3057
                /** 0110 0001 1110 1101   halt          */
3058
182
                if (trace)
3059
0
                  {
3060
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3061
0
                           "/** 0110 0001 1110 1101   halt          */",
3062
0
                           op[0], op[1]);
3063
0
                  }
3064
182
                SYNTAX("halt");
3065
182
#line 582 "rl78-decode.opc"
3066
182
                ID(halt);
3067
3068
              /*----------------------------------------------------------------------*/
3069
3070
182
              }
3071
182
            break;
3072
111
          case 0xee:
3073
234
          case 0xfe:
3074
234
              {
3075
                /** 0110 0001 111r 1110   rolwc %0, %1        */
3076
234
#line 1025 "rl78-decode.opc"
3077
234
                int r AU = (op[1] >> 4) & 0x01;
3078
234
                if (trace)
3079
0
                  {
3080
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3081
0
                           "/** 0110 0001 111r 1110   rolwc %0, %1        */",
3082
0
                           op[0], op[1]);
3083
0
                    printf ("  r = 0x%x\n", r);
3084
0
                  }
3085
234
                SYNTAX("rolwc %0, %1");
3086
234
#line 1025 "rl78-decode.opc"
3087
234
                ID(rolc); W(); DRW(r); SC(1);
3088
3089
234
              }
3090
234
            break;
3091
122
          case 0xf0:
3092
122
              {
3093
                /** 0110 0001 1111 0000   xor %0, %e1       */
3094
122
                if (trace)
3095
0
                  {
3096
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3097
0
                           "/** 0110 0001 1111 0000   xor %0, %e1       */",
3098
0
                           op[0], op[1]);
3099
0
                  }
3100
122
                SYNTAX("xor %0, %e1");
3101
122
#line 1256 "rl78-decode.opc"
3102
122
                ID(xor); DR(A); SM2(HL, B, 0); Fz;
3103
3104
122
              }
3105
122
            break;
3106
180
          case 0xf2:
3107
180
              {
3108
                /** 0110 0001 1111 0010   xor %0, %e1       */
3109
180
                if (trace)
3110
0
                  {
3111
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3112
0
                           "/** 0110 0001 1111 0010   xor %0, %e1       */",
3113
0
                           op[0], op[1]);
3114
0
                  }
3115
180
                SYNTAX("xor %0, %e1");
3116
180
#line 1262 "rl78-decode.opc"
3117
180
                ID(xor); DR(A); SM2(HL, C, 0); Fz;
3118
3119
180
              }
3120
180
            break;
3121
265
          case 0xf3:
3122
265
              {
3123
                /** 0110 0001 1111 0011   sk%c1         */
3124
265
                if (trace)
3125
0
                  {
3126
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3127
0
                           "/** 0110 0001 1111 0011   sk%c1         */",
3128
0
                           op[0], op[1]);
3129
0
                  }
3130
265
                SYNTAX("sk%c1");
3131
265
#line 1109 "rl78-decode.opc"
3132
265
                ID(skip); COND(NH);
3133
3134
265
              }
3135
265
            break;
3136
125
          case 0xf8:
3137
125
              {
3138
                /** 0110 0001 1111 1000   sk%c1         */
3139
125
                if (trace)
3140
0
                  {
3141
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3142
0
                           "/** 0110 0001 1111 1000   sk%c1         */",
3143
0
                           op[0], op[1]);
3144
0
                  }
3145
125
                SYNTAX("sk%c1");
3146
125
#line 1112 "rl78-decode.opc"
3147
125
                ID(skip); COND(NZ);
3148
3149
125
              }
3150
125
            break;
3151
168
          case 0xf9:
3152
168
              {
3153
                /** 0110 0001 1111 1001   mov %e0, %1       */
3154
168
                if (trace)
3155
0
                  {
3156
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3157
0
                           "/** 0110 0001 1111 1001   mov %e0, %1       */",
3158
0
                           op[0], op[1]);
3159
0
                  }
3160
168
                SYNTAX("mov %e0, %1");
3161
168
#line 642 "rl78-decode.opc"
3162
168
                ID(mov); DM2(HL, C, 0); SR(A);
3163
3164
168
              }
3165
168
            break;
3166
133
          case 0xfb:
3167
133
              {
3168
                /** 0110 0001 1111 1011   rorc  %0, %1        */
3169
133
                if (trace)
3170
0
                  {
3171
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3172
0
                           "/** 0110 0001 1111 1011   rorc  %0, %1        */",
3173
0
                           op[0], op[1]);
3174
0
                  }
3175
133
                SYNTAX("rorc  %0, %1");
3176
133
#line 1031 "rl78-decode.opc"
3177
133
                ID(rorc); DR(A); SC(1);
3178
3179
              /*----------------------------------------------------------------------*/
3180
3181
              /* Note that the branch insns need to be listed before the shift
3182
                 ones, as "shift count of zero" means "branch insn" */
3183
3184
133
              }
3185
133
            break;
3186
307
          case 0xfc:
3187
307
              {
3188
                /** 0110 0001 1111 1100   reti          */
3189
307
                if (trace)
3190
0
                  {
3191
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3192
0
                           "/** 0110 0001 1111 1100   reti          */",
3193
0
                           op[0], op[1]);
3194
0
                  }
3195
307
                SYNTAX("reti");
3196
307
#line 1011 "rl78-decode.opc"
3197
307
                ID(reti);
3198
3199
307
              }
3200
307
            break;
3201
159
          case 0xfd:
3202
159
              {
3203
                /** 0110 0001 1111 1101 stop            */
3204
159
                if (trace)
3205
0
                  {
3206
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3207
0
                           "/** 0110 0001 1111 1101 stop            */",
3208
0
                           op[0], op[1]);
3209
0
                  }
3210
159
                SYNTAX("stop");
3211
159
#line 1120 "rl78-decode.opc"
3212
159
                ID(stop);
3213
3214
              /*----------------------------------------------------------------------*/
3215
3216
159
              }
3217
159
            break;
3218
1.72k
          default: UNSUPPORTED(); break;
3219
164k
        }
3220
164k
      break;
3221
164k
    case 0x68:
3222
12.5k
        {
3223
          /** 0110 1000     movw  %e0, %1       */
3224
12.5k
          if (trace)
3225
0
            {
3226
0
              printf ("\033[33m%s\033[0m  %02x\n",
3227
0
                     "/** 0110 1000     movw  %e0, %1       */",
3228
0
                     op[0]);
3229
0
            }
3230
12.5k
          SYNTAX("movw  %e0, %1");
3231
12.5k
#line 880 "rl78-decode.opc"
3232
12.5k
          ID(mov); W(); DM(C, IMMU(2)); SR(AX);
3233
3234
12.5k
        }
3235
12.5k
      break;
3236
14.5k
    case 0x69:
3237
14.5k
        {
3238
          /** 0110 1001     movw  %0, %e1       */
3239
14.5k
          if (trace)
3240
0
            {
3241
0
              printf ("\033[33m%s\033[0m  %02x\n",
3242
0
                     "/** 0110 1001     movw  %0, %e1       */",
3243
0
                     op[0]);
3244
0
            }
3245
14.5k
          SYNTAX("movw  %0, %e1");
3246
14.5k
#line 871 "rl78-decode.opc"
3247
14.5k
          ID(mov); W(); DR(AX); SM(C, IMMU(2));
3248
3249
14.5k
        }
3250
14.5k
      break;
3251
6.72k
    case 0x6a:
3252
6.72k
        {
3253
          /** 0110 1010           or  %0, #%1       */
3254
6.72k
          if (trace)
3255
0
            {
3256
0
              printf ("\033[33m%s\033[0m  %02x\n",
3257
0
                     "/** 0110 1010           or  %0, #%1       */",
3258
0
                     op[0]);
3259
0
            }
3260
6.72k
          SYNTAX("or  %0, #%1");
3261
6.72k
#line 973 "rl78-decode.opc"
3262
6.72k
          ID(or); DM(None, SADDR); SC(IMMU(1)); Fz;
3263
3264
        /*----------------------------------------------------------------------*/
3265
3266
6.72k
        }
3267
6.72k
      break;
3268
4.50k
    case 0x6b:
3269
4.50k
        {
3270
          /** 0110 1011           or  %0, %1        */
3271
4.50k
          if (trace)
3272
0
            {
3273
0
              printf ("\033[33m%s\033[0m  %02x\n",
3274
0
                     "/** 0110 1011           or  %0, %1        */",
3275
0
                     op[0]);
3276
0
            }
3277
4.50k
          SYNTAX("or  %0, %1");
3278
4.50k
#line 970 "rl78-decode.opc"
3279
4.50k
          ID(or); DR(A); SM(None, SADDR); Fz;
3280
3281
4.50k
        }
3282
4.50k
      break;
3283
13.9k
    case 0x6c:
3284
13.9k
        {
3285
          /** 0110 1100           or  %0, #%1       */
3286
13.9k
          if (trace)
3287
0
            {
3288
0
              printf ("\033[33m%s\033[0m  %02x\n",
3289
0
                     "/** 0110 1100           or  %0, #%1       */",
3290
0
                     op[0]);
3291
0
            }
3292
13.9k
          SYNTAX("or  %0, #%1");
3293
13.9k
#line 961 "rl78-decode.opc"
3294
13.9k
          ID(or); DR(A); SC(IMMU(1)); Fz;
3295
3296
13.9k
        }
3297
13.9k
      break;
3298
9.35k
    case 0x6d:
3299
9.35k
        {
3300
          /** 0110 1101     or  %0, %e1       */
3301
9.35k
          if (trace)
3302
0
            {
3303
0
              printf ("\033[33m%s\033[0m  %02x\n",
3304
0
                     "/** 0110 1101     or  %0, %e1       */",
3305
0
                     op[0]);
3306
0
            }
3307
9.35k
          SYNTAX("or  %0, %e1");
3308
9.35k
#line 949 "rl78-decode.opc"
3309
9.35k
          ID(or); DR(A); SM(HL, 0); Fz;
3310
3311
9.35k
        }
3312
9.35k
      break;
3313
13.8k
    case 0x6e:
3314
13.8k
        {
3315
          /** 0110 1110     or  %0, %ea1      */
3316
13.8k
          if (trace)
3317
0
            {
3318
0
              printf ("\033[33m%s\033[0m  %02x\n",
3319
0
                     "/** 0110 1110     or  %0, %ea1      */",
3320
0
                     op[0]);
3321
0
            }
3322
13.8k
          SYNTAX("or  %0, %ea1");
3323
13.8k
#line 955 "rl78-decode.opc"
3324
13.8k
          ID(or); DR(A); SM(HL, IMMU(1)); Fz;
3325
3326
13.8k
        }
3327
13.8k
      break;
3328
14.8k
    case 0x6f:
3329
14.8k
        {
3330
          /** 0110 1111     or  %0, %e!1      */
3331
14.8k
          if (trace)
3332
0
            {
3333
0
              printf ("\033[33m%s\033[0m  %02x\n",
3334
0
                     "/** 0110 1111     or  %0, %e!1      */",
3335
0
                     op[0]);
3336
0
            }
3337
14.8k
          SYNTAX("or  %0, %e!1");
3338
14.8k
#line 946 "rl78-decode.opc"
3339
14.8k
          ID(or); DR(A); SM(None, IMMU(2)); Fz;
3340
3341
14.8k
        }
3342
14.8k
      break;
3343
15.6k
    case 0x70:
3344
29.1k
    case 0x72:
3345
45.3k
    case 0x73:
3346
59.3k
    case 0x74:
3347
66.0k
    case 0x75:
3348
76.7k
    case 0x76:
3349
89.3k
    case 0x77:
3350
89.3k
        {
3351
          /** 0111 0rba     mov %0, %1        */
3352
89.3k
#line 702 "rl78-decode.opc"
3353
89.3k
          int rba AU = op[0] & 0x07;
3354
89.3k
          if (trace)
3355
0
            {
3356
0
              printf ("\033[33m%s\033[0m  %02x\n",
3357
0
                     "/** 0111 0rba     mov %0, %1        */",
3358
0
                     op[0]);
3359
0
              printf ("  rba = 0x%x\n", rba);
3360
0
            }
3361
89.3k
          SYNTAX("mov %0, %1");
3362
89.3k
#line 702 "rl78-decode.opc"
3363
89.3k
          ID(mov); DRB(rba); SR(A);
3364
3365
89.3k
        }
3366
89.3k
      break;
3367
154k
    case 0x71:
3368
154k
        GETBYTE ();
3369
154k
        switch (op[1] & 0xff)
3370
154k
        {
3371
3.12k
          case 0x00:
3372
5.10k
          case 0x10:
3373
5.76k
          case 0x20:
3374
6.82k
          case 0x30:
3375
7.27k
          case 0x40:
3376
8.45k
          case 0x50:
3377
8.79k
          case 0x60:
3378
9.51k
          case 0x70:
3379
9.51k
              {
3380
                /** 0111 0001 0bit 0000   set1  %e!0        */
3381
9.51k
#line 1052 "rl78-decode.opc"
3382
9.51k
                int bit AU = (op[1] >> 4) & 0x07;
3383
9.51k
                if (trace)
3384
0
                  {
3385
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3386
0
                           "/** 0111 0001 0bit 0000   set1  %e!0        */",
3387
0
                           op[0], op[1]);
3388
0
                    printf ("  bit = 0x%x\n", bit);
3389
0
                  }
3390
9.51k
                SYNTAX("set1  %e!0");
3391
9.51k
#line 1052 "rl78-decode.opc"
3392
9.51k
                ID(mov); DM(None, IMMU(2)); DB(bit); SC(1);
3393
3394
9.51k
              }
3395
9.51k
            break;
3396
537
          case 0x01:
3397
5.98k
          case 0x11:
3398
6.37k
          case 0x21:
3399
7.03k
          case 0x31:
3400
7.25k
          case 0x41:
3401
8.48k
          case 0x51:
3402
9.89k
          case 0x61:
3403
53.7k
          case 0x71:
3404
53.7k
              {
3405
                /** 0111 0001 0bit 0001   mov1  %0, cy        */
3406
53.7k
#line 809 "rl78-decode.opc"
3407
53.7k
                int bit AU = (op[1] >> 4) & 0x07;
3408
53.7k
                if (trace)
3409
0
                  {
3410
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3411
0
                           "/** 0111 0001 0bit 0001   mov1  %0, cy        */",
3412
0
                           op[0], op[1]);
3413
0
                    printf ("  bit = 0x%x\n", bit);
3414
0
                  }
3415
53.7k
                SYNTAX("mov1  %0, cy");
3416
53.7k
#line 809 "rl78-decode.opc"
3417
53.7k
                ID(mov); DM(None, SADDR); DB(bit); SCY();
3418
3419
53.7k
              }
3420
53.7k
            break;
3421
127
          case 0x02:
3422
289
          case 0x12:
3423
382
          case 0x22:
3424
734
          case 0x32:
3425
865
          case 0x42:
3426
1.16k
          case 0x52:
3427
2.45k
          case 0x62:
3428
2.83k
          case 0x72:
3429
2.83k
              {
3430
                /** 0111 0001 0bit 0010   set1  %0        */
3431
2.83k
#line 1070 "rl78-decode.opc"
3432
2.83k
                int bit AU = (op[1] >> 4) & 0x07;
3433
2.83k
                if (trace)
3434
0
                  {
3435
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3436
0
                           "/** 0111 0001 0bit 0010   set1  %0        */",
3437
0
                           op[0], op[1]);
3438
0
                    printf ("  bit = 0x%x\n", bit);
3439
0
                  }
3440
2.83k
                SYNTAX("set1  %0");
3441
2.83k
#line 1070 "rl78-decode.opc"
3442
2.83k
                ID(mov); DM(None, SADDR); DB(bit); SC(1);
3443
3444
              /*----------------------------------------------------------------------*/
3445
3446
2.83k
              }
3447
2.83k
            break;
3448
400
          case 0x03:
3449
945
          case 0x13:
3450
1.17k
          case 0x23:
3451
2.94k
          case 0x33:
3452
3.47k
          case 0x43:
3453
3.78k
          case 0x53:
3454
4.45k
          case 0x63:
3455
4.74k
          case 0x73:
3456
4.74k
              {
3457
                /** 0111 0001 0bit 0011   clr1  %0        */
3458
4.74k
#line 462 "rl78-decode.opc"
3459
4.74k
                int bit AU = (op[1] >> 4) & 0x07;
3460
4.74k
                if (trace)
3461
0
                  {
3462
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3463
0
                           "/** 0111 0001 0bit 0011   clr1  %0        */",
3464
0
                           op[0], op[1]);
3465
0
                    printf ("  bit = 0x%x\n", bit);
3466
0
                  }
3467
4.74k
                SYNTAX("clr1  %0");
3468
4.74k
#line 462 "rl78-decode.opc"
3469
4.74k
                ID(mov); DM(None, SADDR); DB(bit); SC(0);
3470
3471
              /*----------------------------------------------------------------------*/
3472
3473
4.74k
              }
3474
4.74k
            break;
3475
160
          case 0x04:
3476
261
          case 0x14:
3477
359
          case 0x24:
3478
1.26k
          case 0x34:
3479
2.06k
          case 0x44:
3480
2.19k
          case 0x54:
3481
2.53k
          case 0x64:
3482
2.86k
          case 0x74:
3483
2.86k
              {
3484
                /** 0111 0001 0bit 0100   mov1  cy, %1        */
3485
2.86k
#line 803 "rl78-decode.opc"
3486
2.86k
                int bit AU = (op[1] >> 4) & 0x07;
3487
2.86k
                if (trace)
3488
0
                  {
3489
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3490
0
                           "/** 0111 0001 0bit 0100   mov1  cy, %1        */",
3491
0
                           op[0], op[1]);
3492
0
                    printf ("  bit = 0x%x\n", bit);
3493
0
                  }
3494
2.86k
                SYNTAX("mov1  cy, %1");
3495
2.86k
#line 803 "rl78-decode.opc"
3496
2.86k
                ID(mov); DCY(); SM(None, SADDR); SB(bit);
3497
3498
2.86k
              }
3499
2.86k
            break;
3500
285
          case 0x05:
3501
468
          case 0x15:
3502
694
          case 0x25:
3503
844
          case 0x35:
3504
1.22k
          case 0x45:
3505
1.78k
          case 0x55:
3506
1.90k
          case 0x65:
3507
2.41k
          case 0x75:
3508
2.41k
              {
3509
                /** 0111 0001 0bit 0101   and1  cy, %s1       */
3510
2.41k
#line 332 "rl78-decode.opc"
3511
2.41k
                int bit AU = (op[1] >> 4) & 0x07;
3512
2.41k
                if (trace)
3513
0
                  {
3514
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3515
0
                           "/** 0111 0001 0bit 0101   and1  cy, %s1       */",
3516
0
                           op[0], op[1]);
3517
0
                    printf ("  bit = 0x%x\n", bit);
3518
0
                  }
3519
2.41k
                SYNTAX("and1  cy, %s1");
3520
2.41k
#line 332 "rl78-decode.opc"
3521
2.41k
                ID(and); DCY(); SM(None, SADDR); SB(bit);
3522
3523
              /*----------------------------------------------------------------------*/
3524
3525
              /* Note that the branch insns need to be listed before the shift
3526
                 ones, as "shift count of zero" means "branch insn" */
3527
3528
2.41k
              }
3529
2.41k
            break;
3530
121
          case 0x06:
3531
548
          case 0x16:
3532
989
          case 0x26:
3533
1.75k
          case 0x36:
3534
1.83k
          case 0x46:
3535
2.66k
          case 0x56:
3536
3.27k
          case 0x66:
3537
3.43k
          case 0x76:
3538
3.43k
              {
3539
                /** 0111 0001 0bit 0110   or1 cy, %s1       */
3540
3.43k
#line 987 "rl78-decode.opc"
3541
3.43k
                int bit AU = (op[1] >> 4) & 0x07;
3542
3.43k
                if (trace)
3543
0
                  {
3544
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3545
0
                           "/** 0111 0001 0bit 0110   or1 cy, %s1       */",
3546
0
                           op[0], op[1]);
3547
0
                    printf ("  bit = 0x%x\n", bit);
3548
0
                  }
3549
3.43k
                SYNTAX("or1 cy, %s1");
3550
3.43k
#line 987 "rl78-decode.opc"
3551
3.43k
                ID(or); DCY(); SM(None, SADDR); SB(bit);
3552
3553
              /*----------------------------------------------------------------------*/
3554
3555
3.43k
              }
3556
3.43k
            break;
3557
238
          case 0x07:
3558
353
          case 0x17:
3559
1.02k
          case 0x27:
3560
1.46k
          case 0x37:
3561
1.62k
          case 0x47:
3562
1.77k
          case 0x57:
3563
2.37k
          case 0x67:
3564
3.48k
          case 0x77:
3565
3.48k
              {
3566
                /** 0111 0001 0bit 0111   xor1  cy, %s1       */
3567
3.48k
#line 1291 "rl78-decode.opc"
3568
3.48k
                int bit AU = (op[1] >> 4) & 0x07;
3569
3.48k
                if (trace)
3570
0
                  {
3571
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3572
0
                           "/** 0111 0001 0bit 0111   xor1  cy, %s1       */",
3573
0
                           op[0], op[1]);
3574
0
                    printf ("  bit = 0x%x\n", bit);
3575
0
                  }
3576
3.48k
                SYNTAX("xor1  cy, %s1");
3577
3.48k
#line 1291 "rl78-decode.opc"
3578
3.48k
                ID(xor); DCY(); SM(None, SADDR); SB(bit);
3579
3580
              /*----------------------------------------------------------------------*/
3581
3582
3.48k
              }
3583
3.48k
            break;
3584
200
          case 0x08:
3585
374
          case 0x18:
3586
2.63k
          case 0x28:
3587
2.85k
          case 0x38:
3588
3.34k
          case 0x48:
3589
3.42k
          case 0x58:
3590
4.48k
          case 0x68:
3591
4.86k
          case 0x78:
3592
4.86k
              {
3593
                /** 0111 0001 0bit 1000   clr1  %e!0        */
3594
4.86k
#line 444 "rl78-decode.opc"
3595
4.86k
                int bit AU = (op[1] >> 4) & 0x07;
3596
4.86k
                if (trace)
3597
0
                  {
3598
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3599
0
                           "/** 0111 0001 0bit 1000   clr1  %e!0        */",
3600
0
                           op[0], op[1]);
3601
0
                    printf ("  bit = 0x%x\n", bit);
3602
0
                  }
3603
4.86k
                SYNTAX("clr1  %e!0");
3604
4.86k
#line 444 "rl78-decode.opc"
3605
4.86k
                ID(mov); DM(None, IMMU(2)); DB(bit); SC(0);
3606
3607
4.86k
              }
3608
4.86k
            break;
3609
761
          case 0x09:
3610
921
          case 0x19:
3611
1.39k
          case 0x29:
3612
1.53k
          case 0x39:
3613
2.10k
          case 0x49:
3614
2.22k
          case 0x59:
3615
2.79k
          case 0x69:
3616
3.23k
          case 0x79:
3617
3.23k
              {
3618
                /** 0111 0001 0bit 1001   mov1  %s0, cy       */
3619
3.23k
#line 812 "rl78-decode.opc"
3620
3.23k
                int bit AU = (op[1] >> 4) & 0x07;
3621
3.23k
                if (trace)
3622
0
                  {
3623
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3624
0
                           "/** 0111 0001 0bit 1001   mov1  %s0, cy       */",
3625
0
                           op[0], op[1]);
3626
0
                    printf ("  bit = 0x%x\n", bit);
3627
0
                  }
3628
3.23k
                SYNTAX("mov1  %s0, cy");
3629
3.23k
#line 812 "rl78-decode.opc"
3630
3.23k
                ID(mov); DM(None, SFR); DB(bit); SCY();
3631
3632
              /*----------------------------------------------------------------------*/
3633
3634
3.23k
              }
3635
3.23k
            break;
3636
152
          case 0x0a:
3637
1.25k
          case 0x1a:
3638
1.56k
          case 0x2a:
3639
1.75k
          case 0x3a:
3640
1.81k
          case 0x4a:
3641
2.04k
          case 0x5a:
3642
2.15k
          case 0x6a:
3643
2.40k
          case 0x7a:
3644
2.40k
              {
3645
                /** 0111 0001 0bit 1010   set1  %s0       */
3646
2.40k
#line 1064 "rl78-decode.opc"
3647
2.40k
                int bit AU = (op[1] >> 4) & 0x07;
3648
2.40k
                if (trace)
3649
0
                  {
3650
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3651
0
                           "/** 0111 0001 0bit 1010   set1  %s0       */",
3652
0
                           op[0], op[1]);
3653
0
                    printf ("  bit = 0x%x\n", bit);
3654
0
                  }
3655
2.40k
                SYNTAX("set1  %s0");
3656
2.40k
#line 1064 "rl78-decode.opc"
3657
2.40k
                op0 = SFR;
3658
2.40k
                ID(mov); DM(None, op0); DB(bit); SC(1);
3659
2.40k
                if (op0 == RL78_SFR_PSW && bit == 7)
3660
67
                  rl78->syntax = "ei";
3661
3662
2.40k
              }
3663
2.40k
            break;
3664
185
          case 0x0b:
3665
258
          case 0x1b:
3666
657
          case 0x2b:
3667
1.24k
          case 0x3b:
3668
1.63k
          case 0x4b:
3669
1.81k
          case 0x5b:
3670
1.88k
          case 0x6b:
3671
2.72k
          case 0x7b:
3672
2.72k
              {
3673
                /** 0111 0001 0bit 1011   clr1  %s0       */
3674
2.72k
#line 456 "rl78-decode.opc"
3675
2.72k
                int bit AU = (op[1] >> 4) & 0x07;
3676
2.72k
                if (trace)
3677
0
                  {
3678
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3679
0
                           "/** 0111 0001 0bit 1011   clr1  %s0       */",
3680
0
                           op[0], op[1]);
3681
0
                    printf ("  bit = 0x%x\n", bit);
3682
0
                  }
3683
2.72k
                SYNTAX("clr1  %s0");
3684
2.72k
#line 456 "rl78-decode.opc"
3685
2.72k
                op0 = SFR;
3686
2.72k
                ID(mov); DM(None, op0); DB(bit); SC(0);
3687
2.72k
                if (op0 == RL78_SFR_PSW && bit == 7)
3688
142
                  rl78->syntax = "di";
3689
3690
2.72k
              }
3691
2.72k
            break;
3692
212
          case 0x0c:
3693
569
          case 0x1c:
3694
1.00k
          case 0x2c:
3695
1.16k
          case 0x3c:
3696
2.18k
          case 0x4c:
3697
2.24k
          case 0x5c:
3698
3.66k
          case 0x6c:
3699
3.97k
          case 0x7c:
3700
3.97k
              {
3701
                /** 0111 0001 0bit 1100   mov1  cy, %s1       */
3702
3.97k
#line 806 "rl78-decode.opc"
3703
3.97k
                int bit AU = (op[1] >> 4) & 0x07;
3704
3.97k
                if (trace)
3705
0
                  {
3706
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3707
0
                           "/** 0111 0001 0bit 1100   mov1  cy, %s1       */",
3708
0
                           op[0], op[1]);
3709
0
                    printf ("  bit = 0x%x\n", bit);
3710
0
                  }
3711
3.97k
                SYNTAX("mov1  cy, %s1");
3712
3.97k
#line 806 "rl78-decode.opc"
3713
3.97k
                ID(mov); DCY(); SM(None, SFR); SB(bit);
3714
3715
3.97k
              }
3716
3.97k
            break;
3717
120
          case 0x0d:
3718
1.24k
          case 0x1d:
3719
1.76k
          case 0x2d:
3720
2.24k
          case 0x3d:
3721
2.59k
          case 0x4d:
3722
3.07k
          case 0x5d:
3723
5.13k
          case 0x6d:
3724
5.28k
          case 0x7d:
3725
5.28k
              {
3726
                /** 0111 0001 0bit 1101   and1  cy, %s1       */
3727
5.28k
#line 329 "rl78-decode.opc"
3728
5.28k
                int bit AU = (op[1] >> 4) & 0x07;
3729
5.28k
                if (trace)
3730
0
                  {
3731
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3732
0
                           "/** 0111 0001 0bit 1101   and1  cy, %s1       */",
3733
0
                           op[0], op[1]);
3734
0
                    printf ("  bit = 0x%x\n", bit);
3735
0
                  }
3736
5.28k
                SYNTAX("and1  cy, %s1");
3737
5.28k
#line 329 "rl78-decode.opc"
3738
5.28k
                ID(and); DCY(); SM(None, SFR); SB(bit);
3739
3740
5.28k
              }
3741
5.28k
            break;
3742
120
          case 0x0e:
3743
590
          case 0x1e:
3744
1.67k
          case 0x2e:
3745
1.81k
          case 0x3e:
3746
2.74k
          case 0x4e:
3747
3.11k
          case 0x5e:
3748
3.28k
          case 0x6e:
3749
3.49k
          case 0x7e:
3750
3.49k
              {
3751
                /** 0111 0001 0bit 1110   or1 cy, %s1       */
3752
3.49k
#line 984 "rl78-decode.opc"
3753
3.49k
                int bit AU = (op[1] >> 4) & 0x07;
3754
3.49k
                if (trace)
3755
0
                  {
3756
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3757
0
                           "/** 0111 0001 0bit 1110   or1 cy, %s1       */",
3758
0
                           op[0], op[1]);
3759
0
                    printf ("  bit = 0x%x\n", bit);
3760
0
                  }
3761
3.49k
                SYNTAX("or1 cy, %s1");
3762
3.49k
#line 984 "rl78-decode.opc"
3763
3.49k
                ID(or); DCY(); SM(None, SFR); SB(bit);
3764
3765
3.49k
              }
3766
3.49k
            break;
3767
146
          case 0x0f:
3768
250
          case 0x1f:
3769
360
          case 0x2f:
3770
779
          case 0x3f:
3771
1.02k
          case 0x4f:
3772
2.27k
          case 0x5f:
3773
2.50k
          case 0x6f:
3774
3.28k
          case 0x7f:
3775
3.28k
              {
3776
                /** 0111 0001 0bit 1111   xor1  cy, %s1       */
3777
3.28k
#line 1288 "rl78-decode.opc"
3778
3.28k
                int bit AU = (op[1] >> 4) & 0x07;
3779
3.28k
                if (trace)
3780
0
                  {
3781
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3782
0
                           "/** 0111 0001 0bit 1111   xor1  cy, %s1       */",
3783
0
                           op[0], op[1]);
3784
0
                    printf ("  bit = 0x%x\n", bit);
3785
0
                  }
3786
3.28k
                SYNTAX("xor1  cy, %s1");
3787
3.28k
#line 1288 "rl78-decode.opc"
3788
3.28k
                ID(xor); DCY(); SM(None, SFR); SB(bit);
3789
3790
3.28k
              }
3791
3.28k
            break;
3792
1.10k
          case 0x80:
3793
1.10k
              {
3794
                /** 0111 0001 1000 0000   set1  cy        */
3795
1.10k
                if (trace)
3796
0
                  {
3797
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3798
0
                           "/** 0111 0001 1000 0000   set1  cy        */",
3799
0
                           op[0], op[1]);
3800
0
                  }
3801
1.10k
                SYNTAX("set1  cy");
3802
1.10k
#line 1061 "rl78-decode.opc"
3803
1.10k
                ID(mov); DCY(); SC(1);
3804
3805
1.10k
              }
3806
1.10k
            break;
3807
35
          case 0x81:
3808
405
          case 0x91:
3809
519
          case 0xa1:
3810
556
          case 0xb1:
3811
634
          case 0xc1:
3812
676
          case 0xd1:
3813
875
          case 0xe1:
3814
2.94k
          case 0xf1:
3815
2.94k
              {
3816
                /** 0111 0001 1bit 0001   mov1  %e0, cy       */
3817
2.94k
#line 791 "rl78-decode.opc"
3818
2.94k
                int bit AU = (op[1] >> 4) & 0x07;
3819
2.94k
                if (trace)
3820
0
                  {
3821
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3822
0
                           "/** 0111 0001 1bit 0001   mov1  %e0, cy       */",
3823
0
                           op[0], op[1]);
3824
0
                    printf ("  bit = 0x%x\n", bit);
3825
0
                  }
3826
2.94k
                SYNTAX("mov1  %e0, cy");
3827
2.94k
#line 791 "rl78-decode.opc"
3828
2.94k
                ID(mov); DM(HL, 0); DB(bit); SCY();
3829
3830
2.94k
              }
3831
2.94k
            break;
3832
188
          case 0x82:
3833
269
          case 0x92:
3834
321
          case 0xa2:
3835
430
          case 0xb2:
3836
591
          case 0xc2:
3837
1.54k
          case 0xd2:
3838
1.66k
          case 0xe2:
3839
2.30k
          case 0xf2:
3840
2.30k
              {
3841
                /** 0111 0001 1bit 0010   set1  %e0       */
3842
2.30k
#line 1055 "rl78-decode.opc"
3843
2.30k
                int bit AU = (op[1] >> 4) & 0x07;
3844
2.30k
                if (trace)
3845
0
                  {
3846
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3847
0
                           "/** 0111 0001 1bit 0010   set1  %e0       */",
3848
0
                           op[0], op[1]);
3849
0
                    printf ("  bit = 0x%x\n", bit);
3850
0
                  }
3851
2.30k
                SYNTAX("set1  %e0");
3852
2.30k
#line 1055 "rl78-decode.opc"
3853
2.30k
                ID(mov); DM(HL, 0); DB(bit); SC(1);
3854
3855
2.30k
              }
3856
2.30k
            break;
3857
37
          case 0x83:
3858
177
          case 0x93:
3859
292
          case 0xa3:
3860
611
          case 0xb3:
3861
698
          case 0xc3:
3862
907
          case 0xd3:
3863
1.21k
          case 0xe3:
3864
1.35k
          case 0xf3:
3865
1.35k
              {
3866
                /** 0111 0001 1bit 0011   clr1  %e0       */
3867
1.35k
#line 447 "rl78-decode.opc"
3868
1.35k
                int bit AU = (op[1] >> 4) & 0x07;
3869
1.35k
                if (trace)
3870
0
                  {
3871
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3872
0
                           "/** 0111 0001 1bit 0011   clr1  %e0       */",
3873
0
                           op[0], op[1]);
3874
0
                    printf ("  bit = 0x%x\n", bit);
3875
0
                  }
3876
1.35k
                SYNTAX("clr1  %e0");
3877
1.35k
#line 447 "rl78-decode.opc"
3878
1.35k
                ID(mov); DM(HL, 0); DB(bit); SC(0);
3879
3880
1.35k
              }
3881
1.35k
            break;
3882
496
          case 0x84:
3883
849
          case 0x94:
3884
913
          case 0xa4:
3885
5.09k
          case 0xb4:
3886
6.69k
          case 0xc4:
3887
6.73k
          case 0xd4:
3888
7.38k
          case 0xe4:
3889
7.78k
          case 0xf4:
3890
7.78k
              {
3891
                /** 0111 0001 1bit 0100   mov1  cy, %e1       */
3892
7.78k
#line 797 "rl78-decode.opc"
3893
7.78k
                int bit AU = (op[1] >> 4) & 0x07;
3894
7.78k
                if (trace)
3895
0
                  {
3896
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3897
0
                           "/** 0111 0001 1bit 0100   mov1  cy, %e1       */",
3898
0
                           op[0], op[1]);
3899
0
                    printf ("  bit = 0x%x\n", bit);
3900
0
                  }
3901
7.78k
                SYNTAX("mov1  cy, %e1");
3902
7.78k
#line 797 "rl78-decode.opc"
3903
7.78k
                ID(mov); DCY(); SM(HL, 0); SB(bit);
3904
3905
7.78k
              }
3906
7.78k
            break;
3907
305
          case 0x85:
3908
385
          case 0x95:
3909
582
          case 0xa5:
3910
918
          case 0xb5:
3911
953
          case 0xc5:
3912
1.11k
          case 0xd5:
3913
1.55k
          case 0xe5:
3914
2.22k
          case 0xf5:
3915
2.22k
              {
3916
                /** 0111 0001 1bit 0101   and1  cy, %e1     */
3917
2.22k
#line 323 "rl78-decode.opc"
3918
2.22k
                int bit AU = (op[1] >> 4) & 0x07;
3919
2.22k
                if (trace)
3920
0
                  {
3921
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3922
0
                           "/** 0111 0001 1bit 0101   and1  cy, %e1     */",
3923
0
                           op[0], op[1]);
3924
0
                    printf ("  bit = 0x%x\n", bit);
3925
0
                  }
3926
2.22k
                SYNTAX("and1  cy, %e1");
3927
2.22k
#line 323 "rl78-decode.opc"
3928
2.22k
                ID(and); DCY(); SM(HL, 0); SB(bit);
3929
3930
2.22k
              }
3931
2.22k
            break;
3932
169
          case 0x86:
3933
644
          case 0x96:
3934
1.14k
          case 0xa6:
3935
1.42k
          case 0xb6:
3936
1.77k
          case 0xc6:
3937
1.84k
          case 0xd6:
3938
2.00k
          case 0xe6:
3939
2.92k
          case 0xf6:
3940
2.92k
              {
3941
                /** 0111 0001 1bit 0110   or1 cy, %e1       */
3942
2.92k
#line 978 "rl78-decode.opc"
3943
2.92k
                int bit AU = (op[1] >> 4) & 0x07;
3944
2.92k
                if (trace)
3945
0
                  {
3946
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3947
0
                           "/** 0111 0001 1bit 0110   or1 cy, %e1       */",
3948
0
                           op[0], op[1]);
3949
0
                    printf ("  bit = 0x%x\n", bit);
3950
0
                  }
3951
2.92k
                SYNTAX("or1 cy, %e1");
3952
2.92k
#line 978 "rl78-decode.opc"
3953
2.92k
                ID(or); DCY(); SM(HL, 0); SB(bit);
3954
3955
2.92k
              }
3956
2.92k
            break;
3957
146
          case 0x87:
3958
361
          case 0x97:
3959
1.23k
          case 0xa7:
3960
1.39k
          case 0xb7:
3961
1.53k
          case 0xc7:
3962
1.76k
          case 0xd7:
3963
2.10k
          case 0xe7:
3964
2.32k
          case 0xf7:
3965
2.32k
              {
3966
                /** 0111 0001 1bit 0111   xor1  cy, %e1       */
3967
2.32k
#line 1282 "rl78-decode.opc"
3968
2.32k
                int bit AU = (op[1] >> 4) & 0x07;
3969
2.32k
                if (trace)
3970
0
                  {
3971
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3972
0
                           "/** 0111 0001 1bit 0111   xor1  cy, %e1       */",
3973
0
                           op[0], op[1]);
3974
0
                    printf ("  bit = 0x%x\n", bit);
3975
0
                  }
3976
2.32k
                SYNTAX("xor1  cy, %e1");
3977
2.32k
#line 1282 "rl78-decode.opc"
3978
2.32k
                ID(xor); DCY(); SM(HL, 0); SB(bit);
3979
3980
2.32k
              }
3981
2.32k
            break;
3982
261
          case 0x88:
3983
261
              {
3984
                /** 0111 0001 1000 1000   clr1  cy        */
3985
261
                if (trace)
3986
0
                  {
3987
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
3988
0
                           "/** 0111 0001 1000 1000   clr1  cy        */",
3989
0
                           op[0], op[1]);
3990
0
                  }
3991
261
                SYNTAX("clr1  cy");
3992
261
#line 453 "rl78-decode.opc"
3993
261
                ID(mov); DCY(); SC(0);
3994
3995
261
              }
3996
261
            break;
3997
394
          case 0x89:
3998
922
          case 0x99:
3999
1.34k
          case 0xa9:
4000
2.27k
          case 0xb9:
4001
2.39k
          case 0xc9:
4002
2.47k
          case 0xd9:
4003
2.57k
          case 0xe9:
4004
3.11k
          case 0xf9:
4005
3.11k
              {
4006
                /** 0111 0001 1bit 1001   mov1  %e0, cy       */
4007
3.11k
#line 794 "rl78-decode.opc"
4008
3.11k
                int bit AU = (op[1] >> 4) & 0x07;
4009
3.11k
                if (trace)
4010
0
                  {
4011
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
4012
0
                           "/** 0111 0001 1bit 1001   mov1  %e0, cy       */",
4013
0
                           op[0], op[1]);
4014
0
                    printf ("  bit = 0x%x\n", bit);
4015
0
                  }
4016
3.11k
                SYNTAX("mov1  %e0, cy");
4017
3.11k
#line 794 "rl78-decode.opc"
4018
3.11k
                ID(mov); DR(A); DB(bit); SCY();
4019
4020
3.11k
              }
4021
3.11k
            break;
4022
199
          case 0x8a:
4023
418
          case 0x9a:
4024
514
          case 0xaa:
4025
616
          case 0xba:
4026
737
          case 0xca:
4027
981
          case 0xda:
4028
1.14k
          case 0xea:
4029
1.29k
          case 0xfa:
4030
1.29k
              {
4031
                /** 0111 0001 1bit 1010   set1  %0        */
4032
1.29k
#line 1058 "rl78-decode.opc"
4033
1.29k
                int bit AU = (op[1] >> 4) & 0x07;
4034
1.29k
                if (trace)
4035
0
                  {
4036
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
4037
0
                           "/** 0111 0001 1bit 1010   set1  %0        */",
4038
0
                           op[0], op[1]);
4039
0
                    printf ("  bit = 0x%x\n", bit);
4040
0
                  }
4041
1.29k
                SYNTAX("set1  %0");
4042
1.29k
#line 1058 "rl78-decode.opc"
4043
1.29k
                ID(mov); DR(A); DB(bit); SC(1);
4044
4045
1.29k
              }
4046
1.29k
            break;
4047
283
          case 0x8b:
4048
377
          case 0x9b:
4049
930
          case 0xab:
4050
1.08k
          case 0xbb:
4051
1.15k
          case 0xcb:
4052
1.24k
          case 0xdb:
4053
1.34k
          case 0xeb:
4054
2.44k
          case 0xfb:
4055
2.44k
              {
4056
                /** 0111 0001 1bit 1011   clr1  %0        */
4057
2.44k
#line 450 "rl78-decode.opc"
4058
2.44k
                int bit AU = (op[1] >> 4) & 0x07;
4059
2.44k
                if (trace)
4060
0
                  {
4061
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
4062
0
                           "/** 0111 0001 1bit 1011   clr1  %0        */",
4063
0
                           op[0], op[1]);
4064
0
                    printf ("  bit = 0x%x\n", bit);
4065
0
                  }
4066
2.44k
                SYNTAX("clr1  %0");
4067
2.44k
#line 450 "rl78-decode.opc"
4068
2.44k
                ID(mov); DR(A); DB(bit); SC(0);
4069
4070
2.44k
              }
4071
2.44k
            break;
4072
524
          case 0x8c:
4073
608
          case 0x9c:
4074
686
          case 0xac:
4075
734
          case 0xbc:
4076
771
          case 0xcc:
4077
1.03k
          case 0xdc:
4078
1.09k
          case 0xec:
4079
1.30k
          case 0xfc:
4080
1.30k
              {
4081
                /** 0111 0001 1bit 1100   mov1  cy, %e1       */
4082
1.30k
#line 800 "rl78-decode.opc"
4083
1.30k
                int bit AU = (op[1] >> 4) & 0x07;
4084
1.30k
                if (trace)
4085
0
                  {
4086
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
4087
0
                           "/** 0111 0001 1bit 1100   mov1  cy, %e1       */",
4088
0
                           op[0], op[1]);
4089
0
                    printf ("  bit = 0x%x\n", bit);
4090
0
                  }
4091
1.30k
                SYNTAX("mov1  cy, %e1");
4092
1.30k
#line 800 "rl78-decode.opc"
4093
1.30k
                ID(mov); DCY(); SR(A); SB(bit);
4094
4095
1.30k
              }
4096
1.30k
            break;
4097
494
          case 0x8d:
4098
666
          case 0x9d:
4099
882
          case 0xad:
4100
1.06k
          case 0xbd:
4101
1.38k
          case 0xcd:
4102
1.67k
          case 0xdd:
4103
1.78k
          case 0xed:
4104
2.15k
          case 0xfd:
4105
2.15k
              {
4106
                /** 0111 0001 1bit 1101   and1  cy, %1        */
4107
2.15k
#line 326 "rl78-decode.opc"
4108
2.15k
                int bit AU = (op[1] >> 4) & 0x07;
4109
2.15k
                if (trace)
4110
0
                  {
4111
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
4112
0
                           "/** 0111 0001 1bit 1101   and1  cy, %1        */",
4113
0
                           op[0], op[1]);
4114
0
                    printf ("  bit = 0x%x\n", bit);
4115
0
                  }
4116
2.15k
                SYNTAX("and1  cy, %1");
4117
2.15k
#line 326 "rl78-decode.opc"
4118
2.15k
                ID(and); DCY(); SR(A); SB(bit);
4119
4120
2.15k
              }
4121
2.15k
            break;
4122
937
          case 0x8e:
4123
1.09k
          case 0x9e:
4124
1.16k
          case 0xae:
4125
1.37k
          case 0xbe:
4126
1.48k
          case 0xce:
4127
2.13k
          case 0xde:
4128
2.25k
          case 0xee:
4129
2.84k
          case 0xfe:
4130
2.84k
              {
4131
                /** 0111 0001 1bit 1110   or1 cy, %1        */
4132
2.84k
#line 981 "rl78-decode.opc"
4133
2.84k
                int bit AU = (op[1] >> 4) & 0x07;
4134
2.84k
                if (trace)
4135
0
                  {
4136
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
4137
0
                           "/** 0111 0001 1bit 1110   or1 cy, %1        */",
4138
0
                           op[0], op[1]);
4139
0
                    printf ("  bit = 0x%x\n", bit);
4140
0
                  }
4141
2.84k
                SYNTAX("or1 cy, %1");
4142
2.84k
#line 981 "rl78-decode.opc"
4143
2.84k
                ID(or); DCY(); SR(A); SB(bit);
4144
4145
2.84k
              }
4146
2.84k
            break;
4147
266
          case 0x8f:
4148
379
          case 0x9f:
4149
604
          case 0xaf:
4150
727
          case 0xbf:
4151
1.02k
          case 0xcf:
4152
1.14k
          case 0xdf:
4153
1.42k
          case 0xef:
4154
2.52k
          case 0xff:
4155
2.52k
              {
4156
                /** 0111 0001 1bit 1111   xor1  cy, %1        */
4157
2.52k
#line 1285 "rl78-decode.opc"
4158
2.52k
                int bit AU = (op[1] >> 4) & 0x07;
4159
2.52k
                if (trace)
4160
0
                  {
4161
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
4162
0
                           "/** 0111 0001 1bit 1111   xor1  cy, %1        */",
4163
0
                           op[0], op[1]);
4164
0
                    printf ("  bit = 0x%x\n", bit);
4165
0
                  }
4166
2.52k
                SYNTAX("xor1  cy, %1");
4167
2.52k
#line 1285 "rl78-decode.opc"
4168
2.52k
                ID(xor); DCY(); SR(A); SB(bit);
4169
4170
2.52k
              }
4171
2.52k
            break;
4172
652
          case 0xc0:
4173
652
              {
4174
                /** 0111 0001 1100 0000   not1  cy        */
4175
652
                if (trace)
4176
0
                  {
4177
0
                    printf ("\033[33m%s\033[0m  %02x %02x\n",
4178
0
                           "/** 0111 0001 1100 0000   not1  cy        */",
4179
0
                           op[0], op[1]);
4180
0
                  }
4181
652
                SYNTAX("not1  cy");
4182
652
#line 922 "rl78-decode.opc"
4183
652
                ID(xor); DCY(); SC(1);
4184
4185
              /*----------------------------------------------------------------------*/
4186
4187
652
              }
4188
652
            break;
4189
2.16k
          default: UNSUPPORTED(); break;
4190
154k
        }
4191
153k
      break;
4192
153k
    case 0x78:
4193
5.91k
        {
4194
          /** 0111 1000     movw  %e0, %1       */
4195
5.91k
          if (trace)
4196
0
            {
4197
0
              printf ("\033[33m%s\033[0m  %02x\n",
4198
0
                     "/** 0111 1000     movw  %e0, %1       */",
4199
0
                     op[0]);
4200
0
            }
4201
5.91k
          SYNTAX("movw  %e0, %1");
4202
5.91k
#line 883 "rl78-decode.opc"
4203
5.91k
          ID(mov); W(); DM(BC, IMMU(2)); SR(AX);
4204
4205
5.91k
        }
4206
5.91k
      break;
4207
6.16k
    case 0x79:
4208
6.16k
        {
4209
          /** 0111 1001     movw  %0, %e1       */
4210
6.16k
          if (trace)
4211
0
            {
4212
0
              printf ("\033[33m%s\033[0m  %02x\n",
4213
0
                     "/** 0111 1001     movw  %0, %e1       */",
4214
0
                     op[0]);
4215
0
            }
4216
6.16k
          SYNTAX("movw  %0, %e1");
4217
6.16k
#line 874 "rl78-decode.opc"
4218
6.16k
          ID(mov); W(); DR(AX); SM(BC, IMMU(2));
4219
4220
6.16k
        }
4221
6.16k
      break;
4222
6.46k
    case 0x7a:
4223
6.46k
        {
4224
          /** 0111 1010           xor %0, #%1       */
4225
6.46k
          if (trace)
4226
0
            {
4227
0
              printf ("\033[33m%s\033[0m  %02x\n",
4228
0
                     "/** 0111 1010           xor %0, #%1       */",
4229
0
                     op[0]);
4230
0
            }
4231
6.46k
          SYNTAX("xor %0, #%1");
4232
6.46k
#line 1277 "rl78-decode.opc"
4233
6.46k
          ID(xor); DM(None, SADDR); SC(IMMU(1)); Fz;
4234
4235
        /*----------------------------------------------------------------------*/
4236
4237
6.46k
        }
4238
6.46k
      break;
4239
5.04k
    case 0x7b:
4240
5.04k
        {
4241
          /** 0111 1011           xor %0, %1        */
4242
5.04k
          if (trace)
4243
0
            {
4244
0
              printf ("\033[33m%s\033[0m  %02x\n",
4245
0
                     "/** 0111 1011           xor %0, %1        */",
4246
0
                     op[0]);
4247
0
            }
4248
5.04k
          SYNTAX("xor %0, %1");
4249
5.04k
#line 1274 "rl78-decode.opc"
4250
5.04k
          ID(xor); DR(A); SM(None, SADDR); Fz;
4251
4252
5.04k
        }
4253
5.04k
      break;
4254
12.2k
    case 0x7c:
4255
12.2k
        {
4256
          /** 0111 1100           xor %0, #%1       */
4257
12.2k
          if (trace)
4258
0
            {
4259
0
              printf ("\033[33m%s\033[0m  %02x\n",
4260
0
                     "/** 0111 1100           xor %0, #%1       */",
4261
0
                     op[0]);
4262
0
            }
4263
12.2k
          SYNTAX("xor %0, #%1");
4264
12.2k
#line 1265 "rl78-decode.opc"
4265
12.2k
          ID(xor); DR(A); SC(IMMU(1)); Fz;
4266
4267
12.2k
        }
4268
12.2k
      break;
4269
3.41k
    case 0x7d:
4270
3.41k
        {
4271
          /** 0111 1101     xor %0, %e1       */
4272
3.41k
          if (trace)
4273
0
            {
4274
0
              printf ("\033[33m%s\033[0m  %02x\n",
4275
0
                     "/** 0111 1101     xor %0, %e1       */",
4276
0
                     op[0]);
4277
0
            }
4278
3.41k
          SYNTAX("xor %0, %e1");
4279
3.41k
#line 1253 "rl78-decode.opc"
4280
3.41k
          ID(xor); DR(A); SM(HL, 0); Fz;
4281
4282
3.41k
        }
4283
3.41k
      break;
4284
4.95k
    case 0x7e:
4285
4.95k
        {
4286
          /** 0111 1110     xor %0, %ea1      */
4287
4.95k
          if (trace)
4288
0
            {
4289
0
              printf ("\033[33m%s\033[0m  %02x\n",
4290
0
                     "/** 0111 1110     xor %0, %ea1      */",
4291
0
                     op[0]);
4292
0
            }
4293
4.95k
          SYNTAX("xor %0, %ea1");
4294
4.95k
#line 1259 "rl78-decode.opc"
4295
4.95k
          ID(xor); DR(A); SM(HL, IMMU(1)); Fz;
4296
4297
4.95k
        }
4298
4.95k
      break;
4299
12.8k
    case 0x7f:
4300
12.8k
        {
4301
          /** 0111 1111     xor %0, %e!1      */
4302
12.8k
          if (trace)
4303
0
            {
4304
0
              printf ("\033[33m%s\033[0m  %02x\n",
4305
0
                     "/** 0111 1111     xor %0, %e!1      */",
4306
0
                     op[0]);
4307
0
            }
4308
12.8k
          SYNTAX("xor %0, %e!1");
4309
12.8k
#line 1250 "rl78-decode.opc"
4310
12.8k
          ID(xor); DR(A); SM(None, IMMU(2)); Fz;
4311
4312
12.8k
        }
4313
12.8k
      break;
4314
15.7k
    case 0x80:
4315
25.1k
    case 0x81:
4316
29.4k
    case 0x82:
4317
35.2k
    case 0x83:
4318
42.1k
    case 0x84:
4319
55.1k
    case 0x85:
4320
61.4k
    case 0x86:
4321
79.3k
    case 0x87:
4322
79.3k
        {
4323
          /** 1000 0reg     inc %0        */
4324
79.3k
#line 593 "rl78-decode.opc"
4325
79.3k
          int reg AU = op[0] & 0x07;
4326
79.3k
          if (trace)
4327
0
            {
4328
0
              printf ("\033[33m%s\033[0m  %02x\n",
4329
0
                     "/** 1000 0reg     inc %0        */",
4330
0
                     op[0]);
4331
0
              printf ("  reg = 0x%x\n", reg);
4332
0
            }
4333
79.3k
          SYNTAX("inc %0");
4334
79.3k
#line 593 "rl78-decode.opc"
4335
79.3k
          ID(add); DRB(reg); SC(1); Fza;
4336
4337
79.3k
        }
4338
79.3k
      break;
4339
4.82k
    case 0x88:
4340
4.82k
        {
4341
          /** 1000 1000     mov %0, %ea1      */
4342
4.82k
          if (trace)
4343
0
            {
4344
0
              printf ("\033[33m%s\033[0m  %02x\n",
4345
0
                     "/** 1000 1000     mov %0, %ea1      */",
4346
0
                     op[0]);
4347
0
            }
4348
4.82k
          SYNTAX("mov %0, %ea1");
4349
4.82k
#line 672 "rl78-decode.opc"
4350
4.82k
          ID(mov); DR(A); SM(SP, IMMU(1));
4351
4352
4.82k
        }
4353
4.82k
      break;
4354
8.83k
    case 0x89:
4355
8.83k
        {
4356
          /** 1000 1001     mov %0, %e1       */
4357
8.83k
          if (trace)
4358
0
            {
4359
0
              printf ("\033[33m%s\033[0m  %02x\n",
4360
0
                     "/** 1000 1001     mov %0, %e1       */",
4361
0
                     op[0]);
4362
0
            }
4363
8.83k
          SYNTAX("mov %0, %e1");
4364
8.83k
#line 654 "rl78-decode.opc"
4365
8.83k
          ID(mov); DR(A); SM(DE, 0);
4366
4367
8.83k
        }
4368
8.83k
      break;
4369
4.16k
    case 0x8a:
4370
4.16k
        {
4371
          /** 1000 1010     mov %0, %ea1      */
4372
4.16k
          if (trace)
4373
0
            {
4374
0
              printf ("\033[33m%s\033[0m  %02x\n",
4375
0
                     "/** 1000 1010     mov %0, %ea1      */",
4376
0
                     op[0]);
4377
0
            }
4378
4.16k
          SYNTAX("mov %0, %ea1");
4379
4.16k
#line 657 "rl78-decode.opc"
4380
4.16k
          ID(mov); DR(A); SM(DE, IMMU(1));
4381
4382
4.16k
        }
4383
4.16k
      break;
4384
7.43k
    case 0x8b:
4385
7.43k
        {
4386
          /** 1000 1011     mov %0, %e1       */
4387
7.43k
          if (trace)
4388
0
            {
4389
0
              printf ("\033[33m%s\033[0m  %02x\n",
4390
0
                     "/** 1000 1011     mov %0, %e1       */",
4391
0
                     op[0]);
4392
0
            }
4393
7.43k
          SYNTAX("mov %0, %e1");
4394
7.43k
#line 660 "rl78-decode.opc"
4395
7.43k
          ID(mov); DR(A); SM(HL, 0);
4396
4397
7.43k
        }
4398
7.43k
      break;
4399
4.39k
    case 0x8c:
4400
4.39k
        {
4401
          /** 1000 1100     mov %0, %ea1      */
4402
4.39k
          if (trace)
4403
0
            {
4404
0
              printf ("\033[33m%s\033[0m  %02x\n",
4405
0
                     "/** 1000 1100     mov %0, %ea1      */",
4406
0
                     op[0]);
4407
0
            }
4408
4.39k
          SYNTAX("mov %0, %ea1");
4409
4.39k
#line 663 "rl78-decode.opc"
4410
4.39k
          ID(mov); DR(A); SM(HL, IMMU(1));
4411
4412
4.39k
        }
4413
4.39k
      break;
4414
10.4k
    case 0x8d:
4415
10.4k
        {
4416
          /** 1000 1101     mov %0, %1        */
4417
10.4k
          if (trace)
4418
0
            {
4419
0
              printf ("\033[33m%s\033[0m  %02x\n",
4420
0
                     "/** 1000 1101     mov %0, %1        */",
4421
0
                     op[0]);
4422
0
            }
4423
10.4k
          SYNTAX("mov %0, %1");
4424
10.4k
#line 696 "rl78-decode.opc"
4425
10.4k
          ID(mov); DR(A); SM(None, SADDR);
4426
4427
10.4k
        }
4428
10.4k
      break;
4429
16.2k
    case 0x8e:
4430
16.2k
        {
4431
          /** 1000 1110     mov %0, %s1       */
4432
16.2k
          if (trace)
4433
0
            {
4434
0
              printf ("\033[33m%s\033[0m  %02x\n",
4435
0
                     "/** 1000 1110     mov %0, %s1       */",
4436
0
                     op[0]);
4437
0
            }
4438
16.2k
          SYNTAX("mov %0, %s1");
4439
16.2k
#line 693 "rl78-decode.opc"
4440
16.2k
          ID(mov); DR(A); SM(None, SFR);
4441
4442
16.2k
        }
4443
16.2k
      break;
4444
5.61k
    case 0x8f:
4445
5.61k
        {
4446
          /** 1000 1111     mov %0, %e!1      */
4447
5.61k
          if (trace)
4448
0
            {
4449
0
              printf ("\033[33m%s\033[0m  %02x\n",
4450
0
                     "/** 1000 1111     mov %0, %e!1      */",
4451
0
                     op[0]);
4452
0
            }
4453
5.61k
          SYNTAX("mov %0, %e!1");
4454
5.61k
#line 651 "rl78-decode.opc"
4455
5.61k
          ID(mov); DR(A); SM(None, IMMU(2));
4456
4457
5.61k
        }
4458
5.61k
      break;
4459
7.89k
    case 0x90:
4460
11.6k
    case 0x91:
4461
16.5k
    case 0x92:
4462
20.5k
    case 0x93:
4463
25.8k
    case 0x94:
4464
30.5k
    case 0x95:
4465
36.1k
    case 0x96:
4466
45.8k
    case 0x97:
4467
45.8k
        {
4468
          /** 1001 0reg     dec %0        */
4469
45.8k
#line 560 "rl78-decode.opc"
4470
45.8k
          int reg AU = op[0] & 0x07;
4471
45.8k
          if (trace)
4472
0
            {
4473
0
              printf ("\033[33m%s\033[0m  %02x\n",
4474
0
                     "/** 1001 0reg     dec %0        */",
4475
0
                     op[0]);
4476
0
              printf ("  reg = 0x%x\n", reg);
4477
0
            }
4478
45.8k
          SYNTAX("dec %0");
4479
45.8k
#line 560 "rl78-decode.opc"
4480
45.8k
          ID(sub); DRB(reg); SC(1); Fza;
4481
4482
45.8k
        }
4483
45.8k
      break;
4484
10.5k
    case 0x98:
4485
10.5k
        {
4486
          /** 1001 1000     mov %a0, %1       */
4487
10.5k
          if (trace)
4488
0
            {
4489
0
              printf ("\033[33m%s\033[0m  %02x\n",
4490
0
                     "/** 1001 1000     mov %a0, %1       */",
4491
0
                     op[0]);
4492
0
            }
4493
10.5k
          SYNTAX("mov %a0, %1");
4494
10.5k
#line 648 "rl78-decode.opc"
4495
10.5k
          ID(mov); DM(SP, IMMU(1)); SR(A);
4496
4497
10.5k
        }
4498
10.5k
      break;
4499
6.87k
    case 0x99:
4500
6.87k
        {
4501
          /** 1001 1001     mov %e0, %1       */
4502
6.87k
          if (trace)
4503
0
            {
4504
0
              printf ("\033[33m%s\033[0m  %02x\n",
4505
0
                     "/** 1001 1001     mov %e0, %1       */",
4506
0
                     op[0]);
4507
0
            }
4508
6.87k
          SYNTAX("mov %e0, %1");
4509
6.87k
#line 621 "rl78-decode.opc"
4510
6.87k
          ID(mov); DM(DE, 0); SR(A);
4511
4512
6.87k
        }
4513
6.87k
      break;
4514
9.02k
    case 0x9a:
4515
9.02k
        {
4516
          /** 1001 1010     mov %ea0, %1        */
4517
9.02k
          if (trace)
4518
0
            {
4519
0
              printf ("\033[33m%s\033[0m  %02x\n",
4520
0
                     "/** 1001 1010     mov %ea0, %1        */",
4521
0
                     op[0]);
4522
0
            }
4523
9.02k
          SYNTAX("mov %ea0, %1");
4524
9.02k
#line 627 "rl78-decode.opc"
4525
9.02k
          ID(mov); DM(DE, IMMU(1)); SR(A);
4526
4527
9.02k
        }
4528
9.02k
      break;
4529
4.89k
    case 0x9b:
4530
4.89k
        {
4531
          /** 1001 1011     mov %e0, %1       */
4532
4.89k
          if (trace)
4533
0
            {
4534
0
              printf ("\033[33m%s\033[0m  %02x\n",
4535
0
                     "/** 1001 1011     mov %e0, %1       */",
4536
0
                     op[0]);
4537
0
            }
4538
4.89k
          SYNTAX("mov %e0, %1");
4539
4.89k
#line 630 "rl78-decode.opc"
4540
4.89k
          ID(mov); DM(HL, 0); SR(A);
4541
4542
4.89k
        }
4543
4.89k
      break;
4544
6.70k
    case 0x9c:
4545
6.70k
        {
4546
          /** 1001 1100     mov %ea0, %1      */
4547
6.70k
          if (trace)
4548
0
            {
4549
0
              printf ("\033[33m%s\033[0m  %02x\n",
4550
0
                     "/** 1001 1100     mov %ea0, %1      */",
4551
0
                     op[0]);
4552
0
            }
4553
6.70k
          SYNTAX("mov %ea0, %1");
4554
6.70k
#line 639 "rl78-decode.opc"
4555
6.70k
          ID(mov); DM(HL, IMMU(1)); SR(A);
4556
4557
6.70k
        }
4558
6.70k
      break;
4559
4.67k
    case 0x9d:
4560
4.67k
        {
4561
          /** 1001 1101     mov %0, %1        */
4562
4.67k
          if (trace)
4563
0
            {
4564
0
              printf ("\033[33m%s\033[0m  %02x\n",
4565
0
                     "/** 1001 1101     mov %0, %1        */",
4566
0
                     op[0]);
4567
0
            }
4568
4.67k
          SYNTAX("mov %0, %1");
4569
4.67k
#line 753 "rl78-decode.opc"
4570
4.67k
          ID(mov); DM(None, SADDR); SR(A);
4571
4572
4.67k
        }
4573
4.67k
      break;
4574
10.5k
    case 0x9e:
4575
10.5k
        {
4576
          /** 1001 1110     mov %s0, %1       */
4577
10.5k
          if (trace)
4578
0
            {
4579
0
              printf ("\033[33m%s\033[0m  %02x\n",
4580
0
                     "/** 1001 1110     mov %s0, %1       */",
4581
0
                     op[0]);
4582
0
            }
4583
10.5k
          SYNTAX("mov %s0, %1");
4584
10.5k
#line 786 "rl78-decode.opc"
4585
10.5k
          ID(mov); DM(None, SFR); SR(A);
4586
4587
        /*----------------------------------------------------------------------*/
4588
4589
10.5k
        }
4590
10.5k
      break;
4591
5.46k
    case 0x9f:
4592
5.46k
        {
4593
          /** 1001 1111     mov %e!0, %1      */
4594
5.46k
          if (trace)
4595
0
            {
4596
0
              printf ("\033[33m%s\033[0m  %02x\n",
4597
0
                     "/** 1001 1111     mov %e!0, %1      */",
4598
0
                     op[0]);
4599
0
            }
4600
5.46k
          SYNTAX("mov %e!0, %1");
4601
5.46k
#line 618 "rl78-decode.opc"
4602
5.46k
          ID(mov); DM(None, IMMU(2)); SR(A);
4603
4604
5.46k
        }
4605
5.46k
      break;
4606
9.49k
    case 0xa0:
4607
9.49k
        {
4608
          /** 1010 0000     inc %e!0        */
4609
9.49k
          if (trace)
4610
0
            {
4611
0
              printf ("\033[33m%s\033[0m  %02x\n",
4612
0
                     "/** 1010 0000     inc %e!0        */",
4613
0
                     op[0]);
4614
0
            }
4615
9.49k
          SYNTAX("inc %e!0");
4616
9.49k
#line 587 "rl78-decode.opc"
4617
9.49k
          ID(add); DM(None, IMMU(2)); SC(1); Fza;
4618
4619
9.49k
        }
4620
9.49k
      break;
4621
6.66k
    case 0xa1:
4622
23.7k
    case 0xa3:
4623
28.1k
    case 0xa5:
4624
31.6k
    case 0xa7:
4625
31.6k
        {
4626
          /** 1010 0rg1     incw  %0        */
4627
31.6k
#line 607 "rl78-decode.opc"
4628
31.6k
          int rg AU = (op[0] >> 1) & 0x03;
4629
31.6k
          if (trace)
4630
0
            {
4631
0
              printf ("\033[33m%s\033[0m  %02x\n",
4632
0
                     "/** 1010 0rg1     incw  %0        */",
4633
0
                     op[0]);
4634
0
              printf ("  rg = 0x%x\n", rg);
4635
0
            }
4636
31.6k
          SYNTAX("incw  %0");
4637
31.6k
#line 607 "rl78-decode.opc"
4638
31.6k
          ID(add); W(); DRW(rg); SC(1);
4639
4640
31.6k
        }
4641
31.6k
      break;
4642
8.96k
    case 0xa2:
4643
8.96k
        {
4644
          /** 1010 0010     incw  %e!0        */
4645
8.96k
          if (trace)
4646
0
            {
4647
0
              printf ("\033[33m%s\033[0m  %02x\n",
4648
0
                     "/** 1010 0010     incw  %e!0        */",
4649
0
                     op[0]);
4650
0
            }
4651
8.96k
          SYNTAX("incw  %e!0");
4652
8.96k
#line 601 "rl78-decode.opc"
4653
8.96k
          ID(add); W(); DM(None, IMMU(2)); SC(1);
4654
4655
8.96k
        }
4656
8.96k
      break;
4657
5.39k
    case 0xa4:
4658
5.39k
        {
4659
          /** 1010 0100     inc %0        */
4660
5.39k
          if (trace)
4661
0
            {
4662
0
              printf ("\033[33m%s\033[0m  %02x\n",
4663
0
                     "/** 1010 0100     inc %0        */",
4664
0
                     op[0]);
4665
0
            }
4666
5.39k
          SYNTAX("inc %0");
4667
5.39k
#line 596 "rl78-decode.opc"
4668
5.39k
          ID(add); DM(None, SADDR); SC(1); Fza;
4669
4670
        /*----------------------------------------------------------------------*/
4671
4672
5.39k
        }
4673
5.39k
      break;
4674
6.47k
    case 0xa6:
4675
6.47k
        {
4676
          /** 1010 0110     incw  %0        */
4677
6.47k
          if (trace)
4678
0
            {
4679
0
              printf ("\033[33m%s\033[0m  %02x\n",
4680
0
                     "/** 1010 0110     incw  %0        */",
4681
0
                     op[0]);
4682
0
            }
4683
6.47k
          SYNTAX("incw  %0");
4684
6.47k
#line 610 "rl78-decode.opc"
4685
6.47k
          ID(add); W(); DM(None, SADDR); SC(1);
4686
4687
        /*----------------------------------------------------------------------*/
4688
4689
6.47k
        }
4690
6.47k
      break;
4691
4.53k
    case 0xa8:
4692
4.53k
        {
4693
          /** 1010 1000     movw  %0, %a1       */
4694
4.53k
          if (trace)
4695
0
            {
4696
0
              printf ("\033[33m%s\033[0m  %02x\n",
4697
0
                     "/** 1010 1000     movw  %0, %a1       */",
4698
0
                     op[0]);
4699
0
            }
4700
4.53k
          SYNTAX("movw  %0, %a1");
4701
4.53k
#line 856 "rl78-decode.opc"
4702
4.53k
          ID(mov); W(); DR(AX); SM(SP, IMMU(1));
4703
4704
4.53k
        }
4705
4.53k
      break;
4706
17.7k
    case 0xa9:
4707
17.7k
        {
4708
          /** 1010 1001     movw  %0, %e1       */
4709
17.7k
          if (trace)
4710
0
            {
4711
0
              printf ("\033[33m%s\033[0m  %02x\n",
4712
0
                     "/** 1010 1001     movw  %0, %e1       */",
4713
0
                     op[0]);
4714
0
            }
4715
17.7k
          SYNTAX("movw  %0, %e1");
4716
17.7k
#line 844 "rl78-decode.opc"
4717
17.7k
          ID(mov); W(); DR(AX); SM(DE, 0);
4718
4719
17.7k
        }
4720
17.7k
      break;
4721
1.90k
    case 0xaa:
4722
1.90k
        {
4723
          /** 1010 1010     movw  %0, %ea1        */
4724
1.90k
          if (trace)
4725
0
            {
4726
0
              printf ("\033[33m%s\033[0m  %02x\n",
4727
0
                     "/** 1010 1010     movw  %0, %ea1        */",
4728
0
                     op[0]);
4729
0
            }
4730
1.90k
          SYNTAX("movw  %0, %ea1");
4731
1.90k
#line 847 "rl78-decode.opc"
4732
1.90k
          ID(mov); W(); DR(AX); SM(DE, IMMU(1));
4733
4734
1.90k
        }
4735
1.90k
      break;
4736
5.71k
    case 0xab:
4737
5.71k
        {
4738
          /** 1010 1011     movw  %0, %e1       */
4739
5.71k
          if (trace)
4740
0
            {
4741
0
              printf ("\033[33m%s\033[0m  %02x\n",
4742
0
                     "/** 1010 1011     movw  %0, %e1       */",
4743
0
                     op[0]);
4744
0
            }
4745
5.71k
          SYNTAX("movw  %0, %e1");
4746
5.71k
#line 850 "rl78-decode.opc"
4747
5.71k
          ID(mov); W(); DR(AX); SM(HL, 0);
4748
4749
5.71k
        }
4750
5.71k
      break;
4751
3.52k
    case 0xac:
4752
3.52k
        {
4753
          /** 1010 1100     movw  %0, %ea1      */
4754
3.52k
          if (trace)
4755
0
            {
4756
0
              printf ("\033[33m%s\033[0m  %02x\n",
4757
0
                     "/** 1010 1100     movw  %0, %ea1      */",
4758
0
                     op[0]);
4759
0
            }
4760
3.52k
          SYNTAX("movw  %0, %ea1");
4761
3.52k
#line 853 "rl78-decode.opc"
4762
3.52k
          ID(mov); W(); DR(AX); SM(HL, IMMU(1));
4763
4764
3.52k
        }
4765
3.52k
      break;
4766
4.69k
    case 0xad:
4767
4.69k
        {
4768
          /** 1010 1101     movw  %0, %1        */
4769
4.69k
          if (trace)
4770
0
            {
4771
0
              printf ("\033[33m%s\033[0m  %02x\n",
4772
0
                     "/** 1010 1101     movw  %0, %1        */",
4773
0
                     op[0]);
4774
0
            }
4775
4.69k
          SYNTAX("movw  %0, %1");
4776
4.69k
#line 886 "rl78-decode.opc"
4777
4.69k
          ID(mov); W(); DR(AX); SM(None, SADDR);
4778
4779
4.69k
        }
4780
4.69k
      break;
4781
4.26k
    case 0xae:
4782
4.26k
        {
4783
          /** 1010 1110     movw  %0, %s1       */
4784
4.26k
          if (trace)
4785
0
            {
4786
0
              printf ("\033[33m%s\033[0m  %02x\n",
4787
0
                     "/** 1010 1110     movw  %0, %s1       */",
4788
0
                     op[0]);
4789
0
            }
4790
4.26k
          SYNTAX("movw  %0, %s1");
4791
4.26k
#line 889 "rl78-decode.opc"
4792
4.26k
          ID(mov); W(); DR(AX); SM(None, SFR);
4793
4794
4.26k
        }
4795
4.26k
      break;
4796
8.21k
    case 0xaf:
4797
8.21k
        {
4798
          /** 1010 1111     movw  %0, %e!1      */
4799
8.21k
          if (trace)
4800
0
            {
4801
0
              printf ("\033[33m%s\033[0m  %02x\n",
4802
0
                     "/** 1010 1111     movw  %0, %e!1      */",
4803
0
                     op[0]);
4804
0
            }
4805
8.21k
          SYNTAX("movw  %0, %e!1");
4806
8.21k
#line 840 "rl78-decode.opc"
4807
8.21k
          ID(mov); W(); DR(AX); SM(None, IMMU(2));
4808
4809
4810
8.21k
        }
4811
8.21k
      break;
4812
3.02k
    case 0xb0:
4813
3.02k
        {
4814
          /** 1011 0000     dec %e!0        */
4815
3.02k
          if (trace)
4816
0
            {
4817
0
              printf ("\033[33m%s\033[0m  %02x\n",
4818
0
                     "/** 1011 0000     dec %e!0        */",
4819
0
                     op[0]);
4820
0
            }
4821
3.02k
          SYNTAX("dec %e!0");
4822
3.02k
#line 554 "rl78-decode.opc"
4823
3.02k
          ID(sub); DM(None, IMMU(2)); SC(1); Fza;
4824
4825
3.02k
        }
4826
3.02k
      break;
4827
3.54k
    case 0xb1:
4828
11.6k
    case 0xb3:
4829
18.5k
    case 0xb5:
4830
23.6k
    case 0xb7:
4831
23.6k
        {
4832
          /** 1011 0rg1       decw  %0        */
4833
23.6k
#line 574 "rl78-decode.opc"
4834
23.6k
          int rg AU = (op[0] >> 1) & 0x03;
4835
23.6k
          if (trace)
4836
0
            {
4837
0
              printf ("\033[33m%s\033[0m  %02x\n",
4838
0
                     "/** 1011 0rg1       decw  %0        */",
4839
0
                     op[0]);
4840
0
              printf ("  rg = 0x%x\n", rg);
4841
0
            }
4842
23.6k
          SYNTAX("decw  %0");
4843
23.6k
#line 574 "rl78-decode.opc"
4844
23.6k
          ID(sub); W(); DRW(rg); SC(1);
4845
4846
23.6k
        }
4847
23.6k
      break;
4848
4.56k
    case 0xb2:
4849
4.56k
        {
4850
          /** 1011 0010     decw  %e!0        */
4851
4.56k
          if (trace)
4852
0
            {
4853
0
              printf ("\033[33m%s\033[0m  %02x\n",
4854
0
                     "/** 1011 0010     decw  %e!0        */",
4855
0
                     op[0]);
4856
0
            }
4857
4.56k
          SYNTAX("decw  %e!0");
4858
4.56k
#line 568 "rl78-decode.opc"
4859
4.56k
          ID(sub); W(); DM(None, IMMU(2)); SC(1);
4860
4861
4.56k
        }
4862
4.56k
      break;
4863
8.25k
    case 0xb4:
4864
8.25k
        {
4865
          /** 1011 0100     dec %0        */
4866
8.25k
          if (trace)
4867
0
            {
4868
0
              printf ("\033[33m%s\033[0m  %02x\n",
4869
0
                     "/** 1011 0100     dec %0        */",
4870
0
                     op[0]);
4871
0
            }
4872
8.25k
          SYNTAX("dec %0");
4873
8.25k
#line 563 "rl78-decode.opc"
4874
8.25k
          ID(sub); DM(None, SADDR); SC(1); Fza;
4875
4876
        /*----------------------------------------------------------------------*/
4877
4878
8.25k
        }
4879
8.25k
      break;
4880
7.56k
    case 0xb6:
4881
7.56k
        {
4882
          /** 1011 0110     decw  %0        */
4883
7.56k
          if (trace)
4884
0
            {
4885
0
              printf ("\033[33m%s\033[0m  %02x\n",
4886
0
                     "/** 1011 0110     decw  %0        */",
4887
0
                     op[0]);
4888
0
            }
4889
7.56k
          SYNTAX("decw  %0");
4890
7.56k
#line 577 "rl78-decode.opc"
4891
7.56k
          ID(sub); W(); DM(None, SADDR); SC(1);
4892
4893
        /*----------------------------------------------------------------------*/
4894
4895
7.56k
        }
4896
7.56k
      break;
4897
5.45k
    case 0xb8:
4898
5.45k
        {
4899
          /** 1011 1000     movw  %a0, %1       */
4900
5.45k
          if (trace)
4901
0
            {
4902
0
              printf ("\033[33m%s\033[0m  %02x\n",
4903
0
                     "/** 1011 1000     movw  %a0, %1       */",
4904
0
                     op[0]);
4905
0
            }
4906
5.45k
          SYNTAX("movw  %a0, %1");
4907
5.45k
#line 837 "rl78-decode.opc"
4908
5.45k
          ID(mov); W(); DM(SP, IMMU(1)); SR(AX);
4909
4910
5.45k
        }
4911
5.45k
      break;
4912
7.70k
    case 0xb9:
4913
7.70k
        {
4914
          /** 1011 1001     movw  %e0, %1       */
4915
7.70k
          if (trace)
4916
0
            {
4917
0
              printf ("\033[33m%s\033[0m  %02x\n",
4918
0
                     "/** 1011 1001     movw  %e0, %1       */",
4919
0
                     op[0]);
4920
0
            }
4921
7.70k
          SYNTAX("movw  %e0, %1");
4922
7.70k
#line 825 "rl78-decode.opc"
4923
7.70k
          ID(mov); W(); DM(DE, 0); SR(AX);
4924
4925
7.70k
        }
4926
7.70k
      break;
4927
4.84k
    case 0xba:
4928
4.84k
        {
4929
          /** 1011 1010     movw  %ea0, %1        */
4930
4.84k
          if (trace)
4931
0
            {
4932
0
              printf ("\033[33m%s\033[0m  %02x\n",
4933
0
                     "/** 1011 1010     movw  %ea0, %1        */",
4934
0
                     op[0]);
4935
0
            }
4936
4.84k
          SYNTAX("movw  %ea0, %1");
4937
4.84k
#line 828 "rl78-decode.opc"
4938
4.84k
          ID(mov); W(); DM(DE, IMMU(1)); SR(AX);
4939
4940
4.84k
        }
4941
4.84k
      break;
4942
2.57k
    case 0xbb:
4943
2.57k
        {
4944
          /** 1011 1011     movw  %e0, %1       */
4945
2.57k
          if (trace)
4946
0
            {
4947
0
              printf ("\033[33m%s\033[0m  %02x\n",
4948
0
                     "/** 1011 1011     movw  %e0, %1       */",
4949
0
                     op[0]);
4950
0
            }
4951
2.57k
          SYNTAX("movw  %e0, %1");
4952
2.57k
#line 831 "rl78-decode.opc"
4953
2.57k
          ID(mov); W(); DM(HL, 0); SR(AX);
4954
4955
2.57k
        }
4956
2.57k
      break;
4957
3.25k
    case 0xbc:
4958
3.25k
        {
4959
          /** 1011 1100     movw  %ea0, %1      */
4960
3.25k
          if (trace)
4961
0
            {
4962
0
              printf ("\033[33m%s\033[0m  %02x\n",
4963
0
                     "/** 1011 1100     movw  %ea0, %1      */",
4964
0
                     op[0]);
4965
0
            }
4966
3.25k
          SYNTAX("movw  %ea0, %1");
4967
3.25k
#line 834 "rl78-decode.opc"
4968
3.25k
          ID(mov); W(); DM(HL, IMMU(1)); SR(AX);
4969
4970
3.25k
        }
4971
3.25k
      break;
4972
6.09k
    case 0xbd:
4973
6.09k
        {
4974
          /** 1011 1101     movw  %0, %1        */
4975
6.09k
          if (trace)
4976
0
            {
4977
0
              printf ("\033[33m%s\033[0m  %02x\n",
4978
0
                     "/** 1011 1101     movw  %0, %1        */",
4979
0
                     op[0]);
4980
0
            }
4981
6.09k
          SYNTAX("movw  %0, %1");
4982
6.09k
#line 901 "rl78-decode.opc"
4983
6.09k
          ID(mov); W(); DM(None, SADDR); SR(AX);
4984
4985
6.09k
        }
4986
6.09k
      break;
4987
5.37k
    case 0xbe:
4988
5.37k
        {
4989
          /** 1011 1110     movw  %s0, %1       */
4990
5.37k
          if (trace)
4991
0
            {
4992
0
              printf ("\033[33m%s\033[0m  %02x\n",
4993
0
                     "/** 1011 1110     movw  %s0, %1       */",
4994
0
                     op[0]);
4995
0
            }
4996
5.37k
          SYNTAX("movw  %s0, %1");
4997
5.37k
#line 907 "rl78-decode.opc"
4998
5.37k
          ID(mov); W(); DM(None, SFR); SR(AX);
4999
5000
        /*----------------------------------------------------------------------*/
5001
5002
5.37k
        }
5003
5.37k
      break;
5004
3.27k
    case 0xbf:
5005
3.27k
        {
5006
          /** 1011 1111     movw  %e!0, %1      */
5007
3.27k
          if (trace)
5008
0
            {
5009
0
              printf ("\033[33m%s\033[0m  %02x\n",
5010
0
                     "/** 1011 1111     movw  %e!0, %1      */",
5011
0
                     op[0]);
5012
0
            }
5013
3.27k
          SYNTAX("movw  %e!0, %1");
5014
3.27k
#line 822 "rl78-decode.opc"
5015
3.27k
          ID(mov); W(); DM(None, IMMU(2)); SR(AX);
5016
5017
3.27k
        }
5018
3.27k
      break;
5019
19.5k
    case 0xc0:
5020
30.2k
    case 0xc2:
5021
44.5k
    case 0xc4:
5022
51.8k
    case 0xc6:
5023
51.8k
        {
5024
          /** 1100 0rg0     pop %0        */
5025
51.8k
#line 992 "rl78-decode.opc"
5026
51.8k
          int rg AU = (op[0] >> 1) & 0x03;
5027
51.8k
          if (trace)
5028
0
            {
5029
0
              printf ("\033[33m%s\033[0m  %02x\n",
5030
0
                     "/** 1100 0rg0     pop %0        */",
5031
0
                     op[0]);
5032
0
              printf ("  rg = 0x%x\n", rg);
5033
0
            }
5034
51.8k
          SYNTAX("pop %0");
5035
51.8k
#line 992 "rl78-decode.opc"
5036
51.8k
          ID(mov); W(); DRW(rg); SPOP();
5037
5038
51.8k
        }
5039
51.8k
      break;
5040
12.4k
    case 0xc1:
5041
22.6k
    case 0xc3:
5042
28.9k
    case 0xc5:
5043
34.6k
    case 0xc7:
5044
34.6k
        {
5045
          /** 1100 0rg1     push  %1        */
5046
34.6k
#line 1000 "rl78-decode.opc"
5047
34.6k
          int rg AU = (op[0] >> 1) & 0x03;
5048
34.6k
          if (trace)
5049
0
            {
5050
0
              printf ("\033[33m%s\033[0m  %02x\n",
5051
0
                     "/** 1100 0rg1     push  %1        */",
5052
0
                     op[0]);
5053
0
              printf ("  rg = 0x%x\n", rg);
5054
0
            }
5055
34.6k
          SYNTAX("push  %1");
5056
34.6k
#line 1000 "rl78-decode.opc"
5057
34.6k
          ID(mov); W(); DPUSH(); SRW(rg);
5058
5059
34.6k
        }
5060
34.6k
      break;
5061
2.30k
    case 0xc8:
5062
2.30k
        {
5063
          /** 1100 1000     mov %a0, #%1      */
5064
2.30k
          if (trace)
5065
0
            {
5066
0
              printf ("\033[33m%s\033[0m  %02x\n",
5067
0
                     "/** 1100 1000     mov %a0, #%1      */",
5068
0
                     op[0]);
5069
0
            }
5070
2.30k
          SYNTAX("mov %a0, #%1");
5071
2.30k
#line 645 "rl78-decode.opc"
5072
2.30k
          ID(mov); DM(SP, IMMU(1)); SC(IMMU(1));
5073
5074
2.30k
        }
5075
2.30k
      break;
5076
3.60k
    case 0xc9:
5077
3.60k
        {
5078
          /** 1100 1001     movw  %0, #%1       */
5079
3.60k
          if (trace)
5080
0
            {
5081
0
              printf ("\033[33m%s\033[0m  %02x\n",
5082
0
                     "/** 1100 1001     movw  %0, #%1       */",
5083
0
                     op[0]);
5084
0
            }
5085
3.60k
          SYNTAX("movw  %0, #%1");
5086
3.60k
#line 898 "rl78-decode.opc"
5087
3.60k
          ID(mov); W(); DM(None, SADDR); SC(IMMU(2));
5088
5089
3.60k
        }
5090
3.60k
      break;
5091
3.30k
    case 0xca:
5092
3.30k
        {
5093
          /** 1100 1010     mov %ea0, #%1     */
5094
3.30k
          if (trace)
5095
0
            {
5096
0
              printf ("\033[33m%s\033[0m  %02x\n",
5097
0
                     "/** 1100 1010     mov %ea0, #%1     */",
5098
0
                     op[0]);
5099
0
            }
5100
3.30k
          SYNTAX("mov %ea0, #%1");
5101
3.30k
#line 624 "rl78-decode.opc"
5102
3.30k
          ID(mov); DM(DE, IMMU(1)); SC(IMMU(1));
5103
5104
3.30k
        }
5105
3.30k
      break;
5106
3.12k
    case 0xcb:
5107
3.12k
        {
5108
          /** 1100 1011     movw  %s0, #%1      */
5109
3.12k
          if (trace)
5110
0
            {
5111
0
              printf ("\033[33m%s\033[0m  %02x\n",
5112
0
                     "/** 1100 1011     movw  %s0, #%1      */",
5113
0
                     op[0]);
5114
0
            }
5115
3.12k
          SYNTAX("movw  %s0, #%1");
5116
3.12k
#line 904 "rl78-decode.opc"
5117
3.12k
          ID(mov); W(); DM(None, SFR); SC(IMMU(2));
5118
5119
3.12k
        }
5120
3.12k
      break;
5121
7.51k
    case 0xcc:
5122
7.51k
        {
5123
          /** 1100 1100     mov %ea0, #%1     */
5124
7.51k
          if (trace)
5125
0
            {
5126
0
              printf ("\033[33m%s\033[0m  %02x\n",
5127
0
                     "/** 1100 1100     mov %ea0, #%1     */",
5128
0
                     op[0]);
5129
0
            }
5130
7.51k
          SYNTAX("mov %ea0, #%1");
5131
7.51k
#line 636 "rl78-decode.opc"
5132
7.51k
          ID(mov); DM(HL, IMMU(1)); SC(IMMU(1));
5133
5134
7.51k
        }
5135
7.51k
      break;
5136
6.67k
    case 0xcd:
5137
6.67k
        {
5138
          /** 1100 1101     mov %0, #%1       */
5139
6.67k
          if (trace)
5140
0
            {
5141
0
              printf ("\033[33m%s\033[0m  %02x\n",
5142
0
                     "/** 1100 1101     mov %0, #%1       */",
5143
0
                     op[0]);
5144
0
            }
5145
6.67k
          SYNTAX("mov %0, #%1");
5146
6.67k
#line 750 "rl78-decode.opc"
5147
6.67k
          ID(mov); DM(None, SADDR); SC(IMMU(1));
5148
5149
6.67k
        }
5150
6.67k
      break;
5151
8.20k
    case 0xce:
5152
8.20k
        {
5153
          /** 1100 1110     mov %s0, #%1      */
5154
8.20k
          if (trace)
5155
0
            {
5156
0
              printf ("\033[33m%s\033[0m  %02x\n",
5157
0
                     "/** 1100 1110     mov %s0, #%1      */",
5158
0
                     op[0]);
5159
0
            }
5160
8.20k
          SYNTAX("mov %s0, #%1");
5161
8.20k
#line 756 "rl78-decode.opc"
5162
8.20k
          op0 = SFR;
5163
8.20k
          op1 = IMMU(1);
5164
8.20k
          ID(mov); DM(None, op0); SC(op1);
5165
8.20k
          if (op0 == 0xffffb && isa == RL78_ISA_G14)
5166
0
            switch (op1)
5167
0
              {
5168
0
              case 0x01:
5169
0
          rl78->syntax = "mulhu"; ID(mulhu);
5170
0
          break;
5171
0
              case 0x02:
5172
0
          rl78->syntax = "mulh"; ID(mulh);
5173
0
          break;
5174
0
              case 0x03:
5175
0
          rl78->syntax = "divhu"; ID(divhu);
5176
0
          break;
5177
0
              case 0x04:
5178
0
          rl78->syntax = "divwu <old-encoding>"; ID(divwu);
5179
0
          break;
5180
0
              case 0x05:
5181
0
          rl78->syntax = "machu"; ID(machu);
5182
0
          break;
5183
0
              case 0x06:
5184
0
          rl78->syntax = "mach"; ID(mach);
5185
0
          break;
5186
0
              case 0x0b:
5187
0
          rl78->syntax = "divwu"; ID(divwu);
5188
0
          break;
5189
0
              }
5190
5191
8.20k
        }
5192
8.20k
      break;
5193
8.20k
    case 0xcf:
5194
4.14k
        {
5195
          /** 1100 1111     mov %e!0, #%1     */
5196
4.14k
          if (trace)
5197
0
            {
5198
0
              printf ("\033[33m%s\033[0m  %02x\n",
5199
0
                     "/** 1100 1111     mov %e!0, #%1     */",
5200
0
                     op[0]);
5201
0
            }
5202
4.14k
          SYNTAX("mov %e!0, #%1");
5203
4.14k
#line 615 "rl78-decode.opc"
5204
4.14k
          ID(mov); DM(None, IMMU(2)); SC(IMMU(1));
5205
5206
4.14k
        }
5207
4.14k
      break;
5208
2.88k
    case 0xd0:
5209
7.45k
    case 0xd1:
5210
17.1k
    case 0xd2:
5211
28.3k
    case 0xd3:
5212
28.3k
        {
5213
          /** 1101 00rg     cmp0  %0        */
5214
28.3k
#line 524 "rl78-decode.opc"
5215
28.3k
          int rg AU = op[0] & 0x03;
5216
28.3k
          if (trace)
5217
0
            {
5218
0
              printf ("\033[33m%s\033[0m  %02x\n",
5219
0
                     "/** 1101 00rg     cmp0  %0        */",
5220
0
                     op[0]);
5221
0
              printf ("  rg = 0x%x\n", rg);
5222
0
            }
5223
28.3k
          SYNTAX("cmp0  %0");
5224
28.3k
#line 524 "rl78-decode.opc"
5225
28.3k
          ID(cmp); DRB(rg); SC(0); Fzac;
5226
5227
28.3k
        }
5228
28.3k
      break;
5229
2.87k
    case 0xd4:
5230
2.87k
        {
5231
          /** 1101 0100     cmp0  %0        */
5232
2.87k
          if (trace)
5233
0
            {
5234
0
              printf ("\033[33m%s\033[0m  %02x\n",
5235
0
                     "/** 1101 0100     cmp0  %0        */",
5236
0
                     op[0]);
5237
0
            }
5238
2.87k
          SYNTAX("cmp0  %0");
5239
2.87k
#line 527 "rl78-decode.opc"
5240
2.87k
          ID(cmp); DM(None, SADDR); SC(0); Fzac;
5241
5242
        /*----------------------------------------------------------------------*/
5243
5244
2.87k
        }
5245
2.87k
      break;
5246
6.00k
    case 0xd5:
5247
6.00k
        {
5248
          /** 1101 0101     cmp0  %e!0        */
5249
6.00k
          if (trace)
5250
0
            {
5251
0
              printf ("\033[33m%s\033[0m  %02x\n",
5252
0
                     "/** 1101 0101     cmp0  %e!0        */",
5253
0
                     op[0]);
5254
0
            }
5255
6.00k
          SYNTAX("cmp0  %e!0");
5256
6.00k
#line 521 "rl78-decode.opc"
5257
6.00k
          ID(cmp); DM(None, IMMU(2)); SC(0); Fzac;
5258
5259
6.00k
        }
5260
6.00k
      break;
5261
8.18k
    case 0xd6:
5262
8.18k
        {
5263
          /** 1101 0110     mulu  x       */
5264
8.18k
          if (trace)
5265
0
            {
5266
0
              printf ("\033[33m%s\033[0m  %02x\n",
5267
0
                     "/** 1101 0110     mulu  x       */",
5268
0
                     op[0]);
5269
0
            }
5270
8.18k
          SYNTAX("mulu  x");
5271
8.18k
#line 912 "rl78-decode.opc"
5272
8.18k
          ID(mulu);
5273
5274
        /*----------------------------------------------------------------------*/
5275
5276
8.18k
        }
5277
8.18k
      break;
5278
13.0k
    case 0xd7:
5279
13.0k
        {
5280
          /** 1101 0111     ret         */
5281
13.0k
          if (trace)
5282
0
            {
5283
0
              printf ("\033[33m%s\033[0m  %02x\n",
5284
0
                     "/** 1101 0111     ret         */",
5285
0
                     op[0]);
5286
0
            }
5287
13.0k
          SYNTAX("ret");
5288
13.0k
#line 1008 "rl78-decode.opc"
5289
13.0k
          ID(ret);
5290
5291
13.0k
        }
5292
13.0k
      break;
5293
6.08k
    case 0xd8:
5294
6.08k
        {
5295
          /** 1101 1000     mov %0, %1        */
5296
6.08k
          if (trace)
5297
0
            {
5298
0
              printf ("\033[33m%s\033[0m  %02x\n",
5299
0
                     "/** 1101 1000     mov %0, %1        */",
5300
0
                     op[0]);
5301
0
            }
5302
6.08k
          SYNTAX("mov %0, %1");
5303
6.08k
#line 717 "rl78-decode.opc"
5304
6.08k
          ID(mov); DR(X); SM(None, SADDR);
5305
5306
6.08k
        }
5307
6.08k
      break;
5308
2.17k
    case 0xd9:
5309
2.17k
        {
5310
          /** 1101 1001     mov %0, %e!1      */
5311
2.17k
          if (trace)
5312
0
            {
5313
0
              printf ("\033[33m%s\033[0m  %02x\n",
5314
0
                     "/** 1101 1001     mov %0, %e!1      */",
5315
0
                     op[0]);
5316
0
            }
5317
2.17k
          SYNTAX("mov %0, %e!1");
5318
2.17k
#line 714 "rl78-decode.opc"
5319
2.17k
          ID(mov); DR(X); SM(None, IMMU(2));
5320
5321
2.17k
        }
5322
2.17k
      break;
5323
7.23k
    case 0xda:
5324
14.7k
    case 0xea:
5325
23.0k
    case 0xfa:
5326
23.0k
        {
5327
          /** 11ra 1010     movw  %0, %1        */
5328
23.0k
#line 895 "rl78-decode.opc"
5329
23.0k
          int ra AU = (op[0] >> 4) & 0x03;
5330
23.0k
          if (trace)
5331
0
            {
5332
0
              printf ("\033[33m%s\033[0m  %02x\n",
5333
0
                     "/** 11ra 1010     movw  %0, %1        */",
5334
0
                     op[0]);
5335
0
              printf ("  ra = 0x%x\n", ra);
5336
0
            }
5337
23.0k
          SYNTAX("movw  %0, %1");
5338
23.0k
#line 895 "rl78-decode.opc"
5339
23.0k
          ID(mov); W(); DRW(ra); SM(None, SADDR);
5340
5341
23.0k
        }
5342
23.0k
      break;
5343
2.49k
    case 0xdb:
5344
7.16k
    case 0xeb:
5345
11.9k
    case 0xfb:
5346
11.9k
        {
5347
          /** 11ra 1011     movw  %0, %es!1     */
5348
11.9k
#line 892 "rl78-decode.opc"
5349
11.9k
          int ra AU = (op[0] >> 4) & 0x03;
5350
11.9k
          if (trace)
5351
0
            {
5352
0
              printf ("\033[33m%s\033[0m  %02x\n",
5353
0
                     "/** 11ra 1011     movw  %0, %es!1     */",
5354
0
                     op[0]);
5355
0
              printf ("  ra = 0x%x\n", ra);
5356
0
            }
5357
11.9k
          SYNTAX("movw  %0, %es!1");
5358
11.9k
#line 892 "rl78-decode.opc"
5359
11.9k
          ID(mov); W(); DRW(ra); SM(None, IMMU(2));
5360
5361
11.9k
        }
5362
11.9k
      break;
5363
2.58k
    case 0xdc:
5364
2.58k
        {
5365
          /** 1101 1100     bc  $%a0        */
5366
2.58k
          if (trace)
5367
0
            {
5368
0
              printf ("\033[33m%s\033[0m  %02x\n",
5369
0
                     "/** 1101 1100     bc  $%a0        */",
5370
0
                     op[0]);
5371
0
            }
5372
2.58k
          SYNTAX("bc  $%a0");
5373
2.58k
#line 340 "rl78-decode.opc"
5374
2.58k
          ID(branch_cond); DC(pc+IMMS(1)+2); SR(None); COND(C);
5375
5376
2.58k
        }
5377
2.58k
      break;
5378
4.82k
    case 0xdd:
5379
4.82k
        {
5380
          /** 1101 1101     bz  $%a0        */
5381
4.82k
          if (trace)
5382
0
            {
5383
0
              printf ("\033[33m%s\033[0m  %02x\n",
5384
0
                     "/** 1101 1101     bz  $%a0        */",
5385
0
                     op[0]);
5386
0
            }
5387
4.82k
          SYNTAX("bz  $%a0");
5388
4.82k
#line 352 "rl78-decode.opc"
5389
4.82k
          ID(branch_cond); DC(pc+IMMS(1)+2); SR(None); COND(Z);
5390
5391
4.82k
        }
5392
4.82k
      break;
5393
4.13k
    case 0xde:
5394
4.13k
        {
5395
          /** 1101 1110     bnc $%a0        */
5396
4.13k
          if (trace)
5397
0
            {
5398
0
              printf ("\033[33m%s\033[0m  %02x\n",
5399
0
                     "/** 1101 1110     bnc $%a0        */",
5400
0
                     op[0]);
5401
0
            }
5402
4.13k
          SYNTAX("bnc $%a0");
5403
4.13k
#line 343 "rl78-decode.opc"
5404
4.13k
          ID(branch_cond); DC(pc+IMMS(1)+2); SR(None); COND(NC);
5405
5406
4.13k
        }
5407
4.13k
      break;
5408
8.35k
    case 0xdf:
5409
8.35k
        {
5410
          /** 1101 1111     bnz $%a0        */
5411
8.35k
          if (trace)
5412
0
            {
5413
0
              printf ("\033[33m%s\033[0m  %02x\n",
5414
0
                     "/** 1101 1111     bnz $%a0        */",
5415
0
                     op[0]);
5416
0
            }
5417
8.35k
          SYNTAX("bnz $%a0");
5418
8.35k
#line 355 "rl78-decode.opc"
5419
8.35k
          ID(branch_cond); DC(pc+IMMS(1)+2); SR(None); COND(NZ);
5420
5421
        /*----------------------------------------------------------------------*/
5422
5423
8.35k
        }
5424
8.35k
      break;
5425
19.7k
    case 0xe0:
5426
26.8k
    case 0xe1:
5427
37.4k
    case 0xe2:
5428
46.8k
    case 0xe3:
5429
46.8k
        {
5430
          /** 1110 00rg     oneb  %0        */
5431
46.8k
#line 930 "rl78-decode.opc"
5432
46.8k
          int rg AU = op[0] & 0x03;
5433
46.8k
          if (trace)
5434
0
            {
5435
0
              printf ("\033[33m%s\033[0m  %02x\n",
5436
0
                     "/** 1110 00rg     oneb  %0        */",
5437
0
                     op[0]);
5438
0
              printf ("  rg = 0x%x\n", rg);
5439
0
            }
5440
46.8k
          SYNTAX("oneb  %0");
5441
46.8k
#line 930 "rl78-decode.opc"
5442
46.8k
          ID(mov); DRB(rg); SC(1);
5443
5444
46.8k
        }
5445
46.8k
      break;
5446
9.06k
    case 0xe4:
5447
9.06k
        {
5448
          /** 1110 0100     oneb  %0        */
5449
9.06k
          if (trace)
5450
0
            {
5451
0
              printf ("\033[33m%s\033[0m  %02x\n",
5452
0
                     "/** 1110 0100     oneb  %0        */",
5453
0
                     op[0]);
5454
0
            }
5455
9.06k
          SYNTAX("oneb  %0");
5456
9.06k
#line 933 "rl78-decode.opc"
5457
9.06k
          ID(mov); DM(None, SADDR); SC(1);
5458
5459
        /*----------------------------------------------------------------------*/
5460
5461
9.06k
        }
5462
9.06k
      break;
5463
2.67k
    case 0xe5:
5464
2.67k
        {
5465
          /** 1110 0101     oneb  %e!0        */
5466
2.67k
          if (trace)
5467
0
            {
5468
0
              printf ("\033[33m%s\033[0m  %02x\n",
5469
0
                     "/** 1110 0101     oneb  %e!0        */",
5470
0
                     op[0]);
5471
0
            }
5472
2.67k
          SYNTAX("oneb  %e!0");
5473
2.67k
#line 927 "rl78-decode.opc"
5474
2.67k
          ID(mov); DM(None, IMMU(2)); SC(1);
5475
5476
2.67k
        }
5477
2.67k
      break;
5478
9.98k
    case 0xe6:
5479
9.98k
        {
5480
          /** 1110 0110     onew  %0        */
5481
9.98k
          if (trace)
5482
0
            {
5483
0
              printf ("\033[33m%s\033[0m  %02x\n",
5484
0
                     "/** 1110 0110     onew  %0        */",
5485
0
                     op[0]);
5486
0
            }
5487
9.98k
          SYNTAX("onew  %0");
5488
9.98k
#line 938 "rl78-decode.opc"
5489
9.98k
          ID(mov); DR(AX); SC(1);
5490
5491
9.98k
        }
5492
9.98k
      break;
5493
5.20k
    case 0xe7:
5494
5.20k
        {
5495
          /** 1110 0111     onew  %0        */
5496
5.20k
          if (trace)
5497
0
            {
5498
0
              printf ("\033[33m%s\033[0m  %02x\n",
5499
0
                     "/** 1110 0111     onew  %0        */",
5500
0
                     op[0]);
5501
0
            }
5502
5.20k
          SYNTAX("onew  %0");
5503
5.20k
#line 941 "rl78-decode.opc"
5504
5.20k
          ID(mov); DR(BC); SC(1);
5505
5506
        /*----------------------------------------------------------------------*/
5507
5508
5.20k
        }
5509
5.20k
      break;
5510
6.45k
    case 0xe8:
5511
6.45k
        {
5512
          /** 1110 1000     mov %0, %1        */
5513
6.45k
          if (trace)
5514
0
            {
5515
0
              printf ("\033[33m%s\033[0m  %02x\n",
5516
0
                     "/** 1110 1000     mov %0, %1        */",
5517
0
                     op[0]);
5518
0
            }
5519
6.45k
          SYNTAX("mov %0, %1");
5520
6.45k
#line 705 "rl78-decode.opc"
5521
6.45k
          ID(mov); DR(B); SM(None, SADDR);
5522
5523
6.45k
        }
5524
6.45k
      break;
5525
3.14k
    case 0xe9:
5526
3.14k
        {
5527
          /** 1110 1001     mov %0, %e!1      */
5528
3.14k
          if (trace)
5529
0
            {
5530
0
              printf ("\033[33m%s\033[0m  %02x\n",
5531
0
                     "/** 1110 1001     mov %0, %e!1      */",
5532
0
                     op[0]);
5533
0
            }
5534
3.14k
          SYNTAX("mov %0, %e!1");
5535
3.14k
#line 699 "rl78-decode.opc"
5536
3.14k
          ID(mov); DR(B); SM(None, IMMU(2));
5537
5538
3.14k
        }
5539
3.14k
      break;
5540
6.07k
    case 0xec:
5541
6.07k
        {
5542
          /** 1110 1100     br  !%!a0       */
5543
6.07k
          if (trace)
5544
0
            {
5545
0
              printf ("\033[33m%s\033[0m  %02x\n",
5546
0
                     "/** 1110 1100     br  !%!a0       */",
5547
0
                     op[0]);
5548
0
            }
5549
6.07k
          SYNTAX("br  !%!a0");
5550
6.07k
#line 374 "rl78-decode.opc"
5551
6.07k
          ID(branch); DC(IMMU(3));
5552
5553
6.07k
        }
5554
6.07k
      break;
5555
3.99k
    case 0xed:
5556
3.99k
        {
5557
          /** 1110 1101     br  %!a0        */
5558
3.99k
          if (trace)
5559
0
            {
5560
0
              printf ("\033[33m%s\033[0m  %02x\n",
5561
0
                     "/** 1110 1101     br  %!a0        */",
5562
0
                     op[0]);
5563
0
            }
5564
3.99k
          SYNTAX("br  %!a0");
5565
3.99k
#line 377 "rl78-decode.opc"
5566
3.99k
          ID(branch); DC(IMMU(2));
5567
5568
3.99k
        }
5569
3.99k
      break;
5570
7.68k
    case 0xee:
5571
7.68k
        {
5572
          /** 1110 1110     br  $%!a0       */
5573
7.68k
          if (trace)
5574
0
            {
5575
0
              printf ("\033[33m%s\033[0m  %02x\n",
5576
0
                     "/** 1110 1110     br  $%!a0       */",
5577
0
                     op[0]);
5578
0
            }
5579
7.68k
          SYNTAX("br  $%!a0");
5580
7.68k
#line 380 "rl78-decode.opc"
5581
7.68k
          ID(branch); DC(pc+IMMS(2)+3);
5582
5583
7.68k
        }
5584
7.68k
      break;
5585
9.20k
    case 0xef:
5586
9.20k
        {
5587
          /** 1110 1111     br  $%a0        */
5588
9.20k
          if (trace)
5589
0
            {
5590
0
              printf ("\033[33m%s\033[0m  %02x\n",
5591
0
                     "/** 1110 1111     br  $%a0        */",
5592
0
                     op[0]);
5593
0
            }
5594
9.20k
          SYNTAX("br  $%a0");
5595
9.20k
#line 383 "rl78-decode.opc"
5596
9.20k
          ID(branch); DC(pc+IMMS(1)+2);
5597
5598
9.20k
        }
5599
9.20k
      break;
5600
8.62k
    case 0xf0:
5601
16.7k
    case 0xf1:
5602
27.6k
    case 0xf2:
5603
42.6k
    case 0xf3:
5604
42.6k
        {
5605
          /** 1111 00rg     clrb  %0        */
5606
42.6k
#line 470 "rl78-decode.opc"
5607
42.6k
          int rg AU = op[0] & 0x03;
5608
42.6k
          if (trace)
5609
0
            {
5610
0
              printf ("\033[33m%s\033[0m  %02x\n",
5611
0
                     "/** 1111 00rg     clrb  %0        */",
5612
0
                     op[0]);
5613
0
              printf ("  rg = 0x%x\n", rg);
5614
0
            }
5615
42.6k
          SYNTAX("clrb  %0");
5616
42.6k
#line 470 "rl78-decode.opc"
5617
42.6k
          ID(mov); DRB(rg); SC(0);
5618
5619
42.6k
        }
5620
42.6k
      break;
5621
7.03k
    case 0xf4:
5622
7.03k
        {
5623
          /** 1111 0100     clrb  %0        */
5624
7.03k
          if (trace)
5625
0
            {
5626
0
              printf ("\033[33m%s\033[0m  %02x\n",
5627
0
                     "/** 1111 0100     clrb  %0        */",
5628
0
                     op[0]);
5629
0
            }
5630
7.03k
          SYNTAX("clrb  %0");
5631
7.03k
#line 473 "rl78-decode.opc"
5632
7.03k
          ID(mov); DM(None, SADDR); SC(0);
5633
5634
        /*----------------------------------------------------------------------*/
5635
5636
7.03k
        }
5637
7.03k
      break;
5638
5.18k
    case 0xf5:
5639
5.18k
        {
5640
          /** 1111 0101     clrb  %e!0        */
5641
5.18k
          if (trace)
5642
0
            {
5643
0
              printf ("\033[33m%s\033[0m  %02x\n",
5644
0
                     "/** 1111 0101     clrb  %e!0        */",
5645
0
                     op[0]);
5646
0
            }
5647
5.18k
          SYNTAX("clrb  %e!0");
5648
5.18k
#line 467 "rl78-decode.opc"
5649
5.18k
          ID(mov); DM(None, IMMU(2)); SC(0);
5650
5651
5.18k
        }
5652
5.18k
      break;
5653
8.71k
    case 0xf6:
5654
8.71k
        {
5655
          /** 1111 0110     clrw  %0        */
5656
8.71k
          if (trace)
5657
0
            {
5658
0
              printf ("\033[33m%s\033[0m  %02x\n",
5659
0
                     "/** 1111 0110     clrw  %0        */",
5660
0
                     op[0]);
5661
0
            }
5662
8.71k
          SYNTAX("clrw  %0");
5663
8.71k
#line 478 "rl78-decode.opc"
5664
8.71k
          ID(mov); DR(AX); SC(0);
5665
5666
8.71k
        }
5667
8.71k
      break;
5668
9.44k
    case 0xf7:
5669
9.44k
        {
5670
          /** 1111 0111     clrw  %0        */
5671
9.44k
          if (trace)
5672
0
            {
5673
0
              printf ("\033[33m%s\033[0m  %02x\n",
5674
0
                     "/** 1111 0111     clrw  %0        */",
5675
0
                     op[0]);
5676
0
            }
5677
9.44k
          SYNTAX("clrw  %0");
5678
9.44k
#line 481 "rl78-decode.opc"
5679
9.44k
          ID(mov); DR(BC); SC(0);
5680
5681
        /*----------------------------------------------------------------------*/
5682
5683
9.44k
        }
5684
9.44k
      break;
5685
9.82k
    case 0xf8:
5686
9.82k
        {
5687
          /** 1111 1000     mov %0, %1        */
5688
9.82k
          if (trace)
5689
0
            {
5690
0
              printf ("\033[33m%s\033[0m  %02x\n",
5691
0
                     "/** 1111 1000     mov %0, %1        */",
5692
0
                     op[0]);
5693
0
            }
5694
9.82k
          SYNTAX("mov %0, %1");
5695
9.82k
#line 711 "rl78-decode.opc"
5696
9.82k
          ID(mov); DR(C); SM(None, SADDR);
5697
5698
9.82k
        }
5699
9.82k
      break;
5700
5.51k
    case 0xf9:
5701
5.51k
        {
5702
          /** 1111 1001     mov %0, %e!1      */
5703
5.51k
          if (trace)
5704
0
            {
5705
0
              printf ("\033[33m%s\033[0m  %02x\n",
5706
0
                     "/** 1111 1001     mov %0, %e!1      */",
5707
0
                     op[0]);
5708
0
            }
5709
5.51k
          SYNTAX("mov %0, %e!1");
5710
5.51k
#line 708 "rl78-decode.opc"
5711
5.51k
          ID(mov); DR(C); SM(None, IMMU(2));
5712
5713
5.51k
        }
5714
5.51k
      break;
5715
10.2k
    case 0xfc:
5716
10.2k
        {
5717
          /** 1111 1100     call  !%!a0       */
5718
10.2k
          if (trace)
5719
0
            {
5720
0
              printf ("\033[33m%s\033[0m  %02x\n",
5721
0
                     "/** 1111 1100     call  !%!a0       */",
5722
0
                     op[0]);
5723
0
            }
5724
10.2k
          SYNTAX("call  !%!a0");
5725
10.2k
#line 427 "rl78-decode.opc"
5726
10.2k
          ID(call); DC(IMMU(3));
5727
5728
10.2k
        }
5729
10.2k
      break;
5730
11.7k
    case 0xfd:
5731
11.7k
        {
5732
          /** 1111 1101     call  %!a0        */
5733
11.7k
          if (trace)
5734
0
            {
5735
0
              printf ("\033[33m%s\033[0m  %02x\n",
5736
0
                     "/** 1111 1101     call  %!a0        */",
5737
0
                     op[0]);
5738
0
            }
5739
11.7k
          SYNTAX("call  %!a0");
5740
11.7k
#line 430 "rl78-decode.opc"
5741
11.7k
          ID(call); DC(IMMU(2));
5742
5743
11.7k
        }
5744
11.7k
      break;
5745
12.6k
    case 0xfe:
5746
12.6k
        {
5747
          /** 1111 1110     call  $%!a0       */
5748
12.6k
          if (trace)
5749
0
            {
5750
0
              printf ("\033[33m%s\033[0m  %02x\n",
5751
0
                     "/** 1111 1110     call  $%!a0       */",
5752
0
                     op[0]);
5753
0
            }
5754
12.6k
          SYNTAX("call  $%!a0");
5755
12.6k
#line 433 "rl78-decode.opc"
5756
12.6k
          ID(call); DC(pc+IMMS(2)+3);
5757
5758
12.6k
        }
5759
12.6k
      break;
5760
358k
    case 0xff:
5761
358k
        {
5762
          /** 1111 1111     brk1          */
5763
358k
          if (trace)
5764
0
            {
5765
0
              printf ("\033[33m%s\033[0m  %02x\n",
5766
0
                     "/** 1111 1111     brk1          */",
5767
0
                     op[0]);
5768
0
            }
5769
358k
          SYNTAX("brk1");
5770
358k
#line 391 "rl78-decode.opc"
5771
358k
          ID(break);
5772
5773
358k
        }
5774
358k
      break;
5775
3.82M
  }
5776
3.45M
#line 1296 "rl78-decode.opc"
5777
5778
3.45M
  return rl78->n_bytes;
5779
3.82M
}