Coverage Report

Created: 2026-05-11 07:54

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/binutils-gdb/opcodes/m32c-dis.c
Line
Count
Source
1
/* DO NOT EDIT!  -*- buffer-read-only: t -*- vi:set ro:  */
2
/* Disassembler interface for targets using CGEN. -*- C -*-
3
   CGEN: Cpu tools GENerator
4
5
   THIS FILE IS MACHINE GENERATED WITH CGEN.
6
   - the resultant file is machine generated, cgen-dis.in isn't
7
8
   Copyright (C) 1996-2026 Free Software Foundation, Inc.
9
10
   This file is part of libopcodes.
11
12
   This library is free software; you can redistribute it and/or modify
13
   it under the terms of the GNU General Public License as published by
14
   the Free Software Foundation; either version 3, or (at your option)
15
   any later version.
16
17
   It is distributed in the hope that it will be useful, but WITHOUT
18
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
19
   or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
20
   License for more details.
21
22
   You should have received a copy of the GNU General Public License
23
   along with this program; if not, write to the Free Software Foundation, Inc.,
24
   51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.  */
25
26
/* ??? Eventually more and more of this stuff can go to cpu-independent files.
27
   Keep that in mind.  */
28
29
#include "sysdep.h"
30
#include <stdio.h>
31
#include "ansidecl.h"
32
#include "disassemble.h"
33
#include "bfd.h"
34
#include "symcat.h"
35
#include "libiberty.h"
36
#include "m32c-desc.h"
37
#include "m32c-opc.h"
38
#include "opintl.h"
39
40
/* Default text to print if an instruction isn't recognized.  */
41
22.7k
#define UNKNOWN_INSN_MSG _("*unknown*")
42
43
static void print_normal
44
  (CGEN_CPU_DESC, void *, long, unsigned int, bfd_vma, int);
45
static void print_address
46
  (CGEN_CPU_DESC, void *, bfd_vma, unsigned int, bfd_vma, int) ATTRIBUTE_UNUSED;
47
static void print_keyword
48
  (CGEN_CPU_DESC, void *, CGEN_KEYWORD *, long, unsigned int) ATTRIBUTE_UNUSED;
49
static void print_insn_normal
50
  (CGEN_CPU_DESC, void *, const CGEN_INSN *, CGEN_FIELDS *, bfd_vma, int);
51
static int print_insn
52
  (CGEN_CPU_DESC, bfd_vma,  disassemble_info *, bfd_byte *, unsigned);
53
static int default_print_insn
54
  (CGEN_CPU_DESC, bfd_vma, disassemble_info *) ATTRIBUTE_UNUSED;
55
static int read_insn
56
  (CGEN_CPU_DESC, bfd_vma, disassemble_info *, bfd_byte *, int, CGEN_EXTRACT_INFO *,
57
   unsigned long *);
58

59
/* -- disassembler routines inserted here.  */
60
61
/* -- dis.c */
62
63
#include "elf/m32c.h"
64
#include "elf-bfd.h"
65
66
/* Always print the short insn format suffix as ':<char>'.  */
67
68
static void
69
print_suffix (void * dis_info, char suffix)
70
130k
{
71
130k
  disassemble_info *info = dis_info;
72
73
130k
  (*info->fprintf_func) (info->stream, ":%c", suffix);
74
130k
}
75
76
static void
77
print_S (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
78
   void * dis_info,
79
   long value ATTRIBUTE_UNUSED,
80
   unsigned int attrs ATTRIBUTE_UNUSED,
81
   bfd_vma pc ATTRIBUTE_UNUSED,
82
   int length ATTRIBUTE_UNUSED)
83
90.0k
{
84
90.0k
  print_suffix (dis_info, 's');
85
90.0k
}
86
87
88
static void
89
print_G (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
90
   void * dis_info,
91
   long value ATTRIBUTE_UNUSED,
92
   unsigned int attrs ATTRIBUTE_UNUSED,
93
   bfd_vma pc ATTRIBUTE_UNUSED,
94
   int length ATTRIBUTE_UNUSED)
95
23.0k
{
96
23.0k
  print_suffix (dis_info, 'g');
97
23.0k
}
98
99
static void
100
print_Q (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
101
   void * dis_info,
102
   long value ATTRIBUTE_UNUSED,
103
   unsigned int attrs ATTRIBUTE_UNUSED,
104
   bfd_vma pc ATTRIBUTE_UNUSED,
105
   int length ATTRIBUTE_UNUSED)
106
12.6k
{
107
12.6k
  print_suffix (dis_info, 'q');
108
12.6k
}
109
110
static void
111
print_Z (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
112
   void * dis_info,
113
   long value ATTRIBUTE_UNUSED,
114
   unsigned int attrs ATTRIBUTE_UNUSED,
115
   bfd_vma pc ATTRIBUTE_UNUSED,
116
   int length ATTRIBUTE_UNUSED)
117
4.98k
{
118
4.98k
  print_suffix (dis_info, 'z');
119
4.98k
}
120
121
/* Print the empty suffix.  */
122
123
static void
124
print_X (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
125
   void * dis_info ATTRIBUTE_UNUSED,
126
   long value ATTRIBUTE_UNUSED,
127
   unsigned int attrs ATTRIBUTE_UNUSED,
128
   bfd_vma pc ATTRIBUTE_UNUSED,
129
   int length ATTRIBUTE_UNUSED)
130
7.85k
{
131
7.85k
  return;
132
7.85k
}
133
134
static void
135
print_r0l_r0h (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
136
         void * dis_info,
137
         long value,
138
         unsigned int attrs ATTRIBUTE_UNUSED,
139
         bfd_vma pc ATTRIBUTE_UNUSED,
140
         int length ATTRIBUTE_UNUSED)
141
9.85k
{
142
9.85k
  disassemble_info *info = dis_info;
143
144
9.85k
  if (value == 0)
145
5.50k
    (*info->fprintf_func) (info->stream, "r0h,r0l");
146
4.35k
  else
147
4.35k
    (*info->fprintf_func) (info->stream, "r0l,r0h");
148
9.85k
}
149
150
static void
151
print_unsigned_bitbase (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
152
      void * dis_info,
153
      unsigned long value,
154
      unsigned int attrs ATTRIBUTE_UNUSED,
155
      bfd_vma pc ATTRIBUTE_UNUSED,
156
      int length ATTRIBUTE_UNUSED)
157
13.3k
{
158
13.3k
  disassemble_info *info = dis_info;
159
160
13.3k
  (*info->fprintf_func) (info->stream, "%ld,0x%lx", value & 0x7, value >> 3);
161
13.3k
}
162
163
static void
164
print_signed_bitbase (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
165
          void * dis_info,
166
          signed long value,
167
          unsigned int attrs ATTRIBUTE_UNUSED,
168
          bfd_vma pc ATTRIBUTE_UNUSED,
169
          int length ATTRIBUTE_UNUSED)
170
527
{
171
527
  disassemble_info *info = dis_info;
172
173
527
  (*info->fprintf_func) (info->stream, "%ld,%ld", value & 0x7, value >> 3);
174
527
}
175
176
static void
177
print_size (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
178
      void * dis_info,
179
      long value ATTRIBUTE_UNUSED,
180
      unsigned int attrs ATTRIBUTE_UNUSED,
181
      bfd_vma pc ATTRIBUTE_UNUSED,
182
      int length ATTRIBUTE_UNUSED)
183
0
{
184
  /* Always print the size as '.w'.  */
185
0
  disassemble_info *info = dis_info;
186
187
0
  (*info->fprintf_func) (info->stream, ".w");
188
0
}
189
190
1.59k
#define POP  0
191
813
#define PUSH 1
192
193
static void print_pop_regset  (CGEN_CPU_DESC, void *, long, unsigned int, bfd_vma, int);
194
static void print_push_regset (CGEN_CPU_DESC, void *, long, unsigned int, bfd_vma, int);
195
196
/* Print a set of registers, R0,R1,A0,A1,SB,FB.  */
197
198
static void
199
print_regset (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
200
        void * dis_info,
201
        long value,
202
        unsigned int attrs ATTRIBUTE_UNUSED,
203
        bfd_vma pc ATTRIBUTE_UNUSED,
204
        int length ATTRIBUTE_UNUSED,
205
        int push)
206
2.41k
{
207
2.41k
  static char * m16c_register_names [] =
208
2.41k
  {
209
2.41k
    "r0", "r1", "r2", "r3", "a0", "a1", "sb", "fb"
210
2.41k
  };
211
2.41k
  disassemble_info *info = dis_info;
212
2.41k
  int mask;
213
2.41k
  int reg_index = 0;
214
2.41k
  char* comma = "";
215
216
2.41k
  if (push)
217
813
    mask = 0x80;
218
1.59k
  else
219
1.59k
    mask = 1;
220
221
2.41k
  if (value & mask)
222
1.47k
    {
223
1.47k
      (*info->fprintf_func) (info->stream, "%s", m16c_register_names [0]);
224
1.47k
      comma = ",";
225
1.47k
    }
226
227
19.2k
  for (reg_index = 1; reg_index <= 7; ++reg_index)
228
16.8k
    {
229
16.8k
      if (push)
230
5.69k
        mask >>= 1;
231
11.1k
      else
232
11.1k
        mask <<= 1;
233
234
16.8k
      if (value & mask)
235
10.0k
        {
236
10.0k
          (*info->fprintf_func) (info->stream, "%s%s", comma,
237
10.0k
         m16c_register_names [reg_index]);
238
10.0k
          comma = ",";
239
10.0k
        }
240
16.8k
    }
241
2.41k
}
242
243
static void
244
print_pop_regset (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
245
      void * dis_info,
246
      long value,
247
      unsigned int attrs ATTRIBUTE_UNUSED,
248
      bfd_vma pc ATTRIBUTE_UNUSED,
249
      int length ATTRIBUTE_UNUSED)
250
1.59k
{
251
1.59k
  print_regset (cd, dis_info, value, attrs, pc, length, POP);
252
1.59k
}
253
254
static void
255
print_push_regset (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
256
       void * dis_info,
257
       long value,
258
       unsigned int attrs ATTRIBUTE_UNUSED,
259
       bfd_vma pc ATTRIBUTE_UNUSED,
260
       int length ATTRIBUTE_UNUSED)
261
813
{
262
813
  print_regset (cd, dis_info, value, attrs, pc, length, PUSH);
263
813
}
264
265
static void
266
print_signed4n (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
267
    void * dis_info,
268
    signed long value,
269
    unsigned int attrs ATTRIBUTE_UNUSED,
270
    bfd_vma pc ATTRIBUTE_UNUSED,
271
    int length ATTRIBUTE_UNUSED)
272
2.29k
{
273
2.29k
  disassemble_info *info = dis_info;
274
275
2.29k
  (*info->fprintf_func) (info->stream, "%ld", -value);
276
2.29k
}
277
278
void m32c_cgen_print_operand
279
  (CGEN_CPU_DESC, int, void *, CGEN_FIELDS *, void const *, bfd_vma, int);
280
281
/* Main entry point for printing operands.
282
   XINFO is a `void *' and not a `disassemble_info *' to not put a requirement
283
   of dis-asm.h on cgen.h.
284
285
   This function is basically just a big switch statement.  Earlier versions
286
   used tables to look up the function to use, but
287
   - if the table contains both assembler and disassembler functions then
288
     the disassembler contains much of the assembler and vice-versa,
289
   - there's a lot of inlining possibilities as things grow,
290
   - using a switch statement avoids the function call overhead.
291
292
   This function could be moved into `print_insn_normal', but keeping it
293
   separate makes clear the interface between `print_insn_normal' and each of
294
   the handlers.  */
295
296
void
297
m32c_cgen_print_operand (CGEN_CPU_DESC cd,
298
         int opindex,
299
         void * xinfo,
300
         CGEN_FIELDS *fields,
301
         void const *attrs ATTRIBUTE_UNUSED,
302
         bfd_vma pc,
303
         int length)
304
429k
{
305
429k
  disassemble_info *info = (disassemble_info *) xinfo;
306
307
429k
  switch (opindex)
308
429k
    {
309
0
    case M32C_OPERAND_A0 :
310
0
      print_keyword (cd, info, & m32c_cgen_opval_h_a0, 0, 0);
311
0
      break;
312
0
    case M32C_OPERAND_A1 :
313
0
      print_keyword (cd, info, & m32c_cgen_opval_h_a1, 0, 0);
314
0
      break;
315
1.36k
    case M32C_OPERAND_AN16_PUSH_S :
316
1.36k
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_HI, fields->f_4_1, 0);
317
1.36k
      break;
318
346
    case M32C_OPERAND_BIT16AN :
319
346
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_dst16_an, 0);
320
346
      break;
321
290
    case M32C_OPERAND_BIT16RN :
322
290
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_HI, fields->f_dst16_rn, 0);
323
290
      break;
324
3.43k
    case M32C_OPERAND_BIT3_S :
325
3.43k
      print_normal (cd, info, fields->f_imm3_S, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
326
3.43k
      break;
327
462
    case M32C_OPERAND_BIT32ANPREFIXED :
328
462
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_dst32_an_prefixed, 0);
329
462
      break;
330
854
    case M32C_OPERAND_BIT32ANUNPREFIXED :
331
854
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_dst32_an_unprefixed, 0);
332
854
      break;
333
52
    case M32C_OPERAND_BIT32RNPREFIXED :
334
52
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_QI, fields->f_dst32_rn_prefixed_QI, 0);
335
52
      break;
336
612
    case M32C_OPERAND_BIT32RNUNPREFIXED :
337
612
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_QI, fields->f_dst32_rn_unprefixed_QI, 0);
338
612
      break;
339
39
    case M32C_OPERAND_BITBASE16_16_S8 :
340
39
      print_signed_bitbase (cd, info, fields->f_dsp_16_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
341
39
      break;
342
225
    case M32C_OPERAND_BITBASE16_16_U16 :
343
225
      print_unsigned_bitbase (cd, info, fields->f_dsp_16_u16, 0, pc, length);
344
225
      break;
345
641
    case M32C_OPERAND_BITBASE16_16_U8 :
346
641
      print_unsigned_bitbase (cd, info, fields->f_dsp_16_u8, 0, pc, length);
347
641
      break;
348
10.9k
    case M32C_OPERAND_BITBASE16_8_U11_S :
349
10.9k
      print_unsigned_bitbase (cd, info, fields->f_bitbase16_u11_S, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
350
10.9k
      break;
351
189
    case M32C_OPERAND_BITBASE32_16_S11_UNPREFIXED :
352
189
      print_signed_bitbase (cd, info, fields->f_bitbase32_16_s11_unprefixed, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
353
189
      break;
354
177
    case M32C_OPERAND_BITBASE32_16_S19_UNPREFIXED :
355
177
      print_signed_bitbase (cd, info, fields->f_bitbase32_16_s19_unprefixed, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
356
177
      break;
357
180
    case M32C_OPERAND_BITBASE32_16_U11_UNPREFIXED :
358
180
      print_unsigned_bitbase (cd, info, fields->f_bitbase32_16_u11_unprefixed, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
359
180
      break;
360
604
    case M32C_OPERAND_BITBASE32_16_U19_UNPREFIXED :
361
604
      print_unsigned_bitbase (cd, info, fields->f_bitbase32_16_u19_unprefixed, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
362
604
      break;
363
303
    case M32C_OPERAND_BITBASE32_16_U27_UNPREFIXED :
364
303
      print_unsigned_bitbase (cd, info, fields->f_bitbase32_16_u27_unprefixed, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
365
303
      break;
366
50
    case M32C_OPERAND_BITBASE32_24_S11_PREFIXED :
367
50
      print_signed_bitbase (cd, info, fields->f_bitbase32_24_s11_prefixed, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
368
50
      break;
369
72
    case M32C_OPERAND_BITBASE32_24_S19_PREFIXED :
370
72
      print_signed_bitbase (cd, info, fields->f_bitbase32_24_s19_prefixed, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
371
72
      break;
372
158
    case M32C_OPERAND_BITBASE32_24_U11_PREFIXED :
373
158
      print_unsigned_bitbase (cd, info, fields->f_bitbase32_24_u11_prefixed, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
374
158
      break;
375
67
    case M32C_OPERAND_BITBASE32_24_U19_PREFIXED :
376
67
      print_unsigned_bitbase (cd, info, fields->f_bitbase32_24_u19_prefixed, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
377
67
      break;
378
155
    case M32C_OPERAND_BITBASE32_24_U27_PREFIXED :
379
155
      print_unsigned_bitbase (cd, info, fields->f_bitbase32_24_u27_prefixed, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
380
155
      break;
381
459
    case M32C_OPERAND_BITNO16R :
382
459
      print_normal (cd, info, fields->f_dsp_16_u8, 0, pc, length);
383
459
      break;
384
163
    case M32C_OPERAND_BITNO32PREFIXED :
385
163
      print_normal (cd, info, fields->f_bitno32_prefixed, 0, pc, length);
386
163
      break;
387
967
    case M32C_OPERAND_BITNO32UNPREFIXED :
388
967
      print_normal (cd, info, fields->f_bitno32_unprefixed, 0, pc, length);
389
967
      break;
390
1.18k
    case M32C_OPERAND_DSP_10_U6 :
391
1.18k
      print_normal (cd, info, fields->f_dsp_10_u6, 0, pc, length);
392
1.18k
      break;
393
1.25k
    case M32C_OPERAND_DSP_16_S16 :
394
1.25k
      print_normal (cd, info, fields->f_dsp_16_s16, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
395
1.25k
      break;
396
4.69k
    case M32C_OPERAND_DSP_16_S8 :
397
4.69k
      print_normal (cd, info, fields->f_dsp_16_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
398
4.69k
      break;
399
11.1k
    case M32C_OPERAND_DSP_16_U16 :
400
11.1k
      print_normal (cd, info, fields->f_dsp_16_u16, 0, pc, length);
401
11.1k
      break;
402
261
    case M32C_OPERAND_DSP_16_U20 :
403
261
      print_normal (cd, info, fields->f_dsp_16_u24, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
404
261
      break;
405
2.62k
    case M32C_OPERAND_DSP_16_U24 :
406
2.62k
      print_normal (cd, info, fields->f_dsp_16_u24, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
407
2.62k
      break;
408
10.1k
    case M32C_OPERAND_DSP_16_U8 :
409
10.1k
      print_normal (cd, info, fields->f_dsp_16_u8, 0, pc, length);
410
10.1k
      break;
411
190
    case M32C_OPERAND_DSP_24_S16 :
412
190
      print_normal (cd, info, fields->f_dsp_24_s16, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
413
190
      break;
414
181
    case M32C_OPERAND_DSP_24_S8 :
415
181
      print_normal (cd, info, fields->f_dsp_24_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
416
181
      break;
417
1.08k
    case M32C_OPERAND_DSP_24_U16 :
418
1.08k
      print_normal (cd, info, fields->f_dsp_24_u16, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
419
1.08k
      break;
420
375
    case M32C_OPERAND_DSP_24_U20 :
421
375
      print_normal (cd, info, fields->f_dsp_24_u24, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
422
375
      break;
423
1.80k
    case M32C_OPERAND_DSP_24_U24 :
424
1.80k
      print_normal (cd, info, fields->f_dsp_24_u24, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
425
1.80k
      break;
426
1.27k
    case M32C_OPERAND_DSP_24_U8 :
427
1.27k
      print_normal (cd, info, fields->f_dsp_24_u8, 0, pc, length);
428
1.27k
      break;
429
110
    case M32C_OPERAND_DSP_32_S16 :
430
110
      print_normal (cd, info, fields->f_dsp_32_s16, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
431
110
      break;
432
359
    case M32C_OPERAND_DSP_32_S8 :
433
359
      print_normal (cd, info, fields->f_dsp_32_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
434
359
      break;
435
1.42k
    case M32C_OPERAND_DSP_32_U16 :
436
1.42k
      print_normal (cd, info, fields->f_dsp_32_u16, 0, pc, length);
437
1.42k
      break;
438
30
    case M32C_OPERAND_DSP_32_U20 :
439
30
      print_normal (cd, info, fields->f_dsp_32_u24, 0, pc, length);
440
30
      break;
441
1.08k
    case M32C_OPERAND_DSP_32_U24 :
442
1.08k
      print_normal (cd, info, fields->f_dsp_32_u24, 0, pc, length);
443
1.08k
      break;
444
1.07k
    case M32C_OPERAND_DSP_32_U8 :
445
1.07k
      print_normal (cd, info, fields->f_dsp_32_u8, 0, pc, length);
446
1.07k
      break;
447
75
    case M32C_OPERAND_DSP_40_S16 :
448
75
      print_normal (cd, info, fields->f_dsp_40_s16, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
449
75
      break;
450
95
    case M32C_OPERAND_DSP_40_S8 :
451
95
      print_normal (cd, info, fields->f_dsp_40_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
452
95
      break;
453
207
    case M32C_OPERAND_DSP_40_U16 :
454
207
      print_normal (cd, info, fields->f_dsp_40_u16, 0, pc, length);
455
207
      break;
456
0
    case M32C_OPERAND_DSP_40_U20 :
457
0
      print_normal (cd, info, fields->f_dsp_40_u20, 0, pc, length);
458
0
      break;
459
144
    case M32C_OPERAND_DSP_40_U24 :
460
144
      print_normal (cd, info, fields->f_dsp_40_u24, 0, pc, length);
461
144
      break;
462
248
    case M32C_OPERAND_DSP_40_U8 :
463
248
      print_normal (cd, info, fields->f_dsp_40_u8, 0, pc, length);
464
248
      break;
465
157
    case M32C_OPERAND_DSP_48_S16 :
466
157
      print_normal (cd, info, fields->f_dsp_48_s16, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
467
157
      break;
468
72
    case M32C_OPERAND_DSP_48_S8 :
469
72
      print_normal (cd, info, fields->f_dsp_48_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
470
72
      break;
471
189
    case M32C_OPERAND_DSP_48_U16 :
472
189
      print_normal (cd, info, fields->f_dsp_48_u16, 0, pc, length);
473
189
      break;
474
0
    case M32C_OPERAND_DSP_48_U20 :
475
0
      print_normal (cd, info, fields->f_dsp_48_u20, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
476
0
      break;
477
90
    case M32C_OPERAND_DSP_48_U24 :
478
90
      print_normal (cd, info, fields->f_dsp_48_u24, 0|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
479
90
      break;
480
71
    case M32C_OPERAND_DSP_48_U8 :
481
71
      print_normal (cd, info, fields->f_dsp_48_u8, 0, pc, length);
482
71
      break;
483
139
    case M32C_OPERAND_DSP_8_S24 :
484
139
      print_normal (cd, info, fields->f_dsp_8_s24, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
485
139
      break;
486
17.3k
    case M32C_OPERAND_DSP_8_S8 :
487
17.3k
      print_normal (cd, info, fields->f_dsp_8_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
488
17.3k
      break;
489
15.1k
    case M32C_OPERAND_DSP_8_U16 :
490
15.1k
      print_normal (cd, info, fields->f_dsp_8_u16, 0, pc, length);
491
15.1k
      break;
492
0
    case M32C_OPERAND_DSP_8_U24 :
493
0
      print_normal (cd, info, fields->f_dsp_8_u24, 0, pc, length);
494
0
      break;
495
84
    case M32C_OPERAND_DSP_8_U6 :
496
84
      print_normal (cd, info, fields->f_dsp_8_u6, 0, pc, length);
497
84
      break;
498
19.1k
    case M32C_OPERAND_DSP_8_U8 :
499
19.1k
      print_normal (cd, info, fields->f_dsp_8_u8, 0, pc, length);
500
19.1k
      break;
501
5.15k
    case M32C_OPERAND_DST16AN :
502
5.15k
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_dst16_an, 0);
503
5.15k
      break;
504
956
    case M32C_OPERAND_DST16AN_S :
505
956
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_HI, fields->f_dst16_an_s, 0);
506
956
      break;
507
790
    case M32C_OPERAND_DST16ANHI :
508
790
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_HI, fields->f_dst16_an, 0);
509
790
      break;
510
1.76k
    case M32C_OPERAND_DST16ANQI :
511
1.76k
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_QI, fields->f_dst16_an, 0);
512
1.76k
      break;
513
3.37k
    case M32C_OPERAND_DST16ANQI_S :
514
3.37k
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_QI, fields->f_dst16_rn_QI_s, 0);
515
3.37k
      break;
516
135
    case M32C_OPERAND_DST16ANSI :
517
135
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_SI, fields->f_dst16_an, 0);
518
135
      break;
519
40
    case M32C_OPERAND_DST16RNEXTQI :
520
40
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_ext_QI, fields->f_dst16_rn_ext, 0);
521
40
      break;
522
2.39k
    case M32C_OPERAND_DST16RNHI :
523
2.39k
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_HI, fields->f_dst16_rn, 0);
524
2.39k
      break;
525
4.20k
    case M32C_OPERAND_DST16RNQI :
526
4.20k
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_QI, fields->f_dst16_rn, 0);
527
4.20k
      break;
528
17.2k
    case M32C_OPERAND_DST16RNQI_S :
529
17.2k
      print_keyword (cd, info, & m32c_cgen_opval_h_r0l_r0h, fields->f_dst16_rn_QI_s, 0);
530
17.2k
      break;
531
144
    case M32C_OPERAND_DST16RNSI :
532
144
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_SI, fields->f_dst16_rn, 0);
533
144
      break;
534
73
    case M32C_OPERAND_DST32ANEXTUNPREFIXED :
535
73
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_dst32_an_unprefixed, 0);
536
73
      break;
537
868
    case M32C_OPERAND_DST32ANPREFIXED :
538
868
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_dst32_an_prefixed, 0);
539
868
      break;
540
291
    case M32C_OPERAND_DST32ANPREFIXEDHI :
541
291
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_HI, fields->f_dst32_an_prefixed, 0);
542
291
      break;
543
201
    case M32C_OPERAND_DST32ANPREFIXEDQI :
544
201
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_QI, fields->f_dst32_an_prefixed, 0);
545
201
      break;
546
107
    case M32C_OPERAND_DST32ANPREFIXEDSI :
547
107
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_dst32_an_prefixed, 0);
548
107
      break;
549
8.16k
    case M32C_OPERAND_DST32ANUNPREFIXED :
550
8.16k
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_dst32_an_unprefixed, 0);
551
8.16k
      break;
552
1.10k
    case M32C_OPERAND_DST32ANUNPREFIXEDHI :
553
1.10k
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_HI, fields->f_dst32_an_unprefixed, 0);
554
1.10k
      break;
555
739
    case M32C_OPERAND_DST32ANUNPREFIXEDQI :
556
739
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_QI, fields->f_dst32_an_unprefixed, 0);
557
739
      break;
558
2.77k
    case M32C_OPERAND_DST32ANUNPREFIXEDSI :
559
2.77k
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_dst32_an_unprefixed, 0);
560
2.77k
      break;
561
2.14k
    case M32C_OPERAND_DST32R0HI_S :
562
2.14k
      print_keyword (cd, info, & m32c_cgen_opval_h_r0, 0, 0);
563
2.14k
      break;
564
551
    case M32C_OPERAND_DST32R0QI_S :
565
551
      print_keyword (cd, info, & m32c_cgen_opval_h_r0l, 0, 0);
566
551
      break;
567
18
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDHI :
568
18
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_ext_HI, fields->f_dst32_rn_ext_unprefixed, 0);
569
18
      break;
570
26
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDQI :
571
26
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_ext_QI, fields->f_dst32_rn_ext_unprefixed, 0);
572
26
      break;
573
140
    case M32C_OPERAND_DST32RNPREFIXEDHI :
574
140
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_HI, fields->f_dst32_rn_prefixed_HI, 0);
575
140
      break;
576
55
    case M32C_OPERAND_DST32RNPREFIXEDQI :
577
55
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_QI, fields->f_dst32_rn_prefixed_QI, 0);
578
55
      break;
579
81
    case M32C_OPERAND_DST32RNPREFIXEDSI :
580
81
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_SI, fields->f_dst32_rn_prefixed_SI, 0);
581
81
      break;
582
3.15k
    case M32C_OPERAND_DST32RNUNPREFIXEDHI :
583
3.15k
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_HI, fields->f_dst32_rn_unprefixed_HI, 0);
584
3.15k
      break;
585
995
    case M32C_OPERAND_DST32RNUNPREFIXEDQI :
586
995
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_QI, fields->f_dst32_rn_unprefixed_QI, 0);
587
995
      break;
588
1.23k
    case M32C_OPERAND_DST32RNUNPREFIXEDSI :
589
1.23k
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_SI, fields->f_dst32_rn_unprefixed_SI, 0);
590
1.23k
      break;
591
23.0k
    case M32C_OPERAND_G :
592
23.0k
      print_G (cd, info, 0, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
593
23.0k
      break;
594
2.31k
    case M32C_OPERAND_IMM_12_S4 :
595
2.31k
      print_normal (cd, info, fields->f_imm_12_s4, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
596
2.31k
      break;
597
927
    case M32C_OPERAND_IMM_12_S4N :
598
927
      print_signed4n (cd, info, fields->f_imm_12_s4, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
599
927
      break;
600
25
    case M32C_OPERAND_IMM_13_U3 :
601
25
      print_normal (cd, info, fields->f_imm_13_u3, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
602
25
      break;
603
3.38k
    case M32C_OPERAND_IMM_16_HI :
604
3.38k
      print_normal (cd, info, fields->f_dsp_16_s16, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
605
3.38k
      break;
606
6.06k
    case M32C_OPERAND_IMM_16_QI :
607
6.06k
      print_normal (cd, info, fields->f_dsp_16_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
608
6.06k
      break;
609
84
    case M32C_OPERAND_IMM_16_SI :
610
84
      print_normal (cd, info, fields->f_dsp_16_s32, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
611
84
      break;
612
0
    case M32C_OPERAND_IMM_20_S4 :
613
0
      print_normal (cd, info, fields->f_imm_20_s4, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
614
0
      break;
615
1.09k
    case M32C_OPERAND_IMM_24_HI :
616
1.09k
      print_normal (cd, info, fields->f_dsp_24_s16, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
617
1.09k
      break;
618
2.03k
    case M32C_OPERAND_IMM_24_QI :
619
2.03k
      print_normal (cd, info, fields->f_dsp_24_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
620
2.03k
      break;
621
19
    case M32C_OPERAND_IMM_24_SI :
622
19
      print_normal (cd, info, fields->f_dsp_24_s32, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
623
19
      break;
624
392
    case M32C_OPERAND_IMM_32_HI :
625
392
      print_normal (cd, info, fields->f_dsp_32_s16, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
626
392
      break;
627
653
    case M32C_OPERAND_IMM_32_QI :
628
653
      print_normal (cd, info, fields->f_dsp_32_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
629
653
      break;
630
60
    case M32C_OPERAND_IMM_32_SI :
631
60
      print_normal (cd, info, fields->f_dsp_32_s32, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
632
60
      break;
633
234
    case M32C_OPERAND_IMM_40_HI :
634
234
      print_normal (cd, info, fields->f_dsp_40_s16, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
635
234
      break;
636
227
    case M32C_OPERAND_IMM_40_QI :
637
227
      print_normal (cd, info, fields->f_dsp_40_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
638
227
      break;
639
60
    case M32C_OPERAND_IMM_40_SI :
640
60
      print_normal (cd, info, fields->f_dsp_40_s32, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
641
60
      break;
642
433
    case M32C_OPERAND_IMM_48_HI :
643
433
      print_normal (cd, info, fields->f_dsp_48_s16, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
644
433
      break;
645
73
    case M32C_OPERAND_IMM_48_QI :
646
73
      print_normal (cd, info, fields->f_dsp_48_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
647
73
      break;
648
0
    case M32C_OPERAND_IMM_48_SI :
649
0
      print_normal (cd, info, fields->f_dsp_48_s32, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
650
0
      break;
651
89
    case M32C_OPERAND_IMM_56_HI :
652
89
      print_normal (cd, info, fields->f_dsp_56_s16, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
653
89
      break;
654
46
    case M32C_OPERAND_IMM_56_QI :
655
46
      print_normal (cd, info, fields->f_dsp_56_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
656
46
      break;
657
141
    case M32C_OPERAND_IMM_64_HI :
658
141
      print_normal (cd, info, fields->f_dsp_64_s16, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
659
141
      break;
660
2.88k
    case M32C_OPERAND_IMM_8_HI :
661
2.88k
      print_normal (cd, info, fields->f_dsp_8_s16, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
662
2.88k
      break;
663
13.2k
    case M32C_OPERAND_IMM_8_QI :
664
13.2k
      print_normal (cd, info, fields->f_dsp_8_s8, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
665
13.2k
      break;
666
1.57k
    case M32C_OPERAND_IMM_8_S4 :
667
1.57k
      print_normal (cd, info, fields->f_imm_8_s4, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
668
1.57k
      break;
669
1.36k
    case M32C_OPERAND_IMM_8_S4N :
670
1.36k
      print_signed4n (cd, info, fields->f_imm_8_s4, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
671
1.36k
      break;
672
3.09k
    case M32C_OPERAND_IMM_SH_12_S4 :
673
3.09k
      print_keyword (cd, info, & m32c_cgen_opval_h_shimm, fields->f_imm_12_s4, 0);
674
3.09k
      break;
675
0
    case M32C_OPERAND_IMM_SH_20_S4 :
676
0
      print_keyword (cd, info, & m32c_cgen_opval_h_shimm, fields->f_imm_20_s4, 0);
677
0
      break;
678
1.89k
    case M32C_OPERAND_IMM_SH_8_S4 :
679
1.89k
      print_keyword (cd, info, & m32c_cgen_opval_h_shimm, fields->f_imm_8_s4, 0);
680
1.89k
      break;
681
2.53k
    case M32C_OPERAND_IMM1_S :
682
2.53k
      print_normal (cd, info, fields->f_imm1_S, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
683
2.53k
      break;
684
3.83k
    case M32C_OPERAND_IMM3_S :
685
3.83k
      print_normal (cd, info, fields->f_imm3_S, 0|(1<<CGEN_OPERAND_SIGNED)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
686
3.83k
      break;
687
1.13k
    case M32C_OPERAND_LAB_16_8 :
688
1.13k
      print_address (cd, info, fields->f_lab_16_8, 0|(1<<CGEN_OPERAND_RELAX)|(1<<CGEN_OPERAND_PCREL_ADDR), pc, length);
689
1.13k
      break;
690
768
    case M32C_OPERAND_LAB_24_8 :
691
768
      print_address (cd, info, fields->f_lab_24_8, 0|(1<<CGEN_OPERAND_RELAX)|(1<<CGEN_OPERAND_PCREL_ADDR), pc, length);
692
768
      break;
693
674
    case M32C_OPERAND_LAB_32_8 :
694
674
      print_address (cd, info, fields->f_lab_32_8, 0|(1<<CGEN_OPERAND_RELAX)|(1<<CGEN_OPERAND_PCREL_ADDR), pc, length);
695
674
      break;
696
89
    case M32C_OPERAND_LAB_40_8 :
697
89
      print_address (cd, info, fields->f_lab_40_8, 0|(1<<CGEN_OPERAND_RELAX)|(1<<CGEN_OPERAND_PCREL_ADDR), pc, length);
698
89
      break;
699
3.93k
    case M32C_OPERAND_LAB_5_3 :
700
3.93k
      print_address (cd, info, fields->f_lab_5_3, 0|(1<<CGEN_OPERAND_RELAX)|(1<<CGEN_OPERAND_PCREL_ADDR), pc, length);
701
3.93k
      break;
702
1.07k
    case M32C_OPERAND_LAB_8_16 :
703
1.07k
      print_address (cd, info, fields->f_lab_8_16, 0|(1<<CGEN_OPERAND_RELAX)|(1<<CGEN_OPERAND_SIGN_OPT)|(1<<CGEN_OPERAND_PCREL_ADDR), pc, length);
704
1.07k
      break;
705
985
    case M32C_OPERAND_LAB_8_24 :
706
985
      print_address (cd, info, fields->f_lab_8_24, 0|(1<<CGEN_OPERAND_RELAX)|(1<<CGEN_OPERAND_ABS_ADDR), pc, length);
707
985
      break;
708
6.10k
    case M32C_OPERAND_LAB_8_8 :
709
6.10k
      print_address (cd, info, fields->f_lab_8_8, 0|(1<<CGEN_OPERAND_RELAX)|(1<<CGEN_OPERAND_PCREL_ADDR), pc, length);
710
6.10k
      break;
711
2.95k
    case M32C_OPERAND_LAB32_JMP_S :
712
2.95k
      print_address (cd, info, fields->f_lab32_jmp_s, 0|(1<<CGEN_OPERAND_RELAX)|(1<<CGEN_OPERAND_PCREL_ADDR)|(1<<CGEN_OPERAND_VIRTUAL), pc, length);
713
2.95k
      break;
714
12.6k
    case M32C_OPERAND_Q :
715
12.6k
      print_Q (cd, info, 0, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
716
12.6k
      break;
717
0
    case M32C_OPERAND_R0 :
718
0
      print_keyword (cd, info, & m32c_cgen_opval_h_r0, 0, 0);
719
0
      break;
720
0
    case M32C_OPERAND_R0H :
721
0
      print_keyword (cd, info, & m32c_cgen_opval_h_r0h, 0, 0);
722
0
      break;
723
0
    case M32C_OPERAND_R0L :
724
0
      print_keyword (cd, info, & m32c_cgen_opval_h_r0l, 0, 0);
725
0
      break;
726
0
    case M32C_OPERAND_R1 :
727
0
      print_keyword (cd, info, & m32c_cgen_opval_h_r1, 0, 0);
728
0
      break;
729
0
    case M32C_OPERAND_R1R2R0 :
730
0
      print_keyword (cd, info, & m32c_cgen_opval_h_r1r2r0, 0, 0);
731
0
      break;
732
0
    case M32C_OPERAND_R2 :
733
0
      print_keyword (cd, info, & m32c_cgen_opval_h_r2, 0, 0);
734
0
      break;
735
0
    case M32C_OPERAND_R2R0 :
736
0
      print_keyword (cd, info, & m32c_cgen_opval_h_r2r0, 0, 0);
737
0
      break;
738
58
    case M32C_OPERAND_R3 :
739
58
      print_keyword (cd, info, & m32c_cgen_opval_h_r3, 0, 0);
740
58
      break;
741
0
    case M32C_OPERAND_R3R1 :
742
0
      print_keyword (cd, info, & m32c_cgen_opval_h_r3r1, 0, 0);
743
0
      break;
744
1.59k
    case M32C_OPERAND_REGSETPOP :
745
1.59k
      print_pop_regset (cd, info, fields->f_8_8, 0, pc, length);
746
1.59k
      break;
747
813
    case M32C_OPERAND_REGSETPUSH :
748
813
      print_push_regset (cd, info, fields->f_8_8, 0, pc, length);
749
813
      break;
750
4.58k
    case M32C_OPERAND_RN16_PUSH_S :
751
4.58k
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_QI, fields->f_4_1, 0);
752
4.58k
      break;
753
90.0k
    case M32C_OPERAND_S :
754
90.0k
      print_S (cd, info, 0, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
755
90.0k
      break;
756
3.61k
    case M32C_OPERAND_SRC16AN :
757
3.61k
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_src16_an, 0);
758
3.61k
      break;
759
523
    case M32C_OPERAND_SRC16ANHI :
760
523
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_HI, fields->f_src16_an, 0);
761
523
      break;
762
307
    case M32C_OPERAND_SRC16ANQI :
763
307
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_QI, fields->f_src16_an, 0);
764
307
      break;
765
1.04k
    case M32C_OPERAND_SRC16RNHI :
766
1.04k
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_HI, fields->f_src16_rn, 0);
767
1.04k
      break;
768
1.95k
    case M32C_OPERAND_SRC16RNQI :
769
1.95k
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_QI, fields->f_src16_rn, 0);
770
1.95k
      break;
771
532
    case M32C_OPERAND_SRC32ANPREFIXED :
772
532
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_src32_an_prefixed, 0);
773
532
      break;
774
120
    case M32C_OPERAND_SRC32ANPREFIXEDHI :
775
120
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_HI, fields->f_src32_an_prefixed, 0);
776
120
      break;
777
75
    case M32C_OPERAND_SRC32ANPREFIXEDQI :
778
75
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_QI, fields->f_src32_an_prefixed, 0);
779
75
      break;
780
0
    case M32C_OPERAND_SRC32ANPREFIXEDSI :
781
0
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_src32_an_prefixed, 0);
782
0
      break;
783
6.21k
    case M32C_OPERAND_SRC32ANUNPREFIXED :
784
6.21k
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_src32_an_unprefixed, 0);
785
6.21k
      break;
786
169
    case M32C_OPERAND_SRC32ANUNPREFIXEDHI :
787
169
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_HI, fields->f_src32_an_unprefixed, 0);
788
169
      break;
789
562
    case M32C_OPERAND_SRC32ANUNPREFIXEDQI :
790
562
      print_keyword (cd, info, & m32c_cgen_opval_h_ar_QI, fields->f_src32_an_unprefixed, 0);
791
562
      break;
792
324
    case M32C_OPERAND_SRC32ANUNPREFIXEDSI :
793
324
      print_keyword (cd, info, & m32c_cgen_opval_h_ar, fields->f_src32_an_unprefixed, 0);
794
324
      break;
795
37
    case M32C_OPERAND_SRC32RNPREFIXEDHI :
796
37
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_HI, fields->f_src32_rn_prefixed_HI, 0);
797
37
      break;
798
623
    case M32C_OPERAND_SRC32RNPREFIXEDQI :
799
623
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_QI, fields->f_src32_rn_prefixed_QI, 0);
800
623
      break;
801
0
    case M32C_OPERAND_SRC32RNPREFIXEDSI :
802
0
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_SI, fields->f_src32_rn_prefixed_SI, 0);
803
0
      break;
804
2.13k
    case M32C_OPERAND_SRC32RNUNPREFIXEDHI :
805
2.13k
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_HI, fields->f_src32_rn_unprefixed_HI, 0);
806
2.13k
      break;
807
968
    case M32C_OPERAND_SRC32RNUNPREFIXEDQI :
808
968
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_QI, fields->f_src32_rn_unprefixed_QI, 0);
809
968
      break;
810
894
    case M32C_OPERAND_SRC32RNUNPREFIXEDSI :
811
894
      print_keyword (cd, info, & m32c_cgen_opval_h_gr_SI, fields->f_src32_rn_unprefixed_SI, 0);
812
894
      break;
813
9.85k
    case M32C_OPERAND_SRCDST16_R0L_R0H_S_NORMAL :
814
9.85k
      print_r0l_r0h (cd, info, fields->f_5_1, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
815
9.85k
      break;
816
7.85k
    case M32C_OPERAND_X :
817
7.85k
      print_X (cd, info, 0, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
818
7.85k
      break;
819
4.98k
    case M32C_OPERAND_Z :
820
4.98k
      print_Z (cd, info, 0, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
821
4.98k
      break;
822
43
    case M32C_OPERAND_COND16_16 :
823
43
      print_keyword (cd, info, & m32c_cgen_opval_h_cond16, fields->f_dsp_16_u8, 0);
824
43
      break;
825
702
    case M32C_OPERAND_COND16_24 :
826
702
      print_keyword (cd, info, & m32c_cgen_opval_h_cond16, fields->f_dsp_24_u8, 0);
827
702
      break;
828
107
    case M32C_OPERAND_COND16_32 :
829
107
      print_keyword (cd, info, & m32c_cgen_opval_h_cond16, fields->f_dsp_32_u8, 0);
830
107
      break;
831
75
    case M32C_OPERAND_COND16C :
832
75
      print_keyword (cd, info, & m32c_cgen_opval_h_cond16c, fields->f_cond16, 0);
833
75
      break;
834
371
    case M32C_OPERAND_COND16J :
835
371
      print_keyword (cd, info, & m32c_cgen_opval_h_cond16j, fields->f_cond16, 0);
836
371
      break;
837
2.90k
    case M32C_OPERAND_COND16J5 :
838
2.90k
      print_keyword (cd, info, & m32c_cgen_opval_h_cond16j_5, fields->f_cond16j_5, 0);
839
2.90k
      break;
840
22
    case M32C_OPERAND_COND32 :
841
22
      print_keyword (cd, info, & m32c_cgen_opval_h_cond32, fields->f_cond32, 0|(1<<CGEN_OPERAND_VIRTUAL));
842
22
      break;
843
288
    case M32C_OPERAND_COND32_16 :
844
288
      print_keyword (cd, info, & m32c_cgen_opval_h_cond32, fields->f_dsp_16_u8, 0);
845
288
      break;
846
144
    case M32C_OPERAND_COND32_24 :
847
144
      print_keyword (cd, info, & m32c_cgen_opval_h_cond32, fields->f_dsp_24_u8, 0);
848
144
      break;
849
364
    case M32C_OPERAND_COND32_32 :
850
364
      print_keyword (cd, info, & m32c_cgen_opval_h_cond32, fields->f_dsp_32_u8, 0);
851
364
      break;
852
53
    case M32C_OPERAND_COND32_40 :
853
53
      print_keyword (cd, info, & m32c_cgen_opval_h_cond32, fields->f_dsp_40_u8, 0);
854
53
      break;
855
2.64k
    case M32C_OPERAND_COND32J :
856
2.64k
      print_keyword (cd, info, & m32c_cgen_opval_h_cond32, fields->f_cond32j, 0|(1<<CGEN_OPERAND_VIRTUAL));
857
2.64k
      break;
858
266
    case M32C_OPERAND_CR1_PREFIXED_32 :
859
266
      print_keyword (cd, info, & m32c_cgen_opval_h_cr1_32, fields->f_21_3, 0);
860
266
      break;
861
143
    case M32C_OPERAND_CR1_UNPREFIXED_32 :
862
143
      print_keyword (cd, info, & m32c_cgen_opval_h_cr1_32, fields->f_13_3, 0);
863
143
      break;
864
224
    case M32C_OPERAND_CR16 :
865
224
      print_keyword (cd, info, & m32c_cgen_opval_h_cr_16, fields->f_9_3, 0);
866
224
      break;
867
3.00k
    case M32C_OPERAND_CR2_32 :
868
3.00k
      print_keyword (cd, info, & m32c_cgen_opval_h_cr2_32, fields->f_13_3, 0);
869
3.00k
      break;
870
191
    case M32C_OPERAND_CR3_PREFIXED_32 :
871
191
      print_keyword (cd, info, & m32c_cgen_opval_h_cr3_32, fields->f_21_3, 0);
872
191
      break;
873
72
    case M32C_OPERAND_CR3_UNPREFIXED_32 :
874
72
      print_keyword (cd, info, & m32c_cgen_opval_h_cr3_32, fields->f_13_3, 0);
875
72
      break;
876
52
    case M32C_OPERAND_FLAGS16 :
877
52
      print_keyword (cd, info, & m32c_cgen_opval_h_flags, fields->f_9_3, 0);
878
52
      break;
879
48
    case M32C_OPERAND_FLAGS32 :
880
48
      print_keyword (cd, info, & m32c_cgen_opval_h_flags, fields->f_13_3, 0);
881
48
      break;
882
234
    case M32C_OPERAND_SCCOND32 :
883
234
      print_keyword (cd, info, & m32c_cgen_opval_h_cond32, fields->f_cond16, 0);
884
234
      break;
885
0
    case M32C_OPERAND_SIZE :
886
0
      print_size (cd, info, 0, 0|(1<<CGEN_OPERAND_SIGNED), pc, length);
887
0
      break;
888
889
0
    default :
890
      /* xgettext:c-format */
891
0
      opcodes_error_handler
892
0
  (_("internal error: unrecognized field %d while printing insn"),
893
0
   opindex);
894
0
      abort ();
895
429k
  }
896
429k
}
897
898
cgen_print_fn * const m32c_cgen_print_handlers[] =
899
{
900
  print_insn_normal,
901
};
902
903
904
void
905
m32c_cgen_init_dis (CGEN_CPU_DESC cd)
906
4
{
907
4
  m32c_cgen_init_opcode_table (cd);
908
4
  m32c_cgen_init_ibld_table (cd);
909
4
  cd->print_handlers = & m32c_cgen_print_handlers[0];
910
4
  cd->print_operand = m32c_cgen_print_operand;
911
4
}
912
913

914
/* Default print handler.  */
915
916
static void
917
print_normal (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
918
        void *dis_info,
919
        long value,
920
        unsigned int attrs,
921
        bfd_vma pc ATTRIBUTE_UNUSED,
922
        int length ATTRIBUTE_UNUSED)
923
140k
{
924
140k
  disassemble_info *info = (disassemble_info *) dis_info;
925
926
  /* Print the operand as directed by the attributes.  */
927
140k
  if (CGEN_BOOL_ATTR (attrs, CGEN_OPERAND_SEM_ONLY))
928
0
    ; /* nothing to do */
929
140k
  else if (CGEN_BOOL_ATTR (attrs, CGEN_OPERAND_SIGNED))
930
69.7k
    (*info->fprintf_func) (info->stream, "%ld", value);
931
70.5k
  else
932
70.5k
    (*info->fprintf_func) (info->stream, "0x%lx", value);
933
140k
}
934
935
/* Default address handler.  */
936
937
static void
938
print_address (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
939
         void *dis_info,
940
         bfd_vma value,
941
         unsigned int attrs,
942
         bfd_vma pc ATTRIBUTE_UNUSED,
943
         int length ATTRIBUTE_UNUSED)
944
17.7k
{
945
17.7k
  disassemble_info *info = (disassemble_info *) dis_info;
946
947
  /* Print the operand as directed by the attributes.  */
948
17.7k
  if (CGEN_BOOL_ATTR (attrs, CGEN_OPERAND_SEM_ONLY))
949
0
    ; /* Nothing to do.  */
950
17.7k
  else if (CGEN_BOOL_ATTR (attrs, CGEN_OPERAND_PCREL_ADDR))
951
16.7k
    (*info->print_address_func) (value, info);
952
985
  else if (CGEN_BOOL_ATTR (attrs, CGEN_OPERAND_ABS_ADDR))
953
985
    (*info->print_address_func) (value, info);
954
0
  else if (CGEN_BOOL_ATTR (attrs, CGEN_OPERAND_SIGNED))
955
0
    (*info->fprintf_func) (info->stream, "%ld", (long) value);
956
0
  else
957
0
    (*info->fprintf_func) (info->stream, "0x%lx", (long) value);
958
17.7k
}
959
960
/* Keyword print handler.  */
961
962
static void
963
print_keyword (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
964
         void *dis_info,
965
         CGEN_KEYWORD *keyword_table,
966
         long value,
967
         unsigned int attrs ATTRIBUTE_UNUSED)
968
104k
{
969
104k
  disassemble_info *info = (disassemble_info *) dis_info;
970
104k
  const CGEN_KEYWORD_ENTRY *ke;
971
972
104k
  ke = cgen_keyword_lookup_value (keyword_table, value);
973
104k
  if (ke != NULL)
974
101k
    (*info->fprintf_func) (info->stream, "%s", ke->name);
975
3.08k
  else
976
3.08k
    (*info->fprintf_func) (info->stream, "???");
977
104k
}
978

979
/* Default insn printer.
980
981
   DIS_INFO is defined as `void *' so the disassembler needn't know anything
982
   about disassemble_info.  */
983
984
static void
985
print_insn_normal (CGEN_CPU_DESC cd,
986
       void *dis_info,
987
       const CGEN_INSN *insn,
988
       CGEN_FIELDS *fields,
989
       bfd_vma pc,
990
       int length)
991
304k
{
992
304k
  const CGEN_SYNTAX *syntax = CGEN_INSN_SYNTAX (insn);
993
304k
  disassemble_info *info = (disassemble_info *) dis_info;
994
304k
  const CGEN_SYNTAX_CHAR_TYPE *syn;
995
996
304k
  CGEN_INIT_PRINT (cd);
997
998
1.80M
  for (syn = CGEN_SYNTAX_STRING (syntax); *syn; ++syn)
999
1.50M
    {
1000
1.50M
      if (CGEN_SYNTAX_MNEMONIC_P (*syn))
1001
304k
  {
1002
304k
    (*info->fprintf_func) (info->stream, "%s", CGEN_INSN_MNEMONIC (insn));
1003
304k
    continue;
1004
304k
  }
1005
1.20M
      if (CGEN_SYNTAX_CHAR_P (*syn))
1006
770k
  {
1007
770k
    (*info->fprintf_func) (info->stream, "%c", CGEN_SYNTAX_CHAR (*syn));
1008
770k
    continue;
1009
770k
  }
1010
1011
      /* We have an operand.  */
1012
429k
      m32c_cgen_print_operand (cd, CGEN_SYNTAX_FIELD (*syn), info,
1013
429k
         fields, CGEN_INSN_ATTRS (insn), pc, length);
1014
429k
    }
1015
304k
}
1016

1017
/* Subroutine of print_insn. Reads an insn into the given buffers and updates
1018
   the extract info.
1019
   Returns 0 if all is well, non-zero otherwise.  */
1020
1021
static int
1022
read_insn (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
1023
     bfd_vma pc,
1024
     disassemble_info *info,
1025
     bfd_byte *buf,
1026
     int buflen,
1027
     CGEN_EXTRACT_INFO *ex_info,
1028
     unsigned long *insn_value)
1029
14.1k
{
1030
14.1k
  int status = (*info->read_memory_func) (pc, buf, buflen, info);
1031
1032
14.1k
  if (status != 0)
1033
13
    {
1034
13
      (*info->memory_error_func) (status, pc, info);
1035
13
      return -1;
1036
13
    }
1037
1038
14.0k
  ex_info->dis_info = info;
1039
14.0k
  ex_info->valid = (1 << buflen) - 1;
1040
14.0k
  ex_info->insn_bytes = buf;
1041
1042
14.0k
  *insn_value = bfd_get_bits (buf, buflen * 8, info->endian == BFD_ENDIAN_BIG);
1043
14.0k
  return 0;
1044
14.1k
}
1045
1046
/* Utility to print an insn.
1047
   BUF is the base part of the insn, target byte order, BUFLEN bytes long.
1048
   The result is the size of the insn in bytes or zero for an unknown insn
1049
   or -1 if an error occurs fetching data (memory_error_func will have
1050
   been called).  */
1051
1052
static int
1053
print_insn (CGEN_CPU_DESC cd,
1054
      bfd_vma pc,
1055
      disassemble_info *info,
1056
      bfd_byte *buf,
1057
      unsigned int buflen)
1058
327k
{
1059
327k
  CGEN_INSN_INT insn_value;
1060
327k
  const CGEN_INSN_LIST *insn_list;
1061
327k
  CGEN_EXTRACT_INFO ex_info;
1062
327k
  int basesize;
1063
1064
  /* Extract base part of instruction, just in case CGEN_DIS_* uses it. */
1065
327k
  basesize = cd->base_insn_bitsize < buflen * 8 ?
1066
327k
                                     cd->base_insn_bitsize : buflen * 8;
1067
327k
  insn_value = cgen_get_insn_value (cd, buf, basesize, cd->insn_endian);
1068
1069
1070
  /* Fill in ex_info fields like read_insn would.  Don't actually call
1071
     read_insn, since the incoming buffer is already read (and possibly
1072
     modified a la m32r).  */
1073
327k
  ex_info.valid = (1 << buflen) - 1;
1074
327k
  ex_info.dis_info = info;
1075
327k
  ex_info.insn_bytes = buf;
1076
1077
  /* The instructions are stored in hash lists.
1078
     Pick the first one and keep trying until we find the right one.  */
1079
1080
327k
  insn_list = CGEN_DIS_LOOKUP_INSN (cd, (char *) buf, insn_value);
1081
3.76G
  while (insn_list != NULL)
1082
3.76G
    {
1083
3.76G
      const CGEN_INSN *insn = insn_list->insn;
1084
3.76G
      CGEN_FIELDS fields;
1085
3.76G
      int length;
1086
3.76G
      unsigned long insn_value_cropped;
1087
1088
3.76G
#ifdef CGEN_VALIDATE_INSN_SUPPORTED
1089
      /* Not needed as insn shouldn't be in hash lists if not supported.  */
1090
      /* Supported by this cpu?  */
1091
3.76G
      if (! m32c_cgen_insn_supported (cd, insn))
1092
1.84G
        {
1093
1.84G
          insn_list = CGEN_DIS_NEXT_INSN (insn_list);
1094
1.84G
    continue;
1095
1.84G
        }
1096
1.92G
#endif
1097
1098
      /* Basic bit mask must be correct.  */
1099
      /* ??? May wish to allow target to defer this check until the extract
1100
   handler.  */
1101
1102
      /* Base size may exceed this instruction's size.  Extract the
1103
         relevant part from the buffer. */
1104
1.92G
      if ((unsigned) (CGEN_INSN_BITSIZE (insn) / 8) < buflen &&
1105
465M
    (unsigned) (CGEN_INSN_BITSIZE (insn) / 8) <= sizeof (unsigned long))
1106
465M
  insn_value_cropped = bfd_get_bits (buf, CGEN_INSN_BITSIZE (insn),
1107
465M
             info->endian == BFD_ENDIAN_BIG);
1108
1.46G
      else
1109
1.46G
  insn_value_cropped = insn_value;
1110
1111
1.92G
      if ((insn_value_cropped & CGEN_INSN_BASE_MASK (insn))
1112
1.92G
    == CGEN_INSN_BASE_VALUE (insn))
1113
304k
  {
1114
    /* Printing is handled in two passes.  The first pass parses the
1115
       machine insn and extracts the fields.  The second pass prints
1116
       them.  */
1117
1118
    /* Make sure the entire insn is loaded into insn_value, if it
1119
       can fit.  */
1120
304k
    if (((unsigned) CGEN_INSN_BITSIZE (insn) > cd->base_insn_bitsize) &&
1121
14.4k
        (unsigned) (CGEN_INSN_BITSIZE (insn) / 8) <= sizeof (unsigned long))
1122
14.1k
      {
1123
14.1k
        unsigned long full_insn_value;
1124
14.1k
        int rc = read_insn (cd, pc, info, buf,
1125
14.1k
          CGEN_INSN_BITSIZE (insn) / 8,
1126
14.1k
          & ex_info, & full_insn_value);
1127
14.1k
        if (rc != 0)
1128
13
    return rc;
1129
14.0k
        length = CGEN_EXTRACT_FN (cd, insn)
1130
14.0k
    (cd, insn, &ex_info, full_insn_value, &fields, pc);
1131
14.0k
      }
1132
290k
    else
1133
290k
      length = CGEN_EXTRACT_FN (cd, insn)
1134
290k
        (cd, insn, &ex_info, insn_value_cropped, &fields, pc);
1135
1136
    /* Length < 0 -> error.  */
1137
304k
    if (length < 0)
1138
0
      return length;
1139
304k
    if (length > 0)
1140
304k
      {
1141
304k
        CGEN_PRINT_FN (cd, insn) (cd, info, insn, &fields, pc, length);
1142
        /* Length is in bits, result is in bytes.  */
1143
304k
        return length / 8;
1144
304k
      }
1145
304k
  }
1146
1147
1.92G
      insn_list = CGEN_DIS_NEXT_INSN (insn_list);
1148
1.92G
    }
1149
1150
22.7k
  return 0;
1151
327k
}
1152
1153
/* Default value for CGEN_PRINT_INSN.
1154
   The result is the size of the insn in bytes or zero for an unknown insn
1155
   or -1 if an error occured fetching bytes.  */
1156
1157
#ifndef CGEN_PRINT_INSN
1158
327k
#define CGEN_PRINT_INSN default_print_insn
1159
#endif
1160
1161
static int
1162
default_print_insn (CGEN_CPU_DESC cd, bfd_vma pc, disassemble_info *info)
1163
327k
{
1164
327k
  bfd_byte buf[CGEN_MAX_INSN_SIZE];
1165
327k
  int buflen;
1166
327k
  int status;
1167
1168
  /* Attempt to read the base part of the insn.  */
1169
327k
  buflen = cd->base_insn_bitsize / 8;
1170
327k
  status = (*info->read_memory_func) (pc, buf, buflen, info);
1171
1172
  /* Try again with the minimum part, if min < base.  */
1173
327k
  if (status != 0 && (cd->min_insn_bitsize < cd->base_insn_bitsize))
1174
747
    {
1175
747
      buflen = cd->min_insn_bitsize / 8;
1176
747
      status = (*info->read_memory_func) (pc, buf, buflen, info);
1177
747
    }
1178
1179
327k
  if (status != 0)
1180
1
    {
1181
1
      (*info->memory_error_func) (status, pc, info);
1182
1
      return -1;
1183
1
    }
1184
1185
327k
  return print_insn (cd, pc, info, buf, buflen);
1186
327k
}
1187
1188
/* Main entry point.
1189
   Print one instruction from PC on INFO->STREAM.
1190
   Return the size of the instruction (in bytes).  */
1191
1192
typedef struct cpu_desc_list
1193
{
1194
  struct cpu_desc_list *next;
1195
  CGEN_BITSET *isa;
1196
  int mach;
1197
  int endian;
1198
  int insn_endian;
1199
  CGEN_CPU_DESC cd;
1200
} cpu_desc_list;
1201
1202
int
1203
print_insn_m32c (bfd_vma pc, disassemble_info *info)
1204
327k
{
1205
327k
  static cpu_desc_list *cd_list = 0;
1206
327k
  cpu_desc_list *cl = 0;
1207
327k
  static CGEN_CPU_DESC cd = 0;
1208
327k
  static CGEN_BITSET *prev_isa;
1209
327k
  static int prev_mach;
1210
327k
  static int prev_endian;
1211
327k
  static int prev_insn_endian;
1212
327k
  int length;
1213
327k
  CGEN_BITSET *isa;
1214
327k
  int mach;
1215
327k
  int endian = (info->endian == BFD_ENDIAN_BIG
1216
327k
    ? CGEN_ENDIAN_BIG
1217
327k
    : CGEN_ENDIAN_LITTLE);
1218
327k
  int insn_endian = (info->endian_code == BFD_ENDIAN_BIG
1219
327k
                     ? CGEN_ENDIAN_BIG
1220
327k
                     : CGEN_ENDIAN_LITTLE);
1221
327k
  enum bfd_architecture arch;
1222
1223
  /* ??? gdb will set mach but leave the architecture as "unknown" */
1224
327k
#ifndef CGEN_BFD_ARCH
1225
327k
#define CGEN_BFD_ARCH bfd_arch_m32c
1226
327k
#endif
1227
327k
  arch = info->arch;
1228
327k
  if (arch == bfd_arch_unknown)
1229
0
    arch = CGEN_BFD_ARCH;
1230
1231
  /* There's no standard way to compute the machine or isa number
1232
     so we leave it to the target.  */
1233
#ifdef CGEN_COMPUTE_MACH
1234
  mach = CGEN_COMPUTE_MACH (info);
1235
#else
1236
327k
  mach = info->mach;
1237
327k
#endif
1238
1239
#ifdef CGEN_COMPUTE_ISA
1240
  {
1241
    static CGEN_BITSET *permanent_isa;
1242
1243
    if (!permanent_isa)
1244
      permanent_isa = cgen_bitset_create (MAX_ISAS);
1245
    isa = permanent_isa;
1246
    cgen_bitset_clear (isa);
1247
    cgen_bitset_add (isa, CGEN_COMPUTE_ISA (info));
1248
  }
1249
#else
1250
327k
  isa = info->private_data;
1251
327k
#endif
1252
1253
  /* If we've switched cpu's, try to find a handle we've used before */
1254
327k
  if (cd
1255
327k
      && (cgen_bitset_compare (isa, prev_isa) != 0
1256
327k
    || mach != prev_mach
1257
91.5k
    || endian != prev_endian))
1258
235k
    {
1259
235k
      cd = 0;
1260
633k
      for (cl = cd_list; cl; cl = cl->next)
1261
633k
  {
1262
633k
    if (cgen_bitset_compare (cl->isa, isa) == 0 &&
1263
398k
        cl->mach == mach &&
1264
235k
        cl->endian == endian)
1265
235k
      {
1266
235k
        cd = cl->cd;
1267
235k
        prev_isa = cd->isas;
1268
235k
        break;
1269
235k
      }
1270
633k
  }
1271
235k
    }
1272
1273
  /* If we haven't initialized yet, initialize the opcode table.  */
1274
327k
  if (! cd)
1275
4
    {
1276
4
      const bfd_arch_info_type *arch_type = bfd_lookup_arch (arch, mach);
1277
4
      const char *mach_name;
1278
1279
4
      if (!arch_type)
1280
0
  abort ();
1281
4
      mach_name = arch_type->printable_name;
1282
1283
4
      prev_isa = cgen_bitset_copy (isa);
1284
4
      prev_mach = mach;
1285
4
      prev_endian = endian;
1286
4
      prev_insn_endian = insn_endian;
1287
4
      cd = m32c_cgen_cpu_open (CGEN_CPU_OPEN_ISAS, prev_isa,
1288
4
         CGEN_CPU_OPEN_BFDMACH, mach_name,
1289
4
         CGEN_CPU_OPEN_ENDIAN, prev_endian,
1290
4
                                 CGEN_CPU_OPEN_INSN_ENDIAN, prev_insn_endian,
1291
4
         CGEN_CPU_OPEN_END);
1292
4
      if (!cd)
1293
0
  abort ();
1294
1295
      /* Save this away for future reference.  */
1296
4
      cl = xmalloc (sizeof (struct cpu_desc_list));
1297
4
      cl->cd = cd;
1298
4
      cl->isa = prev_isa;
1299
4
      cl->mach = mach;
1300
4
      cl->endian = endian;
1301
4
      cl->next = cd_list;
1302
4
      cd_list = cl;
1303
1304
4
      m32c_cgen_init_dis (cd);
1305
4
    }
1306
1307
  /* We try to have as much common code as possible.
1308
     But at this point some targets need to take over.  */
1309
  /* ??? Some targets may need a hook elsewhere.  Try to avoid this,
1310
     but if not possible try to move this hook elsewhere rather than
1311
     have two hooks.  */
1312
327k
  length = CGEN_PRINT_INSN (cd, pc, info);
1313
327k
  if (length > 0)
1314
304k
    return length;
1315
22.7k
  if (length < 0)
1316
14
    return -1;
1317
1318
22.7k
  (*info->fprintf_func) (info->stream, UNKNOWN_INSN_MSG);
1319
22.7k
  return cd->default_insn_bitsize / 8;
1320
22.7k
}