Coverage Report

Created: 2026-03-10 08:46

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