Coverage Report

Created: 2026-05-11 07:54

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/binutils-gdb/opcodes/s12z-opc.c
Line
Count
Source
1
/* s12z-decode.c -- Freescale S12Z disassembly
2
   Copyright (C) 2018-2026 Free Software Foundation, Inc.
3
4
   This file is part of the GNU opcodes library.
5
6
   This library is free software; you can redistribute it and/or modify
7
   it under the terms of the GNU General Public License as published by
8
   the Free Software Foundation; either version 3, or (at your option)
9
   any later version.
10
11
   It is distributed in the hope that it will be useful, but WITHOUT
12
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13
   or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
14
   License for more details.
15
16
   You should have received a copy of the GNU General Public License
17
   along with this program; if not, write to the Free Software
18
   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
19
   MA 02110-1301, USA.  */
20
21
#include "sysdep.h"
22
#include <stdio.h>
23
#include <stdint.h>
24
#include <stdbool.h>
25
#include <assert.h>
26
27
#include "opcode/s12z.h"
28
29
#include "bfd.h"
30
31
#include "s12z-opc.h"
32
33
34
typedef int (*insn_bytes_f) (struct mem_read_abstraction_base *);
35
36
typedef int (*operands_f) (struct mem_read_abstraction_base *,
37
         int *n_operands, struct operand **operand);
38
39
typedef enum optr (*discriminator_f) (struct mem_read_abstraction_base *,
40
              enum optr hint);
41
42
enum OPR_MODE
43
  {
44
    OPR_IMMe4,
45
    OPR_REG,
46
    OPR_OFXYS,
47
    OPR_XY_PRE_INC,
48
    OPR_XY_POST_INC,
49
    OPR_XY_PRE_DEC,
50
    OPR_XY_POST_DEC,
51
    OPR_S_PRE_DEC,
52
    OPR_S_POST_INC,
53
    OPR_REG_DIRECT,
54
    OPR_REG_INDIRECT,
55
    OPR_IDX_DIRECT,
56
    OPR_IDX_INDIRECT,
57
    OPR_EXT1,
58
    OPR_IDX2_REG,
59
    OPR_IDX3_DIRECT,
60
    OPR_IDX3_INDIRECT,
61
62
    OPR_EXT18,
63
    OPR_IDX3_DIRECT_REG,
64
    OPR_EXT3_DIRECT,
65
    OPR_EXT3_INDIRECT
66
  };
67
68
struct opr_pb
69
{
70
  uint8_t mask;
71
  uint8_t value;
72
  int n_operands;
73
  enum OPR_MODE mode;
74
};
75
76
static const  struct opr_pb opr_pb[] = {
77
  {0xF0, 0x70, 1, OPR_IMMe4},
78
  {0xF8, 0xB8, 1, OPR_REG},
79
  {0xC0, 0x40, 1, OPR_OFXYS},
80
  {0xEF, 0xE3, 1, OPR_XY_PRE_INC},
81
  {0xEF, 0xE7, 1, OPR_XY_POST_INC},
82
  {0xEF, 0xC3, 1, OPR_XY_PRE_DEC},
83
  {0xEF, 0xC7, 1, OPR_XY_POST_DEC},
84
  {0xFF, 0xFB, 1, OPR_S_PRE_DEC},
85
  {0xFF, 0xFF, 1, OPR_S_POST_INC},
86
  {0xC8, 0x88, 1, OPR_REG_DIRECT},
87
  {0xE8, 0xC8, 1, OPR_REG_INDIRECT},
88
89
  {0xCE, 0xC0, 2, OPR_IDX_DIRECT},
90
  {0xCE, 0xC4, 2, OPR_IDX_INDIRECT},
91
  {0xC0, 0x00, 2, OPR_EXT1},
92
93
  {0xC8, 0x80, 3, OPR_IDX2_REG},
94
  {0xFA, 0xF8, 3, OPR_EXT18},
95
96
  {0xCF, 0xC2, 4, OPR_IDX3_DIRECT},
97
  {0xCF, 0xC6, 4, OPR_IDX3_INDIRECT},
98
99
  {0xF8, 0xE8, 4, OPR_IDX3_DIRECT_REG},
100
  {0xFF, 0xFA, 4, OPR_EXT3_DIRECT},
101
  {0xFF, 0xFE, 4, OPR_EXT3_INDIRECT},
102
};
103
104
/* Return the number of bytes in a OPR operand, including the XB postbyte.
105
   It does not include any preceeding opcodes. */
106
static int
107
x_opr_n_bytes (struct mem_read_abstraction_base *mra, int offset)
108
148k
{
109
148k
  bfd_byte xb;
110
148k
  int status = mra->read (mra, offset, 1, &xb);
111
148k
  if (status < 0)
112
12
    return status;
113
114
148k
  size_t i;
115
1.47M
  for (i = 0; i < sizeof (opr_pb) / sizeof (opr_pb[0]); ++i)
116
1.47M
    {
117
1.47M
      const struct opr_pb *pb = opr_pb + i;
118
1.47M
      if ((xb & pb->mask) == pb->value)
119
148k
  {
120
148k
    return pb->n_operands;
121
148k
  }
122
1.47M
    }
123
124
0
  return 1;
125
148k
}
126
127
static int
128
opr_n_bytes_p1 (struct mem_read_abstraction_base *mra)
129
97.2k
{
130
97.2k
  int n = x_opr_n_bytes (mra, 0);
131
97.2k
  if (n < 0)
132
0
    return n;
133
97.2k
  return 1 + n;
134
97.2k
}
135
136
static int
137
opr_n_bytes2 (struct mem_read_abstraction_base *mra)
138
2.57k
{
139
2.57k
  int s = x_opr_n_bytes (mra, 0);
140
2.57k
  if (s < 0)
141
0
    return s;
142
2.57k
  int n = x_opr_n_bytes (mra, s);
143
2.57k
  if (n < 0)
144
0
    return n;
145
2.57k
  return s + n + 1;
146
2.57k
}
147
148
enum BB_MODE
149
  {
150
    BB_REG_REG_REG,
151
    BB_REG_REG_IMM,
152
    BB_REG_OPR_REG,
153
    BB_OPR_REG_REG,
154
    BB_REG_OPR_IMM,
155
    BB_OPR_REG_IMM
156
  };
157
158
struct opr_bb
159
{
160
  uint8_t mask;
161
  uint8_t value;
162
  int n_operands;
163
  bool opr;
164
  enum BB_MODE mode;
165
};
166
167
static const struct opr_bb bb_modes[] =
168
  {
169
    {0x60, 0x00, 2, false, BB_REG_REG_REG},
170
    {0x60, 0x20, 3, false, BB_REG_REG_IMM},
171
    {0x70, 0x40, 2, true,  BB_REG_OPR_REG},
172
    {0x70, 0x50, 2, true,  BB_OPR_REG_REG},
173
    {0x70, 0x60, 3, true,  BB_REG_OPR_IMM},
174
    {0x70, 0x70, 3, true,  BB_OPR_REG_IMM}
175
  };
176
177
static int
178
bfextins_n_bytes (struct mem_read_abstraction_base *mra)
179
1.12k
{
180
1.12k
  bfd_byte bb;
181
1.12k
  int status = mra->read (mra, 0, 1, &bb);
182
1.12k
  if (status < 0)
183
0
    return status;
184
185
1.12k
  size_t i;
186
1.12k
  const struct opr_bb *bbs = 0;
187
4.58k
  for (i = 0; i < sizeof (bb_modes) / sizeof (bb_modes[0]); ++i)
188
4.58k
    {
189
4.58k
      bbs = bb_modes + i;
190
4.58k
      if ((bb & bbs->mask) == bbs->value)
191
1.12k
  {
192
1.12k
    break;
193
1.12k
  }
194
4.58k
    }
195
196
1.12k
  int n = bbs->n_operands;
197
1.12k
  if (bbs->opr)
198
895
    {
199
895
      int x = x_opr_n_bytes (mra, n - 1);
200
895
      if (x < 0)
201
0
  return x;
202
895
      n += x;
203
895
    }
204
205
1.12k
  return n;
206
1.12k
}
207
208
static int
209
single (struct mem_read_abstraction_base *mra ATTRIBUTE_UNUSED)
210
253k
{
211
253k
  return 1;
212
253k
}
213
214
static int
215
two (struct mem_read_abstraction_base *mra ATTRIBUTE_UNUSED)
216
28.9k
{
217
28.9k
  return 2;
218
28.9k
}
219
220
static int
221
three (struct mem_read_abstraction_base *mra ATTRIBUTE_UNUSED)
222
26.5k
{
223
26.5k
  return 3;
224
26.5k
}
225
226
static int
227
four (struct mem_read_abstraction_base *mra ATTRIBUTE_UNUSED)
228
13.9k
{
229
13.9k
  return 4;
230
13.9k
}
231
232
static int
233
five (struct mem_read_abstraction_base *mra ATTRIBUTE_UNUSED)
234
8.89k
{
235
8.89k
  return 5;
236
8.89k
}
237
238
static int
239
pcrel_15bit (struct mem_read_abstraction_base *mra)
240
17.0k
{
241
17.0k
  bfd_byte byte;
242
17.0k
  int status = mra->read (mra, 0, 1, &byte);
243
17.0k
  if (status < 0)
244
0
    return status;
245
17.0k
  return (byte & 0x80) ? 3 : 2;
246
17.0k
}
247
248
249

250
static int
251
xysp_reg_from_postbyte (uint8_t postbyte)
252
46.4k
{
253
46.4k
  int reg = -1;
254
46.4k
  switch ((postbyte & 0x30) >> 4)
255
46.4k
    {
256
22.2k
    case 0:
257
22.2k
      reg = REG_X;
258
22.2k
      break;
259
6.03k
    case 1:
260
6.03k
      reg = REG_Y;
261
6.03k
      break;
262
14.9k
    case 2:
263
14.9k
      reg = REG_S;
264
14.9k
      break;
265
3.25k
    default:
266
3.25k
      reg = REG_P;
267
46.4k
    }
268
46.4k
  return reg;
269
46.4k
}
270
271
static struct operand *
272
create_immediate_operand (int value)
273
87.3k
{
274
87.3k
  struct immediate_operand *op = malloc (sizeof (*op));
275
276
87.3k
  if (op != NULL)
277
87.3k
    {
278
87.3k
      op->parent.cl = OPND_CL_IMMEDIATE;
279
87.3k
      op->parent.osize = -1;
280
87.3k
      op->value = value;
281
87.3k
    }
282
87.3k
  return (struct operand *) op;
283
87.3k
}
284
285
static struct operand *
286
create_bitfield_operand (int width, int offset)
287
713
{
288
713
  struct bitfield_operand *op = malloc (sizeof (*op));
289
290
713
  if (op != NULL)
291
713
    {
292
713
      op->parent.cl = OPND_CL_BIT_FIELD;
293
713
      op->parent.osize = -1;
294
713
      op->width = width;
295
713
      op->offset = offset;
296
713
    }
297
713
  return (struct operand *) op;
298
713
}
299
300
static struct operand *
301
create_register_operand_with_size (int reg, short osize)
302
298k
{
303
298k
  struct register_operand *op = malloc (sizeof (*op));
304
305
298k
  if (op != NULL)
306
298k
    {
307
298k
      op->parent.cl = OPND_CL_REGISTER;
308
298k
      op->parent.osize = osize;
309
298k
      op->reg = reg;
310
298k
    }
311
298k
  return (struct operand *) op;
312
298k
}
313
314
static struct operand *
315
create_register_operand (int reg)
316
283k
{
317
283k
  return create_register_operand_with_size (reg, -1);
318
283k
}
319
320
static struct operand *
321
create_register_all_operand (void)
322
2.87k
{
323
2.87k
  struct register_operand *op = malloc (sizeof (*op));
324
325
2.87k
  if (op != NULL)
326
2.87k
    {
327
2.87k
      op->parent.cl = OPND_CL_REGISTER_ALL;
328
2.87k
      op->parent.osize = -1;
329
2.87k
    }
330
2.87k
  return (struct operand *) op;
331
2.87k
}
332
333
static struct operand *
334
create_register_all16_operand (void)
335
646
{
336
646
  struct register_operand *op = malloc (sizeof (*op));
337
338
646
  if (op != NULL)
339
646
    {
340
646
      op->parent.cl = OPND_CL_REGISTER_ALL16;
341
646
      op->parent.osize = -1;
342
646
    }
343
646
  return (struct operand *) op;
344
646
}
345
346
347
static struct operand *
348
create_simple_memory_operand (bfd_vma addr, bfd_vma base, bool relative)
349
88.8k
{
350
88.8k
  struct simple_memory_operand *op;
351
352
88.8k
  assert (relative || base == 0);
353
88.8k
  op = malloc (sizeof (*op));
354
88.8k
  if (op != NULL)
355
88.8k
    {
356
88.8k
      op->parent.cl = OPND_CL_SIMPLE_MEMORY;
357
88.8k
      op->parent.osize = -1;
358
88.8k
      op->addr = addr;
359
88.8k
      op->base = base;
360
88.8k
      op->relative = relative;
361
88.8k
    }
362
88.8k
  return (struct operand *) op;
363
88.8k
}
364
365
static struct operand *
366
create_memory_operand (bool indirect, int base, int n_regs, int reg0, int reg1)
367
76.7k
{
368
76.7k
  struct memory_operand *op = malloc (sizeof (*op));
369
370
76.7k
  if (op != NULL)
371
76.7k
    {
372
76.7k
      op->parent.cl = OPND_CL_MEMORY;
373
76.7k
      op->parent.osize = -1;
374
76.7k
      op->indirect = indirect;
375
76.7k
      op->base_offset = base;
376
76.7k
      op->mutation = OPND_RM_NONE;
377
76.7k
      op->n_regs = n_regs;
378
76.7k
      op->regs[0] = reg0;
379
76.7k
      op->regs[1] = reg1;
380
76.7k
    }
381
76.7k
  return (struct operand *) op;
382
76.7k
}
383
384
static struct operand *
385
create_memory_auto_operand (enum op_reg_mutation mutation, int reg)
386
9.24k
{
387
9.24k
  struct memory_operand *op = malloc (sizeof (*op));
388
389
9.24k
  if (op != NULL)
390
9.24k
    {
391
9.24k
      op->parent.cl = OPND_CL_MEMORY;
392
9.24k
      op->parent.osize = -1;
393
9.24k
      op->indirect = false;
394
9.24k
      op->base_offset = 0;
395
9.24k
      op->mutation = mutation;
396
9.24k
      op->n_regs = 1;
397
9.24k
      op->regs[0] = reg;
398
9.24k
      op->regs[1] = -1;
399
9.24k
    }
400
9.24k
  return (struct operand *) op;
401
9.24k
}
402
403

404
405
static int
406
z_ext24_decode (struct mem_read_abstraction_base *mra, int *n_operands,
407
    struct operand **operand)
408
10.4k
{
409
10.4k
  struct operand *op;
410
10.4k
  uint8_t buffer[3];
411
10.4k
  int status = mra->read (mra, 0, 3, buffer);
412
10.4k
  if (status < 0)
413
32
    return status;
414
415
10.4k
  int i;
416
10.4k
  uint32_t addr = 0;
417
41.8k
  for (i = 0; i < 3; ++i)
418
31.3k
    {
419
31.3k
      addr <<= 8;
420
31.3k
      addr |= buffer[i];
421
31.3k
    }
422
423
10.4k
  op = create_simple_memory_operand (addr, 0, false);
424
10.4k
  if (op == NULL)
425
0
    return -1;
426
10.4k
  operand[(*n_operands)++] = op;
427
10.4k
  return 0;
428
10.4k
}
429
430
431
static int
432
z_decode_signed_value (struct mem_read_abstraction_base *mra, int offset,
433
           short size, uint32_t *result)
434
54.0k
{
435
54.0k
  assert (size >0);
436
54.0k
  assert (size <= 4);
437
54.0k
  bfd_byte buffer[4];
438
54.0k
  int status = mra->read (mra, offset, size, buffer);
439
54.0k
  if (status < 0)
440
112
    return status;
441
442
53.9k
  int i;
443
53.9k
  uint32_t value = 0;
444
178k
  for (i = 0; i < size; ++i)
445
125k
    value = (value << 8) | buffer[i];
446
447
53.9k
  if (buffer[0] & 0x80)
448
20.2k
    {
449
      /* Deal with negative values */
450
20.2k
      value -= 1u << (size * 4) << (size * 4);
451
20.2k
    }
452
53.9k
  *result = value;
453
53.9k
  return 0;
454
54.0k
}
455
456
static int
457
decode_signed_value (struct mem_read_abstraction_base *mra, short size,
458
         uint32_t *result)
459
49.6k
{
460
49.6k
  return z_decode_signed_value (mra, 0, size, result);
461
49.6k
}
462
463
static int
464
x_imm1 (struct mem_read_abstraction_base *mra,
465
  int offset,
466
  int *n_operands, struct operand **operand)
467
4.08k
{
468
4.08k
  struct operand *op;
469
4.08k
  bfd_byte byte;
470
4.08k
  int status = mra->read (mra, offset, 1, &byte);
471
4.08k
  if (status < 0)
472
1
    return status;
473
474
4.08k
  op = create_immediate_operand (byte);
475
4.08k
  if (op == NULL)
476
0
    return -1;
477
4.08k
  operand[(*n_operands)++] = op;
478
4.08k
  return 0;
479
4.08k
}
480
481
/* An eight bit immediate operand.  */
482
static int
483
imm1_decode (struct mem_read_abstraction_base *mra,
484
       int *n_operands, struct operand **operand)
485
3.67k
{
486
3.67k
  return x_imm1 (mra, 0, n_operands, operand);
487
3.67k
}
488
489
static int
490
trap_decode (struct mem_read_abstraction_base *mra,
491
       int *n_operands, struct operand **operand)
492
405
{
493
405
  return x_imm1 (mra, -1, n_operands, operand);
494
405
}
495
496
497
static struct operand *
498
x_opr_decode_with_size (struct mem_read_abstraction_base *mra, int offset,
499
      short osize)
500
142k
{
501
142k
  bfd_byte postbyte;
502
142k
  int status = mra->read (mra, offset, 1, &postbyte);
503
142k
  if (status < 0)
504
101
    return NULL;
505
142k
  offset++;
506
507
142k
  enum OPR_MODE mode = -1;
508
142k
  size_t i;
509
1.46M
  for (i = 0; i < sizeof (opr_pb) / sizeof (opr_pb[0]); ++i)
510
1.46M
    {
511
1.46M
      const struct opr_pb *pb = opr_pb + i;
512
1.46M
      if ((postbyte & pb->mask) == pb->value)
513
142k
  {
514
142k
    mode = pb->mode;
515
142k
    break;
516
142k
  }
517
1.46M
    }
518
519
142k
  struct operand *operand = NULL;
520
142k
  switch (mode)
521
142k
    {
522
5.91k
    case OPR_IMMe4:
523
5.91k
      {
524
5.91k
  int n;
525
5.91k
  uint8_t x = (postbyte & 0x0F);
526
5.91k
  if (x == 0)
527
565
    n = -1;
528
5.34k
  else
529
5.34k
    n = x;
530
531
5.91k
  operand = create_immediate_operand (n);
532
5.91k
  break;
533
0
      }
534
2.71k
    case OPR_REG:
535
2.71k
      {
536
2.71k
  uint8_t x = (postbyte & 0x07);
537
2.71k
  operand = create_register_operand (x);
538
2.71k
  break;
539
0
      }
540
29.5k
    case OPR_OFXYS:
541
29.5k
      {
542
29.5k
  operand = create_memory_operand (false, postbyte & 0x0F, 1,
543
29.5k
           xysp_reg_from_postbyte (postbyte), -1);
544
29.5k
  break;
545
0
      }
546
6.28k
    case OPR_REG_DIRECT:
547
6.28k
      {
548
6.28k
  operand = create_memory_operand (false, 0, 2, postbyte & 0x07,
549
6.28k
           xysp_reg_from_postbyte (postbyte));
550
6.28k
  break;
551
0
      }
552
14.1k
    case OPR_REG_INDIRECT:
553
14.1k
      {
554
14.1k
  operand = create_memory_operand (true, 0, 2, postbyte & 0x07,
555
14.1k
           (postbyte & 0x10) ? REG_Y : REG_X);
556
14.1k
  break;
557
0
      }
558
559
3.35k
    case OPR_IDX_INDIRECT:
560
3.35k
      {
561
3.35k
  uint8_t x1;
562
3.35k
  status = mra->read (mra, offset, 1, &x1);
563
3.35k
  if (status < 0)
564
14
    return NULL;
565
3.33k
  int idx = x1;
566
567
3.33k
  if (postbyte & 0x01)
568
1.39k
    {
569
      /* Deal with negative values */
570
1.39k
      idx -= 0x1UL << 8;
571
1.39k
    }
572
573
3.33k
  operand = create_memory_operand (true, idx, 1,
574
3.33k
           xysp_reg_from_postbyte (postbyte), -1);
575
3.33k
  break;
576
3.35k
      }
577
578
2.02k
    case OPR_IDX3_DIRECT:
579
2.02k
      {
580
2.02k
  uint8_t x[3];
581
2.02k
  status = mra->read (mra, offset, 3, x);
582
2.02k
  if (status < 0)
583
15
    return NULL;
584
2.01k
  int idx = x[0] << 16 | x[1] << 8 | x[2];
585
586
2.01k
  if (x[0] & 0x80)
587
915
    {
588
      /* Deal with negative values */
589
915
      idx -= 0x1UL << 24;
590
915
    }
591
592
2.01k
  operand = create_memory_operand (false, idx, 1,
593
2.01k
           xysp_reg_from_postbyte (postbyte), -1);
594
2.01k
  break;
595
2.02k
      }
596
597
2.54k
    case OPR_IDX3_DIRECT_REG:
598
2.54k
      {
599
2.54k
  uint8_t x[3];
600
2.54k
  status = mra->read (mra, offset, 3, x);
601
2.54k
  if (status < 0)
602
21
    return NULL;
603
2.52k
  int idx = x[0] << 16 | x[1] << 8 | x[2];
604
605
2.52k
  if (x[0] & 0x80)
606
1.70k
    {
607
      /* Deal with negative values */
608
1.70k
      idx -= 0x1UL << 24;
609
1.70k
    }
610
611
2.52k
  operand = create_memory_operand (false, idx, 1, postbyte & 0x07, -1);
612
2.52k
  break;
613
2.54k
      }
614
615
1.54k
    case OPR_IDX3_INDIRECT:
616
1.54k
      {
617
1.54k
  uint8_t x[3];
618
1.54k
  status = mra->read (mra, offset, 3, x);
619
1.54k
  if (status < 0)
620
13
    return NULL;
621
1.52k
  int idx = x[0] << 16 | x[1] << 8 | x[2];
622
623
1.52k
  if (x[0] & 0x80)
624
1.21k
    {
625
      /* Deal with negative values */
626
1.21k
      idx -= 0x1UL << 24;
627
1.21k
    }
628
629
1.52k
  operand = create_memory_operand (true, idx, 1,
630
1.52k
           xysp_reg_from_postbyte (postbyte), -1);
631
1.52k
  break;
632
1.54k
      }
633
634
3.76k
    case OPR_IDX_DIRECT:
635
3.76k
      {
636
3.76k
  uint8_t x1;
637
3.76k
  status = mra->read (mra, offset, 1, &x1);
638
3.76k
  if (status < 0)
639
3
    return NULL;
640
3.76k
  int idx = x1;
641
642
3.76k
  if (postbyte & 0x01)
643
1.67k
    {
644
      /* Deal with negative values */
645
1.67k
      idx -= 0x1UL << 8;
646
1.67k
    }
647
648
3.76k
  operand = create_memory_operand (false, idx, 1,
649
3.76k
           xysp_reg_from_postbyte (postbyte), -1);
650
3.76k
  break;
651
3.76k
      }
652
653
10.1k
    case OPR_IDX2_REG:
654
10.1k
      {
655
10.1k
  uint8_t x[2];
656
10.1k
  status = mra->read (mra, offset, 2, x);
657
10.1k
  if (status < 0)
658
19
    return NULL;
659
10.1k
  uint32_t idx = x[1] | x[0] << 8 ;
660
10.1k
  idx |= (postbyte & 0x30) << 12;
661
662
10.1k
  operand = create_memory_operand (false, idx, 1, postbyte & 0x07, -1);
663
10.1k
  break;
664
10.1k
      }
665
666
3.43k
    case OPR_XY_PRE_INC:
667
3.43k
      {
668
3.43k
  operand = create_memory_auto_operand (OPND_RM_PRE_INC,
669
3.43k
                (postbyte & 0x10) ? REG_Y: REG_X);
670
3.43k
  break;
671
10.1k
      }
672
428
    case OPR_XY_POST_INC:
673
428
      {
674
428
  operand = create_memory_auto_operand (OPND_RM_POST_INC,
675
428
                (postbyte & 0x10) ? REG_Y: REG_X);
676
428
  break;
677
10.1k
      }
678
354
    case OPR_XY_PRE_DEC:
679
354
      {
680
354
  operand = create_memory_auto_operand (OPND_RM_PRE_DEC,
681
354
                (postbyte & 0x10) ? REG_Y: REG_X);
682
354
  break;
683
10.1k
      }
684
1.18k
    case OPR_XY_POST_DEC:
685
1.18k
      {
686
1.18k
  operand = create_memory_auto_operand (OPND_RM_POST_DEC,
687
1.18k
                (postbyte & 0x10) ? REG_Y: REG_X);
688
1.18k
  break;
689
10.1k
      }
690
101
    case OPR_S_PRE_DEC:
691
101
      {
692
101
  operand = create_memory_auto_operand (OPND_RM_PRE_DEC, REG_S);
693
101
  break;
694
10.1k
      }
695
3.74k
    case OPR_S_POST_INC:
696
3.74k
      {
697
3.74k
  operand = create_memory_auto_operand (OPND_RM_POST_INC, REG_S);
698
3.74k
  break;
699
10.1k
      }
700
701
2.34k
    case OPR_EXT18:
702
2.34k
      {
703
2.34k
  const size_t size = 2;
704
2.34k
  bfd_byte buffer[4];
705
2.34k
  status = mra->read (mra, offset, size, buffer);
706
2.34k
  if (status < 0)
707
6
    return NULL;
708
709
2.34k
  uint32_t ext18 = 0;
710
7.02k
  for (i = 0; i < size; ++i)
711
4.68k
    {
712
4.68k
      ext18 <<= 8;
713
4.68k
      ext18 |= buffer[i];
714
4.68k
    }
715
716
2.34k
  ext18 |= (postbyte & 0x01) << 16;
717
2.34k
  ext18 |= (postbyte & 0x04) << 15;
718
719
2.34k
  operand = create_simple_memory_operand (ext18, 0, false);
720
2.34k
  break;
721
2.34k
      }
722
723
48.0k
    case OPR_EXT1:
724
48.0k
      {
725
48.0k
  uint8_t x1 = 0;
726
48.0k
  status = mra->read (mra, offset, 1, &x1);
727
48.0k
  if (status < 0)
728
45
    return NULL;
729
47.9k
  int16_t addr;
730
47.9k
  addr = x1;
731
47.9k
  addr |= (postbyte & 0x3f) << 8;
732
733
47.9k
  operand = create_simple_memory_operand (addr, 0, false);
734
47.9k
  break;
735
48.0k
      }
736
737
445
    case OPR_EXT3_DIRECT:
738
445
      {
739
445
  const size_t size = 3;
740
445
  bfd_byte buffer[4];
741
445
  status = mra->read (mra, offset, size, buffer);
742
445
  if (status < 0)
743
7
    return NULL;
744
745
438
  uint32_t ext24 = 0;
746
1.75k
  for (i = 0; i < size; ++i)
747
1.31k
    {
748
1.31k
      ext24 |= buffer[i] << (8 * (size - i - 1));
749
1.31k
    }
750
751
438
  operand = create_simple_memory_operand (ext24, 0, false);
752
438
  break;
753
445
      }
754
755
682
    case OPR_EXT3_INDIRECT:
756
682
      {
757
682
  const size_t size = 3;
758
682
  bfd_byte buffer[4];
759
682
  status = mra->read (mra, offset, size, buffer);
760
682
  if (status < 0)
761
15
    return NULL;
762
763
667
  uint32_t ext24 = 0;
764
2.66k
  for (i = 0; i < size; ++i)
765
2.00k
    {
766
2.00k
      ext24 |= buffer[i] << (8 * (size - i - 1));
767
2.00k
    }
768
769
667
  operand = create_memory_operand (true, ext24, 0, -1, -1);
770
667
  break;
771
682
      }
772
773
0
    default:
774
0
      printf ("Unknown OPR mode #0x%x (%d)", postbyte, mode);
775
0
      abort ();
776
142k
    }
777
778
142k
  if (operand != NULL)
779
142k
    operand->osize = osize;
780
781
142k
  return operand;
782
142k
}
783
784
static struct operand *
785
x_opr_decode (struct mem_read_abstraction_base *mra, int offset)
786
117k
{
787
117k
  return x_opr_decode_with_size (mra, offset, -1);
788
117k
}
789
790
static int
791
z_opr_decode (struct mem_read_abstraction_base *mra,
792
        int *n_operands, struct operand **operand)
793
89.6k
{
794
89.6k
  struct operand *op = x_opr_decode (mra, 0);
795
89.6k
  if (op == NULL)
796
135
    return -1;
797
89.4k
  operand[(*n_operands)++] = op;
798
89.4k
  return 0;
799
89.6k
}
800
801
static int
802
z_opr_decode2 (struct mem_read_abstraction_base *mra,
803
         int *n_operands, struct operand **operand)
804
2.60k
{
805
2.60k
  int n = x_opr_n_bytes (mra, 0);
806
2.60k
  if (n < 0)
807
3
    return n;
808
2.60k
  struct operand *op = x_opr_decode (mra, 0);
809
2.60k
  if (op == NULL)
810
11
    return -1;
811
2.58k
  operand[(*n_operands)++] = op;
812
2.58k
  op = x_opr_decode (mra, n);
813
2.58k
  if (op == NULL)
814
17
    return -1;
815
2.57k
  operand[(*n_operands)++] = op;
816
2.57k
  return 0;
817
2.58k
}
818
819
static int
820
imm1234 (struct mem_read_abstraction_base *mra, int base,
821
   int *n_operands, struct operand **operand)
822
42.0k
{
823
42.0k
  struct operand *op;
824
42.0k
  bfd_byte opcode;
825
42.0k
  int status = mra->read (mra, -1, 1, &opcode);
826
42.0k
  if (status < 0)
827
0
    return status;
828
829
42.0k
  opcode -= base;
830
831
42.0k
  int size = registers[opcode & 0xF].bytes;
832
833
42.0k
  uint32_t imm;
834
42.0k
  if (decode_signed_value (mra, size, &imm) < 0)
835
72
    return -1;
836
837
41.9k
  op = create_immediate_operand (imm);
838
41.9k
  if (op == NULL)
839
0
    return -1;
840
41.9k
  operand[(*n_operands)++] = op;
841
41.9k
  return 0;
842
41.9k
}
843
844
845
/* Special case of LD and CMP with register S and IMM operand */
846
static int
847
reg_s_imm (struct mem_read_abstraction_base *mra, int *n_operands,
848
     struct operand **operand)
849
1.00k
{
850
1.00k
  struct operand *op;
851
852
1.00k
  op = create_register_operand (REG_S);
853
1.00k
  if (op == NULL)
854
0
    return -1;
855
1.00k
  operand[(*n_operands)++] = op;
856
857
1.00k
  uint32_t imm;
858
1.00k
  if (decode_signed_value (mra, 3, &imm) < 0)
859
3
    return -1;
860
1.00k
  op = create_immediate_operand (imm);
861
1.00k
  if (op == NULL)
862
0
    return -1;
863
1.00k
  operand[(*n_operands)++] = op;
864
1.00k
  return 0;
865
1.00k
}
866
867
/* Special case of LD, CMP and ST with register S and OPR operand */
868
static int
869
reg_s_opr (struct mem_read_abstraction_base *mra, int *n_operands,
870
     struct operand **operand)
871
546
{
872
546
  struct operand *op;
873
874
546
  op = create_register_operand (REG_S);
875
546
  if (op == NULL)
876
0
    return -1;
877
546
  operand[(*n_operands)++] = op;
878
546
  op = x_opr_decode (mra, 0);
879
546
  if (op == NULL)
880
0
    return -1;
881
546
  operand[(*n_operands)++] = op;
882
546
  return 0;
883
546
}
884
885
static int
886
z_imm1234_8base (struct mem_read_abstraction_base *mra, int *n_operands,
887
     struct operand **operand)
888
11.3k
{
889
11.3k
  return imm1234 (mra, 8, n_operands, operand);
890
11.3k
}
891
892
static int
893
z_imm1234_0base (struct mem_read_abstraction_base *mra, int *n_operands,
894
     struct operand **operand)
895
30.7k
{
896
30.7k
  return imm1234 (mra, 0, n_operands, operand);
897
30.7k
}
898
899
900
static int
901
z_tfr (struct mem_read_abstraction_base *mra, int *n_operands,
902
       struct operand **operand)
903
1.03k
{
904
1.03k
  struct operand *op;
905
1.03k
  bfd_byte byte;
906
1.03k
  int status = mra->read (mra, 0, 1, &byte);
907
1.03k
  if (status < 0)
908
1
    return status;
909
910
1.02k
  op = create_register_operand (byte >> 4);
911
1.02k
  if (op == NULL)
912
0
    return -1;
913
1.02k
  operand[(*n_operands)++] = op;
914
1.02k
  op = create_register_operand (byte & 0x0F);
915
1.02k
  if (op == NULL)
916
0
    return -1;
917
1.02k
  operand[(*n_operands)++] = op;
918
1.02k
  return 0;
919
1.02k
}
920
921
static int
922
z_reg (struct mem_read_abstraction_base *mra, int *n_operands,
923
       struct operand **operand)
924
157k
{
925
157k
  struct operand *op;
926
157k
  bfd_byte byte;
927
157k
  int status = mra->read (mra, -1, 1, &byte);
928
157k
  if (status < 0)
929
0
    return status;
930
931
157k
  op = create_register_operand (byte & 0x07);
932
157k
  if (op == NULL)
933
0
    return -1;
934
157k
  operand[(*n_operands)++] = op;
935
157k
  return 0;
936
157k
}
937
938
939
static int
940
reg_xy (struct mem_read_abstraction_base *mra,
941
  int *n_operands, struct operand **operand)
942
15.9k
{
943
15.9k
  struct operand *op;
944
15.9k
  bfd_byte byte;
945
15.9k
  int status = mra->read (mra, -1, 1, &byte);
946
15.9k
  if (status < 0)
947
0
    return status;
948
949
15.9k
  op = create_register_operand ((byte & 0x01) ? REG_Y : REG_X);
950
15.9k
  if (op == NULL)
951
0
    return -1;
952
15.9k
  operand[(*n_operands)++] = op;
953
15.9k
  return 0;
954
15.9k
}
955
956
static int
957
lea_reg_xys_opr (struct mem_read_abstraction_base *mra,
958
     int *n_operands, struct operand **operand)
959
7.21k
{
960
7.21k
  struct operand *op;
961
7.21k
  bfd_byte byte;
962
7.21k
  int status = mra->read (mra, -1, 1, &byte);
963
7.21k
  if (status < 0)
964
0
    return status;
965
966
7.21k
  int reg_xys = -1;
967
7.21k
  switch (byte & 0x03)
968
7.21k
    {
969
2.19k
    case 0x00:
970
2.19k
      reg_xys = REG_X;
971
2.19k
      break;
972
4.00k
    case 0x01:
973
4.00k
      reg_xys = REG_Y;
974
4.00k
      break;
975
1.01k
    case 0x02:
976
1.01k
      reg_xys = REG_S;
977
1.01k
      break;
978
7.21k
    }
979
980
7.21k
  op = create_register_operand (reg_xys);
981
7.21k
  if (op == NULL)
982
0
    return -1;
983
7.21k
  operand[(*n_operands)++] = op;
984
7.21k
  op = x_opr_decode (mra, 0);
985
7.21k
  if (op == NULL)
986
10
    return -1;
987
7.20k
  operand[(*n_operands)++] = op;
988
7.20k
  return 0;
989
7.21k
}
990
991
static int
992
lea_reg_xys (struct mem_read_abstraction_base *mra,
993
       int *n_operands, struct operand **operand)
994
2.86k
{
995
2.86k
  struct operand *op;
996
2.86k
  bfd_byte byte;
997
2.86k
  int status = mra->read (mra, -1, 1, &byte);
998
2.86k
  if (status < 0)
999
0
    return status;
1000
1001
2.86k
  int reg_n = -1;
1002
2.86k
  switch (byte & 0x03)
1003
2.86k
    {
1004
532
    case 0x00:
1005
532
      reg_n = REG_X;
1006
532
      break;
1007
961
    case 0x01:
1008
961
      reg_n = REG_Y;
1009
961
      break;
1010
1.37k
    case 0x02:
1011
1.37k
      reg_n = REG_S;
1012
1.37k
      break;
1013
2.86k
    }
1014
1015
2.86k
  status = mra->read (mra, 0, 1, &byte);
1016
2.86k
  if (status < 0)
1017
11
    return status;
1018
1019
2.85k
  op = create_register_operand (reg_n);
1020
2.85k
  if (op == NULL)
1021
0
    return -1;
1022
2.85k
  operand[(*n_operands)++] = op;
1023
2.85k
  op = create_memory_operand (false, (int8_t) byte, 1, reg_n, -1);
1024
2.85k
  if (op == NULL)
1025
0
    return -1;
1026
2.85k
  operand[(*n_operands)++] = op;
1027
2.85k
  return 0;
1028
2.85k
}
1029
1030
1031
/* PC Relative offsets of size 15 or 7 bits */
1032
static int
1033
rel_15_7 (struct mem_read_abstraction_base *mra, int offset,
1034
    int *n_operands, struct operand **operands)
1035
27.6k
{
1036
27.6k
  struct operand *op;
1037
27.6k
  bfd_byte upper;
1038
27.6k
  int status = mra->read (mra, offset - 1, 1, &upper);
1039
27.6k
  if (status < 0)
1040
18
    return status;
1041
1042
27.6k
  bool rel_size = (upper & 0x80);
1043
1044
27.6k
  int16_t addr = upper;
1045
27.6k
  if (rel_size)
1046
7.13k
    {
1047
      /* 15 bits.  Get the next byte */
1048
7.13k
      bfd_byte lower;
1049
7.13k
      status = mra->read (mra, offset, 1, &lower);
1050
7.13k
      if (status < 0)
1051
5
  return status;
1052
1053
7.12k
      addr <<= 8;
1054
7.12k
      addr |= lower;
1055
7.12k
      addr &= 0x7FFF;
1056
1057
7.12k
      bool negative = (addr & 0x4000);
1058
7.12k
      addr &= 0x3FFF;
1059
7.12k
      if (negative)
1060
4.85k
  addr = addr - 0x4000;
1061
7.12k
    }
1062
20.5k
  else
1063
20.5k
    {
1064
      /* 7 bits. */
1065
20.5k
      bool negative = (addr & 0x40);
1066
20.5k
      addr &= 0x3F;
1067
20.5k
      if (negative)
1068
5.09k
  addr = addr - 0x40;
1069
20.5k
    }
1070
1071
27.6k
  op = create_simple_memory_operand (addr, mra->posn (mra) - 1, true);
1072
27.6k
  if (op == NULL)
1073
0
    return -1;
1074
27.6k
  operands[(*n_operands)++] = op;
1075
27.6k
  return 0;
1076
27.6k
}
1077
1078
1079
/* PC Relative offsets of size 15 or 7 bits */
1080
static int
1081
decode_rel_15_7 (struct mem_read_abstraction_base *mra,
1082
     int *n_operands, struct operand **operand)
1083
17.0k
{
1084
17.0k
  return rel_15_7 (mra, 1, n_operands, operand);
1085
17.0k
}
1086
1087
static int shift_n_bytes (struct mem_read_abstraction_base *);
1088
static int mov_imm_opr_n_bytes (struct mem_read_abstraction_base *);
1089
static int loop_prim_n_bytes (struct mem_read_abstraction_base *);
1090
static int bm_rel_n_bytes (struct mem_read_abstraction_base *);
1091
static int mul_n_bytes (struct mem_read_abstraction_base *);
1092
static int bm_n_bytes (struct mem_read_abstraction_base *);
1093
1094
static int psh_pul_decode (struct mem_read_abstraction_base *mra, int *n_operands, struct operand **operand);
1095
static int shift_decode (struct mem_read_abstraction_base *mra, int *n_operands, struct operand **operand);
1096
static int mul_decode (struct mem_read_abstraction_base *mra, int *n_operands, struct operand **operand);
1097
static int bm_decode (struct mem_read_abstraction_base *mra, int *n_operands, struct operand **operand);
1098
static int bm_rel_decode (struct mem_read_abstraction_base *mra, int *n_operands, struct operand **operand);
1099
static int mov_imm_opr (struct mem_read_abstraction_base *mra, int *n_operands, struct operand **operand);
1100
static int loop_primitive_decode (struct mem_read_abstraction_base *mra, int *n_operands, struct operand **operands);
1101
static int bit_field_decode (struct mem_read_abstraction_base *mra, int *n_operands, struct operand **operands);
1102
static int exg_sex_decode (struct mem_read_abstraction_base *mra, int *n_operands, struct operand **operands);
1103
1104
1105
static enum optr shift_discrim (struct mem_read_abstraction_base *mra, enum optr hint);
1106
static enum optr psh_pul_discrim (struct mem_read_abstraction_base *mra, enum optr hint);
1107
static enum optr mul_discrim (struct mem_read_abstraction_base *mra, enum optr hint);
1108
static enum optr loop_primitive_discrim (struct mem_read_abstraction_base *mra, enum optr hint);
1109
static enum optr bit_field_discrim (struct mem_read_abstraction_base *mra, enum optr hint);
1110
static enum optr exg_sex_discrim (struct mem_read_abstraction_base *mra, enum optr hint);
1111
1112
1113
static int
1114
cmp_xy (struct mem_read_abstraction_base *mra ATTRIBUTE_UNUSED,
1115
  int *n_operands, struct operand **operand)
1116
5.15k
{
1117
5.15k
  struct operand *op;
1118
1119
5.15k
  op = create_register_operand (REG_X);
1120
5.15k
  if (op == NULL)
1121
0
    return -1;
1122
5.15k
  operand[(*n_operands)++] = op;
1123
5.15k
  op = create_register_operand (REG_Y);
1124
5.15k
  if (op == NULL)
1125
0
    return -1;
1126
5.15k
  operand[(*n_operands)++] = op;
1127
5.15k
  return 0;
1128
5.15k
}
1129
1130
static int
1131
sub_d6_x_y (struct mem_read_abstraction_base *mra ATTRIBUTE_UNUSED,
1132
      int *n_operands, struct operand **operand)
1133
3.67k
{
1134
3.67k
  struct operand *op;
1135
1136
3.67k
  op = create_register_operand (REG_D6);
1137
3.67k
  if (op == NULL)
1138
0
    return -1;
1139
3.67k
  operand[(*n_operands)++] = op;
1140
3.67k
  op = create_register_operand (REG_X);
1141
3.67k
  if (op == NULL)
1142
0
    return -1;
1143
3.67k
  operand[(*n_operands)++] = op;
1144
3.67k
  op = create_register_operand (REG_Y);
1145
3.67k
  if (op == NULL)
1146
0
    return -1;
1147
3.67k
  operand[(*n_operands)++] = op;
1148
3.67k
  return 0;
1149
3.67k
}
1150
1151
static int
1152
sub_d6_y_x (struct mem_read_abstraction_base *mra ATTRIBUTE_UNUSED,
1153
      int *n_operands, struct operand **operand)
1154
1.62k
{
1155
1.62k
  struct operand *op;
1156
1157
1.62k
  op = create_register_operand (REG_D6);
1158
1.62k
  if (op == NULL)
1159
0
    return -1;
1160
1.62k
  operand[(*n_operands)++] = op;
1161
1.62k
  op = create_register_operand (REG_Y);
1162
1.62k
  if (op == NULL)
1163
0
    return -1;
1164
1.62k
  operand[(*n_operands)++] = op;
1165
1.62k
  op = create_register_operand (REG_X);
1166
1.62k
  if (op == NULL)
1167
0
    return -1;
1168
1.62k
  operand[(*n_operands)++] = op;
1169
1.62k
  return 0;
1170
1.62k
}
1171
1172
static int
1173
ld_18bit_decode (struct mem_read_abstraction_base *mra, int *n_operands,
1174
     struct operand **operand);
1175
1176
static enum optr
1177
mul_discrim (struct mem_read_abstraction_base *mra, enum optr hint)
1178
16.0k
{
1179
16.0k
  uint8_t mb;
1180
16.0k
  int status = mra->read (mra, 0, 1, &mb);
1181
16.0k
  if (status < 0)
1182
31
    return OP_INVALID;
1183
1184
16.0k
  bool signed_op = (mb & 0x80);
1185
1186
16.0k
  switch (hint)
1187
16.0k
    {
1188
14.6k
    case OPBASE_mul:
1189
14.6k
      return signed_op ? OP_muls : OP_mulu;
1190
0
      break;
1191
35
    case OPBASE_div:
1192
35
      return signed_op ? OP_divs : OP_divu;
1193
0
      break;
1194
744
    case OPBASE_mod:
1195
744
      return signed_op ? OP_mods : OP_modu;
1196
0
      break;
1197
559
    case OPBASE_mac:
1198
559
      return signed_op ? OP_macs : OP_macu;
1199
0
      break;
1200
20
    case OPBASE_qmul:
1201
20
      return signed_op ? OP_qmuls : OP_qmulu;
1202
0
      break;
1203
0
    default:
1204
0
      abort ();
1205
16.0k
    }
1206
1207
0
  return OP_INVALID;
1208
16.0k
}
1209
1210
struct opcode
1211
{
1212
  /* The operation that this opcode performs.  */
1213
  enum optr operator;
1214
1215
  /* The size of this operation.  May be -1 if it is implied
1216
     in the operands or if size is not applicable.  */
1217
  short osize;
1218
1219
  /* Some operations need this function to work out which operation
1220
   is intended.  */
1221
  discriminator_f discriminator;
1222
1223
  /* A function returning the number of bytes in this instruction.  */
1224
  insn_bytes_f insn_bytes;
1225
1226
  operands_f operands;
1227
  operands_f operands2;
1228
};
1229
1230
static const struct opcode page2[] =
1231
  {
1232
    [0x00] = {OP_ld, -1, 0,  opr_n_bytes_p1, reg_s_opr, 0},
1233
    [0x01] = {OP_st, -1, 0,  opr_n_bytes_p1, reg_s_opr, 0},
1234
    [0x02] = {OP_cmp, -1, 0, opr_n_bytes_p1, reg_s_opr, 0},
1235
    [0x03] = {OP_ld, -1, 0,  four, reg_s_imm, 0},
1236
    [0x04] = {OP_cmp, -1, 0, four, reg_s_imm, 0},
1237
    [0x05] = {OP_stop, -1, 0, single, 0, 0},
1238
    [0x06] = {OP_wai, -1, 0,  single, 0, 0},
1239
    [0x07] = {OP_sys, -1, 0,  single, 0, 0},
1240
    [0x08] = {0xFFFF, -1, bit_field_discrim,  bfextins_n_bytes, bit_field_decode, 0},  /* BFEXT / BFINS */
1241
    [0x09] = {0xFFFF, -1, bit_field_discrim,  bfextins_n_bytes, bit_field_decode, 0},
1242
    [0x0a] = {0xFFFF, -1, bit_field_discrim,  bfextins_n_bytes, bit_field_decode, 0},
1243
    [0x0b] = {0xFFFF, -1, bit_field_discrim,  bfextins_n_bytes, bit_field_decode, 0},
1244
    [0x0c] = {0xFFFF, -1, bit_field_discrim,  bfextins_n_bytes, bit_field_decode, 0},
1245
    [0x0d] = {0xFFFF, -1, bit_field_discrim,  bfextins_n_bytes, bit_field_decode, 0},
1246
    [0x0e] = {0xFFFF, -1, bit_field_discrim,  bfextins_n_bytes, bit_field_decode, 0},
1247
    [0x0f] = {0xFFFF, -1, bit_field_discrim,  bfextins_n_bytes, bit_field_decode, 0},
1248
    [0x10] = {OP_minu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1249
    [0x11] = {OP_minu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1250
    [0x12] = {OP_minu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1251
    [0x13] = {OP_minu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1252
    [0x14] = {OP_minu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1253
    [0x15] = {OP_minu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1254
    [0x16] = {OP_minu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1255
    [0x17] = {OP_minu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1256
    [0x18] = {OP_maxu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1257
    [0x19] = {OP_maxu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1258
    [0x1a] = {OP_maxu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1259
    [0x1b] = {OP_maxu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1260
    [0x1c] = {OP_maxu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1261
    [0x1d] = {OP_maxu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1262
    [0x1e] = {OP_maxu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1263
    [0x1f] = {OP_maxu, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1264
    [0x20] = {OP_mins, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1265
    [0x21] = {OP_mins, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1266
    [0x22] = {OP_mins, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1267
    [0x23] = {OP_mins, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1268
    [0x24] = {OP_mins, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1269
    [0x25] = {OP_mins, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1270
    [0x26] = {OP_mins, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1271
    [0x27] = {OP_mins, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1272
    [0x28] = {OP_maxs, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1273
    [0x29] = {OP_maxs, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1274
    [0x2a] = {OP_maxs, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1275
    [0x2b] = {OP_maxs, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1276
    [0x2c] = {OP_maxs, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1277
    [0x2d] = {OP_maxs, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1278
    [0x2e] = {OP_maxs, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1279
    [0x2f] = {OP_maxs, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1280
    [0x30] = {OPBASE_div, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1281
    [0x31] = {OPBASE_div, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1282
    [0x32] = {OPBASE_div, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1283
    [0x33] = {OPBASE_div, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1284
    [0x34] = {OPBASE_div, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1285
    [0x35] = {OPBASE_div, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1286
    [0x36] = {OPBASE_div, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1287
    [0x37] = {OPBASE_div, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1288
    [0x38] = {OPBASE_mod, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1289
    [0x39] = {OPBASE_mod, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1290
    [0x3a] = {OPBASE_mod, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1291
    [0x3b] = {OPBASE_mod, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1292
    [0x3c] = {OPBASE_mod, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1293
    [0x3d] = {OPBASE_mod, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1294
    [0x3e] = {OPBASE_mod, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1295
    [0x3f] = {OPBASE_mod, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1296
    [0x40] = {OP_abs, -1, 0, single, z_reg, 0},
1297
    [0x41] = {OP_abs, -1, 0, single, z_reg, 0},
1298
    [0x42] = {OP_abs, -1, 0, single, z_reg, 0},
1299
    [0x43] = {OP_abs, -1, 0, single, z_reg, 0},
1300
    [0x44] = {OP_abs, -1, 0, single, z_reg, 0},
1301
    [0x45] = {OP_abs, -1, 0, single, z_reg, 0},
1302
    [0x46] = {OP_abs, -1, 0, single, z_reg, 0},
1303
    [0x47] = {OP_abs, -1, 0, single, z_reg, 0},
1304
    [0x48] = {OPBASE_mac, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1305
    [0x49] = {OPBASE_mac, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1306
    [0x4a] = {OPBASE_mac, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1307
    [0x4b] = {OPBASE_mac, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1308
    [0x4c] = {OPBASE_mac, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1309
    [0x4d] = {OPBASE_mac, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1310
    [0x4e] = {OPBASE_mac, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1311
    [0x4f] = {OPBASE_mac, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1312
    [0x50] = {OP_adc, -1, 0, three, z_reg, z_imm1234_0base},
1313
    [0x51] = {OP_adc, -1, 0, three, z_reg, z_imm1234_0base},
1314
    [0x52] = {OP_adc, -1, 0, three, z_reg, z_imm1234_0base},
1315
    [0x53] = {OP_adc, -1, 0, three, z_reg, z_imm1234_0base},
1316
    [0x54] = {OP_adc, -1, 0, two,   z_reg, z_imm1234_0base},
1317
    [0x55] = {OP_adc, -1, 0, two,   z_reg, z_imm1234_0base},
1318
    [0x56] = {OP_adc, -1, 0, five,  z_reg, z_imm1234_0base},
1319
    [0x57] = {OP_adc, -1, 0, five,  z_reg, z_imm1234_0base},
1320
    [0x58] = {OP_bit, -1, 0, three, z_reg, z_imm1234_8base},
1321
    [0x59] = {OP_bit, -1, 0, three, z_reg, z_imm1234_8base},
1322
    [0x5a] = {OP_bit, -1, 0, three, z_reg, z_imm1234_8base},
1323
    [0x5b] = {OP_bit, -1, 0, three, z_reg, z_imm1234_8base},
1324
    [0x5c] = {OP_bit, -1, 0, two,   z_reg, z_imm1234_8base},
1325
    [0x5d] = {OP_bit, -1, 0, two,   z_reg, z_imm1234_8base},
1326
    [0x5e] = {OP_bit, -1, 0, five,  z_reg, z_imm1234_8base},
1327
    [0x5f] = {OP_bit, -1, 0, five,  z_reg, z_imm1234_8base},
1328
    [0x60] = {OP_adc, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1329
    [0x61] = {OP_adc, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1330
    [0x62] = {OP_adc, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1331
    [0x63] = {OP_adc, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1332
    [0x64] = {OP_adc, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1333
    [0x65] = {OP_adc, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1334
    [0x66] = {OP_adc, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1335
    [0x67] = {OP_adc, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1336
    [0x68] = {OP_bit, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1337
    [0x69] = {OP_bit, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1338
    [0x6a] = {OP_bit, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1339
    [0x6b] = {OP_bit, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1340
    [0x6c] = {OP_bit, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1341
    [0x6d] = {OP_bit, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1342
    [0x6e] = {OP_bit, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1343
    [0x6f] = {OP_bit, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1344
    [0x70] = {OP_sbc, -1, 0, three, z_reg, z_imm1234_0base},
1345
    [0x71] = {OP_sbc, -1, 0, three, z_reg, z_imm1234_0base},
1346
    [0x72] = {OP_sbc, -1, 0, three, z_reg, z_imm1234_0base},
1347
    [0x73] = {OP_sbc, -1, 0, three, z_reg, z_imm1234_0base},
1348
    [0x74] = {OP_sbc, -1, 0, two,   z_reg, z_imm1234_0base},
1349
    [0x75] = {OP_sbc, -1, 0, two,   z_reg, z_imm1234_0base},
1350
    [0x76] = {OP_sbc, -1, 0, five,  z_reg, z_imm1234_0base},
1351
    [0x77] = {OP_sbc, -1, 0, five,  z_reg, z_imm1234_0base},
1352
    [0x78] = {OP_eor, -1, 0, three, z_reg, z_imm1234_8base},
1353
    [0x79] = {OP_eor, -1, 0, three, z_reg, z_imm1234_8base},
1354
    [0x7a] = {OP_eor, -1, 0, three, z_reg, z_imm1234_8base},
1355
    [0x7b] = {OP_eor, -1, 0, three, z_reg, z_imm1234_8base},
1356
    [0x7c] = {OP_eor, -1, 0, two,   z_reg, z_imm1234_8base},
1357
    [0x7d] = {OP_eor, -1, 0, two,   z_reg, z_imm1234_8base},
1358
    [0x7e] = {OP_eor, -1, 0, five,  z_reg, z_imm1234_8base},
1359
    [0x7f] = {OP_eor, -1, 0, five,  z_reg, z_imm1234_8base},
1360
    [0x80] = {OP_sbc, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1361
    [0x81] = {OP_sbc, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1362
    [0x82] = {OP_sbc, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1363
    [0x83] = {OP_sbc, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1364
    [0x84] = {OP_sbc, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1365
    [0x85] = {OP_sbc, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1366
    [0x86] = {OP_sbc, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1367
    [0x87] = {OP_sbc, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1368
    [0x88] = {OP_eor, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1369
    [0x89] = {OP_eor, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1370
    [0x8a] = {OP_eor, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1371
    [0x8b] = {OP_eor, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1372
    [0x8c] = {OP_eor, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1373
    [0x8d] = {OP_eor, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1374
    [0x8e] = {OP_eor, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1375
    [0x8f] = {OP_eor, -1, 0,  opr_n_bytes_p1, z_reg, z_opr_decode},
1376
    [0x90] = {OP_rti, -1, 0,  single, 0, 0},
1377
    [0x91] = {OP_clb, -1, 0,   two, z_tfr, 0},
1378
    [0x92] = {OP_trap, -1, 0,  single, trap_decode, 0},
1379
    [0x93] = {OP_trap, -1, 0,  single, trap_decode, 0},
1380
    [0x94] = {OP_trap, -1, 0,  single, trap_decode, 0},
1381
    [0x95] = {OP_trap, -1, 0,  single, trap_decode, 0},
1382
    [0x96] = {OP_trap, -1, 0,  single, trap_decode, 0},
1383
    [0x97] = {OP_trap, -1, 0,  single, trap_decode, 0},
1384
    [0x98] = {OP_trap, -1, 0,  single, trap_decode, 0},
1385
    [0x99] = {OP_trap, -1, 0,  single, trap_decode, 0},
1386
    [0x9a] = {OP_trap, -1, 0,  single, trap_decode, 0},
1387
    [0x9b] = {OP_trap, -1, 0,  single, trap_decode, 0},
1388
    [0x9c] = {OP_trap, -1, 0,  single, trap_decode, 0},
1389
    [0x9d] = {OP_trap, -1, 0,  single, trap_decode, 0},
1390
    [0x9e] = {OP_trap, -1, 0,  single, trap_decode, 0},
1391
    [0x9f] = {OP_trap, -1, 0,  single, trap_decode, 0},
1392
    [0xa0] = {OP_sat, -1, 0, single, z_reg, 0},
1393
    [0xa1] = {OP_sat, -1, 0, single, z_reg, 0},
1394
    [0xa2] = {OP_sat, -1, 0, single, z_reg, 0},
1395
    [0xa3] = {OP_sat, -1, 0, single, z_reg, 0},
1396
    [0xa4] = {OP_sat, -1, 0, single, z_reg, 0},
1397
    [0xa5] = {OP_sat, -1, 0, single, z_reg, 0},
1398
    [0xa6] = {OP_sat, -1, 0, single, z_reg, 0},
1399
    [0xa7] = {OP_sat, -1, 0, single, z_reg, 0},
1400
    [0xa8] = {OP_trap, -1, 0,  single, trap_decode, 0},
1401
    [0xa9] = {OP_trap, -1, 0,  single, trap_decode, 0},
1402
    [0xaa] = {OP_trap, -1, 0,  single, trap_decode, 0},
1403
    [0xab] = {OP_trap, -1, 0,  single, trap_decode, 0},
1404
    [0xac] = {OP_trap, -1, 0,  single, trap_decode, 0},
1405
    [0xad] = {OP_trap, -1, 0,  single, trap_decode, 0},
1406
    [0xae] = {OP_trap, -1, 0,  single, trap_decode, 0},
1407
    [0xaf] = {OP_trap, -1, 0,  single, trap_decode, 0},
1408
    [0xb0] = {OPBASE_qmul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1409
    [0xb1] = {OPBASE_qmul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1410
    [0xb2] = {OPBASE_qmul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1411
    [0xb3] = {OPBASE_qmul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1412
    [0xb4] = {OPBASE_qmul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1413
    [0xb5] = {OPBASE_qmul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1414
    [0xb6] = {OPBASE_qmul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1415
    [0xb7] = {OPBASE_qmul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1416
    [0xb8] = {OP_trap, -1, 0,  single, trap_decode, 0},
1417
    [0xb9] = {OP_trap, -1, 0,  single, trap_decode, 0},
1418
    [0xba] = {OP_trap, -1, 0,  single, trap_decode, 0},
1419
    [0xbb] = {OP_trap, -1, 0,  single, trap_decode, 0},
1420
    [0xbc] = {OP_trap, -1, 0,  single, trap_decode, 0},
1421
    [0xbd] = {OP_trap, -1, 0,  single, trap_decode, 0},
1422
    [0xbe] = {OP_trap, -1, 0,  single, trap_decode, 0},
1423
    [0xbf] = {OP_trap, -1, 0,  single, trap_decode, 0},
1424
    [0xc0] = {OP_trap, -1, 0,  single, trap_decode, 0},
1425
    [0xc1] = {OP_trap, -1, 0,  single, trap_decode, 0},
1426
    [0xc2] = {OP_trap, -1, 0,  single, trap_decode, 0},
1427
    [0xc3] = {OP_trap, -1, 0,  single, trap_decode, 0},
1428
    [0xc4] = {OP_trap, -1, 0,  single, trap_decode, 0},
1429
    [0xc5] = {OP_trap, -1, 0,  single, trap_decode, 0},
1430
    [0xc6] = {OP_trap, -1, 0,  single, trap_decode, 0},
1431
    [0xc7] = {OP_trap, -1, 0,  single, trap_decode, 0},
1432
    [0xc8] = {OP_trap, -1, 0,  single, trap_decode, 0},
1433
    [0xc9] = {OP_trap, -1, 0,  single, trap_decode, 0},
1434
    [0xca] = {OP_trap, -1, 0,  single, trap_decode, 0},
1435
    [0xcb] = {OP_trap, -1, 0,  single, trap_decode, 0},
1436
    [0xcc] = {OP_trap, -1, 0,  single, trap_decode, 0},
1437
    [0xcd] = {OP_trap, -1, 0,  single, trap_decode, 0},
1438
    [0xce] = {OP_trap, -1, 0,  single, trap_decode, 0},
1439
    [0xcf] = {OP_trap, -1, 0,  single, trap_decode, 0},
1440
    [0xd0] = {OP_trap, -1, 0,  single, trap_decode, 0},
1441
    [0xd1] = {OP_trap, -1, 0,  single, trap_decode, 0},
1442
    [0xd2] = {OP_trap, -1, 0,  single, trap_decode, 0},
1443
    [0xd3] = {OP_trap, -1, 0,  single, trap_decode, 0},
1444
    [0xd4] = {OP_trap, -1, 0,  single, trap_decode, 0},
1445
    [0xd5] = {OP_trap, -1, 0,  single, trap_decode, 0},
1446
    [0xd6] = {OP_trap, -1, 0,  single, trap_decode, 0},
1447
    [0xd7] = {OP_trap, -1, 0,  single, trap_decode, 0},
1448
    [0xd8] = {OP_trap, -1, 0,  single, trap_decode, 0},
1449
    [0xd9] = {OP_trap, -1, 0,  single, trap_decode, 0},
1450
    [0xda] = {OP_trap, -1, 0,  single, trap_decode, 0},
1451
    [0xdb] = {OP_trap, -1, 0,  single, trap_decode, 0},
1452
    [0xdc] = {OP_trap, -1, 0,  single, trap_decode, 0},
1453
    [0xdd] = {OP_trap, -1, 0,  single, trap_decode, 0},
1454
    [0xde] = {OP_trap, -1, 0,  single, trap_decode, 0},
1455
    [0xdf] = {OP_trap, -1, 0,  single, trap_decode, 0},
1456
    [0xe0] = {OP_trap, -1, 0,  single, trap_decode, 0},
1457
    [0xe1] = {OP_trap, -1, 0,  single, trap_decode, 0},
1458
    [0xe2] = {OP_trap, -1, 0,  single, trap_decode, 0},
1459
    [0xe3] = {OP_trap, -1, 0,  single, trap_decode, 0},
1460
    [0xe4] = {OP_trap, -1, 0,  single, trap_decode, 0},
1461
    [0xe5] = {OP_trap, -1, 0,  single, trap_decode, 0},
1462
    [0xe6] = {OP_trap, -1, 0,  single, trap_decode, 0},
1463
    [0xe7] = {OP_trap, -1, 0,  single, trap_decode, 0},
1464
    [0xe8] = {OP_trap, -1, 0,  single, trap_decode, 0},
1465
    [0xe9] = {OP_trap, -1, 0,  single, trap_decode, 0},
1466
    [0xea] = {OP_trap, -1, 0,  single, trap_decode, 0},
1467
    [0xeb] = {OP_trap, -1, 0,  single, trap_decode, 0},
1468
    [0xec] = {OP_trap, -1, 0,  single, trap_decode, 0},
1469
    [0xed] = {OP_trap, -1, 0,  single, trap_decode, 0},
1470
    [0xee] = {OP_trap, -1, 0,  single, trap_decode, 0},
1471
    [0xef] = {OP_trap, -1, 0,  single, trap_decode, 0},
1472
    [0xf0] = {OP_trap, -1, 0,  single, trap_decode, 0},
1473
    [0xf1] = {OP_trap, -1, 0,  single, trap_decode, 0},
1474
    [0xf2] = {OP_trap, -1, 0,  single, trap_decode, 0},
1475
    [0xf3] = {OP_trap, -1, 0,  single, trap_decode, 0},
1476
    [0xf4] = {OP_trap, -1, 0,  single, trap_decode, 0},
1477
    [0xf5] = {OP_trap, -1, 0,  single, trap_decode, 0},
1478
    [0xf6] = {OP_trap, -1, 0,  single, trap_decode, 0},
1479
    [0xf7] = {OP_trap, -1, 0,  single, trap_decode, 0},
1480
    [0xf8] = {OP_trap, -1, 0,  single, trap_decode, 0},
1481
    [0xf9] = {OP_trap, -1, 0,  single, trap_decode, 0},
1482
    [0xfa] = {OP_trap, -1, 0,  single, trap_decode, 0},
1483
    [0xfb] = {OP_trap, -1, 0,  single, trap_decode, 0},
1484
    [0xfc] = {OP_trap, -1, 0,  single, trap_decode, 0},
1485
    [0xfd] = {OP_trap, -1, 0,  single, trap_decode, 0},
1486
    [0xfe] = {OP_trap, -1, 0,  single, trap_decode, 0},
1487
    [0xff] = {OP_trap, -1, 0,  single, trap_decode, 0},
1488
  };
1489
1490
static const struct opcode page1[] =
1491
  {
1492
    [0x00] = {OP_bgnd, -1, 0, single, 0, 0},
1493
    [0x01] = {OP_nop, -1, 0,  single, 0, 0},
1494
    [0x02] = {OP_brclr, -1, 0, bm_rel_n_bytes, bm_rel_decode, 0},
1495
    [0x03] = {OP_brset, -1, 0, bm_rel_n_bytes, bm_rel_decode, 0},
1496
    [0x04] = {0xFFFF, -1, psh_pul_discrim,   two, psh_pul_decode, 0}, /* psh/pul */
1497
    [0x05] = {OP_rts, -1, 0,  single, 0, 0},
1498
    [0x06] = {OP_lea, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1499
    [0x07] = {OP_lea, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1500
    [0x08] = {OP_lea, -1, 0, opr_n_bytes_p1, lea_reg_xys_opr, 0},
1501
    [0x09] = {OP_lea, -1, 0, opr_n_bytes_p1, lea_reg_xys_opr, 0},
1502
    [0x0a] = {OP_lea, -1, 0, opr_n_bytes_p1, lea_reg_xys_opr, 0},
1503
    [0x0b] = {0xFFFF, -1, loop_primitive_discrim, loop_prim_n_bytes, loop_primitive_decode, 0}, /* Loop primitives TBcc / DBcc */
1504
    [0x0c] = {OP_mov, 0, 0, mov_imm_opr_n_bytes, mov_imm_opr, 0},
1505
    [0x0d] = {OP_mov, 1, 0, mov_imm_opr_n_bytes, mov_imm_opr, 0},
1506
    [0x0e] = {OP_mov, 2, 0, mov_imm_opr_n_bytes, mov_imm_opr, 0},
1507
    [0x0f] = {OP_mov, 3, 0, mov_imm_opr_n_bytes, mov_imm_opr, 0},
1508
    [0x10] = {0xFFFF, -1, shift_discrim,  shift_n_bytes, shift_decode, 0},  /* lsr/lsl/asl/asr/rol/ror */
1509
    [0x11] = {0xFFFF, -1, shift_discrim,  shift_n_bytes, shift_decode, 0},
1510
    [0x12] = {0xFFFF, -1, shift_discrim,  shift_n_bytes, shift_decode, 0},
1511
    [0x13] = {0xFFFF, -1, shift_discrim,  shift_n_bytes, shift_decode, 0},
1512
    [0x14] = {0xFFFF, -1, shift_discrim,  shift_n_bytes, shift_decode, 0},
1513
    [0x15] = {0xFFFF, -1, shift_discrim,  shift_n_bytes, shift_decode, 0},
1514
    [0x16] = {0xFFFF, -1, shift_discrim,  shift_n_bytes, shift_decode, 0},
1515
    [0x17] = {0xFFFF, -1, shift_discrim,  shift_n_bytes, shift_decode, 0},
1516
    [0x18] = {OP_lea, -1, 0,  two, lea_reg_xys, NULL},
1517
    [0x19] = {OP_lea, -1, 0,  two, lea_reg_xys, NULL},
1518
    [0x1a] = {OP_lea, -1, 0,  two, lea_reg_xys, NULL},
1519
    /* 0x1b PG2 */
1520
    [0x1c] = {OP_mov, 0, 0, opr_n_bytes2, z_opr_decode2, 0},
1521
    [0x1d] = {OP_mov, 1, 0, opr_n_bytes2, z_opr_decode2, 0},
1522
    [0x1e] = {OP_mov, 2, 0, opr_n_bytes2, z_opr_decode2, 0},
1523
    [0x1f] = {OP_mov, 3, 0, opr_n_bytes2, z_opr_decode2, 0},
1524
    [0x20] = {OP_bra, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1525
    [0x21] = {OP_bsr, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1526
    [0x22] = {OP_bhi, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1527
    [0x23] = {OP_bls, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1528
    [0x24] = {OP_bcc, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1529
    [0x25] = {OP_bcs, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1530
    [0x26] = {OP_bne, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1531
    [0x27] = {OP_beq, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1532
    [0x28] = {OP_bvc, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1533
    [0x29] = {OP_bvs, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1534
    [0x2a] = {OP_bpl, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1535
    [0x2b] = {OP_bmi, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1536
    [0x2c] = {OP_bge, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1537
    [0x2d] = {OP_blt, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1538
    [0x2e] = {OP_bgt, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1539
    [0x2f] = {OP_ble, -1, 0,  pcrel_15bit, decode_rel_15_7, 0},
1540
    [0x30] = {OP_inc, -1, 0, single, z_reg, 0},
1541
    [0x31] = {OP_inc, -1, 0, single, z_reg, 0},
1542
    [0x32] = {OP_inc, -1, 0, single, z_reg, 0},
1543
    [0x33] = {OP_inc, -1, 0, single, z_reg, 0},
1544
    [0x34] = {OP_inc, -1, 0, single, z_reg, 0},
1545
    [0x35] = {OP_inc, -1, 0, single, z_reg, 0},
1546
    [0x36] = {OP_inc, -1, 0, single, z_reg, 0},
1547
    [0x37] = {OP_inc, -1, 0, single, z_reg, 0},
1548
    [0x38] = {OP_clr, -1, 0, single, z_reg, 0},
1549
    [0x39] = {OP_clr, -1, 0, single, z_reg, 0},
1550
    [0x3a] = {OP_clr, -1, 0, single, z_reg, 0},
1551
    [0x3b] = {OP_clr, -1, 0, single, z_reg, 0},
1552
    [0x3c] = {OP_clr, -1, 0, single, z_reg, 0},
1553
    [0x3d] = {OP_clr, -1, 0, single, z_reg, 0},
1554
    [0x3e] = {OP_clr, -1, 0, single, z_reg, 0},
1555
    [0x3f] = {OP_clr, -1, 0, single, z_reg, 0},
1556
    [0x40] = {OP_dec, -1, 0, single, z_reg, 0},
1557
    [0x41] = {OP_dec, -1, 0, single, z_reg, 0},
1558
    [0x42] = {OP_dec, -1, 0, single, z_reg, 0},
1559
    [0x43] = {OP_dec, -1, 0, single, z_reg, 0},
1560
    [0x44] = {OP_dec, -1, 0, single, z_reg, 0},
1561
    [0x45] = {OP_dec, -1, 0, single, z_reg, 0},
1562
    [0x46] = {OP_dec, -1, 0, single, z_reg, 0},
1563
    [0x47] = {OP_dec, -1, 0, single, z_reg, 0},
1564
    [0x48] = {OPBASE_mul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1565
    [0x49] = {OPBASE_mul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1566
    [0x4a] = {OPBASE_mul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1567
    [0x4b] = {OPBASE_mul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1568
    [0x4c] = {OPBASE_mul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1569
    [0x4d] = {OPBASE_mul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1570
    [0x4e] = {OPBASE_mul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1571
    [0x4f] = {OPBASE_mul, -1, mul_discrim, mul_n_bytes, mul_decode, 0},
1572
    [0x50] = {OP_add, -1, 0, three, z_reg, z_imm1234_0base},
1573
    [0x51] = {OP_add, -1, 0, three, z_reg, z_imm1234_0base},
1574
    [0x52] = {OP_add, -1, 0, three, z_reg, z_imm1234_0base},
1575
    [0x53] = {OP_add, -1, 0, three, z_reg, z_imm1234_0base},
1576
    [0x54] = {OP_add, -1, 0, two,   z_reg, z_imm1234_0base},
1577
    [0x55] = {OP_add, -1, 0, two,   z_reg, z_imm1234_0base},
1578
    [0x56] = {OP_add, -1, 0, five,  z_reg, z_imm1234_0base},
1579
    [0x57] = {OP_add, -1, 0, five,  z_reg, z_imm1234_0base},
1580
    [0x58] = {OP_and, -1, 0, three, z_reg, z_imm1234_8base},
1581
    [0x59] = {OP_and, -1, 0, three, z_reg, z_imm1234_8base},
1582
    [0x5a] = {OP_and, -1, 0, three, z_reg, z_imm1234_8base},
1583
    [0x5b] = {OP_and, -1, 0, three, z_reg, z_imm1234_8base},
1584
    [0x5c] = {OP_and, -1, 0, two,   z_reg, z_imm1234_8base},
1585
    [0x5d] = {OP_and, -1, 0, two,   z_reg, z_imm1234_8base},
1586
    [0x5e] = {OP_and, -1, 0, five,  z_reg, z_imm1234_8base},
1587
    [0x5f] = {OP_and, -1, 0, five,  z_reg, z_imm1234_8base},
1588
    [0x60] = {OP_add, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1589
    [0x61] = {OP_add, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1590
    [0x62] = {OP_add, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1591
    [0x63] = {OP_add, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1592
    [0x64] = {OP_add, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1593
    [0x65] = {OP_add, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1594
    [0x66] = {OP_add, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1595
    [0x67] = {OP_add, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1596
    [0x68] = {OP_and, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1597
    [0x69] = {OP_and, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1598
    [0x6a] = {OP_and, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1599
    [0x6b] = {OP_and, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1600
    [0x6c] = {OP_and, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1601
    [0x6d] = {OP_and, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1602
    [0x6e] = {OP_and, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1603
    [0x6f] = {OP_and, -1, 0, opr_n_bytes_p1, z_reg, z_opr_decode},
1604
    [0x70] = {OP_sub, -1, 0, three, z_reg, z_imm1234_0base},
1605
    [0x71] = {OP_sub, -1, 0, three, z_reg, z_imm1234_0base},
1606
    [0x72] = {OP_sub, -1, 0, three, z_reg, z_imm1234_0base},
1607
    [0x73] = {OP_sub, -1, 0, three, z_reg, z_imm1234_0base},
1608
    [0x74] = {OP_sub, -1, 0, two,   z_reg, z_imm1234_0base},
1609
    [0x75] = {OP_sub, -1, 0, two,   z_reg, z_imm1234_0base},
1610
    [0x76] = {OP_sub, -1, 0, five,  z_reg, z_imm1234_0base},
1611
    [0x77] = {OP_sub, -1, 0, five,  z_reg, z_imm1234_0base},
1612
    [0x78] = {OP_or, -1, 0, three, z_reg, z_imm1234_8base},
1613
    [0x79] = {OP_or, -1, 0, three, z_reg, z_imm1234_8base},
1614
    [0x7a] = {OP_or, -1, 0, three, z_reg, z_imm1234_8base},
1615
    [0x7b] = {OP_or, -1, 0, three, z_reg, z_imm1234_8base},
1616
    [0x7c] = {OP_or, -1, 0, two,   z_reg, z_imm1234_8base},
1617
    [0x7d] = {OP_or, -1, 0, two,   z_reg, z_imm1234_8base},
1618
    [0x7e] = {OP_or, -1, 0, five,  z_reg, z_imm1234_8base},
1619
    [0x7f] = {OP_or, -1, 0, five,  z_reg, z_imm1234_8base},
1620
    [0x80] = {OP_sub, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1621
    [0x81] = {OP_sub, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1622
    [0x82] = {OP_sub, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1623
    [0x83] = {OP_sub, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1624
    [0x84] = {OP_sub, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1625
    [0x85] = {OP_sub, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1626
    [0x86] = {OP_sub, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1627
    [0x87] = {OP_sub, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1628
    [0x88] = {OP_or, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1629
    [0x89] = {OP_or, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1630
    [0x8a] = {OP_or, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1631
    [0x8b] = {OP_or, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1632
    [0x8c] = {OP_or, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1633
    [0x8d] = {OP_or, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1634
    [0x8e] = {OP_or, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1635
    [0x8f] = {OP_or, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1636
    [0x90] = {OP_ld, -1, 0, three,  z_reg, z_imm1234_0base},
1637
    [0x91] = {OP_ld, -1, 0, three,  z_reg, z_imm1234_0base},
1638
    [0x92] = {OP_ld, -1, 0, three,  z_reg, z_imm1234_0base},
1639
    [0x93] = {OP_ld, -1, 0, three,  z_reg, z_imm1234_0base},
1640
    [0x94] = {OP_ld, -1, 0, two,    z_reg, z_imm1234_0base},
1641
    [0x95] = {OP_ld, -1, 0, two,    z_reg, z_imm1234_0base},
1642
    [0x96] = {OP_ld, -1, 0, five,   z_reg, z_imm1234_0base},
1643
    [0x97] = {OP_ld, -1, 0, five,   z_reg, z_imm1234_0base},
1644
    [0x98] = {OP_ld, -1, 0, four,   reg_xy, z_imm1234_0base},
1645
    [0x99] = {OP_ld, -1, 0, four,   reg_xy, z_imm1234_0base},
1646
    [0x9a] = {OP_clr, -1, 0, single, reg_xy, 0},
1647
    [0x9b] = {OP_clr, -1, 0, single, reg_xy, 0},
1648
    [0x9c] = {OP_inc, 0, 0, opr_n_bytes_p1, z_opr_decode, 0},
1649
    [0x9d] = {OP_inc, 1, 0, opr_n_bytes_p1, z_opr_decode, 0},
1650
    [0x9e] = {OP_tfr, -1, 0, two, z_tfr, NULL},
1651
    [0x9f] = {OP_inc, 3, 0, opr_n_bytes_p1, z_opr_decode, 0},
1652
    [0xa0] = {OP_ld, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1653
    [0xa1] = {OP_ld, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1654
    [0xa2] = {OP_ld, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1655
    [0xa3] = {OP_ld, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1656
    [0xa4] = {OP_ld, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1657
    [0xa5] = {OP_ld, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1658
    [0xa6] = {OP_ld, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1659
    [0xa7] = {OP_ld, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1660
    [0xa8] = {OP_ld, -1, 0, opr_n_bytes_p1, reg_xy, z_opr_decode},
1661
    [0xa9] = {OP_ld, -1, 0, opr_n_bytes_p1, reg_xy, z_opr_decode},
1662
    [0xaa] = {OP_jmp, -1, 0, opr_n_bytes_p1, z_opr_decode, 0},
1663
    [0xab] = {OP_jsr, -1, 0, opr_n_bytes_p1, z_opr_decode, 0},
1664
    [0xac] = {OP_dec, 0, 0, opr_n_bytes_p1, z_opr_decode, 0},
1665
    [0xad] = {OP_dec, 1, 0, opr_n_bytes_p1, z_opr_decode, 0},
1666
    [0xae] = {0xFFFF, -1, exg_sex_discrim,   two, exg_sex_decode, 0},  /* EXG / SEX */
1667
    [0xaf] = {OP_dec, 3, 0, opr_n_bytes_p1, 0, z_opr_decode},
1668
    [0xb0] = {OP_ld, -1, 0, four,  z_reg, z_ext24_decode},
1669
    [0xb1] = {OP_ld, -1, 0, four,  z_reg, z_ext24_decode},
1670
    [0xb2] = {OP_ld, -1, 0, four,  z_reg, z_ext24_decode},
1671
    [0xb3] = {OP_ld, -1, 0, four,  z_reg, z_ext24_decode},
1672
    [0xb4] = {OP_ld, -1, 0, four,  z_reg, z_ext24_decode},
1673
    [0xb5] = {OP_ld, -1, 0, four,  z_reg, z_ext24_decode},
1674
    [0xb6] = {OP_ld, -1, 0, four,  z_reg, z_ext24_decode},
1675
    [0xb7] = {OP_ld, -1, 0, four,  z_reg, z_ext24_decode},
1676
    [0xb8] = {OP_ld, -1, 0, four,  reg_xy, z_ext24_decode},
1677
    [0xb9] = {OP_ld, -1, 0, four,  reg_xy, z_ext24_decode},
1678
    [0xba] = {OP_jmp, -1, 0, four, z_ext24_decode, 0},
1679
    [0xbb] = {OP_jsr, -1, 0, four, z_ext24_decode, 0},
1680
    [0xbc] = {OP_clr, 0, 0, opr_n_bytes_p1, z_opr_decode, 0},
1681
    [0xbd] = {OP_clr, 1, 0, opr_n_bytes_p1, z_opr_decode, 0},
1682
    [0xbe] = {OP_clr, 2, 0, opr_n_bytes_p1, z_opr_decode, 0},
1683
    [0xbf] = {OP_clr, 3, 0, opr_n_bytes_p1, z_opr_decode, 0},
1684
    [0xc0] = {OP_st, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1685
    [0xc1] = {OP_st, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1686
    [0xc2] = {OP_st, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1687
    [0xc3] = {OP_st, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1688
    [0xc4] = {OP_st, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1689
    [0xc5] = {OP_st, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1690
    [0xc6] = {OP_st, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1691
    [0xc7] = {OP_st, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1692
    [0xc8] = {OP_st, -1, 0, opr_n_bytes_p1, reg_xy, z_opr_decode},
1693
    [0xc9] = {OP_st, -1, 0, opr_n_bytes_p1, reg_xy, z_opr_decode},
1694
    [0xca] = {OP_ld, -1, 0, three, reg_xy, ld_18bit_decode},
1695
    [0xcb] = {OP_ld, -1, 0, three, reg_xy, ld_18bit_decode},
1696
    [0xcc] = {OP_com, 0, 0, opr_n_bytes_p1, NULL, z_opr_decode},
1697
    [0xcd] = {OP_com, 1, 0, opr_n_bytes_p1, NULL, z_opr_decode},
1698
    [0xce] = {OP_andcc, -1, 0, two, imm1_decode, 0},
1699
    [0xcf] = {OP_com, 3, 0, opr_n_bytes_p1, NULL, z_opr_decode},
1700
    [0xd0] = {OP_st, -1, 0, four,  z_reg, z_ext24_decode},
1701
    [0xd1] = {OP_st, -1, 0, four,  z_reg, z_ext24_decode},
1702
    [0xd2] = {OP_st, -1, 0, four,  z_reg, z_ext24_decode},
1703
    [0xd3] = {OP_st, -1, 0, four,  z_reg, z_ext24_decode},
1704
    [0xd4] = {OP_st, -1, 0, four,  z_reg, z_ext24_decode},
1705
    [0xd5] = {OP_st, -1, 0, four,  z_reg, z_ext24_decode},
1706
    [0xd6] = {OP_st, -1, 0, four,  z_reg, z_ext24_decode},
1707
    [0xd7] = {OP_st, -1, 0, four,  z_reg, z_ext24_decode},
1708
    [0xd8] = {OP_st, -1, 0, four,  reg_xy, z_ext24_decode},
1709
    [0xd9] = {OP_st, -1, 0, four,  reg_xy, z_ext24_decode},
1710
    [0xda] = {OP_ld, -1, 0, three, reg_xy, ld_18bit_decode},
1711
    [0xdb] = {OP_ld, -1, 0, three, reg_xy, ld_18bit_decode},
1712
    [0xdc] = {OP_neg, 0, 0, opr_n_bytes_p1, NULL, z_opr_decode},
1713
    [0xdd] = {OP_neg, 1, 0, opr_n_bytes_p1, NULL, z_opr_decode},
1714
    [0xde] = {OP_orcc, -1, 0,  two,  imm1_decode, 0},
1715
    [0xdf] = {OP_neg,  3, 0, opr_n_bytes_p1, NULL, z_opr_decode},
1716
    [0xe0] = {OP_cmp, -1, 0, three,  z_reg, z_imm1234_0base},
1717
    [0xe1] = {OP_cmp, -1, 0, three,  z_reg, z_imm1234_0base},
1718
    [0xe2] = {OP_cmp, -1, 0, three,  z_reg, z_imm1234_0base},
1719
    [0xe3] = {OP_cmp, -1, 0, three,  z_reg, z_imm1234_0base},
1720
    [0xe4] = {OP_cmp, -1, 0, two,    z_reg, z_imm1234_0base},
1721
    [0xe5] = {OP_cmp, -1, 0, two,    z_reg, z_imm1234_0base},
1722
    [0xe6] = {OP_cmp, -1, 0, five,   z_reg, z_imm1234_0base},
1723
    [0xe7] = {OP_cmp, -1, 0, five,   z_reg, z_imm1234_0base},
1724
    [0xe8] = {OP_cmp, -1, 0, four,   reg_xy, z_imm1234_0base},
1725
    [0xe9] = {OP_cmp, -1, 0, four,   reg_xy, z_imm1234_0base},
1726
    [0xea] = {OP_ld, -1, 0, three, reg_xy, ld_18bit_decode},
1727
    [0xeb] = {OP_ld, -1, 0, three, reg_xy, ld_18bit_decode},
1728
    [0xec] = {OP_bclr, -1, 0, bm_n_bytes, bm_decode, 0},
1729
    [0xed] = {OP_bset, -1, 0, bm_n_bytes, bm_decode, 0},
1730
    [0xee] = {OP_btgl, -1, 0, bm_n_bytes, bm_decode, 0},
1731
    [0xef] = {OP_INVALID, -1, 0, NULL, NULL, NULL}, /* SPARE */
1732
    [0xf0] = {OP_cmp, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1733
    [0xf1] = {OP_cmp, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1734
    [0xf2] = {OP_cmp, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1735
    [0xf3] = {OP_cmp, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1736
    [0xf4] = {OP_cmp, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1737
    [0xf5] = {OP_cmp, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1738
    [0xf6] = {OP_cmp, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1739
    [0xf7] = {OP_cmp, -1, 0, opr_n_bytes_p1, z_reg,    z_opr_decode},
1740
    [0xf8] = {OP_cmp, -1, 0, opr_n_bytes_p1, reg_xy, z_opr_decode},
1741
    [0xf9] = {OP_cmp, -1, 0, opr_n_bytes_p1, reg_xy, z_opr_decode},
1742
    [0xfa] = {OP_ld, -1, 0,  three, reg_xy, ld_18bit_decode},
1743
    [0xfb] = {OP_ld, -1, 0,  three, reg_xy, ld_18bit_decode},
1744
    [0xfc] = {OP_cmp, -1, 0, single, cmp_xy, 0},
1745
    [0xfd] = {OP_sub, -1, 0, single, sub_d6_x_y, 0},
1746
    [0xfe] = {OP_sub, -1, 0, single, sub_d6_y_x, 0},
1747
    [0xff] = {OP_swi, -1, 0, single, 0, 0}
1748
  };
1749
1750
static const int oprregs1[] =
1751
  {
1752
    REG_D3, REG_D2, REG_D1, REG_D0, REG_CCL, REG_CCH
1753
  };
1754
1755
static const int oprregs2[] =
1756
  {
1757
    REG_Y,  REG_X,  REG_D7, REG_D6, REG_D5,  REG_D4
1758
  };
1759
1760
1761

1762
1763
enum MUL_MODE
1764
  {
1765
    MUL_REG_REG,
1766
    MUL_REG_OPR,
1767
    MUL_REG_IMM,
1768
    MUL_OPR_OPR
1769
  };
1770
1771
struct mb
1772
{
1773
  uint8_t mask;
1774
  uint8_t value;
1775
  enum MUL_MODE mode;
1776
};
1777
1778
static const struct mb mul_table[] = {
1779
  {0x40, 0x00, MUL_REG_REG},
1780
1781
  {0x47, 0x40, MUL_REG_OPR},
1782
  {0x47, 0x41, MUL_REG_OPR},
1783
  {0x47, 0x43, MUL_REG_OPR},
1784
1785
  {0x47, 0x44, MUL_REG_IMM},
1786
  {0x47, 0x45, MUL_REG_IMM},
1787
  {0x47, 0x47, MUL_REG_IMM},
1788
1789
  {0x43, 0x42, MUL_OPR_OPR},
1790
};
1791
1792
1793
static int
1794
mul_decode (struct mem_read_abstraction_base *mra,
1795
      int *n_operands, struct operand **operand)
1796
16.0k
{
1797
16.0k
  uint8_t mb;
1798
16.0k
  struct operand *op;
1799
16.0k
  int status = mra->read (mra, 0, 1, &mb);
1800
16.0k
  if (status < 0)
1801
0
    return status;
1802
1803
16.0k
  uint8_t byte;
1804
16.0k
  status = mra->read (mra, -1, 1, &byte);
1805
16.0k
  if (status < 0)
1806
0
    return status;
1807
1808
16.0k
  enum MUL_MODE mode = -1;
1809
16.0k
  size_t i;
1810
90.0k
  for (i = 0; i < sizeof (mul_table) / sizeof (mul_table[0]); ++i)
1811
90.0k
    {
1812
90.0k
      const struct mb *mm = mul_table + i;
1813
90.0k
      if ((mb & mm->mask) == mm->value)
1814
16.0k
  {
1815
16.0k
    mode = mm->mode;
1816
16.0k
    break;
1817
16.0k
  }
1818
90.0k
    }
1819
16.0k
  op = create_register_operand (byte & 0x07);
1820
16.0k
  if (op == NULL)
1821
0
    return -1;
1822
16.0k
  operand[(*n_operands)++] = op;
1823
1824
16.0k
  switch (mode)
1825
16.0k
    {
1826
4.40k
    case MUL_REG_IMM:
1827
4.40k
      {
1828
4.40k
  int size = (mb & 0x3);
1829
4.40k
  op = create_register_operand_with_size ((mb & 0x38) >> 3, size);
1830
4.40k
  if (op == NULL)
1831
0
    return -1;
1832
4.40k
  operand[(*n_operands)++] = op;
1833
1834
4.40k
  uint32_t imm;
1835
4.40k
  if (z_decode_signed_value (mra, 1, size + 1, &imm) < 0)
1836
5
    return -1;
1837
4.40k
  op = create_immediate_operand (imm);
1838
4.40k
  if (op == NULL)
1839
0
    return -1;
1840
4.40k
  operand[(*n_operands)++] = op;
1841
4.40k
      }
1842
0
      break;
1843
3.10k
    case MUL_REG_REG:
1844
3.10k
      op = create_register_operand ((mb & 0x38) >> 3);
1845
3.10k
      if (op == NULL)
1846
0
  return -1;
1847
3.10k
      operand[(*n_operands)++] = op;
1848
3.10k
      op = create_register_operand (mb & 0x07);
1849
3.10k
      if (op == NULL)
1850
0
  return -1;
1851
3.10k
      operand[(*n_operands)++] = op;
1852
3.10k
      break;
1853
1.82k
    case MUL_REG_OPR:
1854
1.82k
      op = create_register_operand ((mb & 0x38) >> 3);
1855
1.82k
      if (op == NULL)
1856
0
  return -1;
1857
1.82k
      operand[(*n_operands)++] = op;
1858
1.82k
      op = x_opr_decode_with_size (mra, 1, mb & 0x3);
1859
1.82k
      if (op == NULL)
1860
5
  return -1;
1861
1.81k
      operand[(*n_operands)++] = op;
1862
1.81k
      break;
1863
6.72k
    case MUL_OPR_OPR:
1864
6.72k
      {
1865
6.72k
  int first = x_opr_n_bytes (mra, 1);
1866
6.72k
  if (first < 0)
1867
8
    return first;
1868
6.71k
  op = x_opr_decode_with_size (mra, 1, (mb & 0x30) >> 4);
1869
6.71k
  if (op == NULL)
1870
3
    return -1;
1871
6.71k
  operand[(*n_operands)++] = op;
1872
6.71k
  op = x_opr_decode_with_size (mra, first + 1, (mb & 0x0c) >> 2);
1873
6.71k
  if (op == NULL)
1874
7
    return -1;
1875
6.70k
  operand[(*n_operands)++] = op;
1876
6.70k
  break;
1877
6.71k
      }
1878
16.0k
    }
1879
16.0k
  return 0;
1880
16.0k
}
1881
1882
1883
static int
1884
mul_n_bytes (struct mem_read_abstraction_base *mra)
1885
16.0k
{
1886
16.0k
  int nx = 2;
1887
16.0k
  int first, second;
1888
16.0k
  uint8_t mb;
1889
16.0k
  int status = mra->read (mra, 0, 1, &mb);
1890
16.0k
  if (status < 0)
1891
0
    return status;
1892
1893
16.0k
  enum MUL_MODE mode = -1;
1894
16.0k
  size_t i;
1895
89.8k
  for (i = 0; i < sizeof (mul_table) / sizeof (mul_table[0]); ++i)
1896
89.8k
    {
1897
89.8k
      const struct mb *mm = mul_table + i;
1898
89.8k
      if ((mb & mm->mask) == mm->value)
1899
16.0k
  {
1900
16.0k
    mode = mm->mode;
1901
16.0k
    break;
1902
16.0k
  }
1903
89.8k
    }
1904
1905
16.0k
  int size = (mb & 0x3) + 1;
1906
1907
16.0k
  switch (mode)
1908
16.0k
    {
1909
4.40k
    case MUL_REG_IMM:
1910
4.40k
      nx += size;
1911
4.40k
      break;
1912
3.10k
    case MUL_REG_REG:
1913
3.10k
      break;
1914
1.81k
    case MUL_REG_OPR:
1915
1.81k
      first = x_opr_n_bytes (mra, 1);
1916
1.81k
      if (first < 0)
1917
0
  return first;
1918
1.81k
      nx += first;
1919
1.81k
      break;
1920
6.70k
    case MUL_OPR_OPR:
1921
6.70k
      first = x_opr_n_bytes (mra, nx - 1);
1922
6.70k
      if (first < 0)
1923
0
  return first;
1924
6.70k
      nx += first;
1925
6.70k
      second = x_opr_n_bytes (mra, nx - 1);
1926
6.70k
      if (second < 0)
1927
0
  return second;
1928
6.70k
      nx += second;
1929
6.70k
      break;
1930
16.0k
    }
1931
1932
16.0k
  return nx;
1933
16.0k
}
1934
1935

1936
/* The NXP documentation is vague about BM_RESERVED0 and BM_RESERVED1,
1937
   and contains obvious typos.
1938
   However the Freescale tools and experiments with the chip itself
1939
   seem to indicate that they behave like BM_REG_IMM and BM_OPR_REG
1940
   respectively.  */
1941
1942
enum BM_MODE
1943
{
1944
  BM_REG_IMM,
1945
  BM_RESERVED0,
1946
  BM_OPR_B,
1947
  BM_OPR_W,
1948
  BM_OPR_L,
1949
  BM_OPR_REG,
1950
  BM_RESERVED1
1951
};
1952
1953
struct bm
1954
{
1955
  uint8_t mask;
1956
  uint8_t value;
1957
  enum BM_MODE mode;
1958
};
1959
1960
static const  struct bm bm_table[] = {
1961
  { 0xC6, 0x04,     BM_REG_IMM},
1962
  { 0x84, 0x00,     BM_REG_IMM},
1963
  { 0x06, 0x06,     BM_REG_IMM},
1964
  { 0xC6, 0x44,     BM_RESERVED0},
1965
1966
  { 0x8F, 0x80,     BM_OPR_B},
1967
  { 0x8E, 0x82,     BM_OPR_W},
1968
  { 0x8C, 0x88,     BM_OPR_L},
1969
1970
  { 0x83, 0x81,     BM_OPR_REG},
1971
  { 0x87, 0x84,     BM_RESERVED1},
1972
};
1973
1974
static int
1975
bm_decode (struct mem_read_abstraction_base *mra,
1976
     int *n_operands, struct operand **operand)
1977
4.19k
{
1978
4.19k
  struct operand *op;
1979
4.19k
  uint8_t bm;
1980
4.19k
  int status = mra->read (mra, 0, 1, &bm);
1981
4.19k
  if (status < 0)
1982
3
    return status;
1983
1984
4.19k
  size_t i;
1985
4.19k
  enum BM_MODE mode = -1;
1986
21.6k
  for (i = 0; i < sizeof (bm_table) / sizeof (bm_table[0]); ++i)
1987
21.6k
    {
1988
21.6k
      const struct bm *bme = bm_table + i;
1989
21.6k
      if ((bm & bme->mask) == bme->value)
1990
4.19k
  {
1991
4.19k
    mode = bme->mode;
1992
4.19k
    break;
1993
4.19k
  }
1994
21.6k
    }
1995
1996
4.19k
  switch (mode)
1997
4.19k
    {
1998
1.96k
    case BM_REG_IMM:
1999
2.15k
    case BM_RESERVED0:
2000
2.15k
      op = create_register_operand (bm & 0x07);
2001
2.15k
      if (op == NULL)
2002
0
  return -1;
2003
2.15k
      operand[(*n_operands)++] = op;
2004
2.15k
      break;
2005
86
    case BM_OPR_B:
2006
86
      op = x_opr_decode_with_size (mra, 1, 0);
2007
86
      if (op == NULL)
2008
1
  return -1;
2009
85
      operand[(*n_operands)++] = op;
2010
85
      break;
2011
396
    case BM_OPR_W:
2012
396
      op = x_opr_decode_with_size (mra, 1, 1);
2013
396
      if (op == NULL)
2014
2
  return -1;
2015
394
      operand[(*n_operands)++] = op;
2016
394
      break;
2017
322
    case BM_OPR_L:
2018
322
      op = x_opr_decode_with_size (mra, 1, 3);
2019
322
      if (op == NULL)
2020
2
  return -1;
2021
320
      operand[(*n_operands)++] = op;
2022
320
      break;
2023
565
    case BM_OPR_REG:
2024
1.23k
    case BM_RESERVED1:
2025
1.23k
      {
2026
1.23k
  uint8_t xb;
2027
1.23k
  status = mra->read (mra, 1, 1, &xb);
2028
1.23k
  if (status < 0)
2029
4
    return status;
2030
  /* Don't emit a size suffix for register operands */
2031
1.22k
  if ((xb & 0xF8) != 0xB8)
2032
1.01k
    op = x_opr_decode_with_size (mra, 1, (bm & 0x0c) >> 2);
2033
212
  else
2034
212
    op = x_opr_decode (mra, 1);
2035
1.22k
  if (op == NULL)
2036
5
    return -1;
2037
1.22k
  operand[(*n_operands)++] = op;
2038
1.22k
      }
2039
0
      break;
2040
4.19k
    }
2041
2042
4.17k
  uint8_t imm = 0;
2043
4.17k
  switch (mode)
2044
4.17k
    {
2045
1.96k
    case BM_REG_IMM:
2046
2.15k
    case BM_RESERVED0:
2047
2.15k
      imm = (bm & 0x38) >> 3;
2048
2.15k
      op = create_immediate_operand (imm);
2049
2.15k
      if (op == NULL)
2050
0
  return -1;
2051
2.15k
      operand[(*n_operands)++] = op;
2052
2.15k
      break;
2053
320
    case BM_OPR_L:
2054
320
      imm |= (bm & 0x03) << 3;
2055
      /* fallthrough */
2056
714
    case BM_OPR_W:
2057
714
      imm |= (bm & 0x01) << 3;
2058
      /* fallthrough */
2059
799
    case BM_OPR_B:
2060
799
      imm |= (bm & 0x70) >> 4;
2061
799
      op = create_immediate_operand (imm);
2062
799
      if (op == NULL)
2063
0
  return -1;
2064
799
      operand[(*n_operands)++] = op;
2065
799
      break;
2066
559
    case BM_OPR_REG:
2067
1.22k
    case BM_RESERVED1:
2068
1.22k
      op = create_register_operand ((bm & 0x70) >> 4);
2069
1.22k
      if (op == NULL)
2070
0
  return -1;
2071
1.22k
      operand[(*n_operands)++] = op;
2072
1.22k
      break;
2073
4.17k
    }
2074
4.17k
  return 0;
2075
4.17k
}
2076
2077
2078
static int
2079
bm_rel_decode (struct mem_read_abstraction_base *mra,
2080
         int *n_operands, struct operand **operand)
2081
8.88k
{
2082
8.88k
  struct operand *op;
2083
8.88k
  uint8_t bm;
2084
8.88k
  int status = mra->read (mra, 0, 1, &bm);
2085
8.88k
  if (status < 0)
2086
14
    return status;
2087
2088
8.86k
  size_t i;
2089
8.86k
  enum BM_MODE mode = -1;
2090
33.6k
  for (i = 0; i < sizeof (bm_table) / sizeof (bm_table[0]); ++i)
2091
33.6k
    {
2092
33.6k
      const struct bm *bme = bm_table + i;
2093
33.6k
      if ((bm & bme->mask) == bme->value)
2094
8.86k
  {
2095
8.86k
    mode = bme->mode;
2096
8.86k
    break;
2097
8.86k
  }
2098
33.6k
    }
2099
2100
8.86k
  int n = 1;
2101
8.86k
  switch (mode)
2102
8.86k
    {
2103
5.80k
    case BM_REG_IMM:
2104
5.91k
    case BM_RESERVED0:
2105
5.91k
      op = create_register_operand (bm & 0x07);
2106
5.91k
      if (op == NULL)
2107
0
  return -1;
2108
5.91k
      operand[(*n_operands)++] = op;
2109
5.91k
      break;
2110
447
    case BM_OPR_B:
2111
447
      op = x_opr_decode_with_size (mra, 1, 0);
2112
447
      if (op == NULL)
2113
0
  return -1;
2114
447
      operand[(*n_operands)++] = op;
2115
447
      n = x_opr_n_bytes (mra, 1);
2116
447
      if (n < 0)
2117
0
  return n;
2118
447
      n += 1;
2119
447
      break;
2120
794
    case BM_OPR_W:
2121
794
      op = x_opr_decode_with_size (mra, 1, 1);
2122
794
      if (op == NULL)
2123
3
  return -1;
2124
791
      operand[(*n_operands)++] = op;
2125
791
      n = x_opr_n_bytes (mra, 1);
2126
791
      if (n < 0)
2127
0
  return n;
2128
791
      n += 1;
2129
791
      break;
2130
617
    case BM_OPR_L:
2131
617
      op = x_opr_decode_with_size (mra, 1, 3);
2132
617
      if (op == NULL)
2133
2
  return -1;
2134
615
      operand[(*n_operands)++] = op;
2135
615
      n = x_opr_n_bytes (mra, 1);
2136
615
      if (n < 0)
2137
0
  return n;
2138
615
      n += 1;
2139
615
      break;
2140
587
    case BM_OPR_REG:
2141
1.09k
    case BM_RESERVED1:
2142
1.09k
      {
2143
1.09k
  uint8_t xb;
2144
1.09k
  status = mra->read (mra, +1, 1, &xb);
2145
1.09k
  if (status < 0)
2146
1
    return status;
2147
  /* Don't emit a size suffix for register operands */
2148
1.09k
  if ((xb & 0xF8) != 0xB8)
2149
1.05k
    {
2150
1.05k
      short os = (bm & 0x0c) >> 2;
2151
1.05k
      op = x_opr_decode_with_size (mra, 1, os);
2152
1.05k
    }
2153
43
  else
2154
43
    op = x_opr_decode (mra, 1);
2155
1.09k
  if (op == NULL)
2156
1
    return -1;
2157
1.09k
  operand[(*n_operands)++] = op;
2158
1.09k
      }
2159
0
      break;
2160
8.86k
    }
2161
2162
8.86k
  int x, imm = 0;
2163
8.86k
  switch (mode)
2164
8.86k
    {
2165
615
    case BM_OPR_L:
2166
615
      imm |= (bm & 0x02) << 3;
2167
      /* fall through */
2168
1.40k
    case BM_OPR_W:
2169
1.40k
      imm |= (bm & 0x01) << 3;
2170
      /* fall through */
2171
1.85k
    case BM_OPR_B:
2172
1.85k
      imm |= (bm & 0x70) >> 4;
2173
1.85k
      op = create_immediate_operand (imm);
2174
1.85k
      if (op == NULL)
2175
0
  return -1;
2176
1.85k
      operand[(*n_operands)++] = op;
2177
1.85k
      break;
2178
110
    case BM_RESERVED0:
2179
110
      imm = (bm & 0x38) >> 3;
2180
110
      op = create_immediate_operand (imm);
2181
110
      if (op == NULL)
2182
0
  return -1;
2183
110
      operand[(*n_operands)++] = op;
2184
110
      break;
2185
5.80k
    case BM_REG_IMM:
2186
5.80k
      imm = (bm & 0xF8) >> 3;
2187
5.80k
      op = create_immediate_operand (imm);
2188
5.80k
      if (op == NULL)
2189
0
  return -1;
2190
5.80k
      operand[(*n_operands)++] = op;
2191
5.80k
      break;
2192
586
    case BM_OPR_REG:
2193
1.09k
    case BM_RESERVED1:
2194
1.09k
      op = create_register_operand ((bm & 0x70) >> 4);
2195
1.09k
      if (op == NULL)
2196
0
  return -1;
2197
1.09k
      operand[(*n_operands)++] = op;
2198
1.09k
      x = x_opr_n_bytes (mra, 1);
2199
1.09k
      if (x < 0)
2200
0
  return x;
2201
1.09k
      n += x;
2202
1.09k
      break;
2203
8.86k
    }
2204
2205
8.86k
  return rel_15_7 (mra, n + 1, n_operands, operand);
2206
8.86k
}
2207
2208
static int
2209
bm_n_bytes (struct mem_read_abstraction_base *mra)
2210
13.0k
{
2211
13.0k
  uint8_t bm;
2212
13.0k
  int status = mra->read (mra, 0, 1, &bm);
2213
13.0k
  if (status < 0)
2214
0
    return status;
2215
2216
13.0k
  size_t i;
2217
13.0k
  enum BM_MODE mode = -1;
2218
55.0k
  for (i = 0; i < sizeof (bm_table) / sizeof (bm_table[0]); ++i)
2219
55.0k
    {
2220
55.0k
      const struct bm *bme = bm_table + i;
2221
55.0k
      if ((bm & bme->mask) == bme->value)
2222
13.0k
  {
2223
13.0k
    mode = bme->mode;
2224
13.0k
    break;
2225
13.0k
  }
2226
55.0k
    }
2227
2228
13.0k
  int n = 0;
2229
13.0k
  switch (mode)
2230
13.0k
    {
2231
7.75k
    case BM_REG_IMM:
2232
8.05k
    case BM_RESERVED0:
2233
8.05k
      break;
2234
2235
532
    case BM_OPR_B:
2236
1.71k
    case BM_OPR_W:
2237
2.65k
    case BM_OPR_L:
2238
3.79k
    case BM_OPR_REG:
2239
4.96k
    case BM_RESERVED1:
2240
4.96k
      n = x_opr_n_bytes (mra, 1);
2241
4.96k
      if (n < 0)
2242
0
  return n;
2243
4.96k
      break;
2244
13.0k
    }
2245
2246
13.0k
  return n + 2;
2247
13.0k
}
2248
2249
static int
2250
bm_rel_n_bytes (struct mem_read_abstraction_base *mra)
2251
8.85k
{
2252
8.85k
  int n = 1 + bm_n_bytes (mra);
2253
2254
8.85k
  bfd_byte rb;
2255
8.85k
  int status = mra->read (mra, n - 2, 1, &rb);
2256
8.85k
  if (status != 0)
2257
0
    return status;
2258
2259
8.85k
  if (rb & 0x80)
2260
2.57k
    n++;
2261
2262
8.85k
  return n;
2263
8.85k
}
2264
2265
2266

2267
2268
2269
/* shift direction */
2270
enum SB_DIR
2271
  {
2272
    SB_LEFT,
2273
    SB_RIGHT
2274
  };
2275
2276
enum SB_TYPE
2277
  {
2278
    SB_ARITHMETIC,
2279
    SB_LOGICAL
2280
  };
2281
2282
2283
enum SB_MODE
2284
  {
2285
    SB_REG_REG_N_EFF,
2286
    SB_REG_REG_N,
2287
    SB_REG_OPR_EFF,
2288
    SB_ROT,
2289
    SB_REG_OPR_OPR,
2290
    SB_OPR_N
2291
  };
2292
2293
struct sb
2294
{
2295
  uint8_t mask;
2296
  uint8_t value;
2297
  enum SB_MODE mode;
2298
};
2299
2300
static const  struct sb sb_table[] = {
2301
  {0x30, 0x00,     SB_REG_REG_N_EFF},
2302
  {0x30, 0x10,     SB_REG_REG_N},
2303
  {0x34, 0x20,     SB_REG_OPR_EFF},
2304
  {0x34, 0x24,     SB_ROT},
2305
  {0x34, 0x30,     SB_REG_OPR_OPR},
2306
  {0x34, 0x34,     SB_OPR_N},
2307
};
2308
2309
static int
2310
shift_n_bytes (struct mem_read_abstraction_base *mra)
2311
14.3k
{
2312
14.3k
  bfd_byte sb;
2313
14.3k
  int opr1, opr2;
2314
14.3k
  int status = mra->read (mra, 0, 1, &sb);
2315
14.3k
  if (status != 0)
2316
0
    return status;
2317
2318
14.3k
  size_t i;
2319
14.3k
  enum SB_MODE mode = -1;
2320
100k
  for (i = 0; i < sizeof (sb_table) / sizeof (sb_table[0]); ++i)
2321
86.0k
    {
2322
86.0k
      const struct sb *sbe = sb_table + i;
2323
86.0k
      if ((sb & sbe->mask) == sbe->value)
2324
14.3k
  mode = sbe->mode;
2325
86.0k
    }
2326
2327
14.3k
  switch (mode)
2328
14.3k
    {
2329
3.67k
    case SB_REG_REG_N_EFF:
2330
3.67k
      return 2;
2331
546
    case SB_REG_OPR_EFF:
2332
1.12k
    case SB_ROT:
2333
1.12k
      opr1 = x_opr_n_bytes (mra, 1);
2334
1.12k
      if (opr1 < 0)
2335
0
  return opr1;
2336
1.12k
      return 2 + opr1;
2337
1.42k
    case SB_REG_OPR_OPR:
2338
1.42k
      opr1 = x_opr_n_bytes (mra, 1);
2339
1.42k
      if (opr1 < 0)
2340
0
  return opr1;
2341
1.42k
      opr2 = 0;
2342
1.42k
      if ((sb & 0x30) != 0x20)
2343
1.42k
  {
2344
1.42k
    opr2 = x_opr_n_bytes (mra, opr1 + 1);
2345
1.42k
    if (opr2 < 0)
2346
0
      return opr2;
2347
1.42k
  }
2348
1.42k
      return 2 + opr1 + opr2;
2349
8.11k
    default:
2350
8.11k
      return 3;
2351
14.3k
    }
2352
2353
  /* not reached */
2354
0
  return -1;
2355
14.3k
}
2356

2357
2358
static int
2359
mov_imm_opr_n_bytes (struct mem_read_abstraction_base *mra)
2360
6.57k
{
2361
6.57k
  bfd_byte byte;
2362
6.57k
  int status = mra->read (mra, -1, 1, &byte);
2363
6.57k
  if (status < 0)
2364
0
    return status;
2365
2366
6.57k
  int size = byte - 0x0c + 1;
2367
6.57k
  int n = x_opr_n_bytes (mra, size);
2368
6.57k
  if (n < 0)
2369
0
    return n;
2370
2371
6.57k
  return size + n + 1;
2372
6.57k
}
2373
2374
static int
2375
mov_imm_opr (struct mem_read_abstraction_base *mra,
2376
       int *n_operands, struct operand **operand)
2377
6.63k
{
2378
6.63k
  struct operand *op;
2379
6.63k
  bfd_byte byte;
2380
6.63k
  int status = mra->read (mra, -1, 1, &byte);
2381
6.63k
  if (status < 0)
2382
0
    return status;
2383
2384
6.63k
  int size = byte - 0x0c + 1;
2385
6.63k
  uint32_t imm;
2386
6.63k
  if (decode_signed_value (mra, size, &imm))
2387
32
    return -1;
2388
2389
6.60k
  op = create_immediate_operand (imm);
2390
6.60k
  if (op == NULL)
2391
0
    return -1;
2392
6.60k
  operand[(*n_operands)++] = op;
2393
6.60k
  op = x_opr_decode (mra, size);
2394
6.60k
  if (op == NULL)
2395
33
    return -1;
2396
6.57k
  operand[(*n_operands)++] = op;
2397
6.57k
  return 0;
2398
6.60k
}
2399
2400

2401
2402
static int
2403
ld_18bit_decode (struct mem_read_abstraction_base *mra,
2404
     int *n_operands, struct operand **operand)
2405
6.65k
{
2406
6.65k
  struct operand *op;
2407
6.65k
  size_t size = 3;
2408
6.65k
  bfd_byte buffer[3];
2409
6.65k
  int status = mra->read (mra, 0, 2, buffer + 1);
2410
6.65k
  if (status < 0)
2411
16
    return status;
2412
2413
6.63k
  status = mra->read (mra, -1, 1, buffer);
2414
6.63k
  if (status < 0)
2415
0
    return status;
2416
2417
6.63k
  buffer[0] = (buffer[0] & 0x30) >> 4;
2418
2419
6.63k
  size_t i;
2420
6.63k
  uint32_t imm = 0;
2421
26.5k
  for (i = 0; i < size; ++i)
2422
19.9k
    {
2423
19.9k
      imm |= buffer[i] << (8 * (size - i - 1));
2424
19.9k
    }
2425
2426
6.63k
  op = create_immediate_operand (imm);
2427
6.63k
  if (op == NULL)
2428
0
    return -1;
2429
6.63k
  operand[(*n_operands)++] = op;
2430
6.63k
  return 0;
2431
6.63k
}
2432
2433

2434
2435
/* Loop Primitives */
2436
2437
enum LP_MODE {
2438
  LP_REG,
2439
  LP_XY,
2440
  LP_OPR
2441
};
2442
2443
struct lp
2444
{
2445
  uint8_t mask;
2446
  uint8_t value;
2447
  enum LP_MODE mode;
2448
};
2449
2450
static const struct lp lp_mode[] = {
2451
  {0x08, 0x00, LP_REG},
2452
  {0x0C, 0x08, LP_XY},
2453
  {0x0C, 0x0C, LP_OPR},
2454
};
2455
2456
2457
static int
2458
loop_prim_n_bytes (struct mem_read_abstraction_base *mra)
2459
1.75k
{
2460
1.75k
  int mx = 0;
2461
1.75k
  uint8_t lb;
2462
1.75k
  int status = mra->read (mra, mx++, 1, &lb);
2463
1.75k
  if (status < 0)
2464
0
    return status;
2465
2466
1.75k
  enum LP_MODE mode = -1;
2467
1.75k
  size_t i;
2468
3.35k
  for (i = 0; i < sizeof (lp_mode) / sizeof (lp_mode[0]); ++i)
2469
3.35k
    {
2470
3.35k
      const struct lp *pb = lp_mode + i;
2471
3.35k
      if ((lb & pb->mask) == pb->value)
2472
1.75k
  {
2473
1.75k
    mode = pb->mode;
2474
1.75k
    break;
2475
1.75k
  }
2476
3.35k
    }
2477
2478
1.75k
  if (mode == LP_OPR)
2479
598
    {
2480
598
      int n = x_opr_n_bytes (mra, mx);
2481
598
      if (n < 0)
2482
0
  return n;
2483
598
      mx += n;
2484
598
    }
2485
2486
1.75k
  uint8_t rb;
2487
1.75k
  status = mra->read (mra, mx++, 1, &rb);
2488
1.75k
  if (status < 0)
2489
0
    return status;
2490
1.75k
  if (rb & 0x80)
2491
512
    mx++;
2492
2493
1.75k
  return mx + 1;
2494
1.75k
}
2495
2496
2497

2498
2499
static enum optr
2500
exg_sex_discrim (struct mem_read_abstraction_base *mra,
2501
     enum optr hint ATTRIBUTE_UNUSED)
2502
2.43k
{
2503
2.43k
  uint8_t eb;
2504
2.43k
  int status = mra->read (mra, 0, 1, &eb);
2505
2.43k
  enum optr operator = OP_INVALID;
2506
2.43k
  if (status < 0)
2507
7
    return operator;
2508
2509
2.42k
  struct operand *op0 = create_register_operand ((eb & 0xf0) >> 4);
2510
2.42k
  if (op0 == NULL)
2511
0
    return -1;
2512
2.42k
  struct operand *op1 = create_register_operand (eb & 0xf);
2513
2.42k
  if (op1 == NULL)
2514
0
    return -1;
2515
2516
2.42k
  int reg0 = ((struct register_operand *) op0)->reg;
2517
2.42k
  int reg1 = ((struct register_operand *) op1)->reg;
2518
2.42k
  if (reg0 >= 0 && reg0 < S12Z_N_REGISTERS
2519
2.30k
      && reg1 >= 0 && reg1 < S12Z_N_REGISTERS)
2520
2.21k
    {
2521
2.21k
      const struct reg *r0 = registers + reg0;
2522
2.21k
      const struct reg *r1 = registers + reg1;
2523
2524
2.21k
      operator = r0->bytes < r1->bytes ? OP_sex : OP_exg;
2525
2.21k
    }
2526
2527
2.42k
  free (op0);
2528
2.42k
  free (op1);
2529
2530
2.42k
  return operator;
2531
2.42k
}
2532
2533
2534
static int
2535
exg_sex_decode (struct mem_read_abstraction_base *mra,
2536
    int *n_operands, struct operand **operands)
2537
2.21k
{
2538
2.21k
  struct operand *op;
2539
2.21k
  uint8_t eb;
2540
2.21k
  int status = mra->read (mra, 0, 1, &eb);
2541
2.21k
  if (status < 0)
2542
0
    return status;
2543
2544
  /* Ship out the operands.  */
2545
2.21k
  op = create_register_operand ((eb & 0xf0) >> 4);
2546
2.21k
  if (op == NULL)
2547
0
    return -1;
2548
2.21k
  operands[(*n_operands)++] = op;
2549
2.21k
  op = create_register_operand (eb & 0xf);
2550
2.21k
  if (op == NULL)
2551
0
    return -1;
2552
2.21k
  operands[(*n_operands)++] = op;
2553
2.21k
  return 0;
2554
2.21k
}
2555
2556
static enum optr
2557
loop_primitive_discrim (struct mem_read_abstraction_base *mra,
2558
      enum optr hint ATTRIBUTE_UNUSED)
2559
1.76k
{
2560
1.76k
  uint8_t lb;
2561
1.76k
  int status = mra->read (mra, 0, 1, &lb);
2562
1.76k
  if (status < 0)
2563
2
    return OP_INVALID;
2564
2565
1.75k
  enum optr opbase = (lb & 0x80) ? OP_dbNE : OP_tbNE;
2566
1.75k
  return opbase + ((lb & 0x70) >> 4);
2567
1.76k
}
2568
2569
static int
2570
loop_primitive_decode (struct mem_read_abstraction_base *mra,
2571
           int *n_operands, struct operand **operands)
2572
1.75k
{
2573
1.75k
  struct operand *op;
2574
1.75k
  int n, offs = 1;
2575
1.75k
  uint8_t lb;
2576
1.75k
  int status = mra->read (mra, 0, 1, &lb);
2577
1.75k
  if (status < 0)
2578
0
    return status;
2579
2580
1.75k
  enum LP_MODE mode = -1;
2581
1.75k
  size_t i;
2582
3.35k
  for (i = 0; i < sizeof (lp_mode) / sizeof (lp_mode[0]); ++i)
2583
3.35k
    {
2584
3.35k
      const struct lp *pb = lp_mode + i;
2585
3.35k
      if ((lb & pb->mask) == pb->value)
2586
1.75k
  {
2587
1.75k
    mode = pb->mode;
2588
1.75k
    break;
2589
1.75k
  }
2590
3.35k
    }
2591
2592
1.75k
  switch (mode)
2593
1.75k
    {
2594
758
    case LP_REG:
2595
758
      op = create_register_operand (lb & 0x07);
2596
758
      if (op == NULL)
2597
0
  return -1;
2598
758
      operands[(*n_operands)++] = op;
2599
758
      break;
2600
402
    case LP_XY:
2601
402
      op = create_register_operand ((lb & 0x01) + REG_X);
2602
402
      if (op == NULL)
2603
0
  return -1;
2604
402
      operands[(*n_operands)++] = op;
2605
402
      break;
2606
599
    case LP_OPR:
2607
599
      n = x_opr_n_bytes (mra, 1);
2608
599
      if (n < 0)
2609
1
  return n;
2610
598
      offs += n;
2611
598
      op = x_opr_decode_with_size (mra, 1, lb & 0x03);
2612
598
      if (op == NULL)
2613
0
  return -1;
2614
598
      operands[(*n_operands)++] = op;
2615
598
      break;
2616
1.75k
    }
2617
2618
1.75k
  return rel_15_7 (mra, offs + 1, n_operands, operands);
2619
1.75k
}
2620
2621
2622
static enum optr
2623
shift_discrim (struct mem_read_abstraction_base *mra,
2624
         enum optr hint ATTRIBUTE_UNUSED)
2625
14.3k
{
2626
14.3k
  size_t i;
2627
14.3k
  uint8_t sb;
2628
14.3k
  int status = mra->read (mra, 0, 1, &sb);
2629
14.3k
  if (status < 0)
2630
13
    return OP_INVALID;
2631
2632
14.3k
  enum SB_DIR  dir = (sb & 0x40) ? SB_LEFT : SB_RIGHT;
2633
14.3k
  enum SB_TYPE type = (sb & 0x80) ? SB_ARITHMETIC : SB_LOGICAL;
2634
14.3k
  enum SB_MODE mode = -1;
2635
100k
  for (i = 0; i < sizeof (sb_table) / sizeof (sb_table[0]); ++i)
2636
86.2k
    {
2637
86.2k
      const struct sb *sbe = sb_table + i;
2638
86.2k
      if ((sb & sbe->mask) == sbe->value)
2639
14.3k
  mode = sbe->mode;
2640
86.2k
    }
2641
2642
14.3k
  if (mode == SB_ROT)
2643
582
    return (dir == SB_LEFT) ? OP_rol : OP_ror;
2644
2645
13.7k
  if (type == SB_LOGICAL)
2646
10.7k
    return (dir == SB_LEFT) ? OP_lsl : OP_lsr;
2647
2648
3.07k
  return (dir == SB_LEFT) ? OP_asl : OP_asr;
2649
13.7k
}
2650
2651
2652
static int
2653
shift_decode (struct mem_read_abstraction_base *mra, int *n_operands,
2654
        struct operand **operands)
2655
14.3k
{
2656
14.3k
  struct operand *op;
2657
14.3k
  size_t i;
2658
14.3k
  uint8_t byte;
2659
14.3k
  int status = mra->read (mra, -1, 1, &byte);
2660
14.3k
  if (status < 0)
2661
0
    return status;
2662
2663
14.3k
  uint8_t sb;
2664
14.3k
  status = mra->read (mra, 0, 1, &sb);
2665
14.3k
  if (status < 0)
2666
0
    return status;
2667
2668
14.3k
  enum SB_MODE mode = -1;
2669
100k
  for (i = 0; i < sizeof (sb_table) / sizeof (sb_table[0]); ++i)
2670
86.2k
    {
2671
86.2k
      const struct sb *sbe = sb_table + i;
2672
86.2k
      if ((sb & sbe->mask) == sbe->value)
2673
14.3k
  mode = sbe->mode;
2674
86.2k
    }
2675
2676
14.3k
  short osize = -1;
2677
14.3k
  switch (mode)
2678
14.3k
    {
2679
549
    case SB_REG_OPR_EFF:
2680
1.13k
    case SB_ROT:
2681
2.56k
    case SB_REG_OPR_OPR:
2682
2.56k
      osize = sb & 0x03;
2683
2.56k
      break;
2684
1.61k
    case SB_OPR_N:
2685
1.61k
      {
2686
1.61k
  uint8_t xb;
2687
1.61k
  status = mra->read (mra, 1, 1, &xb);
2688
1.61k
  if (status < 0)
2689
6
    return status;
2690
  /* The size suffix is not printed if the OPR operand refers
2691
     directly to a register, because the size is implied by the
2692
     size of that register. */
2693
1.60k
  if ((xb & 0xF8) != 0xB8)
2694
1.58k
    osize = sb & 0x03;
2695
1.60k
      }
2696
0
      break;
2697
10.1k
    default:
2698
10.1k
      break;
2699
14.3k
    };
2700
2701
  /* Destination register */
2702
14.3k
  switch (mode)
2703
14.3k
    {
2704
3.67k
    case SB_REG_REG_N_EFF:
2705
10.1k
    case SB_REG_REG_N:
2706
10.1k
      op = create_register_operand (byte & 0x07);
2707
10.1k
      if (op == NULL)
2708
0
  return -1;
2709
10.1k
      operands[(*n_operands)++] = op;
2710
10.1k
      break;
2711
549
    case SB_REG_OPR_EFF:
2712
1.97k
    case SB_REG_OPR_OPR:
2713
1.97k
      op = create_register_operand (byte & 0x07);
2714
1.97k
      if (op == NULL)
2715
0
  return -1;
2716
1.97k
      operands[(*n_operands)++] = op;
2717
1.97k
      break;
2718
2719
582
    case SB_ROT:
2720
582
      op = x_opr_decode_with_size (mra, 1, osize);
2721
582
      if (op == NULL)
2722
1
  return -1;
2723
581
      operands[(*n_operands)++] = op;
2724
581
      break;
2725
2726
1.60k
    default:
2727
1.60k
      break;
2728
14.3k
    }
2729
2730
  /* Source register */
2731
14.3k
  switch (mode)
2732
14.3k
    {
2733
3.67k
    case SB_REG_REG_N_EFF:
2734
10.1k
    case SB_REG_REG_N:
2735
10.1k
      op = create_register_operand_with_size (sb & 0x07, osize);
2736
10.1k
      if (op == NULL)
2737
0
  return -1;
2738
10.1k
      operands[(*n_operands)++] = op;
2739
10.1k
      break;
2740
2741
1.42k
    case SB_REG_OPR_OPR:
2742
1.42k
      op = x_opr_decode_with_size (mra, 1, osize);
2743
1.42k
      if (op == NULL)
2744
2
  return -1;
2745
1.42k
      operands[(*n_operands)++] = op;
2746
1.42k
      break;
2747
2748
2.73k
    default:
2749
2.73k
      break;
2750
14.3k
    }
2751
2752
  /* 3rd arg */
2753
14.3k
  switch (mode)
2754
14.3k
    {
2755
549
    case SB_REG_OPR_EFF:
2756
2.15k
    case SB_OPR_N:
2757
2.15k
      op = x_opr_decode_with_size (mra, 1, osize);
2758
2.15k
      if (op == NULL)
2759
3
  return -1;
2760
2.15k
      operands[(*n_operands)++] = op;
2761
2.15k
      break;
2762
2763
6.52k
    case SB_REG_REG_N:
2764
6.52k
      {
2765
6.52k
  uint8_t xb;
2766
6.52k
  status = mra->read (mra, 1, 1, &xb);
2767
6.52k
  if (status < 0)
2768
3
    return status;
2769
2770
  /* This case is slightly unusual.
2771
     If XB matches the binary pattern 0111XXXX, then instead of
2772
     interpreting this as a general OPR postbyte in the IMMe4 mode,
2773
     the XB byte is interpreted in s special way.  */
2774
6.52k
  if ((xb & 0xF0) == 0x70)
2775
142
    {
2776
142
      if (byte & 0x10)
2777
142
        {
2778
142
    int shift = ((sb & 0x08) >> 3) | ((xb & 0x0f) << 1);
2779
142
    op = create_immediate_operand (shift);
2780
142
    if (op == NULL)
2781
0
      return -1;
2782
142
    operands[(*n_operands)++] = op;
2783
142
        }
2784
0
      else
2785
0
        {
2786
    /* This should not happen.  */
2787
0
    abort ();
2788
0
        }
2789
142
    }
2790
6.38k
  else
2791
6.38k
    {
2792
6.38k
      op = x_opr_decode (mra, 1);
2793
6.38k
      if (op == NULL)
2794
11
        return -1;
2795
6.37k
      operands[(*n_operands)++] = op;
2796
6.37k
    }
2797
6.52k
      }
2798
6.51k
      break;
2799
6.51k
    case SB_REG_OPR_OPR:
2800
1.42k
      {
2801
1.42k
  uint8_t xb;
2802
1.42k
  int n = x_opr_n_bytes (mra, 1);
2803
1.42k
  if (n < 0)
2804
0
    return n;
2805
1.42k
  status = mra->read (mra, 1 + n, 1, &xb);
2806
1.42k
  if (status < 0)
2807
3
    return status;
2808
2809
1.42k
  if ((xb & 0xF0) == 0x70)
2810
69
    {
2811
69
      int imm = xb & 0x0F;
2812
69
      imm <<= 1;
2813
69
      imm |= (sb & 0x08) >> 3;
2814
69
      op = create_immediate_operand (imm);
2815
69
      if (op == NULL)
2816
0
        return -1;
2817
69
      operands[(*n_operands)++] = op;
2818
69
    }
2819
1.35k
  else
2820
1.35k
    {
2821
1.35k
      op = x_opr_decode (mra, 1 + n);
2822
1.35k
      if (op == NULL)
2823
0
        return -1;
2824
1.35k
      operands[(*n_operands)++] = op;
2825
1.35k
    }
2826
1.42k
      }
2827
1.42k
      break;
2828
4.25k
    default:
2829
4.25k
      break;
2830
14.3k
    }
2831
2832
14.3k
  switch (mode)
2833
14.3k
    {
2834
3.67k
    case SB_REG_REG_N_EFF:
2835
4.21k
    case SB_REG_OPR_EFF:
2836
5.82k
    case SB_OPR_N:
2837
5.82k
      {
2838
5.82k
  int imm = (sb & 0x08) ? 2 : 1;
2839
5.82k
  op = create_immediate_operand (imm);
2840
5.82k
  if (op == NULL)
2841
0
    return -1;
2842
5.82k
  operands[(*n_operands)++] = op;
2843
5.82k
      }
2844
0
      break;
2845
2846
8.51k
    default:
2847
8.51k
      break;
2848
14.3k
    }
2849
14.3k
  return 0;
2850
14.3k
}
2851
2852
static enum optr
2853
psh_pul_discrim (struct mem_read_abstraction_base *mra,
2854
     enum optr hint ATTRIBUTE_UNUSED)
2855
8.47k
{
2856
8.47k
  uint8_t byte;
2857
8.47k
  int status = mra->read (mra, 0, 1, &byte);
2858
8.47k
  if (status != 0)
2859
14
    return OP_INVALID;
2860
2861
8.46k
  return (byte & 0x80) ? OP_pull: OP_push;
2862
8.47k
}
2863
2864
2865
static int
2866
psh_pul_decode (struct mem_read_abstraction_base *mra,
2867
    int *n_operands, struct operand **operand)
2868
8.46k
{
2869
8.46k
  struct operand *op;
2870
8.46k
  uint8_t byte;
2871
8.46k
  int status = mra->read (mra, 0, 1, &byte);
2872
8.46k
  if (status != 0)
2873
0
    return status;
2874
8.46k
  int bit;
2875
8.46k
  if (byte & 0x40)
2876
2.38k
    {
2877
2.38k
      if ((byte & 0x3F) == 0)
2878
646
  {
2879
646
    op = create_register_all16_operand ();
2880
646
    if (op == NULL)
2881
0
      return -1;
2882
646
    operand[(*n_operands)++] = op;
2883
646
  }
2884
1.73k
      else
2885
12.1k
  for (bit = 5; bit >= 0; --bit)
2886
10.4k
    {
2887
10.4k
      if (byte & (0x1 << bit))
2888
4.96k
        {
2889
4.96k
    op = create_register_operand (oprregs2[bit]);
2890
4.96k
    if (op == NULL)
2891
0
      return -1;
2892
4.96k
    operand[(*n_operands)++] = op;
2893
4.96k
        }
2894
10.4k
    }
2895
2.38k
    }
2896
6.07k
  else
2897
6.07k
    {
2898
6.07k
      if ((byte & 0x3F) == 0)
2899
2.87k
  {
2900
2.87k
    op = create_register_all_operand ();
2901
2.87k
    if (op == NULL)
2902
0
      return -1;
2903
2.87k
    operand[(*n_operands)++] = op;
2904
2.87k
  }
2905
3.20k
      else
2906
22.4k
  for (bit = 5; bit >= 0; --bit)
2907
19.2k
    {
2908
19.2k
      if (byte & (0x1 << bit))
2909
4.08k
        {
2910
4.08k
    op = create_register_operand (oprregs1[bit]);
2911
4.08k
    if (op == NULL)
2912
0
      return -1;
2913
4.08k
    operand[(*n_operands)++] = op;
2914
4.08k
        }
2915
19.2k
    }
2916
6.07k
    }
2917
8.46k
  return 0;
2918
8.46k
}
2919
2920
static enum optr
2921
bit_field_discrim (struct mem_read_abstraction_base *mra,
2922
       enum optr hint ATTRIBUTE_UNUSED)
2923
1.12k
{
2924
1.12k
  int status;
2925
1.12k
  bfd_byte bb;
2926
1.12k
  status = mra->read (mra, 0, 1, &bb);
2927
1.12k
  if (status != 0)
2928
0
    return OP_INVALID;
2929
2930
1.12k
  return (bb & 0x80) ? OP_bfins : OP_bfext;
2931
1.12k
}
2932
2933
static int
2934
bit_field_decode (struct mem_read_abstraction_base *mra,
2935
      int *n_operands, struct operand **operands)
2936
1.12k
{
2937
1.12k
  struct operand *op;
2938
1.12k
  int status;
2939
2940
1.12k
  bfd_byte byte2;
2941
1.12k
  status = mra->read (mra, -1, 1, &byte2);
2942
1.12k
  if (status != 0)
2943
0
    return status;
2944
2945
1.12k
  bfd_byte bb;
2946
1.12k
  status = mra->read (mra, 0, 1, &bb);
2947
1.12k
  if (status != 0)
2948
0
    return status;
2949
2950
1.12k
  enum BB_MODE mode = -1;
2951
1.12k
  size_t i;
2952
1.12k
  const struct opr_bb *bbs = 0;
2953
4.60k
  for (i = 0; i < sizeof (bb_modes) / sizeof (bb_modes[0]); ++i)
2954
4.60k
    {
2955
4.60k
      bbs = bb_modes + i;
2956
4.60k
      if ((bb & bbs->mask) == bbs->value)
2957
1.12k
  {
2958
1.12k
    mode = bbs->mode;
2959
1.12k
    break;
2960
1.12k
  }
2961
4.60k
    }
2962
1.12k
  int reg1 = byte2 & 0x07;
2963
  /* First operand */
2964
1.12k
  switch (mode)
2965
1.12k
    {
2966
132
    case BB_REG_REG_REG:
2967
228
    case BB_REG_REG_IMM:
2968
460
    case BB_REG_OPR_REG:
2969
787
    case BB_REG_OPR_IMM:
2970
787
      op = create_register_operand (reg1);
2971
787
      if (op == NULL)
2972
0
  return -1;
2973
787
      operands[(*n_operands)++] = op;
2974
787
      break;
2975
47
    case BB_OPR_REG_REG:
2976
47
      op = x_opr_decode_with_size (mra, 1, (bb >> 2) & 0x03);
2977
47
      if (op == NULL)
2978
1
  return -1;
2979
46
      operands[(*n_operands)++] = op;
2980
46
      break;
2981
294
    case BB_OPR_REG_IMM:
2982
294
      op = x_opr_decode_with_size (mra, 2, (bb >> 2) & 0x03);
2983
294
      if (op == NULL)
2984
1
  return -1;
2985
293
      operands[(*n_operands)++] = op;
2986
293
      break;
2987
1.12k
    }
2988
2989
  /* Second operand */
2990
1.12k
  switch (mode)
2991
1.12k
    {
2992
132
    case BB_REG_REG_REG:
2993
228
    case BB_REG_REG_IMM:
2994
228
      {
2995
228
  int reg_src = (bb >> 2) & 0x07;
2996
228
  op = create_register_operand (reg_src);
2997
228
  if (op == NULL)
2998
0
    return -1;
2999
228
  operands[(*n_operands)++] = op;
3000
228
      }
3001
0
      break;
3002
46
    case BB_OPR_REG_REG:
3003
339
    case BB_OPR_REG_IMM:
3004
339
      {
3005
339
  int reg_src = (byte2 & 0x07);
3006
339
  op = create_register_operand (reg_src);
3007
339
  if (op == NULL)
3008
0
    return -1;
3009
339
  operands[(*n_operands)++] = op;
3010
339
      }
3011
0
      break;
3012
232
    case BB_REG_OPR_REG:
3013
232
      op = x_opr_decode_with_size (mra, 1, (bb >> 2) & 0x03);
3014
232
      if (op == NULL)
3015
1
  return -1;
3016
231
      operands[(*n_operands)++] = op;
3017
231
      break;
3018
327
    case BB_REG_OPR_IMM:
3019
327
      op = x_opr_decode_with_size (mra, 2, (bb >> 2) & 0x03);
3020
327
      if (op == NULL)
3021
2
  return -1;
3022
325
      operands[(*n_operands)++] = op;
3023
325
      break;
3024
1.12k
    }
3025
3026
  /* Third operand */
3027
1.12k
  switch (mode)
3028
1.12k
    {
3029
132
    case BB_REG_REG_REG:
3030
178
    case BB_OPR_REG_REG:
3031
409
    case BB_REG_OPR_REG:
3032
409
      {
3033
409
  int reg_parm = bb & 0x03;
3034
409
  op = create_register_operand (reg_parm);
3035
409
  if (op == NULL)
3036
0
    return -1;
3037
409
  operands[(*n_operands)++] = op;
3038
409
      }
3039
0
      break;
3040
96
    case BB_REG_REG_IMM:
3041
389
    case BB_OPR_REG_IMM:
3042
714
    case BB_REG_OPR_IMM:
3043
714
      {
3044
714
  bfd_byte i1;
3045
714
  status = mra->read (mra, 1, 1, &i1);
3046
714
  if (status < 0)
3047
1
    return status;
3048
713
  int offset = i1 & 0x1f;
3049
713
  int width = bb & 0x03;
3050
713
  width <<= 3;
3051
713
  width |= i1 >> 5;
3052
713
  op = create_bitfield_operand (width, offset);
3053
713
  if (op == NULL)
3054
0
    return -1;
3055
713
  operands[(*n_operands)++] = op;
3056
713
      }
3057
0
      break;
3058
1.12k
    }
3059
1.12k
  return 0;
3060
1.12k
}
3061
3062
3063
/* Decode the next instruction at MRA, according to OPC.
3064
   The operation to be performed is returned.
3065
   The number of operands, will be placed in N_OPERANDS.
3066
   The operands themselved into OPERANDS.  */
3067
static enum optr
3068
decode_operation (const struct opcode *opc,
3069
      struct mem_read_abstraction_base *mra,
3070
      int *n_operands, struct operand **operands)
3071
503k
{
3072
503k
  enum optr op = opc->operator;
3073
503k
  if (opc->discriminator)
3074
44.2k
    {
3075
44.2k
      op = opc->discriminator (mra, opc->operator);
3076
44.2k
      if (op == OP_INVALID)
3077
272
  return op;
3078
44.2k
    }
3079
3080
502k
  if (opc->operands)
3081
290k
    if (opc->operands (mra, n_operands, operands) < 0)
3082
260
      return OP_INVALID;
3083
3084
502k
  if (opc->operands2)
3085
142k
    if (opc->operands2 (mra, n_operands, operands) < 0)
3086
242
      return OP_INVALID;
3087
3088
502k
  return op;
3089
502k
}
3090
3091
int
3092
decode_s12z (enum optr *myoperator, short *osize,
3093
       int *n_operands, struct operand **operands,
3094
       struct mem_read_abstraction_base *mra)
3095
503k
{
3096
503k
  int n_bytes = 0;
3097
503k
  bfd_byte byte;
3098
3099
503k
  int status = mra->read (mra, 0, 1, &byte);
3100
503k
  if (status < 0)
3101
1
    return status;
3102
3103
503k
  mra->advance (mra);
3104
3105
503k
  const struct opcode *opc = page1 + byte;
3106
503k
  if (byte == PAGE2_PREBYTE)
3107
4.92k
    {
3108
      /* Opcodes in page2 have an additional byte */
3109
4.92k
      n_bytes++;
3110
3111
4.92k
      bfd_byte byte2;
3112
4.92k
      status = mra->read (mra, 0, 1, &byte2);
3113
4.92k
      if (status < 0)
3114
11
  return status;
3115
4.91k
      mra->advance (mra);
3116
4.91k
      opc = page2 + byte2;
3117
4.91k
    }
3118
503k
  *myoperator = decode_operation (opc, mra, n_operands, operands);
3119
503k
  *osize = opc->osize;
3120
3121
  /* Return the number of bytes in the instruction.  */
3122
503k
  if (*myoperator != OP_INVALID && opc->insn_bytes)
3123
501k
    {
3124
501k
      int n = opc->insn_bytes (mra);
3125
501k
      if (n < 0)
3126
0
  return n;
3127
501k
      n_bytes += n;
3128
501k
    }
3129
2.06k
  else
3130
2.06k
    n_bytes += 1;
3131
3132
503k
  return n_bytes;
3133
503k
}
3134