Coverage Report

Created: 2025-07-08 11:15

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