Coverage Report

Created: 2026-05-11 07:54

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/binutils-gdb/opcodes/disassemble.c
Line
Count
Source
1
/* Select disassembly routine for specified architecture.
2
   Copyright (C) 1994-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 of the License, or
9
   (at your option) any later version.
10
11
   This program is distributed in the hope that it will be useful,
12
   but WITHOUT ANY WARRANTY; without even the implied warranty of
13
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
   GNU General Public 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 "disassemble.h"
23
#include "safe-ctype.h"
24
#include "opintl.h"
25
26
#ifdef ARCH_all
27
#ifdef BFD64
28
#define ARCH_aarch64
29
#define ARCH_alpha
30
#define ARCH_bpf
31
#define ARCH_ia64
32
#define ARCH_loongarch
33
#define ARCH_mips
34
#define ARCH_mmix
35
#define ARCH_nfp
36
#define ARCH_riscv
37
#define ARCH_score
38
#define ARCH_tilegx
39
#endif
40
#define ARCH_arc
41
#define ARCH_arm
42
#define ARCH_avr
43
#define ARCH_bfin
44
#define ARCH_cr16
45
#define ARCH_cris
46
#define ARCH_crx
47
#define ARCH_csky
48
#define ARCH_d10v
49
#define ARCH_d30v
50
#define ARCH_dlx
51
#define ARCH_epiphany
52
#define ARCH_fr30
53
#define ARCH_frv
54
#define ARCH_ft32
55
#define ARCH_h8300
56
#define ARCH_hppa
57
#define ARCH_i386
58
#define ARCH_ip2k
59
#define ARCH_iq2000
60
#define ARCH_kvx
61
#define ARCH_lm32
62
#define ARCH_m32c
63
#define ARCH_m32r
64
#define ARCH_m68hc11
65
#define ARCH_m68hc12
66
#define ARCH_m68k
67
#define ARCH_mcore
68
#define ARCH_mep
69
#define ARCH_metag
70
#define ARCH_microblaze
71
#define ARCH_mn10200
72
#define ARCH_mn10300
73
#define ARCH_moxie
74
#define ARCH_mt
75
#define ARCH_msp430
76
#define ARCH_nds32
77
#define ARCH_ns32k
78
#define ARCH_or1k
79
#define ARCH_pdp11
80
#define ARCH_pj
81
#define ARCH_powerpc
82
#define ARCH_pru
83
#define ARCH_rs6000
84
#define ARCH_rl78
85
#define ARCH_rx
86
#define ARCH_s12z
87
#define ARCH_s390
88
#define ARCH_sh
89
#define ARCH_sparc
90
#define ARCH_spu
91
#define ARCH_tic30
92
#define ARCH_tic4x
93
#define ARCH_tic54x
94
#define ARCH_tic6x
95
#define ARCH_tilepro
96
#define ARCH_v850
97
#define ARCH_vax
98
#define ARCH_visium
99
#define ARCH_wasm32
100
#define ARCH_xstormy16
101
#define ARCH_xgate
102
#define ARCH_xtensa
103
#define ARCH_z80
104
#define ARCH_z8k
105
#endif
106
107
#ifdef ARCH_m32c
108
#include "m32c-desc.h"
109
#endif
110
111
disassembler_ftype
112
disassembler (enum bfd_architecture a,
113
        bool big ATTRIBUTE_UNUSED,
114
        unsigned long mach ATTRIBUTE_UNUSED,
115
        bfd *abfd ATTRIBUTE_UNUSED)
116
93.0k
{
117
93.0k
  disassembler_ftype disassemble;
118
119
93.0k
  switch (a)
120
93.0k
    {
121
      /* If you add a case to this table, also add it to the
122
   ARCH_all definition right above this function.  */
123
0
#ifdef ARCH_aarch64
124
12.5k
    case bfd_arch_aarch64:
125
12.5k
      disassemble = print_insn_aarch64;
126
12.5k
      break;
127
0
#endif
128
0
#ifdef ARCH_alpha
129
192
    case bfd_arch_alpha:
130
192
      disassemble = print_insn_alpha;
131
192
      break;
132
0
#endif
133
0
#ifdef ARCH_arc
134
3.58k
    case bfd_arch_arc:
135
3.58k
      disassemble = arc_get_disassembler (abfd);
136
3.58k
      break;
137
0
#endif
138
0
#ifdef ARCH_arm
139
17.4k
    case bfd_arch_arm:
140
17.4k
      if (big)
141
7.67k
  disassemble = print_insn_big_arm;
142
9.77k
      else
143
9.77k
  disassemble = print_insn_little_arm;
144
17.4k
      break;
145
0
#endif
146
0
#ifdef ARCH_avr
147
268
    case bfd_arch_avr:
148
268
      disassemble = print_insn_avr;
149
268
      break;
150
0
#endif
151
0
#ifdef ARCH_bfin
152
2.25k
    case bfd_arch_bfin:
153
2.25k
      disassemble = print_insn_bfin;
154
2.25k
      break;
155
0
#endif
156
0
#ifdef ARCH_cr16
157
295
    case bfd_arch_cr16:
158
295
      disassemble = print_insn_cr16;
159
295
      break;
160
0
#endif
161
0
#ifdef ARCH_cris
162
536
    case bfd_arch_cris:
163
536
      disassemble = cris_get_disassembler (abfd);
164
536
      break;
165
0
#endif
166
0
#ifdef ARCH_crx
167
271
    case bfd_arch_crx:
168
271
      disassemble = print_insn_crx;
169
271
      break;
170
0
#endif
171
0
#ifdef ARCH_csky
172
937
    case bfd_arch_csky:
173
937
      disassemble = csky_get_disassembler (abfd);
174
937
      break;
175
0
#endif
176
177
0
#ifdef ARCH_d10v
178
105
    case bfd_arch_d10v:
179
105
      disassemble = print_insn_d10v;
180
105
      break;
181
0
#endif
182
0
#ifdef ARCH_d30v
183
189
    case bfd_arch_d30v:
184
189
      disassemble = print_insn_d30v;
185
189
      break;
186
0
#endif
187
0
#ifdef ARCH_dlx
188
74
    case bfd_arch_dlx:
189
      /* As far as I know we only handle big-endian DLX objects.  */
190
74
      disassemble = print_insn_dlx;
191
74
      break;
192
0
#endif
193
0
#ifdef ARCH_h8300
194
325
    case bfd_arch_h8300:
195
325
      if (mach == bfd_mach_h8300h || mach == bfd_mach_h8300hn)
196
34
  disassemble = print_insn_h8300h;
197
291
      else if (mach == bfd_mach_h8300s
198
285
         || mach == bfd_mach_h8300sn
199
281
         || mach == bfd_mach_h8300sx
200
271
         || mach == bfd_mach_h8300sxn)
201
40
  disassemble = print_insn_h8300s;
202
251
      else
203
251
  disassemble = print_insn_h8300;
204
325
      break;
205
0
#endif
206
0
#ifdef ARCH_hppa
207
447
    case bfd_arch_hppa:
208
447
      disassemble = print_insn_hppa;
209
447
      break;
210
0
#endif
211
0
#ifdef ARCH_i386
212
14.4k
    case bfd_arch_i386:
213
14.6k
    case bfd_arch_iamcu:
214
14.6k
      disassemble = print_insn_i386;
215
14.6k
      break;
216
0
#endif
217
0
#ifdef ARCH_ia64
218
191
    case bfd_arch_ia64:
219
191
      disassemble = print_insn_ia64;
220
191
      break;
221
0
#endif
222
0
#ifdef ARCH_ip2k
223
69
    case bfd_arch_ip2k:
224
69
      disassemble = print_insn_ip2k;
225
69
      break;
226
0
#endif
227
0
#ifdef ARCH_bpf
228
16
    case bfd_arch_bpf:
229
16
      disassemble = print_insn_bpf;
230
16
      break;
231
0
#endif
232
0
#ifdef ARCH_epiphany
233
148
    case bfd_arch_epiphany:
234
148
      disassemble = print_insn_epiphany;
235
148
      break;
236
0
#endif
237
0
#ifdef ARCH_fr30
238
173
    case bfd_arch_fr30:
239
173
      disassemble = print_insn_fr30;
240
173
      break;
241
0
#endif
242
0
#ifdef ARCH_kvx
243
424
    case bfd_arch_kvx:
244
424
      disassemble = print_insn_kvx;
245
424
      break;
246
0
#endif
247
0
#ifdef ARCH_lm32
248
74
    case bfd_arch_lm32:
249
74
      disassemble = print_insn_lm32;
250
74
      break;
251
0
#endif
252
0
#ifdef ARCH_m32r
253
189
    case bfd_arch_m32r:
254
189
      disassemble = print_insn_m32r;
255
189
      break;
256
0
#endif
257
0
#if defined(ARCH_m68hc11) || defined(ARCH_m68hc12) \
258
0
    || defined(ARCH_9s12x) || defined(ARCH_m9s12xg)
259
45
    case bfd_arch_m68hc11:
260
45
      disassemble = print_insn_m68hc11;
261
45
      break;
262
123
    case bfd_arch_m68hc12:
263
123
      disassemble = print_insn_m68hc12;
264
123
      break;
265
115
    case bfd_arch_m9s12x:
266
115
      disassemble = print_insn_m9s12x;
267
115
      break;
268
70
    case bfd_arch_m9s12xg:
269
70
      disassemble = print_insn_m9s12xg;
270
70
      break;
271
0
#endif
272
0
#if defined(ARCH_s12z)
273
433
    case bfd_arch_s12z:
274
433
      disassemble = print_insn_s12z;
275
433
      break;
276
0
#endif
277
0
#ifdef ARCH_m68k
278
647
    case bfd_arch_m68k:
279
647
      disassemble = print_insn_m68k;
280
647
      break;
281
0
#endif
282
0
#ifdef ARCH_mt
283
159
    case bfd_arch_mt:
284
159
      disassemble = print_insn_mt;
285
159
      break;
286
0
#endif
287
0
#ifdef ARCH_microblaze
288
158
    case bfd_arch_microblaze:
289
158
      disassemble = print_insn_microblaze;
290
158
      break;
291
0
#endif
292
0
#ifdef ARCH_msp430
293
479
    case bfd_arch_msp430:
294
479
      disassemble = print_insn_msp430;
295
479
      break;
296
0
#endif
297
0
#ifdef ARCH_nds32
298
779
    case bfd_arch_nds32:
299
779
      disassemble = print_insn_nds32;
300
779
      break;
301
0
#endif
302
0
#ifdef ARCH_nfp
303
577
    case bfd_arch_nfp:
304
577
      disassemble = print_insn_nfp;
305
577
      break;
306
0
#endif
307
0
#ifdef ARCH_ns32k
308
427
    case bfd_arch_ns32k:
309
427
      disassemble = print_insn_ns32k;
310
427
      break;
311
0
#endif
312
0
#ifdef ARCH_mcore
313
201
    case bfd_arch_mcore:
314
201
      disassemble = print_insn_mcore;
315
201
      break;
316
0
#endif
317
0
#ifdef ARCH_mep
318
229
    case bfd_arch_mep:
319
229
      disassemble = print_insn_mep;
320
229
      break;
321
0
#endif
322
0
#ifdef ARCH_metag
323
1.72k
    case bfd_arch_metag:
324
1.72k
      disassemble = print_insn_metag;
325
1.72k
      break;
326
0
#endif
327
0
#ifdef ARCH_mips
328
7.87k
    case bfd_arch_mips:
329
7.87k
      if (big)
330
3.35k
  disassemble = print_insn_big_mips;
331
4.52k
      else
332
4.52k
  disassemble = print_insn_little_mips;
333
7.87k
      break;
334
0
#endif
335
0
#ifdef ARCH_mmix
336
199
    case bfd_arch_mmix:
337
199
      disassemble = print_insn_mmix;
338
199
      break;
339
0
#endif
340
0
#ifdef ARCH_mn10200
341
229
    case bfd_arch_mn10200:
342
229
      disassemble = print_insn_mn10200;
343
229
      break;
344
0
#endif
345
0
#ifdef ARCH_mn10300
346
332
    case bfd_arch_mn10300:
347
332
      disassemble = print_insn_mn10300;
348
332
      break;
349
0
#endif
350
0
#ifdef ARCH_or1k
351
127
    case bfd_arch_or1k:
352
127
      disassemble = print_insn_or1k;
353
127
      break;
354
0
#endif
355
0
#ifdef ARCH_pdp11
356
242
    case bfd_arch_pdp11:
357
242
      disassemble = print_insn_pdp11;
358
242
      break;
359
0
#endif
360
0
#ifdef ARCH_pj
361
0
    case bfd_arch_pj:
362
0
      disassemble = print_insn_pj;
363
0
      break;
364
0
#endif
365
0
#ifdef ARCH_powerpc
366
694
    case bfd_arch_powerpc:
367
694
#endif
368
694
#ifdef ARCH_rs6000
369
744
    case bfd_arch_rs6000:
370
744
#endif
371
744
#if defined ARCH_powerpc || defined ARCH_rs6000
372
744
      if (big)
373
183
  disassemble = print_insn_big_powerpc;
374
561
      else
375
561
  disassemble = print_insn_little_powerpc;
376
744
      break;
377
0
#endif
378
0
#ifdef ARCH_pru
379
100
    case bfd_arch_pru:
380
100
      disassemble = print_insn_pru;
381
100
      break;
382
0
#endif
383
0
#ifdef ARCH_riscv
384
890
    case bfd_arch_riscv:
385
890
      disassemble = print_insn_riscv;
386
890
      break;
387
0
#endif
388
0
#ifdef ARCH_rl78
389
2.99k
    case bfd_arch_rl78:
390
2.99k
      disassemble = rl78_get_disassembler (abfd);
391
2.99k
      break;
392
0
#endif
393
0
#ifdef ARCH_rx
394
8.48k
    case bfd_arch_rx:
395
8.48k
      disassemble = print_insn_rx;
396
8.48k
      break;
397
0
#endif
398
0
#ifdef ARCH_s390
399
172
    case bfd_arch_s390:
400
172
      disassemble = print_insn_s390;
401
172
      break;
402
0
#endif
403
0
#ifdef ARCH_score
404
335
    case bfd_arch_score:
405
335
      if (big)
406
64
  disassemble = print_insn_big_score;
407
271
      else
408
271
  disassemble = print_insn_little_score;
409
335
     break;
410
0
#endif
411
0
#ifdef ARCH_sh
412
729
    case bfd_arch_sh:
413
729
      disassemble = print_insn_sh;
414
729
      break;
415
0
#endif
416
0
#ifdef ARCH_sparc
417
354
    case bfd_arch_sparc:
418
354
      disassemble = print_insn_sparc;
419
354
      break;
420
0
#endif
421
0
#ifdef ARCH_spu
422
210
    case bfd_arch_spu:
423
210
      disassemble = print_insn_spu;
424
210
      break;
425
0
#endif
426
0
#ifdef ARCH_tic30
427
294
    case bfd_arch_tic30:
428
294
      disassemble = print_insn_tic30;
429
294
      break;
430
0
#endif
431
0
#ifdef ARCH_tic4x
432
273
    case bfd_arch_tic4x:
433
273
      disassemble = print_insn_tic4x;
434
273
      break;
435
0
#endif
436
0
#ifdef ARCH_tic54x
437
330
    case bfd_arch_tic54x:
438
330
      disassemble = print_insn_tic54x;
439
330
      break;
440
0
#endif
441
0
#ifdef ARCH_tic6x
442
110
    case bfd_arch_tic6x:
443
110
      disassemble = print_insn_tic6x;
444
110
      break;
445
0
#endif
446
0
#ifdef ARCH_ft32
447
140
    case bfd_arch_ft32:
448
140
      disassemble = print_insn_ft32;
449
140
      break;
450
0
#endif
451
0
#ifdef ARCH_v850
452
292
    case bfd_arch_v850:
453
388
    case bfd_arch_v850_rh850:
454
388
      disassemble = print_insn_v850;
455
388
      break;
456
0
#endif
457
0
#ifdef ARCH_wasm32
458
352
    case bfd_arch_wasm32:
459
352
      disassemble = print_insn_wasm32;
460
352
      break;
461
0
#endif
462
0
#ifdef ARCH_xgate
463
122
    case bfd_arch_xgate:
464
122
      disassemble = print_insn_xgate;
465
122
      break;
466
0
#endif
467
0
#ifdef ARCH_xstormy16
468
108
    case bfd_arch_xstormy16:
469
108
      disassemble = print_insn_xstormy16;
470
108
      break;
471
0
#endif
472
0
#ifdef ARCH_xtensa
473
2.64k
    case bfd_arch_xtensa:
474
2.64k
      disassemble = print_insn_xtensa;
475
2.64k
      break;
476
0
#endif
477
0
#ifdef ARCH_z80
478
281
    case bfd_arch_z80:
479
281
      disassemble = print_insn_z80;
480
281
      break;
481
0
#endif
482
0
#ifdef ARCH_z8k
483
251
    case bfd_arch_z8k:
484
251
      if (mach == bfd_mach_z8001)
485
66
  disassemble = print_insn_z8001;
486
185
      else
487
185
  disassemble = print_insn_z8002;
488
251
      break;
489
0
#endif
490
0
#ifdef ARCH_vax
491
193
    case bfd_arch_vax:
492
193
      disassemble = print_insn_vax;
493
193
      break;
494
0
#endif
495
0
#ifdef ARCH_visium
496
444
     case bfd_arch_visium:
497
444
       disassemble = print_insn_visium;
498
444
       break;
499
0
#endif
500
0
#ifdef ARCH_frv
501
239
    case bfd_arch_frv:
502
239
      disassemble = print_insn_frv;
503
239
      break;
504
0
#endif
505
0
#ifdef ARCH_moxie
506
71
    case bfd_arch_moxie:
507
71
      disassemble = print_insn_moxie;
508
71
      break;
509
0
#endif
510
0
#ifdef ARCH_iq2000
511
114
    case bfd_arch_iq2000:
512
114
      disassemble = print_insn_iq2000;
513
114
      break;
514
0
#endif
515
0
#ifdef ARCH_m32c
516
543
    case bfd_arch_m32c:
517
543
      disassemble = print_insn_m32c;
518
543
      break;
519
0
#endif
520
0
#ifdef ARCH_tilegx
521
131
    case bfd_arch_tilegx:
522
131
      disassemble = print_insn_tilegx;
523
131
      break;
524
0
#endif
525
0
#ifdef ARCH_tilepro
526
115
    case bfd_arch_tilepro:
527
115
      disassemble = print_insn_tilepro;
528
115
      break;
529
0
#endif
530
0
#ifdef ARCH_loongarch
531
170
    case bfd_arch_loongarch:
532
170
      disassemble = print_insn_loongarch;
533
170
      break;
534
0
#endif
535
179
    default:
536
179
      return 0;
537
93.0k
    }
538
92.8k
  return disassemble;
539
93.0k
}
540
541
void
542
disassembler_usage (FILE *stream ATTRIBUTE_UNUSED)
543
0
{
544
0
#ifdef ARCH_aarch64
545
0
  print_aarch64_disassembler_options (stream);
546
0
#endif
547
0
#ifdef ARCH_arc
548
0
  print_arc_disassembler_options (stream);
549
0
#endif
550
0
#ifdef ARCH_arm
551
0
  print_arm_disassembler_options (stream);
552
0
#endif
553
0
#ifdef ARCH_mips
554
0
  print_mips_disassembler_options (stream);
555
0
#endif
556
0
#ifdef ARCH_nfp
557
0
  print_nfp_disassembler_options (stream);
558
0
#endif
559
0
#ifdef ARCH_powerpc
560
0
  print_ppc_disassembler_options (stream);
561
0
#endif
562
0
#ifdef ARCH_riscv
563
0
  print_riscv_disassembler_options (stream);
564
0
#endif
565
0
#ifdef ARCH_i386
566
0
  print_i386_disassembler_options (stream);
567
0
#endif
568
0
#ifdef ARCH_kvx
569
0
  print_kvx_disassembler_options (stream);
570
0
#endif
571
0
#ifdef ARCH_s390
572
0
  print_s390_disassembler_options (stream);
573
0
#endif
574
0
#ifdef ARCH_wasm32
575
0
  print_wasm32_disassembler_options (stream);
576
0
#endif
577
0
#ifdef ARCH_loongarch
578
0
  print_loongarch_disassembler_options (stream);
579
0
#endif
580
0
#ifdef ARCH_bpf
581
0
  print_bpf_disassembler_options (stream);
582
0
#endif
583
0
  return;
584
0
}
585
586
void
587
disassemble_init_for_target (struct disassemble_info * info)
588
92.8k
{
589
92.8k
  if (info == NULL)
590
0
    return;
591
592
92.8k
  switch (info->arch)
593
92.8k
    {
594
0
#ifdef ARCH_aarch64
595
12.5k
    case bfd_arch_aarch64:
596
12.5k
      info->symbol_is_valid = aarch64_symbol_is_valid;
597
12.5k
      info->disassembler_needs_relocs = true;
598
12.5k
      info->created_styled_output = true;
599
12.5k
      break;
600
0
#endif
601
0
#ifdef ARCH_arc
602
3.58k
    case bfd_arch_arc:
603
3.58k
      info->created_styled_output = true;
604
3.58k
      break;
605
0
#endif
606
0
#ifdef ARCH_arm
607
17.4k
    case bfd_arch_arm:
608
17.4k
      info->symbol_is_valid = arm_symbol_is_valid;
609
17.4k
      info->disassembler_needs_relocs = true;
610
17.4k
      info->created_styled_output = true;
611
17.4k
      break;
612
0
#endif
613
0
#ifdef ARCH_avr
614
268
    case bfd_arch_avr:
615
268
      info->created_styled_output = true;
616
268
      break;
617
0
#endif
618
0
#ifdef ARCH_csky
619
937
    case bfd_arch_csky:
620
937
      info->symbol_is_valid = csky_symbol_is_valid;
621
937
      info->disassembler_needs_relocs = true;
622
937
      break;
623
0
#endif
624
0
#ifdef ARCH_i386
625
14.4k
    case bfd_arch_i386:
626
14.6k
    case bfd_arch_iamcu:
627
14.6k
      info->created_styled_output = true;
628
14.6k
      break;
629
0
#endif
630
0
#ifdef ARCH_ia64
631
191
    case bfd_arch_ia64:
632
191
      info->skip_zeroes = 16;
633
191
      break;
634
0
#endif
635
0
#ifdef ARCH_loongarch
636
170
    case bfd_arch_loongarch:
637
170
      info->created_styled_output = true;
638
170
      break;
639
0
#endif
640
0
#ifdef ARCH_tic4x
641
273
    case bfd_arch_tic4x:
642
273
      info->skip_zeroes = 32;
643
273
      break;
644
0
#endif
645
0
#ifdef ARCH_m68k
646
647
    case bfd_arch_m68k:
647
647
      info->created_styled_output = true;
648
647
      break;
649
0
#endif
650
0
#ifdef ARCH_mep
651
229
    case bfd_arch_mep:
652
229
      info->skip_zeroes = 256;
653
229
      info->skip_zeroes_at_end = 0;
654
229
      break;
655
0
#endif
656
0
#ifdef ARCH_metag
657
1.72k
    case bfd_arch_metag:
658
1.72k
      info->disassembler_needs_relocs = true;
659
1.72k
      break;
660
0
#endif
661
0
#ifdef ARCH_mips
662
7.87k
    case bfd_arch_mips:
663
7.87k
      info->created_styled_output = true;
664
7.87k
      break;
665
0
#endif
666
0
#ifdef ARCH_m32c
667
543
    case bfd_arch_m32c:
668
      /* This processor in fact is little endian.  The value set here
669
   reflects the way opcodes are written in the cgen description.  */
670
543
      info->endian = BFD_ENDIAN_BIG;
671
543
      if (!info->private_data)
672
543
  {
673
543
    info->private_data = cgen_bitset_create (ISA_MAX);
674
543
    if (info->mach == bfd_mach_m16c)
675
171
      cgen_bitset_set (info->private_data, ISA_M16C);
676
372
    else
677
372
      cgen_bitset_set (info->private_data, ISA_M32C);
678
543
  }
679
543
      break;
680
0
#endif
681
0
#ifdef ARCH_bpf
682
16
    case bfd_arch_bpf:
683
16
      info->created_styled_output = true;
684
16
      break;
685
0
#endif
686
0
#ifdef ARCH_pru
687
100
    case bfd_arch_pru:
688
100
      info->disassembler_needs_relocs = true;
689
100
      break;
690
0
#endif
691
0
#ifdef ARCH_powerpc
692
694
    case bfd_arch_powerpc:
693
694
#endif
694
694
#ifdef ARCH_rs6000
695
744
    case bfd_arch_rs6000:
696
744
#endif
697
744
#if defined (ARCH_powerpc) || defined (ARCH_rs6000)
698
744
      disassemble_init_powerpc (info);
699
744
      info->created_styled_output = true;
700
744
      break;
701
0
#endif
702
0
#ifdef ARCH_riscv
703
890
    case bfd_arch_riscv:
704
890
      info->symbol_is_valid = riscv_symbol_is_valid;
705
890
      info->created_styled_output = true;
706
890
      break;
707
0
#endif
708
0
#ifdef ARCH_wasm32
709
352
    case bfd_arch_wasm32:
710
352
      disassemble_init_wasm32 (info);
711
352
      break;
712
0
#endif
713
0
#ifdef ARCH_s390
714
172
    case bfd_arch_s390:
715
172
      disassemble_init_s390 (info);
716
172
      info->created_styled_output = true;
717
172
      break;
718
0
#endif
719
0
#ifdef ARCH_nds32
720
779
    case bfd_arch_nds32:
721
779
      disassemble_init_nds32 (info);
722
779
      break;
723
0
 #endif
724
28.7k
    default:
725
28.7k
      break;
726
92.8k
    }
727
92.8k
}
728
729
void
730
disassemble_free_target (struct disassemble_info *info)
731
92.8k
{
732
92.8k
  if (info == NULL)
733
0
    return;
734
735
92.8k
  switch (info->arch)
736
92.8k
    {
737
85.7k
    default:
738
85.7k
      return;
739
740
85.7k
#ifdef ARCH_m32c
741
85.7k
    case bfd_arch_m32c:
742
543
#endif
743
543
#if defined ARCH_m32c
744
543
      if (info->private_data)
745
543
  {
746
543
    CGEN_BITSET *mask = info->private_data;
747
543
    free (mask->bits);
748
543
  }
749
543
      break;
750
0
#endif
751
752
0
#ifdef ARCH_arc
753
3.58k
    case bfd_arch_arc:
754
3.58k
      break;
755
0
#endif
756
0
#ifdef ARCH_cris
757
536
    case bfd_arch_cris:
758
536
      break;
759
0
#endif
760
0
#ifdef ARCH_mmix
761
199
    case bfd_arch_mmix:
762
199
      break;
763
0
#endif
764
0
#ifdef ARCH_nfp
765
577
    case bfd_arch_nfp:
766
577
      break;
767
0
#endif
768
0
#ifdef ARCH_powerpc
769
694
    case bfd_arch_powerpc:
770
694
      disassemble_free_powerpc (info);
771
694
      break;
772
0
#endif
773
0
#ifdef ARCH_riscv
774
890
    case bfd_arch_riscv:
775
890
      disassemble_free_riscv (info);
776
890
      break;
777
0
#endif
778
0
#ifdef ARCH_rs6000
779
50
    case bfd_arch_rs6000:
780
50
      break;
781
92.8k
#endif
782
92.8k
    }
783
784
7.07k
  free (info->private_data);
785
7.07k
}
786
787
/* Remove whitespace and consecutive commas from OPTIONS.  */
788
789
char *
790
remove_whitespace_and_extra_commas (char *options)
791
0
{
792
0
  char *str;
793
0
  size_t i, len;
794
795
0
  if (options == NULL)
796
0
    return NULL;
797
798
  /* Strip off all trailing whitespace and commas.  */
799
0
  for (len = strlen (options); len > 0; len--)
800
0
    {
801
0
      if (!ISSPACE (options[len - 1]) && options[len - 1] != ',')
802
0
  break;
803
0
      options[len - 1] = '\0';
804
0
    }
805
806
  /* Convert all remaining whitespace to commas.  */
807
0
  for (i = 0; options[i] != '\0'; i++)
808
0
    if (ISSPACE (options[i]))
809
0
      options[i] = ',';
810
811
  /* Remove consecutive commas.  */
812
0
  for (str = options; *str != '\0'; str++)
813
0
    if (*str == ',' && (*(str + 1) == ',' || str == options))
814
0
      {
815
0
  char *next = str + 1;
816
0
  while (*next == ',')
817
0
    next++;
818
0
  len = strlen (next);
819
0
  if (str != options)
820
0
    str++;
821
0
  memmove (str, next, len);
822
0
  next[len - (size_t)(next - str)] = '\0';
823
0
      }
824
0
  return (strlen (options) != 0) ? options : NULL;
825
0
}
826
827
/* Call FUNC for each comma separated option in INFO->disassembler_options,
828
   passing a zero terminated option and DATA.  The iteration terminates
829
   should FUNC return false.  */
830
831
bool
832
for_each_disassembler_option (struct disassemble_info *info,
833
            bool (*func) (const char *, void *),
834
            void *data)
835
337k
{
836
337k
  char *opt = (char *) info->disassembler_options;
837
337k
  bool ok = true;
838
337k
  if (opt != NULL)
839
40.0k
    while (ok)
840
40.0k
      {
841
40.0k
  char *opt_end = strchr (opt, ',');
842
40.0k
  if (opt_end != NULL)
843
21.6k
    *opt_end = 0;
844
40.0k
  ok = func (opt, data);
845
40.0k
  if (opt_end == NULL)
846
18.4k
    break;
847
21.6k
  *opt_end = ',';
848
21.6k
  opt = opt_end + 1;
849
21.6k
      }
850
337k
  return ok;
851
337k
}
852
853
void
854
opcodes_assert (const char *file, int line)
855
0
{
856
0
  opcodes_error_handler (_("assertion fail %s:%d"), file, line);
857
0
  opcodes_error_handler (_("Please report this bug"));
858
0
  abort ();
859
0
}
860
861
/* Set the stream, and the styled and unstyled printf functions within
862
   INFO.  */
863
864
void
865
disassemble_set_printf (struct disassemble_info *info, void *stream,
866
      fprintf_ftype unstyled_printf,
867
      fprintf_styled_ftype styled_printf)
868
69.0M
{
869
69.0M
  info->stream = stream;
870
69.0M
  info->fprintf_func = unstyled_printf;
871
69.0M
  info->fprintf_styled_func = styled_printf;
872
69.0M
}