Automatic date update in version.in
[binutils-gdb.git] / opcodes / nios2-dis.c
blob344474633a3cf00d93417d1a7336fbf47446f4c5
1 /* Altera Nios II disassemble routines
2 Copyright (C) 2012-2024 Free Software Foundation, Inc.
3 Contributed by Nigel Gray (ngray@altera.com).
4 Contributed by Mentor Graphics, Inc.
6 This file is part of the GNU opcodes library.
8 This library is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3, or (at your option)
11 any later version.
13 It is distributed in the hope that it will be useful, but WITHOUT
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
15 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
16 License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this file; see the file COPYING. If not, write to the
20 Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston,
21 MA 02110-1301, USA. */
23 #include "sysdep.h"
24 #include "disassemble.h"
25 #include "opintl.h"
26 #include "opcode/nios2.h"
27 #include "libiberty.h"
28 #include <string.h>
29 #include <assert.h>
31 /* No symbol table is available when this code runs out in an embedded
32 system as when it is used for disassembler support in a monitor. */
33 #if !defined(EMBEDDED_ENV)
34 #define SYMTAB_AVAILABLE 1
35 #include "elf-bfd.h"
36 #include "elf/nios2.h"
37 #endif
39 /* Default length of Nios II instruction in bytes. */
40 #define INSNLEN 4
42 /* Data structures used by the opcode hash table. */
43 typedef struct _nios2_opcode_hash
45 const struct nios2_opcode *opcode;
46 struct _nios2_opcode_hash *next;
47 } nios2_opcode_hash;
49 /* Hash table size. */
50 #define OPCODE_HASH_SIZE (IW_R1_OP_UNSHIFTED_MASK + 1)
52 /* Extract the opcode from an instruction word. */
53 static unsigned int
54 nios2_r1_extract_opcode (unsigned int x)
56 return GET_IW_R1_OP (x);
59 static unsigned int
60 nios2_r2_extract_opcode (unsigned int x)
62 return GET_IW_R2_OP (x);
65 /* We maintain separate hash tables for R1 and R2 opcodes, and pseudo-ops
66 are stored in a different table than regular instructions. */
68 typedef struct _nios2_disassembler_state
70 const struct nios2_opcode *opcodes;
71 const int *num_opcodes;
72 unsigned int (*extract_opcode) (unsigned int);
73 nios2_opcode_hash *hash[OPCODE_HASH_SIZE];
74 nios2_opcode_hash *ps_hash[OPCODE_HASH_SIZE];
75 const struct nios2_opcode *nop;
76 bool init;
77 } nios2_disassembler_state;
79 static nios2_disassembler_state
80 nios2_r1_disassembler_state = {
81 nios2_r1_opcodes,
82 &nios2_num_r1_opcodes,
83 nios2_r1_extract_opcode,
84 {},
85 {},
86 NULL,
90 static nios2_disassembler_state
91 nios2_r2_disassembler_state = {
92 nios2_r2_opcodes,
93 &nios2_num_r2_opcodes,
94 nios2_r2_extract_opcode,
95 {},
96 {},
97 NULL,
101 /* Function to initialize the opcode hash table. */
102 static void
103 nios2_init_opcode_hash (nios2_disassembler_state *state)
105 unsigned int i;
106 register const struct nios2_opcode *op;
108 for (i = 0; i < OPCODE_HASH_SIZE; i++)
109 for (op = state->opcodes; op < &state->opcodes[*(state->num_opcodes)]; op++)
111 nios2_opcode_hash *new_hash;
112 nios2_opcode_hash **bucket = NULL;
114 if ((op->pinfo & NIOS2_INSN_MACRO) == NIOS2_INSN_MACRO)
116 if (i == state->extract_opcode (op->match)
117 && (op->pinfo & (NIOS2_INSN_MACRO_MOV | NIOS2_INSN_MACRO_MOVI)
118 & 0x7fffffff))
120 bucket = &(state->ps_hash[i]);
121 if (strcmp (op->name, "nop") == 0)
122 state->nop = op;
125 else if (i == state->extract_opcode (op->match))
126 bucket = &(state->hash[i]);
128 if (bucket)
130 new_hash =
131 (nios2_opcode_hash *) malloc (sizeof (nios2_opcode_hash));
132 if (new_hash == NULL)
134 /* xgettext:c-format */
135 opcodes_error_handler (_("out of memory"));
136 exit (1);
138 new_hash->opcode = op;
139 new_hash->next = NULL;
140 while (*bucket)
141 bucket = &((*bucket)->next);
142 *bucket = new_hash;
145 state->init = 1;
147 #ifdef DEBUG_HASHTABLE
148 for (i = 0; i < OPCODE_HASH_SIZE; ++i)
150 nios2_opcode_hash *tmp_hash = state->hash[i];
151 printf ("index: 0x%02X ops: ", i);
152 while (tmp_hash != NULL)
154 printf ("%s ", tmp_hash->opcode->name);
155 tmp_hash = tmp_hash->next;
157 printf ("\n");
160 for (i = 0; i < OPCODE_HASH_SIZE; ++i)
162 nios2_opcode_hash *tmp_hash = state->ps_hash[i];
163 printf ("index: 0x%02X ops: ", i);
164 while (tmp_hash != NULL)
166 printf ("%s ", tmp_hash->opcode->name);
167 tmp_hash = tmp_hash->next;
169 printf ("\n");
171 #endif /* DEBUG_HASHTABLE */
174 /* Return a pointer to an nios2_opcode struct for a given instruction
175 word OPCODE for bfd machine MACH, or NULL if there is an error. */
176 const struct nios2_opcode *
177 nios2_find_opcode_hash (unsigned long opcode, unsigned long mach)
179 nios2_opcode_hash *entry;
180 nios2_disassembler_state *state;
182 /* Select the right instruction set, hash tables, and opcode accessor
183 for the mach variant. */
184 if (mach == bfd_mach_nios2r2)
185 state = &nios2_r2_disassembler_state;
186 else
187 state = &nios2_r1_disassembler_state;
189 /* Build a hash table to shorten the search time. */
190 if (!state->init)
191 nios2_init_opcode_hash (state);
193 /* Check for NOP first. Both NOP and MOV are macros that expand into
194 an ADD instruction, and we always want to give priority to NOP. */
195 if (state->nop->match == (opcode & state->nop->mask))
196 return state->nop;
198 /* First look in the pseudo-op hashtable. */
199 for (entry = state->ps_hash[state->extract_opcode (opcode)];
200 entry; entry = entry->next)
201 if (entry->opcode->match == (opcode & entry->opcode->mask))
202 return entry->opcode;
204 /* Otherwise look in the main hashtable. */
205 for (entry = state->hash[state->extract_opcode (opcode)];
206 entry; entry = entry->next)
207 if (entry->opcode->match == (opcode & entry->opcode->mask))
208 return entry->opcode;
210 return NULL;
213 /* There are 32 regular registers, 32 coprocessor registers,
214 and 32 control registers. */
215 #define NUMREGNAMES 32
217 /* Return a pointer to the base of the coprocessor register name array. */
218 static struct nios2_reg *
219 nios2_coprocessor_regs (void)
221 static struct nios2_reg *cached = NULL;
223 if (!cached)
225 int i;
226 for (i = NUMREGNAMES; i < nios2_num_regs; i++)
227 if (!strcmp (nios2_regs[i].name, "c0"))
229 cached = nios2_regs + i;
230 break;
232 assert (cached);
234 return cached;
237 /* Return a pointer to the base of the control register name array. */
238 static struct nios2_reg *
239 nios2_control_regs (void)
241 static struct nios2_reg *cached = NULL;
243 if (!cached)
245 int i;
246 for (i = NUMREGNAMES; i < nios2_num_regs; i++)
247 if (!strcmp (nios2_regs[i].name, "status"))
249 cached = nios2_regs + i;
250 break;
252 assert (cached);
254 return cached;
257 /* Helper routine to report internal errors. */
258 static void
259 bad_opcode (const struct nios2_opcode *op)
261 opcodes_error_handler
262 /* xgettext:c-format */
263 (_("internal error: broken opcode descriptor for `%s %s'"),
264 op->name, op->args);
265 abort ();
268 /* The function nios2_print_insn_arg uses the character pointed
269 to by ARGPTR to determine how it print the next token or separator
270 character in the arguments to an instruction. */
271 static int
272 nios2_print_insn_arg (const char *argptr,
273 unsigned long opcode, bfd_vma address,
274 disassemble_info *info,
275 const struct nios2_opcode *op)
277 unsigned long i = 0;
278 long s = 0;
279 int32_t o = 0;
280 struct nios2_reg *reg_base;
282 switch (*argptr)
284 case ',':
285 case '(':
286 case ')':
287 (*info->fprintf_func) (info->stream, "%c", *argptr);
288 break;
290 case 'c':
291 /* Control register index. */
292 switch (op->format)
294 case iw_r_type:
295 i = GET_IW_R_IMM5 (opcode);
296 break;
297 case iw_F3X6L5_type:
298 i = GET_IW_F3X6L5_IMM5 (opcode);
299 break;
300 default:
301 bad_opcode (op);
303 reg_base = nios2_control_regs ();
304 (*info->fprintf_func) (info->stream, "%s", reg_base[i].name);
305 break;
307 case 'd':
308 reg_base = nios2_regs;
309 switch (op->format)
311 case iw_r_type:
312 i = GET_IW_R_C (opcode);
313 break;
314 case iw_custom_type:
315 i = GET_IW_CUSTOM_C (opcode);
316 if (GET_IW_CUSTOM_READC (opcode) == 0)
317 reg_base = nios2_coprocessor_regs ();
318 break;
319 case iw_F3X6L5_type:
320 case iw_F3X6_type:
321 i = GET_IW_F3X6L5_C (opcode);
322 break;
323 case iw_F3X8_type:
324 i = GET_IW_F3X8_C (opcode);
325 if (GET_IW_F3X8_READC (opcode) == 0)
326 reg_base = nios2_coprocessor_regs ();
327 break;
328 case iw_F2_type:
329 i = GET_IW_F2_B (opcode);
330 break;
331 default:
332 bad_opcode (op);
334 if (i < NUMREGNAMES)
335 (*info->fprintf_func) (info->stream, "%s", reg_base[i].name);
336 else
337 (*info->fprintf_func) (info->stream, "unknown");
338 break;
340 case 's':
341 reg_base = nios2_regs;
342 switch (op->format)
344 case iw_r_type:
345 i = GET_IW_R_A (opcode);
346 break;
347 case iw_i_type:
348 i = GET_IW_I_A (opcode);
349 break;
350 case iw_custom_type:
351 i = GET_IW_CUSTOM_A (opcode);
352 if (GET_IW_CUSTOM_READA (opcode) == 0)
353 reg_base = nios2_coprocessor_regs ();
354 break;
355 case iw_F2I16_type:
356 i = GET_IW_F2I16_A (opcode);
357 break;
358 case iw_F2X4I12_type:
359 i = GET_IW_F2X4I12_A (opcode);
360 break;
361 case iw_F1X4I12_type:
362 i = GET_IW_F1X4I12_A (opcode);
363 break;
364 case iw_F1X4L17_type:
365 i = GET_IW_F1X4L17_A (opcode);
366 break;
367 case iw_F3X6L5_type:
368 case iw_F3X6_type:
369 i = GET_IW_F3X6L5_A (opcode);
370 break;
371 case iw_F2X6L10_type:
372 i = GET_IW_F2X6L10_A (opcode);
373 break;
374 case iw_F3X8_type:
375 i = GET_IW_F3X8_A (opcode);
376 if (GET_IW_F3X8_READA (opcode) == 0)
377 reg_base = nios2_coprocessor_regs ();
378 break;
379 case iw_F1X1_type:
380 i = GET_IW_F1X1_A (opcode);
381 break;
382 case iw_F1I5_type:
383 i = 27; /* Implicit stack pointer reference. */
384 break;
385 case iw_F2_type:
386 i = GET_IW_F2_A (opcode);
387 break;
388 default:
389 bad_opcode (op);
391 if (i < NUMREGNAMES)
392 (*info->fprintf_func) (info->stream, "%s", reg_base[i].name);
393 else
394 (*info->fprintf_func) (info->stream, "unknown");
395 break;
397 case 't':
398 reg_base = nios2_regs;
399 switch (op->format)
401 case iw_r_type:
402 i = GET_IW_R_B (opcode);
403 break;
404 case iw_i_type:
405 i = GET_IW_I_B (opcode);
406 break;
407 case iw_custom_type:
408 i = GET_IW_CUSTOM_B (opcode);
409 if (GET_IW_CUSTOM_READB (opcode) == 0)
410 reg_base = nios2_coprocessor_regs ();
411 break;
412 case iw_F2I16_type:
413 i = GET_IW_F2I16_B (opcode);
414 break;
415 case iw_F2X4I12_type:
416 i = GET_IW_F2X4I12_B (opcode);
417 break;
418 case iw_F3X6L5_type:
419 case iw_F3X6_type:
420 i = GET_IW_F3X6L5_B (opcode);
421 break;
422 case iw_F2X6L10_type:
423 i = GET_IW_F2X6L10_B (opcode);
424 break;
425 case iw_F3X8_type:
426 i = GET_IW_F3X8_B (opcode);
427 if (GET_IW_F3X8_READB (opcode) == 0)
428 reg_base = nios2_coprocessor_regs ();
429 break;
430 case iw_F1I5_type:
431 i = GET_IW_F1I5_B (opcode);
432 break;
433 case iw_F2_type:
434 i = GET_IW_F2_B (opcode);
435 break;
436 case iw_T1X1I6_type:
437 i = 0;
438 break;
439 default:
440 bad_opcode (op);
442 if (i < NUMREGNAMES)
443 (*info->fprintf_func) (info->stream, "%s", reg_base[i].name);
444 else
445 (*info->fprintf_func) (info->stream, "unknown");
446 break;
448 case 'D':
449 switch (op->format)
451 case iw_T1I7_type:
452 i = GET_IW_T1I7_A3 (opcode);
453 break;
454 case iw_T2X1L3_type:
455 i = GET_IW_T2X1L3_B3 (opcode);
456 break;
457 case iw_T2X1I3_type:
458 i = GET_IW_T2X1I3_B3 (opcode);
459 break;
460 case iw_T3X1_type:
461 i = GET_IW_T3X1_C3 (opcode);
462 break;
463 case iw_T2X3_type:
464 if (op->num_args == 3)
465 i = GET_IW_T2X3_A3 (opcode);
466 else
467 i = GET_IW_T2X3_B3 (opcode);
468 break;
469 default:
470 bad_opcode (op);
472 i = nios2_r2_reg3_mappings[i];
473 (*info->fprintf_func) (info->stream, "%s", nios2_regs[i].name);
474 break;
476 case 'M':
477 /* 6-bit unsigned immediate with no shift. */
478 switch (op->format)
480 case iw_T1X1I6_type:
481 i = GET_IW_T1X1I6_IMM6 (opcode);
482 break;
483 default:
484 bad_opcode (op);
486 (*info->fprintf_func) (info->stream, "%ld", i);
487 break;
489 case 'N':
490 /* 6-bit unsigned immediate with 2-bit shift. */
491 switch (op->format)
493 case iw_T1X1I6_type:
494 i = GET_IW_T1X1I6_IMM6 (opcode) << 2;
495 break;
496 default:
497 bad_opcode (op);
499 (*info->fprintf_func) (info->stream, "%ld", i);
500 break;
502 case 'S':
503 switch (op->format)
505 case iw_T1I7_type:
506 i = GET_IW_T1I7_A3 (opcode);
507 break;
508 case iw_T2I4_type:
509 i = GET_IW_T2I4_A3 (opcode);
510 break;
511 case iw_T2X1L3_type:
512 i = GET_IW_T2X1L3_A3 (opcode);
513 break;
514 case iw_T2X1I3_type:
515 i = GET_IW_T2X1I3_A3 (opcode);
516 break;
517 case iw_T3X1_type:
518 i = GET_IW_T3X1_A3 (opcode);
519 break;
520 case iw_T2X3_type:
521 i = GET_IW_T2X3_A3 (opcode);
522 break;
523 case iw_T1X1I6_type:
524 i = GET_IW_T1X1I6_A3 (opcode);
525 break;
526 default:
527 bad_opcode (op);
529 i = nios2_r2_reg3_mappings[i];
530 (*info->fprintf_func) (info->stream, "%s", nios2_regs[i].name);
531 break;
533 case 'T':
534 switch (op->format)
536 case iw_T2I4_type:
537 i = GET_IW_T2I4_B3 (opcode);
538 break;
539 case iw_T3X1_type:
540 i = GET_IW_T3X1_B3 (opcode);
541 break;
542 case iw_T2X3_type:
543 i = GET_IW_T2X3_B3 (opcode);
544 break;
545 default:
546 bad_opcode (op);
548 i = nios2_r2_reg3_mappings[i];
549 (*info->fprintf_func) (info->stream, "%s", nios2_regs[i].name);
550 break;
552 case 'i':
553 /* 16-bit signed immediate. */
554 switch (op->format)
556 case iw_i_type:
557 s = ((int32_t) ((GET_IW_I_IMM16 (opcode) & 0xffff) ^ 0x8000)
558 - 0x8000);
559 break;
560 case iw_F2I16_type:
561 s = ((int32_t) ((GET_IW_F2I16_IMM16 (opcode) & 0xffff) ^ 0x8000)
562 - 0x8000);
563 break;
564 default:
565 bad_opcode (op);
567 (*info->fprintf_func) (info->stream, "%ld", s);
568 break;
570 case 'I':
571 /* 12-bit signed immediate. */
572 switch (op->format)
574 case iw_F2X4I12_type:
575 s = ((int32_t) ((GET_IW_F2X4I12_IMM12 (opcode) & 0xfff) ^ 0x800)
576 - 0x800);
577 break;
578 case iw_F1X4I12_type:
579 s = ((int32_t) ((GET_IW_F1X4I12_IMM12 (opcode) & 0xfff) ^ 0x800)
580 - 0x800);
581 break;
582 default:
583 bad_opcode (op);
585 (*info->fprintf_func) (info->stream, "%ld", s);
586 break;
588 case 'u':
589 /* 16-bit unsigned immediate. */
590 switch (op->format)
592 case iw_i_type:
593 i = GET_IW_I_IMM16 (opcode);
594 break;
595 case iw_F2I16_type:
596 i = GET_IW_F2I16_IMM16 (opcode);
597 break;
598 default:
599 bad_opcode (op);
601 (*info->fprintf_func) (info->stream, "%ld", i);
602 break;
604 case 'U':
605 /* 7-bit unsigned immediate with 2-bit shift. */
606 switch (op->format)
608 case iw_T1I7_type:
609 i = GET_IW_T1I7_IMM7 (opcode) << 2;
610 break;
611 case iw_X1I7_type:
612 i = GET_IW_X1I7_IMM7 (opcode) << 2;
613 break;
614 default:
615 bad_opcode (op);
617 (*info->fprintf_func) (info->stream, "%ld", i);
618 break;
620 case 'V':
621 /* 5-bit unsigned immediate with 2-bit shift. */
622 switch (op->format)
624 case iw_F1I5_type:
625 i = GET_IW_F1I5_IMM5 (opcode) << 2;
626 break;
627 default:
628 bad_opcode (op);
630 (*info->fprintf_func) (info->stream, "%ld", i);
631 break;
633 case 'W':
634 /* 4-bit unsigned immediate with 2-bit shift. */
635 switch (op->format)
637 case iw_T2I4_type:
638 i = GET_IW_T2I4_IMM4 (opcode) << 2;
639 break;
640 case iw_L5I4X1_type:
641 i = GET_IW_L5I4X1_IMM4 (opcode) << 2;
642 break;
643 default:
644 bad_opcode (op);
646 (*info->fprintf_func) (info->stream, "%ld", i);
647 break;
649 case 'X':
650 /* 4-bit unsigned immediate with 1-bit shift. */
651 switch (op->format)
653 case iw_T2I4_type:
654 i = GET_IW_T2I4_IMM4 (opcode) << 1;
655 break;
656 default:
657 bad_opcode (op);
659 (*info->fprintf_func) (info->stream, "%ld", i);
660 break;
662 case 'Y':
663 /* 4-bit unsigned immediate without shift. */
664 switch (op->format)
666 case iw_T2I4_type:
667 i = GET_IW_T2I4_IMM4 (opcode);
668 break;
669 default:
670 bad_opcode (op);
672 (*info->fprintf_func) (info->stream, "%ld", i);
673 break;
675 case 'o':
676 /* 16-bit signed immediate address offset. */
677 switch (op->format)
679 case iw_i_type:
680 o = ((GET_IW_I_IMM16 (opcode) & 0xffff) ^ 0x8000) - 0x8000;
681 break;
682 case iw_F2I16_type:
683 o = ((GET_IW_F2I16_IMM16 (opcode) & 0xffff) ^ 0x8000) - 0x8000;
684 break;
685 default:
686 bad_opcode (op);
688 address = address + 4 + o;
689 (*info->print_address_func) (address, info);
690 break;
692 case 'O':
693 /* 10-bit signed address offset with 1-bit shift. */
694 switch (op->format)
696 case iw_I10_type:
697 o = (((GET_IW_I10_IMM10 (opcode) & 0x3ff) ^ 0x200) - 0x200) * 2;
698 break;
699 default:
700 bad_opcode (op);
702 address = address + 2 + o;
703 (*info->print_address_func) (address, info);
704 break;
706 case 'P':
707 /* 7-bit signed address offset with 1-bit shift. */
708 switch (op->format)
710 case iw_T1I7_type:
711 o = (((GET_IW_T1I7_IMM7 (opcode) & 0x7f) ^ 0x40) - 0x40) * 2;
712 break;
713 default:
714 bad_opcode (op);
716 address = address + 2 + o;
717 (*info->print_address_func) (address, info);
718 break;
720 case 'j':
721 /* 5-bit unsigned immediate. */
722 switch (op->format)
724 case iw_r_type:
725 i = GET_IW_R_IMM5 (opcode);
726 break;
727 case iw_F3X6L5_type:
728 i = GET_IW_F3X6L5_IMM5 (opcode);
729 break;
730 case iw_F2X6L10_type:
731 i = GET_IW_F2X6L10_MSB (opcode);
732 break;
733 case iw_X2L5_type:
734 i = GET_IW_X2L5_IMM5 (opcode);
735 break;
736 default:
737 bad_opcode (op);
739 (*info->fprintf_func) (info->stream, "%ld", i);
740 break;
742 case 'k':
743 /* Second 5-bit unsigned immediate field. */
744 switch (op->format)
746 case iw_F2X6L10_type:
747 i = GET_IW_F2X6L10_LSB (opcode);
748 break;
749 default:
750 bad_opcode (op);
752 (*info->fprintf_func) (info->stream, "%ld", i);
753 break;
755 case 'l':
756 /* 8-bit unsigned immediate. */
757 switch (op->format)
759 case iw_custom_type:
760 i = GET_IW_CUSTOM_N (opcode);
761 break;
762 case iw_F3X8_type:
763 i = GET_IW_F3X8_N (opcode);
764 break;
765 default:
766 bad_opcode (op);
768 (*info->fprintf_func) (info->stream, "%lu", i);
769 break;
771 case 'm':
772 /* 26-bit unsigned immediate. */
773 switch (op->format)
775 case iw_j_type:
776 i = GET_IW_J_IMM26 (opcode);
777 break;
778 case iw_L26_type:
779 i = GET_IW_L26_IMM26 (opcode);
780 break;
781 default:
782 bad_opcode (op);
784 /* This translates to an address because it's only used in call
785 instructions. */
786 address = (address & 0xf0000000) | (i << 2);
787 (*info->print_address_func) (address, info);
788 break;
790 case 'e':
791 /* Encoded enumeration for addi.n/subi.n. */
792 switch (op->format)
794 case iw_T2X1I3_type:
795 i = nios2_r2_asi_n_mappings[GET_IW_T2X1I3_IMM3 (opcode)];
796 break;
797 default:
798 bad_opcode (op);
800 (*info->fprintf_func) (info->stream, "%lu", i);
801 break;
803 case 'f':
804 /* Encoded enumeration for slli.n/srli.n. */
805 switch (op->format)
807 case iw_T2X1L3_type:
808 i = nios2_r2_shi_n_mappings[GET_IW_T2X1I3_IMM3 (opcode)];
809 break;
810 default:
811 bad_opcode (op);
813 (*info->fprintf_func) (info->stream, "%lu", i);
814 break;
816 case 'g':
817 /* Encoded enumeration for andi.n. */
818 switch (op->format)
820 case iw_T2I4_type:
821 i = nios2_r2_andi_n_mappings[GET_IW_T2I4_IMM4 (opcode)];
822 break;
823 default:
824 bad_opcode (op);
826 (*info->fprintf_func) (info->stream, "%lu", i);
827 break;
829 case 'h':
830 /* Encoded enumeration for movi.n. */
831 switch (op->format)
833 case iw_T1I7_type:
834 i = GET_IW_T1I7_IMM7 (opcode);
835 if (i == 125)
836 i = 0xff;
837 else if (i == 126)
838 i = -2;
839 else if (i == 127)
840 i = -1;
841 break;
842 default:
843 bad_opcode (op);
845 (*info->fprintf_func) (info->stream, "%ld", i);
846 break;
848 case 'R':
850 unsigned long reglist = 0;
851 int dir = 1;
852 int k, t;
854 switch (op->format)
856 case iw_F1X4L17_type:
857 /* Encoding for ldwm/stwm. */
858 i = GET_IW_F1X4L17_REGMASK (opcode);
859 if (GET_IW_F1X4L17_RS (opcode))
861 reglist = ((i << 14) & 0x00ffc000);
862 if (i & (1 << 10))
863 reglist |= (1 << 28);
864 if (i & (1 << 11))
865 reglist |= (1u << 31);
867 else
868 reglist = i << 2;
869 dir = GET_IW_F1X4L17_REGMASK (opcode) ? 1 : -1;
870 break;
872 case iw_L5I4X1_type:
873 /* Encoding for push.n/pop.n. */
874 reglist |= (1u << 31);
875 if (GET_IW_L5I4X1_FP (opcode))
876 reglist |= (1 << 28);
877 if (GET_IW_L5I4X1_CS (opcode))
879 int val = GET_IW_L5I4X1_REGRANGE (opcode);
880 reglist |= nios2_r2_reg_range_mappings[val];
882 dir = (op->match == MATCH_R2_POP_N ? 1 : -1);
883 break;
885 default:
886 bad_opcode (op);
889 t = 0;
890 (*info->fprintf_func) (info->stream, "{");
891 for (k = (dir == 1 ? 0 : 31);
892 (dir == 1 && k < 32) || (dir == -1 && k >= 0);
893 k += dir)
894 if (reglist & (1u << k))
896 if (t)
897 (*info->fprintf_func) (info->stream, ",");
898 else
899 t++;
900 (*info->fprintf_func) (info->stream, "%s", nios2_regs[k].name);
902 (*info->fprintf_func) (info->stream, "}");
903 break;
906 case 'B':
907 /* Base register and options for ldwm/stwm. */
908 switch (op->format)
910 case iw_F1X4L17_type:
911 if (GET_IW_F1X4L17_ID (opcode) == 0)
912 (*info->fprintf_func) (info->stream, "--");
914 i = GET_IW_F1X4I12_A (opcode);
915 (*info->fprintf_func) (info->stream, "(%s)",
916 nios2_builtin_regs[i].name);
918 if (GET_IW_F1X4L17_ID (opcode))
919 (*info->fprintf_func) (info->stream, "++");
920 if (GET_IW_F1X4L17_WB (opcode))
921 (*info->fprintf_func) (info->stream, ",writeback");
922 if (GET_IW_F1X4L17_PC (opcode))
923 (*info->fprintf_func) (info->stream, ",ret");
924 break;
925 default:
926 bad_opcode (op);
928 break;
930 default:
931 (*info->fprintf_func) (info->stream, "unknown");
932 break;
934 return 0;
937 /* nios2_disassemble does all the work of disassembling a Nios II
938 instruction opcode. */
939 static int
940 nios2_disassemble (bfd_vma address, unsigned long opcode,
941 disassemble_info *info)
943 const struct nios2_opcode *op;
945 info->bytes_per_line = INSNLEN;
946 info->bytes_per_chunk = INSNLEN;
947 info->display_endian = info->endian;
948 info->insn_info_valid = 1;
949 info->branch_delay_insns = 0;
950 info->data_size = 0;
951 info->insn_type = dis_nonbranch;
952 info->target = 0;
953 info->target2 = 0;
955 /* Find the major opcode and use this to disassemble
956 the instruction and its arguments. */
957 op = nios2_find_opcode_hash (opcode, info->mach);
959 if (op != NULL)
961 const char *argstr = op->args;
962 (*info->fprintf_func) (info->stream, "%s", op->name);
963 if (argstr != NULL && *argstr != '\0')
965 (*info->fprintf_func) (info->stream, "\t");
966 while (*argstr != '\0')
968 nios2_print_insn_arg (argstr, opcode, address, info, op);
969 ++argstr;
972 /* Tell the caller how far to advance the program counter. */
973 info->bytes_per_chunk = op->size;
974 return op->size;
976 else
978 /* Handle undefined instructions. */
979 info->insn_type = dis_noninsn;
980 (*info->fprintf_func) (info->stream, "0x%lx", opcode);
981 return INSNLEN;
986 /* print_insn_nios2 is the main disassemble function for Nios II.
987 The function diassembler(abfd) (source in disassemble.c) returns a
988 pointer to this either print_insn_big_nios2 or
989 print_insn_little_nios2, which in turn call this function when the
990 bfd machine type is Nios II. print_insn_nios2 reads the
991 instruction word at the address given, and prints the disassembled
992 instruction on the stream info->stream using info->fprintf_func. */
994 static int
995 print_insn_nios2 (bfd_vma address, disassemble_info *info,
996 enum bfd_endian endianness)
998 bfd_byte buffer[INSNLEN];
999 int status;
1001 status = (*info->read_memory_func) (address, buffer, INSNLEN, info);
1002 if (status == 0)
1004 unsigned long insn;
1005 if (endianness == BFD_ENDIAN_BIG)
1006 insn = (unsigned long) bfd_getb32 (buffer);
1007 else
1008 insn = (unsigned long) bfd_getl32 (buffer);
1009 return nios2_disassemble (address, insn, info);
1012 /* We might have a 16-bit R2 instruction at the end of memory. Try that. */
1013 if (info->mach == bfd_mach_nios2r2)
1015 status = (*info->read_memory_func) (address, buffer, 2, info);
1016 if (status == 0)
1018 unsigned long insn;
1019 if (endianness == BFD_ENDIAN_BIG)
1020 insn = (unsigned long) bfd_getb16 (buffer);
1021 else
1022 insn = (unsigned long) bfd_getl16 (buffer);
1023 return nios2_disassemble (address, insn, info);
1027 /* If we got here, we couldn't read anything. */
1028 (*info->memory_error_func) (status, address, info);
1029 return -1;
1032 /* These two functions are the main entry points, accessed from
1033 disassemble.c. */
1035 print_insn_big_nios2 (bfd_vma address, disassemble_info *info)
1037 return print_insn_nios2 (address, info, BFD_ENDIAN_BIG);
1041 print_insn_little_nios2 (bfd_vma address, disassemble_info *info)
1043 return print_insn_nios2 (address, info, BFD_ENDIAN_LITTLE);