Coverage Report

Created: 2026-04-04 08:16

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
91.2k
{
117
91.2k
  disassembler_ftype disassemble;
118
119
91.2k
  switch (a)
120
91.2k
    {
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.2k
    case bfd_arch_aarch64:
125
12.2k
      disassemble = print_insn_aarch64;
126
12.2k
      break;
127
0
#endif
128
0
#ifdef ARCH_alpha
129
227
    case bfd_arch_alpha:
130
227
      disassemble = print_insn_alpha;
131
227
      break;
132
0
#endif
133
0
#ifdef ARCH_arc
134
3.47k
    case bfd_arch_arc:
135
3.47k
      disassemble = arc_get_disassembler (abfd);
136
3.47k
      break;
137
0
#endif
138
0
#ifdef ARCH_arm
139
17.1k
    case bfd_arch_arm:
140
17.1k
      if (big)
141
7.62k
  disassemble = print_insn_big_arm;
142
9.48k
      else
143
9.48k
  disassemble = print_insn_little_arm;
144
17.1k
      break;
145
0
#endif
146
0
#ifdef ARCH_avr
147
299
    case bfd_arch_avr:
148
299
      disassemble = print_insn_avr;
149
299
      break;
150
0
#endif
151
0
#ifdef ARCH_bfin
152
2.34k
    case bfd_arch_bfin:
153
2.34k
      disassemble = print_insn_bfin;
154
2.34k
      break;
155
0
#endif
156
0
#ifdef ARCH_cr16
157
307
    case bfd_arch_cr16:
158
307
      disassemble = print_insn_cr16;
159
307
      break;
160
0
#endif
161
0
#ifdef ARCH_cris
162
464
    case bfd_arch_cris:
163
464
      disassemble = cris_get_disassembler (abfd);
164
464
      break;
165
0
#endif
166
0
#ifdef ARCH_crx
167
277
    case bfd_arch_crx:
168
277
      disassemble = print_insn_crx;
169
277
      break;
170
0
#endif
171
0
#ifdef ARCH_csky
172
930
    case bfd_arch_csky:
173
930
      disassemble = csky_get_disassembler (abfd);
174
930
      break;
175
0
#endif
176
177
0
#ifdef ARCH_d10v
178
117
    case bfd_arch_d10v:
179
117
      disassemble = print_insn_d10v;
180
117
      break;
181
0
#endif
182
0
#ifdef ARCH_d30v
183
221
    case bfd_arch_d30v:
184
221
      disassemble = print_insn_d30v;
185
221
      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
320
    case bfd_arch_h8300:
195
320
      if (mach == bfd_mach_h8300h || mach == bfd_mach_h8300hn)
196
24
  disassemble = print_insn_h8300h;
197
296
      else if (mach == bfd_mach_h8300s
198
287
         || mach == bfd_mach_h8300sn
199
283
         || mach == bfd_mach_h8300sx
200
276
         || mach == bfd_mach_h8300sxn)
201
36
  disassemble = print_insn_h8300s;
202
260
      else
203
260
  disassemble = print_insn_h8300;
204
320
      break;
205
0
#endif
206
0
#ifdef ARCH_hppa
207
488
    case bfd_arch_hppa:
208
488
      disassemble = print_insn_hppa;
209
488
      break;
210
0
#endif
211
0
#ifdef ARCH_i386
212
14.1k
    case bfd_arch_i386:
213
14.3k
    case bfd_arch_iamcu:
214
14.3k
      disassemble = print_insn_i386;
215
14.3k
      break;
216
0
#endif
217
0
#ifdef ARCH_ia64
218
202
    case bfd_arch_ia64:
219
202
      disassemble = print_insn_ia64;
220
202
      break;
221
0
#endif
222
0
#ifdef ARCH_ip2k
223
74
    case bfd_arch_ip2k:
224
74
      disassemble = print_insn_ip2k;
225
74
      break;
226
0
#endif
227
0
#ifdef ARCH_bpf
228
15
    case bfd_arch_bpf:
229
15
      disassemble = print_insn_bpf;
230
15
      break;
231
0
#endif
232
0
#ifdef ARCH_epiphany
233
137
    case bfd_arch_epiphany:
234
137
      disassemble = print_insn_epiphany;
235
137
      break;
236
0
#endif
237
0
#ifdef ARCH_fr30
238
176
    case bfd_arch_fr30:
239
176
      disassemble = print_insn_fr30;
240
176
      break;
241
0
#endif
242
0
#ifdef ARCH_kvx
243
416
    case bfd_arch_kvx:
244
416
      disassemble = print_insn_kvx;
245
416
      break;
246
0
#endif
247
0
#ifdef ARCH_lm32
248
78
    case bfd_arch_lm32:
249
78
      disassemble = print_insn_lm32;
250
78
      break;
251
0
#endif
252
0
#ifdef ARCH_m32r
253
200
    case bfd_arch_m32r:
254
200
      disassemble = print_insn_m32r;
255
200
      break;
256
0
#endif
257
0
#if defined(ARCH_m68hc11) || defined(ARCH_m68hc12) \
258
0
    || defined(ARCH_9s12x) || defined(ARCH_m9s12xg)
259
44
    case bfd_arch_m68hc11:
260
44
      disassemble = print_insn_m68hc11;
261
44
      break;
262
127
    case bfd_arch_m68hc12:
263
127
      disassemble = print_insn_m68hc12;
264
127
      break;
265
97
    case bfd_arch_m9s12x:
266
97
      disassemble = print_insn_m9s12x;
267
97
      break;
268
76
    case bfd_arch_m9s12xg:
269
76
      disassemble = print_insn_m9s12xg;
270
76
      break;
271
0
#endif
272
0
#if defined(ARCH_s12z)
273
412
    case bfd_arch_s12z:
274
412
      disassemble = print_insn_s12z;
275
412
      break;
276
0
#endif
277
0
#ifdef ARCH_m68k
278
677
    case bfd_arch_m68k:
279
677
      disassemble = print_insn_m68k;
280
677
      break;
281
0
#endif
282
0
#ifdef ARCH_mt
283
124
    case bfd_arch_mt:
284
124
      disassemble = print_insn_mt;
285
124
      break;
286
0
#endif
287
0
#ifdef ARCH_microblaze
288
151
    case bfd_arch_microblaze:
289
151
      disassemble = print_insn_microblaze;
290
151
      break;
291
0
#endif
292
0
#ifdef ARCH_msp430
293
491
    case bfd_arch_msp430:
294
491
      disassemble = print_insn_msp430;
295
491
      break;
296
0
#endif
297
0
#ifdef ARCH_nds32
298
746
    case bfd_arch_nds32:
299
746
      disassemble = print_insn_nds32;
300
746
      break;
301
0
#endif
302
0
#ifdef ARCH_nfp
303
588
    case bfd_arch_nfp:
304
588
      disassemble = print_insn_nfp;
305
588
      break;
306
0
#endif
307
0
#ifdef ARCH_ns32k
308
382
    case bfd_arch_ns32k:
309
382
      disassemble = print_insn_ns32k;
310
382
      break;
311
0
#endif
312
0
#ifdef ARCH_mcore
313
205
    case bfd_arch_mcore:
314
205
      disassemble = print_insn_mcore;
315
205
      break;
316
0
#endif
317
0
#ifdef ARCH_mep
318
224
    case bfd_arch_mep:
319
224
      disassemble = print_insn_mep;
320
224
      break;
321
0
#endif
322
0
#ifdef ARCH_metag
323
1.71k
    case bfd_arch_metag:
324
1.71k
      disassemble = print_insn_metag;
325
1.71k
      break;
326
0
#endif
327
0
#ifdef ARCH_mips
328
7.72k
    case bfd_arch_mips:
329
7.72k
      if (big)
330
3.28k
  disassemble = print_insn_big_mips;
331
4.44k
      else
332
4.44k
  disassemble = print_insn_little_mips;
333
7.72k
      break;
334
0
#endif
335
0
#ifdef ARCH_mmix
336
195
    case bfd_arch_mmix:
337
195
      disassemble = print_insn_mmix;
338
195
      break;
339
0
#endif
340
0
#ifdef ARCH_mn10200
341
254
    case bfd_arch_mn10200:
342
254
      disassemble = print_insn_mn10200;
343
254
      break;
344
0
#endif
345
0
#ifdef ARCH_mn10300
346
344
    case bfd_arch_mn10300:
347
344
      disassemble = print_insn_mn10300;
348
344
      break;
349
0
#endif
350
0
#ifdef ARCH_or1k
351
114
    case bfd_arch_or1k:
352
114
      disassemble = print_insn_or1k;
353
114
      break;
354
0
#endif
355
0
#ifdef ARCH_pdp11
356
267
    case bfd_arch_pdp11:
357
267
      disassemble = print_insn_pdp11;
358
267
      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
647
    case bfd_arch_powerpc:
367
647
#endif
368
647
#ifdef ARCH_rs6000
369
707
    case bfd_arch_rs6000:
370
707
#endif
371
707
#if defined ARCH_powerpc || defined ARCH_rs6000
372
707
      if (big)
373
212
  disassemble = print_insn_big_powerpc;
374
495
      else
375
495
  disassemble = print_insn_little_powerpc;
376
707
      break;
377
0
#endif
378
0
#ifdef ARCH_pru
379
99
    case bfd_arch_pru:
380
99
      disassemble = print_insn_pru;
381
99
      break;
382
0
#endif
383
0
#ifdef ARCH_riscv
384
881
    case bfd_arch_riscv:
385
881
      disassemble = print_insn_riscv;
386
881
      break;
387
0
#endif
388
0
#ifdef ARCH_rl78
389
2.90k
    case bfd_arch_rl78:
390
2.90k
      disassemble = rl78_get_disassembler (abfd);
391
2.90k
      break;
392
0
#endif
393
0
#ifdef ARCH_rx
394
8.29k
    case bfd_arch_rx:
395
8.29k
      disassemble = print_insn_rx;
396
8.29k
      break;
397
0
#endif
398
0
#ifdef ARCH_s390
399
165
    case bfd_arch_s390:
400
165
      disassemble = print_insn_s390;
401
165
      break;
402
0
#endif
403
0
#ifdef ARCH_score
404
355
    case bfd_arch_score:
405
355
      if (big)
406
84
  disassemble = print_insn_big_score;
407
271
      else
408
271
  disassemble = print_insn_little_score;
409
355
     break;
410
0
#endif
411
0
#ifdef ARCH_sh
412
680
    case bfd_arch_sh:
413
680
      disassemble = print_insn_sh;
414
680
      break;
415
0
#endif
416
0
#ifdef ARCH_sparc
417
365
    case bfd_arch_sparc:
418
365
      disassemble = print_insn_sparc;
419
365
      break;
420
0
#endif
421
0
#ifdef ARCH_spu
422
215
    case bfd_arch_spu:
423
215
      disassemble = print_insn_spu;
424
215
      break;
425
0
#endif
426
0
#ifdef ARCH_tic30
427
301
    case bfd_arch_tic30:
428
301
      disassemble = print_insn_tic30;
429
301
      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
301
    case bfd_arch_tic54x:
438
301
      disassemble = print_insn_tic54x;
439
301
      break;
440
0
#endif
441
0
#ifdef ARCH_tic6x
442
113
    case bfd_arch_tic6x:
443
113
      disassemble = print_insn_tic6x;
444
113
      break;
445
0
#endif
446
0
#ifdef ARCH_ft32
447
130
    case bfd_arch_ft32:
448
130
      disassemble = print_insn_ft32;
449
130
      break;
450
0
#endif
451
0
#ifdef ARCH_v850
452
239
    case bfd_arch_v850:
453
306
    case bfd_arch_v850_rh850:
454
306
      disassemble = print_insn_v850;
455
306
      break;
456
0
#endif
457
0
#ifdef ARCH_wasm32
458
323
    case bfd_arch_wasm32:
459
323
      disassemble = print_insn_wasm32;
460
323
      break;
461
0
#endif
462
0
#ifdef ARCH_xgate
463
124
    case bfd_arch_xgate:
464
124
      disassemble = print_insn_xgate;
465
124
      break;
466
0
#endif
467
0
#ifdef ARCH_xstormy16
468
105
    case bfd_arch_xstormy16:
469
105
      disassemble = print_insn_xstormy16;
470
105
      break;
471
0
#endif
472
0
#ifdef ARCH_xtensa
473
2.44k
    case bfd_arch_xtensa:
474
2.44k
      disassemble = print_insn_xtensa;
475
2.44k
      break;
476
0
#endif
477
0
#ifdef ARCH_z80
478
306
    case bfd_arch_z80:
479
306
      disassemble = print_insn_z80;
480
306
      break;
481
0
#endif
482
0
#ifdef ARCH_z8k
483
240
    case bfd_arch_z8k:
484
240
      if (mach == bfd_mach_z8001)
485
60
  disassemble = print_insn_z8001;
486
180
      else
487
180
  disassemble = print_insn_z8002;
488
240
      break;
489
0
#endif
490
0
#ifdef ARCH_vax
491
196
    case bfd_arch_vax:
492
196
      disassemble = print_insn_vax;
493
196
      break;
494
0
#endif
495
0
#ifdef ARCH_visium
496
428
     case bfd_arch_visium:
497
428
       disassemble = print_insn_visium;
498
428
       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
72
    case bfd_arch_moxie:
507
72
      disassemble = print_insn_moxie;
508
72
      break;
509
0
#endif
510
0
#ifdef ARCH_iq2000
511
93
    case bfd_arch_iq2000:
512
93
      disassemble = print_insn_iq2000;
513
93
      break;
514
0
#endif
515
0
#ifdef ARCH_m32c
516
510
    case bfd_arch_m32c:
517
510
      disassemble = print_insn_m32c;
518
510
      break;
519
0
#endif
520
0
#ifdef ARCH_tilegx
521
128
    case bfd_arch_tilegx:
522
128
      disassemble = print_insn_tilegx;
523
128
      break;
524
0
#endif
525
0
#ifdef ARCH_tilepro
526
126
    case bfd_arch_tilepro:
527
126
      disassemble = print_insn_tilepro;
528
126
      break;
529
0
#endif
530
0
#ifdef ARCH_loongarch
531
187
    case bfd_arch_loongarch:
532
187
      disassemble = print_insn_loongarch;
533
187
      break;
534
0
#endif
535
212
    default:
536
212
      return 0;
537
91.2k
    }
538
91.0k
  return disassemble;
539
91.2k
}
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
91.0k
{
589
91.0k
  if (info == NULL)
590
0
    return;
591
592
91.0k
  switch (info->arch)
593
91.0k
    {
594
0
#ifdef ARCH_aarch64
595
12.2k
    case bfd_arch_aarch64:
596
12.2k
      info->symbol_is_valid = aarch64_symbol_is_valid;
597
12.2k
      info->disassembler_needs_relocs = true;
598
12.2k
      info->created_styled_output = true;
599
12.2k
      break;
600
0
#endif
601
0
#ifdef ARCH_arc
602
3.47k
    case bfd_arch_arc:
603
3.47k
      info->created_styled_output = true;
604
3.47k
      break;
605
0
#endif
606
0
#ifdef ARCH_arm
607
17.1k
    case bfd_arch_arm:
608
17.1k
      info->symbol_is_valid = arm_symbol_is_valid;
609
17.1k
      info->disassembler_needs_relocs = true;
610
17.1k
      info->created_styled_output = true;
611
17.1k
      break;
612
0
#endif
613
0
#ifdef ARCH_avr
614
299
    case bfd_arch_avr:
615
299
      info->created_styled_output = true;
616
299
      break;
617
0
#endif
618
0
#ifdef ARCH_csky
619
930
    case bfd_arch_csky:
620
930
      info->symbol_is_valid = csky_symbol_is_valid;
621
930
      info->disassembler_needs_relocs = true;
622
930
      break;
623
0
#endif
624
0
#ifdef ARCH_i386
625
14.1k
    case bfd_arch_i386:
626
14.3k
    case bfd_arch_iamcu:
627
14.3k
      info->created_styled_output = true;
628
14.3k
      break;
629
0
#endif
630
0
#ifdef ARCH_ia64
631
202
    case bfd_arch_ia64:
632
202
      info->skip_zeroes = 16;
633
202
      break;
634
0
#endif
635
0
#ifdef ARCH_loongarch
636
187
    case bfd_arch_loongarch:
637
187
      info->created_styled_output = true;
638
187
      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
677
    case bfd_arch_m68k:
647
677
      info->created_styled_output = true;
648
677
      break;
649
0
#endif
650
0
#ifdef ARCH_mep
651
224
    case bfd_arch_mep:
652
224
      info->skip_zeroes = 256;
653
224
      info->skip_zeroes_at_end = 0;
654
224
      break;
655
0
#endif
656
0
#ifdef ARCH_metag
657
1.71k
    case bfd_arch_metag:
658
1.71k
      info->disassembler_needs_relocs = true;
659
1.71k
      break;
660
0
#endif
661
0
#ifdef ARCH_mips
662
7.72k
    case bfd_arch_mips:
663
7.72k
      info->created_styled_output = true;
664
7.72k
      break;
665
0
#endif
666
0
#ifdef ARCH_m32c
667
510
    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
510
      info->endian = BFD_ENDIAN_BIG;
671
510
      if (!info->private_data)
672
510
  {
673
510
    info->private_data = cgen_bitset_create (ISA_MAX);
674
510
    if (info->mach == bfd_mach_m16c)
675
164
      cgen_bitset_set (info->private_data, ISA_M16C);
676
346
    else
677
346
      cgen_bitset_set (info->private_data, ISA_M32C);
678
510
  }
679
510
      break;
680
0
#endif
681
0
#ifdef ARCH_bpf
682
15
    case bfd_arch_bpf:
683
15
      info->created_styled_output = true;
684
15
      break;
685
0
#endif
686
0
#ifdef ARCH_pru
687
99
    case bfd_arch_pru:
688
99
      info->disassembler_needs_relocs = true;
689
99
      break;
690
0
#endif
691
0
#ifdef ARCH_powerpc
692
647
    case bfd_arch_powerpc:
693
647
#endif
694
647
#ifdef ARCH_rs6000
695
707
    case bfd_arch_rs6000:
696
707
#endif
697
707
#if defined (ARCH_powerpc) || defined (ARCH_rs6000)
698
707
      disassemble_init_powerpc (info);
699
707
      info->created_styled_output = true;
700
707
      break;
701
0
#endif
702
0
#ifdef ARCH_riscv
703
881
    case bfd_arch_riscv:
704
881
      info->symbol_is_valid = riscv_symbol_is_valid;
705
881
      info->created_styled_output = true;
706
881
      break;
707
0
#endif
708
0
#ifdef ARCH_wasm32
709
323
    case bfd_arch_wasm32:
710
323
      disassemble_init_wasm32 (info);
711
323
      break;
712
0
#endif
713
0
#ifdef ARCH_s390
714
165
    case bfd_arch_s390:
715
165
      disassemble_init_s390 (info);
716
165
      info->created_styled_output = true;
717
165
      break;
718
0
#endif
719
0
#ifdef ARCH_nds32
720
746
    case bfd_arch_nds32:
721
746
      disassemble_init_nds32 (info);
722
746
      break;
723
0
 #endif
724
28.2k
    default:
725
28.2k
      break;
726
91.0k
    }
727
91.0k
}
728
729
void
730
disassemble_free_target (struct disassemble_info *info)
731
91.0k
{
732
91.0k
  if (info == NULL)
733
0
    return;
734
735
91.0k
  switch (info->arch)
736
91.0k
    {
737
84.2k
    default:
738
84.2k
      return;
739
740
84.2k
#ifdef ARCH_m32c
741
84.2k
    case bfd_arch_m32c:
742
510
#endif
743
510
#if defined ARCH_m32c
744
510
      if (info->private_data)
745
510
  {
746
510
    CGEN_BITSET *mask = info->private_data;
747
510
    free (mask->bits);
748
510
  }
749
510
      break;
750
0
#endif
751
752
0
#ifdef ARCH_arc
753
3.47k
    case bfd_arch_arc:
754
3.47k
      break;
755
0
#endif
756
0
#ifdef ARCH_cris
757
464
    case bfd_arch_cris:
758
464
      break;
759
0
#endif
760
0
#ifdef ARCH_mmix
761
195
    case bfd_arch_mmix:
762
195
      break;
763
0
#endif
764
0
#ifdef ARCH_nfp
765
588
    case bfd_arch_nfp:
766
588
      break;
767
0
#endif
768
0
#ifdef ARCH_powerpc
769
647
    case bfd_arch_powerpc:
770
647
      disassemble_free_powerpc (info);
771
647
      break;
772
0
#endif
773
0
#ifdef ARCH_riscv
774
881
    case bfd_arch_riscv:
775
881
      disassemble_free_riscv (info);
776
881
      break;
777
0
#endif
778
0
#ifdef ARCH_rs6000
779
60
    case bfd_arch_rs6000:
780
60
      break;
781
91.0k
#endif
782
91.0k
    }
783
784
6.81k
  free (info->private_data);
785
6.81k
}
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
319k
{
836
319k
  char *opt = (char *) info->disassembler_options;
837
319k
  bool ok = true;
838
319k
  if (opt != NULL)
839
37.4k
    while (ok)
840
37.4k
      {
841
37.4k
  char *opt_end = strchr (opt, ',');
842
37.4k
  if (opt_end != NULL)
843
19.3k
    *opt_end = 0;
844
37.4k
  ok = func (opt, data);
845
37.4k
  if (opt_end == NULL)
846
18.1k
    break;
847
19.3k
  *opt_end = ',';
848
19.3k
  opt = opt_end + 1;
849
19.3k
      }
850
319k
  return ok;
851
319k
}
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
67.2M
{
869
67.2M
  info->stream = stream;
870
67.2M
  info->fprintf_func = unstyled_printf;
871
67.2M
  info->fprintf_styled_func = styled_printf;
872
67.2M
}