1 /* DO NOT EDIT! -*- buffer-read-only: t -*- vi:set ro: */
2 /* Disassembler interface for targets using CGEN. -*- C -*-
3 CGEN: Cpu tools GENerator
5 THIS FILE IS MACHINE GENERATED WITH CGEN.
6 - the resultant file is machine generated, cgen-dis.in isn't
8 Copyright (C) 1996-2019 Free Software Foundation, Inc.
10 This file is part of libopcodes.
12 This library is free software; you can redistribute it and/or modify
13 it under the terms of the GNU General Public License as published by
14 the Free Software Foundation; either version 3, or (at your option)
17 It is distributed in the hope that it will be useful, but WITHOUT
18 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
19 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
20 License for more details.
22 You should have received a copy of the GNU General Public License
23 along with this program; if not, write to the Free Software Foundation, Inc.,
24 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA. */
26 /* ??? Eventually more and more of this stuff can go to cpu-independent files.
32 #include "disassemble.h"
35 #include "libiberty.h"
40 /* Default text to print if an instruction isn't recognized. */
41 #define UNKNOWN_INSN_MSG _("*unknown*")
43 static void print_normal
44 (CGEN_CPU_DESC
, void *, long, unsigned int, bfd_vma
, int);
45 static void print_address
46 (CGEN_CPU_DESC
, void *, bfd_vma
, unsigned int, bfd_vma
, int) ATTRIBUTE_UNUSED
;
47 static void print_keyword
48 (CGEN_CPU_DESC
, void *, CGEN_KEYWORD
*, long, unsigned int) ATTRIBUTE_UNUSED
;
49 static void print_insn_normal
50 (CGEN_CPU_DESC
, void *, const CGEN_INSN
*, CGEN_FIELDS
*, bfd_vma
, int);
52 (CGEN_CPU_DESC
, bfd_vma
, disassemble_info
*, bfd_byte
*, unsigned);
53 static int default_print_insn
54 (CGEN_CPU_DESC
, bfd_vma
, disassemble_info
*) ATTRIBUTE_UNUSED
;
56 (CGEN_CPU_DESC
, bfd_vma
, disassemble_info
*, bfd_byte
*, int, CGEN_EXTRACT_INFO
*,
59 /* -- disassembler routines inserted here. */
66 #define CGEN_VALIDATE_INSN_SUPPORTED
68 static void print_tpreg (CGEN_CPU_DESC
, PTR
, CGEN_KEYWORD
*, long, unsigned int);
69 static void print_spreg (CGEN_CPU_DESC
, PTR
, CGEN_KEYWORD
*, long, unsigned int);
72 print_tpreg (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED
, PTR dis_info
,
73 CGEN_KEYWORD
*table ATTRIBUTE_UNUSED
, long val ATTRIBUTE_UNUSED
,
74 unsigned int flags ATTRIBUTE_UNUSED
)
76 disassemble_info
*info
= (disassemble_info
*) dis_info
;
78 (*info
->fprintf_func
) (info
->stream
, "$tp");
82 print_spreg (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED
, PTR dis_info
,
83 CGEN_KEYWORD
*table ATTRIBUTE_UNUSED
, long val ATTRIBUTE_UNUSED
,
84 unsigned int flags ATTRIBUTE_UNUSED
)
86 disassemble_info
*info
= (disassemble_info
*) dis_info
;
88 (*info
->fprintf_func
) (info
->stream
, "$sp");
91 /* begin-cop-ip-print-handlers */
93 print_ivc2_cr (CGEN_CPU_DESC
,
97 unsigned int) ATTRIBUTE_UNUSED
;
99 print_ivc2_cr (CGEN_CPU_DESC cd
,
101 CGEN_KEYWORD
*keyword_table ATTRIBUTE_UNUSED
,
105 print_keyword (cd
, dis_info
, & mep_cgen_opval_h_cr_ivc2
, value
, attrs
);
108 print_ivc2_ccr (CGEN_CPU_DESC
,
112 unsigned int) ATTRIBUTE_UNUSED
;
114 print_ivc2_ccr (CGEN_CPU_DESC cd
,
116 CGEN_KEYWORD
*keyword_table ATTRIBUTE_UNUSED
,
120 print_keyword (cd
, dis_info
, & mep_cgen_opval_h_ccr_ivc2
, value
, attrs
);
122 /* end-cop-ip-print-handlers */
124 /************************************************************\
125 *********************** Experimental *************************
126 \************************************************************/
128 #undef CGEN_PRINT_INSN
129 #define CGEN_PRINT_INSN mep_print_insn
132 mep_print_vliw_insns (CGEN_CPU_DESC cd
, bfd_vma pc
, disassemble_info
*info
,
133 bfd_byte
*buf
, int corelength
, int copro1length
,
134 int copro2length ATTRIBUTE_UNUSED
)
138 /* char insnbuf[CGEN_MAX_INSN_SIZE]; */
139 bfd_byte insnbuf
[64];
141 /* If corelength > 0 then there is a core insn present. It
142 will be at the beginning of the buffer. After printing
143 the core insn, we need to print the + on the next line. */
148 for (i
= 0; i
< corelength
; i
++ )
150 cd
->isas
= & MEP_CORE_ISA
;
152 my_status
= print_insn (cd
, pc
, info
, insnbuf
, corelength
);
153 if (my_status
!= corelength
)
155 (*info
->fprintf_func
) (info
->stream
, UNKNOWN_INSN_MSG
);
156 my_status
= corelength
;
160 /* Print the + to indicate that the following copro insn is */
161 /* part of a vliw group. */
162 if (copro1length
> 0)
163 (*info
->fprintf_func
) (info
->stream
, " + ");
166 /* Now all that is left to be processed is the coprocessor insns
167 In vliw mode, there will always be one. Its positioning will
168 be from byte corelength to byte corelength+copro1length -1.
169 No need to check for existence. Also, the first vliw insn,
170 will, as spec'd, always be at least as long as the core insn
171 so we don't need to flush the buffer. */
172 if (copro1length
> 0)
176 for (i
= corelength
; i
< corelength
+ copro1length
; i
++ )
177 insnbuf
[i
- corelength
] = buf
[i
];
179 switch (copro1length
)
184 cd
->isas
= & MEP_COP16_ISA
;
187 cd
->isas
= & MEP_COP32_ISA
;
190 cd
->isas
= & MEP_COP48_ISA
;
193 cd
->isas
= & MEP_COP64_ISA
;
196 /* Shouldn't be anything but 16,32,48,64. */
200 my_status
= print_insn (cd
, pc
, info
, insnbuf
, copro1length
);
202 if (my_status
!= copro1length
)
204 (*info
->fprintf_func
) (info
->stream
, UNKNOWN_INSN_MSG
);
205 my_status
= copro1length
;
211 /* Now we need to process the second copro insn if it exists. We
212 have no guarantee that the second copro insn will be longer
213 than the first, so we have to flush the buffer if we are have
214 a second copro insn to process. If present, this insn will
215 be in the position from byte corelength+copro1length to byte
216 corelength+copro1length+copro2length-1 (which better equal 8
217 or else we're in big trouble. */
218 if (copro2length
> 0)
222 for (i
= 0; i
< 64 ; i
++)
225 for (i
= corelength
+ copro1length
; i
< 64; i
++)
226 insnbuf
[i
- (corelength
+ copro1length
)] = buf
[i
];
228 switch (copro2length
)
231 cd
->isas
= 1 << ISA_EXT_COP1_16
;
234 cd
->isas
= 1 << ISA_EXT_COP1_32
;
237 cd
->isas
= 1 << ISA_EXT_COP1_48
;
240 cd
->isas
= 1 << ISA_EXT_COP1_64
;
243 /* Shouldn't be anything but 16,32,48,64. */
247 my_status
= print_insn (cd
, pc
, info
, insnbuf
, copro2length
);
249 if (my_status
!= copro2length
)
251 (*info
->fprintf_func
) (info
->stream
, UNKNOWN_INSN_MSG
);
252 my_status
= copro2length
;
259 /* Status should now be the number of bytes that were printed
260 which should be 4 for VLIW32 mode and 64 for VLIW64 mode. */
262 if ((!MEP_VLIW64
&& (status
!= 4)) || (MEP_VLIW64
&& (status
!= 8)))
268 /* The two functions mep_examine_vliw[32,64]_insns are used find out
269 which vliw combinaion (16 bit core with 48 bit copro, 32 bit core
270 with 32 bit copro, etc.) is present. Later on, when internally
271 parallel coprocessors are handled, only these functions should
274 At this time only the following combinations are supported:
277 16 bit core insn (core) and 16 bit coprocessor insn (cop1)
278 32 bit core insn (core)
279 32 bit coprocessor insn (cop1)
280 Note: As of this time, I do not believe we have enough information
281 to distinguish a 32 bit core insn from a 32 bit cop insn. Also,
282 no 16 bit coprocessor insns have been specified.
285 16 bit core insn (core) and 48 bit coprocessor insn (cop1)
286 32 bit core insn (core) and 32 bit coprocessor insn (cop1)
287 64 bit coprocessor insn (cop1)
289 The framework for an internally parallel coprocessor is also
290 present (2nd coprocessor insn is cop2), but at this time it
291 is not used. This only appears to be valid in VLIW64 mode. */
294 mep_examine_vliw32_insns (CGEN_CPU_DESC cd
, bfd_vma pc
, disassemble_info
*info
)
301 bfd_byte buf
[CGEN_MAX_INSN_SIZE
];
303 char indicatorcop32
[2];
305 /* At this time we're not supporting internally parallel coprocessors,
306 so cop2buflength will always be 0. */
309 /* Read in 32 bits. */
310 buflength
= 4; /* VLIW insn spans 4 bytes. */
311 status
= (*info
->read_memory_func
) (pc
, buf
, buflength
, info
);
315 (*info
->memory_error_func
) (status
, pc
, info
);
319 /* Put the big endian representation of the bytes to be examined
320 in the temporary buffers for examination. */
322 if (info
->endian
== BFD_ENDIAN_BIG
)
324 indicator16
[0] = buf
[0];
325 indicatorcop32
[0] = buf
[0];
326 indicatorcop32
[1] = buf
[1];
330 indicator16
[0] = buf
[1];
331 indicatorcop32
[0] = buf
[1];
332 indicatorcop32
[1] = buf
[0];
335 /* If the two high order bits are 00, 01 or 10, we have a 16 bit
336 core insn and a 48 bit copro insn. */
338 if ((indicator16
[0] & 0x80) && (indicator16
[0] & 0x40))
340 if ((indicatorcop32
[0] & 0xf0) == 0xf0 && (indicatorcop32
[1] & 0x07) == 0x07)
342 /* We have a 32 bit copro insn. */
344 /* All 4 4ytes are one copro insn. */
349 /* We have a 32 bit core. */
356 /* We have a 16 bit core insn and a 16 bit copro insn. */
361 /* Now we have the distrubution set. Print them out. */
362 status
= mep_print_vliw_insns (cd
, pc
, info
, buf
, corebuflength
,
363 cop1buflength
, cop2buflength
);
369 mep_examine_vliw64_insns (CGEN_CPU_DESC cd
, bfd_vma pc
, disassemble_info
*info
)
376 bfd_byte buf
[CGEN_MAX_INSN_SIZE
];
380 /* At this time we're not supporting internally parallel
381 coprocessors, so cop2buflength will always be 0. */
384 /* Read in 64 bits. */
385 buflength
= 8; /* VLIW insn spans 8 bytes. */
386 status
= (*info
->read_memory_func
) (pc
, buf
, buflength
, info
);
390 (*info
->memory_error_func
) (status
, pc
, info
);
394 /* We have all 64 bits in the buffer now. We have to figure out
395 what combination of instruction sizes are present. The two
396 high order bits will indicate whether or not we have a 16 bit
397 core insn or not. If not, then we have to look at the 7,8th
398 bytes to tell whether we have 64 bit copro insn or a 32 bit
399 core insn with a 32 bit copro insn. Endianness will make a
402 /* Put the big endian representation of the bytes to be examined
403 in the temporary buffers for examination. */
405 /* indicator16[0] = buf[0]; */
406 if (info
->endian
== BFD_ENDIAN_BIG
)
408 indicator16
[0] = buf
[0];
409 indicator64
[0] = buf
[0];
410 indicator64
[1] = buf
[1];
411 indicator64
[2] = buf
[2];
412 indicator64
[3] = buf
[3];
416 indicator16
[0] = buf
[1];
417 indicator64
[0] = buf
[1];
418 indicator64
[1] = buf
[0];
419 indicator64
[2] = buf
[3];
420 indicator64
[3] = buf
[2];
423 /* If the two high order bits are 00, 01 or 10, we have a 16 bit
424 core insn and a 48 bit copro insn. */
426 if ((indicator16
[0] & 0x80) && (indicator16
[0] & 0x40))
428 if ((indicator64
[0] & 0xf0) == 0xf0 && (indicator64
[1] & 0x07) == 0x07
429 && ((indicator64
[2] & 0xfe) != 0xf0 || (indicator64
[3] & 0xf4) != 0))
431 /* We have a 64 bit copro insn. */
433 /* All 8 bytes are one copro insn. */
438 /* We have a 32 bit core insn and a 32 bit copro insn. */
445 /* We have a 16 bit core insn and a 48 bit copro insn. */
450 /* Now we have the distrubution set. Print them out. */
451 status
= mep_print_vliw_insns (cd
, pc
, info
, buf
, corebuflength
,
452 cop1buflength
, cop2buflength
);
457 #ifdef MEP_IVC2_SUPPORTED
460 print_slot_insn (CGEN_CPU_DESC cd
,
462 disassemble_info
*info
,
466 const CGEN_INSN_LIST
*insn_list
;
467 CGEN_INSN_INT insn_value
;
468 CGEN_EXTRACT_INFO ex_info
;
470 insn_value
= cgen_get_insn_value (cd
, buf
, 32);
472 /* Fill in ex_info fields like read_insn would. Don't actually call
473 read_insn, since the incoming buffer is already read (and possibly
474 modified a la m32r). */
475 ex_info
.valid
= (1 << 8) - 1;
476 ex_info
.dis_info
= info
;
477 ex_info
.insn_bytes
= buf
;
479 /* The instructions are stored in hash lists.
480 Pick the first one and keep trying until we find the right one. */
482 insn_list
= CGEN_DIS_LOOKUP_INSN (cd
, (char *) buf
, insn_value
);
483 while (insn_list
!= NULL
)
485 const CGEN_INSN
*insn
= insn_list
->insn
;
489 if ((CGEN_INSN_ATTR_VALUE (insn
, CGEN_INSN_CONFIG
)
490 && CGEN_INSN_ATTR_VALUE (insn
, CGEN_INSN_CONFIG
) != MEP_CONFIG
)
491 || ! (CGEN_ATTR_CGEN_INSN_SLOTS_VALUE (CGEN_INSN_ATTRS (insn
)) & (1 << slot
)))
493 insn_list
= CGEN_DIS_NEXT_INSN (insn_list
);
497 if ((insn_value
& CGEN_INSN_BASE_MASK (insn
))
498 == CGEN_INSN_BASE_VALUE (insn
))
500 /* Printing is handled in two passes. The first pass parses the
501 machine insn and extracts the fields. The second pass prints
504 length
= CGEN_EXTRACT_FN (cd
, insn
)
505 (cd
, insn
, &ex_info
, insn_value
, &fields
, pc
);
507 /* Length < 0 -> error. */
512 CGEN_PRINT_FN (cd
, insn
) (cd
, info
, insn
, &fields
, pc
, length
);
513 /* Length is in bits, result is in bytes. */
518 insn_list
= CGEN_DIS_NEXT_INSN (insn_list
);
521 if (slot
== SLOTS_P0S
)
522 (*info
->fprintf_func
) (info
->stream
, "*unknown-p0s*");
523 else if (slot
== SLOTS_P0
)
524 (*info
->fprintf_func
) (info
->stream
, "*unknown-p0*");
525 else if (slot
== SLOTS_P1
)
526 (*info
->fprintf_func
) (info
->stream
, "*unknown-p1*");
527 else if (slot
== SLOTS_C3
)
528 (*info
->fprintf_func
) (info
->stream
, "*unknown-c3*");
533 mep_examine_ivc2_insns (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED
, bfd_vma pc ATTRIBUTE_UNUSED
, disassemble_info
*info ATTRIBUTE_UNUSED
)
541 /* Read in 64 bits. */
542 buflength
= 8; /* VLIW insn spans 8 bytes. */
543 status
= (*info
->read_memory_func
) (pc
, buf
, buflength
, info
);
547 (*info
->memory_error_func
) (status
, pc
, info
);
551 if (info
->endian
== BFD_ENDIAN_LITTLE
)
556 if (((unsigned char)buf
[0^e
] & 0xf0) < 0xc0)
558 /* <--00--><--11--><--22--><--33--><--44--><--55--><--66--><--77--> */
559 /* V1 [-----core-----][--------p0s-------][------------p1------------] */
561 print_insn (cd
, pc
, info
, buf
, 2);
564 insn
[1^e
] = buf
[2^e
];
565 insn
[2^e
] = buf
[3^e
];
566 insn
[3^e
] = buf
[4^e
] & 0xf0;
567 (*info
->fprintf_func
) (info
->stream
, " + ");
568 print_slot_insn (cd
, pc
, info
, SLOTS_P0S
, insn
);
570 insn
[0^e
] = buf
[4^e
] << 4 | buf
[5^e
] >> 4;
571 insn
[1^e
] = buf
[5^e
] << 4 | buf
[6^e
] >> 4;
572 insn
[2^e
] = buf
[6^e
] << 4 | buf
[7^e
] >> 4;
573 insn
[3^e
] = buf
[7^e
] << 4;
574 (*info
->fprintf_func
) (info
->stream
, " + ");
575 print_slot_insn (cd
, pc
, info
, SLOTS_P1
, insn
);
577 else if ((buf
[0^e
] & 0xf0) == 0xf0 && (buf
[1^e
] & 0x0f) == 0x07)
579 /* <--00--><--11--><--22--><--33--><--44--><--55--><--66--><--77--> */
580 /* V3 1111[--p0--]0111[--------p0--------][------------p1------------] */
581 /* 00000000111111112222222233333333 */
583 insn
[0^e
] = buf
[0^e
] << 4 | buf
[1^e
] >> 4;
584 insn
[1^e
] = buf
[2^e
];
585 insn
[2^e
] = buf
[3^e
];
586 insn
[3^e
] = buf
[4^e
] & 0xf0;
587 print_slot_insn (cd
, pc
, info
, SLOTS_P0
, insn
);
589 insn
[0^e
] = buf
[4^e
] << 4 | buf
[5^e
] >> 4;
590 insn
[1^e
] = buf
[5^e
] << 4 | buf
[6^e
] >> 4;
591 insn
[2^e
] = buf
[6^e
] << 4 | buf
[7^e
] >> 4;
592 insn
[3^e
] = buf
[7^e
] << 4;
593 (*info
->fprintf_func
) (info
->stream
, " + ");
594 print_slot_insn (cd
, pc
, info
, SLOTS_P1
, insn
);
598 /* <--00--><--11--><--22--><--33--><--44--><--55--><--66--><--77--> */
599 /* V2 [-------------core-------------]xxxx[------------p1------------] */
600 print_insn (cd
, pc
, info
, buf
, 4);
602 insn
[0^e
] = buf
[4^e
] << 4 | buf
[5^e
] >> 4;
603 insn
[1^e
] = buf
[5^e
] << 4 | buf
[6^e
] >> 4;
604 insn
[2^e
] = buf
[6^e
] << 4 | buf
[7^e
] >> 4;
605 insn
[3^e
] = buf
[7^e
] << 4;
606 (*info
->fprintf_func
) (info
->stream
, " + ");
607 print_slot_insn (cd
, pc
, info
, SLOTS_P1
, insn
);
613 #endif /* MEP_IVC2_SUPPORTED */
615 /* This is a hack. SID calls this to update the disassembler as the
616 CPU changes modes. */
617 static int mep_ivc2_disassemble_p
= 0;
618 static int mep_ivc2_vliw_disassemble_p
= 0;
621 mep_print_insn_set_ivc2_mode (int ivc2_p
, int vliw_p
, int cfg_idx
);
623 mep_print_insn_set_ivc2_mode (int ivc2_p
, int vliw_p
, int cfg_idx
)
625 mep_ivc2_disassemble_p
= ivc2_p
;
626 mep_ivc2_vliw_disassemble_p
= vliw_p
;
627 mep_config_index
= cfg_idx
;
631 mep_print_insn (CGEN_CPU_DESC cd
, bfd_vma pc
, disassemble_info
*info
)
636 static CGEN_ATTR_VALUE_BITSET_TYPE
*ivc2_core_isa
= NULL
;
638 if (ivc2_core_isa
== NULL
)
640 /* IVC2 has some core-only coprocessor instructions. We
641 use COP32 to flag those, and COP64 for the VLIW ones,
642 since they have the same names. */
643 ivc2_core_isa
= cgen_bitset_create (MAX_ISAS
);
646 /* Extract and adapt to configuration number, if available. */
647 if (info
->section
&& info
->section
->owner
)
649 bfd
*abfd
= info
->section
->owner
;
650 mep_config_index
= abfd
->tdata
.elf_obj_data
->elf_header
->e_flags
& EF_MEP_INDEX_MASK
;
651 /* This instantly redefines MEP_CONFIG, MEP_OMASK, .... MEP_VLIW64 */
653 cop_type
= abfd
->tdata
.elf_obj_data
->elf_header
->e_flags
& EF_MEP_COP_MASK
;
654 if (cop_type
== EF_MEP_COP_IVC2
)
658 /* Picking the right ISA bitmask for the current context is tricky. */
661 if (info
->section
->flags
& SEC_MEP_VLIW
)
663 #ifdef MEP_IVC2_SUPPORTED
666 /* ivc2 has its own way of selecting its functions. */
667 cd
->isas
= & MEP_CORE_ISA
;
668 status
= mep_examine_ivc2_insns (cd
, pc
, info
);
672 /* Are we in 32 or 64 bit vliw mode? */
674 status
= mep_examine_vliw64_insns (cd
, pc
, info
);
676 status
= mep_examine_vliw32_insns (cd
, pc
, info
);
677 /* Both the above branches set their own isa bitmasks. */
683 cgen_bitset_clear (ivc2_core_isa
);
684 cgen_bitset_union (ivc2_core_isa
, &MEP_CORE_ISA
, ivc2_core_isa
);
685 cgen_bitset_union (ivc2_core_isa
, &MEP_COP32_ISA
, ivc2_core_isa
);
686 cd
->isas
= ivc2_core_isa
;
689 cd
->isas
= & MEP_CORE_ISA
;
690 status
= default_print_insn (cd
, pc
, info
);
693 else /* sid or gdb */
695 #ifdef MEP_IVC2_SUPPORTED
696 if (mep_ivc2_disassemble_p
)
698 if (mep_ivc2_vliw_disassemble_p
)
700 cd
->isas
= & MEP_CORE_ISA
;
701 status
= mep_examine_ivc2_insns (cd
, pc
, info
);
707 cd
->isas
= ivc2_core_isa
;
712 status
= default_print_insn (cd
, pc
, info
);
721 void mep_cgen_print_operand
722 (CGEN_CPU_DESC
, int, PTR
, CGEN_FIELDS
*, void const *, bfd_vma
, int);
724 /* Main entry point for printing operands.
725 XINFO is a `void *' and not a `disassemble_info *' to not put a requirement
726 of dis-asm.h on cgen.h.
728 This function is basically just a big switch statement. Earlier versions
729 used tables to look up the function to use, but
730 - if the table contains both assembler and disassembler functions then
731 the disassembler contains much of the assembler and vice-versa,
732 - there's a lot of inlining possibilities as things grow,
733 - using a switch statement avoids the function call overhead.
735 This function could be moved into `print_insn_normal', but keeping it
736 separate makes clear the interface between `print_insn_normal' and each of
740 mep_cgen_print_operand (CGEN_CPU_DESC cd
,
744 void const *attrs ATTRIBUTE_UNUSED
,
748 disassemble_info
*info
= (disassemble_info
*) xinfo
;
752 case MEP_OPERAND_ADDR24A4
:
753 print_normal (cd
, info
, fields
->f_24u8a4n
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
755 case MEP_OPERAND_C5RMUIMM20
:
756 print_normal (cd
, info
, fields
->f_c5_rmuimm20
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
758 case MEP_OPERAND_C5RNMUIMM24
:
759 print_normal (cd
, info
, fields
->f_c5_rnmuimm24
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
761 case MEP_OPERAND_CALLNUM
:
762 print_normal (cd
, info
, fields
->f_callnum
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
764 case MEP_OPERAND_CCCC
:
765 print_normal (cd
, info
, fields
->f_rm
, 0, pc
, length
);
767 case MEP_OPERAND_CCRN
:
768 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr
, fields
->f_ccrn
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
770 case MEP_OPERAND_CDISP10
:
771 print_normal (cd
, info
, fields
->f_cdisp10
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
773 case MEP_OPERAND_CDISP10A2
:
774 print_normal (cd
, info
, fields
->f_cdisp10
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
776 case MEP_OPERAND_CDISP10A4
:
777 print_normal (cd
, info
, fields
->f_cdisp10
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
779 case MEP_OPERAND_CDISP10A8
:
780 print_normal (cd
, info
, fields
->f_cdisp10
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
782 case MEP_OPERAND_CDISP12
:
783 print_normal (cd
, info
, fields
->f_12s20
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
785 case MEP_OPERAND_CIMM4
:
786 print_normal (cd
, info
, fields
->f_rn
, 0, pc
, length
);
788 case MEP_OPERAND_CIMM5
:
789 print_normal (cd
, info
, fields
->f_5u24
, 0, pc
, length
);
791 case MEP_OPERAND_CODE16
:
792 print_normal (cd
, info
, fields
->f_16u16
, 0, pc
, length
);
794 case MEP_OPERAND_CODE24
:
795 print_normal (cd
, info
, fields
->f_24u4n
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
797 case MEP_OPERAND_CP_FLAG
:
798 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr
, 0, 0);
800 case MEP_OPERAND_CRN
:
801 print_keyword (cd
, info
, & mep_cgen_opval_h_cr
, fields
->f_crn
, 0);
803 case MEP_OPERAND_CRN64
:
804 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_crn
, 0);
806 case MEP_OPERAND_CRNX
:
807 print_keyword (cd
, info
, & mep_cgen_opval_h_cr
, fields
->f_crnx
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
809 case MEP_OPERAND_CRNX64
:
810 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_crnx
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
812 case MEP_OPERAND_CROC
:
813 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u7
, 0);
815 case MEP_OPERAND_CROP
:
816 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u23
, 0);
818 case MEP_OPERAND_CRPC
:
819 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u26
, 0);
821 case MEP_OPERAND_CRPP
:
822 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u18
, 0);
824 case MEP_OPERAND_CRQC
:
825 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u21
, 0);
827 case MEP_OPERAND_CRQP
:
828 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u13
, 0);
830 case MEP_OPERAND_CSRN
:
831 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, fields
->f_csrn
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
833 case MEP_OPERAND_CSRN_IDX
:
834 print_normal (cd
, info
, fields
->f_csrn
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
836 case MEP_OPERAND_DBG
:
837 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
839 case MEP_OPERAND_DEPC
:
840 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
842 case MEP_OPERAND_EPC
:
843 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
845 case MEP_OPERAND_EXC
:
846 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
848 case MEP_OPERAND_HI
:
849 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
851 case MEP_OPERAND_IMM16P0
:
852 print_normal (cd
, info
, fields
->f_ivc2_imm16p0
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
854 case MEP_OPERAND_IMM3P12
:
855 print_normal (cd
, info
, fields
->f_ivc2_3u12
, 0, pc
, length
);
857 case MEP_OPERAND_IMM3P25
:
858 print_normal (cd
, info
, fields
->f_ivc2_3u25
, 0, pc
, length
);
860 case MEP_OPERAND_IMM3P4
:
861 print_normal (cd
, info
, fields
->f_ivc2_3u4
, 0, pc
, length
);
863 case MEP_OPERAND_IMM3P5
:
864 print_normal (cd
, info
, fields
->f_ivc2_3u5
, 0, pc
, length
);
866 case MEP_OPERAND_IMM3P9
:
867 print_normal (cd
, info
, fields
->f_ivc2_3u9
, 0, pc
, length
);
869 case MEP_OPERAND_IMM4P10
:
870 print_normal (cd
, info
, fields
->f_ivc2_4u10
, 0, pc
, length
);
872 case MEP_OPERAND_IMM4P4
:
873 print_normal (cd
, info
, fields
->f_ivc2_4u4
, 0, pc
, length
);
875 case MEP_OPERAND_IMM4P8
:
876 print_normal (cd
, info
, fields
->f_ivc2_4u8
, 0, pc
, length
);
878 case MEP_OPERAND_IMM5P23
:
879 print_normal (cd
, info
, fields
->f_ivc2_5u23
, 0, pc
, length
);
881 case MEP_OPERAND_IMM5P3
:
882 print_normal (cd
, info
, fields
->f_ivc2_5u3
, 0, pc
, length
);
884 case MEP_OPERAND_IMM5P7
:
885 print_normal (cd
, info
, fields
->f_ivc2_5u7
, 0, pc
, length
);
887 case MEP_OPERAND_IMM5P8
:
888 print_normal (cd
, info
, fields
->f_ivc2_5u8
, 0, pc
, length
);
890 case MEP_OPERAND_IMM6P2
:
891 print_normal (cd
, info
, fields
->f_ivc2_6u2
, 0, pc
, length
);
893 case MEP_OPERAND_IMM6P6
:
894 print_normal (cd
, info
, fields
->f_ivc2_6u6
, 0, pc
, length
);
896 case MEP_OPERAND_IMM8P0
:
897 print_normal (cd
, info
, fields
->f_ivc2_8u0
, 0, pc
, length
);
899 case MEP_OPERAND_IMM8P20
:
900 print_normal (cd
, info
, fields
->f_ivc2_8u20
, 0, pc
, length
);
902 case MEP_OPERAND_IMM8P4
:
903 print_normal (cd
, info
, fields
->f_ivc2_8u4
, 0, pc
, length
);
905 case MEP_OPERAND_IVC_X_0_2
:
906 print_normal (cd
, info
, fields
->f_ivc2_2u0
, 0, pc
, length
);
908 case MEP_OPERAND_IVC_X_0_3
:
909 print_normal (cd
, info
, fields
->f_ivc2_3u0
, 0, pc
, length
);
911 case MEP_OPERAND_IVC_X_0_4
:
912 print_normal (cd
, info
, fields
->f_ivc2_4u0
, 0, pc
, length
);
914 case MEP_OPERAND_IVC_X_0_5
:
915 print_normal (cd
, info
, fields
->f_ivc2_5u0
, 0, pc
, length
);
917 case MEP_OPERAND_IVC_X_6_1
:
918 print_normal (cd
, info
, fields
->f_ivc2_1u6
, 0, pc
, length
);
920 case MEP_OPERAND_IVC_X_6_2
:
921 print_normal (cd
, info
, fields
->f_ivc2_2u6
, 0, pc
, length
);
923 case MEP_OPERAND_IVC_X_6_3
:
924 print_normal (cd
, info
, fields
->f_ivc2_3u6
, 0, pc
, length
);
926 case MEP_OPERAND_IVC2_ACC0_0
:
927 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
929 case MEP_OPERAND_IVC2_ACC0_1
:
930 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
932 case MEP_OPERAND_IVC2_ACC0_2
:
933 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
935 case MEP_OPERAND_IVC2_ACC0_3
:
936 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
938 case MEP_OPERAND_IVC2_ACC0_4
:
939 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
941 case MEP_OPERAND_IVC2_ACC0_5
:
942 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
944 case MEP_OPERAND_IVC2_ACC0_6
:
945 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
947 case MEP_OPERAND_IVC2_ACC0_7
:
948 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
950 case MEP_OPERAND_IVC2_ACC1_0
:
951 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
953 case MEP_OPERAND_IVC2_ACC1_1
:
954 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
956 case MEP_OPERAND_IVC2_ACC1_2
:
957 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
959 case MEP_OPERAND_IVC2_ACC1_3
:
960 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
962 case MEP_OPERAND_IVC2_ACC1_4
:
963 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
965 case MEP_OPERAND_IVC2_ACC1_5
:
966 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
968 case MEP_OPERAND_IVC2_ACC1_6
:
969 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
971 case MEP_OPERAND_IVC2_ACC1_7
:
972 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
974 case MEP_OPERAND_IVC2_CC
:
975 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
977 case MEP_OPERAND_IVC2_COFA0
:
978 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
980 case MEP_OPERAND_IVC2_COFA1
:
981 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
983 case MEP_OPERAND_IVC2_COFR0
:
984 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
986 case MEP_OPERAND_IVC2_COFR1
:
987 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
989 case MEP_OPERAND_IVC2_CSAR0
:
990 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
992 case MEP_OPERAND_IVC2_CSAR1
:
993 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
995 case MEP_OPERAND_IVC2C3CCRN
:
996 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, fields
->f_ivc2_ccrn_c3
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
998 case MEP_OPERAND_IVC2CCRN
:
999 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, fields
->f_ivc2_ccrn
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
1001 case MEP_OPERAND_IVC2CRN
:
1002 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_crnx
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
1004 case MEP_OPERAND_IVC2RM
:
1005 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_ivc2_crm
, 0);
1007 case MEP_OPERAND_LO
:
1008 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1010 case MEP_OPERAND_LP
:
1011 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1013 case MEP_OPERAND_MB0
:
1014 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1016 case MEP_OPERAND_MB1
:
1017 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1019 case MEP_OPERAND_ME0
:
1020 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1022 case MEP_OPERAND_ME1
:
1023 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1025 case MEP_OPERAND_NPC
:
1026 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1028 case MEP_OPERAND_OPT
:
1029 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1031 case MEP_OPERAND_PCABS24A2
:
1032 print_address (cd
, info
, fields
->f_24u5a2n
, 0|(1<<CGEN_OPERAND_ABS_ADDR
)|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
1034 case MEP_OPERAND_PCREL12A2
:
1035 print_address (cd
, info
, fields
->f_12s4a2
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_RELAX
)|(1<<CGEN_OPERAND_PCREL_ADDR
), pc
, length
);
1037 case MEP_OPERAND_PCREL17A2
:
1038 print_address (cd
, info
, fields
->f_17s16a2
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_RELAX
)|(1<<CGEN_OPERAND_PCREL_ADDR
), pc
, length
);
1040 case MEP_OPERAND_PCREL24A2
:
1041 print_address (cd
, info
, fields
->f_24s5a2n
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_PCREL_ADDR
)|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
1043 case MEP_OPERAND_PCREL8A2
:
1044 print_address (cd
, info
, fields
->f_8s8a2
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_RELAX
)|(1<<CGEN_OPERAND_PCREL_ADDR
), pc
, length
);
1046 case MEP_OPERAND_PSW
:
1047 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1049 case MEP_OPERAND_R0
:
1050 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1052 case MEP_OPERAND_R1
:
1053 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1055 case MEP_OPERAND_RL
:
1056 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rl
, 0);
1058 case MEP_OPERAND_RL5
:
1059 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rl5
, 0);
1061 case MEP_OPERAND_RM
:
1062 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rm
, 0);
1064 case MEP_OPERAND_RMA
:
1065 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rm
, 0);
1067 case MEP_OPERAND_RN
:
1068 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1070 case MEP_OPERAND_RN3
:
1071 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1073 case MEP_OPERAND_RN3C
:
1074 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1076 case MEP_OPERAND_RN3L
:
1077 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1079 case MEP_OPERAND_RN3S
:
1080 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1082 case MEP_OPERAND_RN3UC
:
1083 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1085 case MEP_OPERAND_RN3UL
:
1086 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1088 case MEP_OPERAND_RN3US
:
1089 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1091 case MEP_OPERAND_RNC
:
1092 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1094 case MEP_OPERAND_RNL
:
1095 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1097 case MEP_OPERAND_RNS
:
1098 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1100 case MEP_OPERAND_RNUC
:
1101 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1103 case MEP_OPERAND_RNUL
:
1104 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1106 case MEP_OPERAND_RNUS
:
1107 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1109 case MEP_OPERAND_SAR
:
1110 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1112 case MEP_OPERAND_SDISP16
:
1113 print_normal (cd
, info
, fields
->f_16s16
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1115 case MEP_OPERAND_SIMM16
:
1116 print_normal (cd
, info
, fields
->f_16s16
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1118 case MEP_OPERAND_SIMM16P0
:
1119 print_normal (cd
, info
, fields
->f_ivc2_simm16p0
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
1121 case MEP_OPERAND_SIMM6
:
1122 print_normal (cd
, info
, fields
->f_6s8
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1124 case MEP_OPERAND_SIMM8
:
1125 print_normal (cd
, info
, fields
->f_8s8
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_RELOC_IMPLIES_OVERFLOW
), pc
, length
);
1127 case MEP_OPERAND_SIMM8P0
:
1128 print_normal (cd
, info
, fields
->f_ivc2_8s0
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1130 case MEP_OPERAND_SIMM8P20
:
1131 print_normal (cd
, info
, fields
->f_ivc2_8s20
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1133 case MEP_OPERAND_SIMM8P4
:
1134 print_normal (cd
, info
, fields
->f_ivc2_8s4
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1136 case MEP_OPERAND_SP
:
1137 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1139 case MEP_OPERAND_SPR
:
1140 print_spreg (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1142 case MEP_OPERAND_TP
:
1143 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1145 case MEP_OPERAND_TPR
:
1146 print_tpreg (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1148 case MEP_OPERAND_UDISP2
:
1149 print_normal (cd
, info
, fields
->f_2u6
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1151 case MEP_OPERAND_UDISP7
:
1152 print_normal (cd
, info
, fields
->f_7u9
, 0, pc
, length
);
1154 case MEP_OPERAND_UDISP7A2
:
1155 print_normal (cd
, info
, fields
->f_7u9a2
, 0, pc
, length
);
1157 case MEP_OPERAND_UDISP7A4
:
1158 print_normal (cd
, info
, fields
->f_7u9a4
, 0, pc
, length
);
1160 case MEP_OPERAND_UIMM16
:
1161 print_normal (cd
, info
, fields
->f_16u16
, 0, pc
, length
);
1163 case MEP_OPERAND_UIMM2
:
1164 print_normal (cd
, info
, fields
->f_2u10
, 0, pc
, length
);
1166 case MEP_OPERAND_UIMM24
:
1167 print_normal (cd
, info
, fields
->f_24u8n
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
1169 case MEP_OPERAND_UIMM3
:
1170 print_normal (cd
, info
, fields
->f_3u5
, 0, pc
, length
);
1172 case MEP_OPERAND_UIMM4
:
1173 print_normal (cd
, info
, fields
->f_4u8
, 0, pc
, length
);
1175 case MEP_OPERAND_UIMM5
:
1176 print_normal (cd
, info
, fields
->f_5u8
, 0, pc
, length
);
1178 case MEP_OPERAND_UIMM7A4
:
1179 print_normal (cd
, info
, fields
->f_7u9a4
, 0, pc
, length
);
1181 case MEP_OPERAND_ZERO
:
1182 print_normal (cd
, info
, 0, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1186 /* xgettext:c-format */
1187 opcodes_error_handler
1188 (_("internal error: unrecognized field %d while printing insn"),
1194 cgen_print_fn
* const mep_cgen_print_handlers
[] =
1201 mep_cgen_init_dis (CGEN_CPU_DESC cd
)
1203 mep_cgen_init_opcode_table (cd
);
1204 mep_cgen_init_ibld_table (cd
);
1205 cd
->print_handlers
= & mep_cgen_print_handlers
[0];
1206 cd
->print_operand
= mep_cgen_print_operand
;
1210 /* Default print handler. */
1213 print_normal (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED
,
1217 bfd_vma pc ATTRIBUTE_UNUSED
,
1218 int length ATTRIBUTE_UNUSED
)
1220 disassemble_info
*info
= (disassemble_info
*) dis_info
;
1222 /* Print the operand as directed by the attributes. */
1223 if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_SEM_ONLY
))
1224 ; /* nothing to do */
1225 else if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_SIGNED
))
1226 (*info
->fprintf_func
) (info
->stream
, "%ld", value
);
1228 (*info
->fprintf_func
) (info
->stream
, "0x%lx", value
);
1231 /* Default address handler. */
1234 print_address (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED
,
1238 bfd_vma pc ATTRIBUTE_UNUSED
,
1239 int length ATTRIBUTE_UNUSED
)
1241 disassemble_info
*info
= (disassemble_info
*) dis_info
;
1243 /* Print the operand as directed by the attributes. */
1244 if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_SEM_ONLY
))
1245 ; /* Nothing to do. */
1246 else if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_PCREL_ADDR
))
1247 (*info
->print_address_func
) (value
, info
);
1248 else if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_ABS_ADDR
))
1249 (*info
->print_address_func
) (value
, info
);
1250 else if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_SIGNED
))
1251 (*info
->fprintf_func
) (info
->stream
, "%ld", (long) value
);
1253 (*info
->fprintf_func
) (info
->stream
, "0x%lx", (long) value
);
1256 /* Keyword print handler. */
1259 print_keyword (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED
,
1261 CGEN_KEYWORD
*keyword_table
,
1263 unsigned int attrs ATTRIBUTE_UNUSED
)
1265 disassemble_info
*info
= (disassemble_info
*) dis_info
;
1266 const CGEN_KEYWORD_ENTRY
*ke
;
1268 ke
= cgen_keyword_lookup_value (keyword_table
, value
);
1270 (*info
->fprintf_func
) (info
->stream
, "%s", ke
->name
);
1272 (*info
->fprintf_func
) (info
->stream
, "???");
1275 /* Default insn printer.
1277 DIS_INFO is defined as `void *' so the disassembler needn't know anything
1278 about disassemble_info. */
1281 print_insn_normal (CGEN_CPU_DESC cd
,
1283 const CGEN_INSN
*insn
,
1284 CGEN_FIELDS
*fields
,
1288 const CGEN_SYNTAX
*syntax
= CGEN_INSN_SYNTAX (insn
);
1289 disassemble_info
*info
= (disassemble_info
*) dis_info
;
1290 const CGEN_SYNTAX_CHAR_TYPE
*syn
;
1292 CGEN_INIT_PRINT (cd
);
1294 for (syn
= CGEN_SYNTAX_STRING (syntax
); *syn
; ++syn
)
1296 if (CGEN_SYNTAX_MNEMONIC_P (*syn
))
1298 (*info
->fprintf_func
) (info
->stream
, "%s", CGEN_INSN_MNEMONIC (insn
));
1301 if (CGEN_SYNTAX_CHAR_P (*syn
))
1303 (*info
->fprintf_func
) (info
->stream
, "%c", CGEN_SYNTAX_CHAR (*syn
));
1307 /* We have an operand. */
1308 mep_cgen_print_operand (cd
, CGEN_SYNTAX_FIELD (*syn
), info
,
1309 fields
, CGEN_INSN_ATTRS (insn
), pc
, length
);
1313 /* Subroutine of print_insn. Reads an insn into the given buffers and updates
1315 Returns 0 if all is well, non-zero otherwise. */
1318 read_insn (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED
,
1320 disassemble_info
*info
,
1323 CGEN_EXTRACT_INFO
*ex_info
,
1324 unsigned long *insn_value
)
1326 int status
= (*info
->read_memory_func
) (pc
, buf
, buflen
, info
);
1330 (*info
->memory_error_func
) (status
, pc
, info
);
1334 ex_info
->dis_info
= info
;
1335 ex_info
->valid
= (1 << buflen
) - 1;
1336 ex_info
->insn_bytes
= buf
;
1338 *insn_value
= bfd_get_bits (buf
, buflen
* 8, info
->endian
== BFD_ENDIAN_BIG
);
1342 /* Utility to print an insn.
1343 BUF is the base part of the insn, target byte order, BUFLEN bytes long.
1344 The result is the size of the insn in bytes or zero for an unknown insn
1345 or -1 if an error occurs fetching data (memory_error_func will have
1349 print_insn (CGEN_CPU_DESC cd
,
1351 disassemble_info
*info
,
1353 unsigned int buflen
)
1355 CGEN_INSN_INT insn_value
;
1356 const CGEN_INSN_LIST
*insn_list
;
1357 CGEN_EXTRACT_INFO ex_info
;
1360 /* Extract base part of instruction, just in case CGEN_DIS_* uses it. */
1361 basesize
= cd
->base_insn_bitsize
< buflen
* 8 ?
1362 cd
->base_insn_bitsize
: buflen
* 8;
1363 insn_value
= cgen_get_insn_value (cd
, buf
, basesize
);
1366 /* Fill in ex_info fields like read_insn would. Don't actually call
1367 read_insn, since the incoming buffer is already read (and possibly
1368 modified a la m32r). */
1369 ex_info
.valid
= (1 << buflen
) - 1;
1370 ex_info
.dis_info
= info
;
1371 ex_info
.insn_bytes
= buf
;
1373 /* The instructions are stored in hash lists.
1374 Pick the first one and keep trying until we find the right one. */
1376 insn_list
= CGEN_DIS_LOOKUP_INSN (cd
, (char *) buf
, insn_value
);
1377 while (insn_list
!= NULL
)
1379 const CGEN_INSN
*insn
= insn_list
->insn
;
1382 unsigned long insn_value_cropped
;
1384 #ifdef CGEN_VALIDATE_INSN_SUPPORTED
1385 /* Not needed as insn shouldn't be in hash lists if not supported. */
1386 /* Supported by this cpu? */
1387 if (! mep_cgen_insn_supported (cd
, insn
))
1389 insn_list
= CGEN_DIS_NEXT_INSN (insn_list
);
1394 /* Basic bit mask must be correct. */
1395 /* ??? May wish to allow target to defer this check until the extract
1398 /* Base size may exceed this instruction's size. Extract the
1399 relevant part from the buffer. */
1400 if ((unsigned) (CGEN_INSN_BITSIZE (insn
) / 8) < buflen
&&
1401 (unsigned) (CGEN_INSN_BITSIZE (insn
) / 8) <= sizeof (unsigned long))
1402 insn_value_cropped
= bfd_get_bits (buf
, CGEN_INSN_BITSIZE (insn
),
1403 info
->endian
== BFD_ENDIAN_BIG
);
1405 insn_value_cropped
= insn_value
;
1407 if ((insn_value_cropped
& CGEN_INSN_BASE_MASK (insn
))
1408 == CGEN_INSN_BASE_VALUE (insn
))
1410 /* Printing is handled in two passes. The first pass parses the
1411 machine insn and extracts the fields. The second pass prints
1414 /* Make sure the entire insn is loaded into insn_value, if it
1416 if (((unsigned) CGEN_INSN_BITSIZE (insn
) > cd
->base_insn_bitsize
) &&
1417 (unsigned) (CGEN_INSN_BITSIZE (insn
) / 8) <= sizeof (unsigned long))
1419 unsigned long full_insn_value
;
1420 int rc
= read_insn (cd
, pc
, info
, buf
,
1421 CGEN_INSN_BITSIZE (insn
) / 8,
1422 & ex_info
, & full_insn_value
);
1425 length
= CGEN_EXTRACT_FN (cd
, insn
)
1426 (cd
, insn
, &ex_info
, full_insn_value
, &fields
, pc
);
1429 length
= CGEN_EXTRACT_FN (cd
, insn
)
1430 (cd
, insn
, &ex_info
, insn_value_cropped
, &fields
, pc
);
1432 /* Length < 0 -> error. */
1437 CGEN_PRINT_FN (cd
, insn
) (cd
, info
, insn
, &fields
, pc
, length
);
1438 /* Length is in bits, result is in bytes. */
1443 insn_list
= CGEN_DIS_NEXT_INSN (insn_list
);
1449 /* Default value for CGEN_PRINT_INSN.
1450 The result is the size of the insn in bytes or zero for an unknown insn
1451 or -1 if an error occured fetching bytes. */
1453 #ifndef CGEN_PRINT_INSN
1454 #define CGEN_PRINT_INSN default_print_insn
1458 default_print_insn (CGEN_CPU_DESC cd
, bfd_vma pc
, disassemble_info
*info
)
1460 bfd_byte buf
[CGEN_MAX_INSN_SIZE
];
1464 /* Attempt to read the base part of the insn. */
1465 buflen
= cd
->base_insn_bitsize
/ 8;
1466 status
= (*info
->read_memory_func
) (pc
, buf
, buflen
, info
);
1468 /* Try again with the minimum part, if min < base. */
1469 if (status
!= 0 && (cd
->min_insn_bitsize
< cd
->base_insn_bitsize
))
1471 buflen
= cd
->min_insn_bitsize
/ 8;
1472 status
= (*info
->read_memory_func
) (pc
, buf
, buflen
, info
);
1477 (*info
->memory_error_func
) (status
, pc
, info
);
1481 return print_insn (cd
, pc
, info
, buf
, buflen
);
1484 /* Main entry point.
1485 Print one instruction from PC on INFO->STREAM.
1486 Return the size of the instruction (in bytes). */
1488 typedef struct cpu_desc_list
1490 struct cpu_desc_list
*next
;
1498 print_insn_mep (bfd_vma pc
, disassemble_info
*info
)
1500 static cpu_desc_list
*cd_list
= 0;
1501 cpu_desc_list
*cl
= 0;
1502 static CGEN_CPU_DESC cd
= 0;
1503 static CGEN_BITSET
*prev_isa
;
1504 static int prev_mach
;
1505 static int prev_endian
;
1509 int endian
= (info
->endian
== BFD_ENDIAN_BIG
1511 : CGEN_ENDIAN_LITTLE
);
1512 enum bfd_architecture arch
;
1514 /* ??? gdb will set mach but leave the architecture as "unknown" */
1515 #ifndef CGEN_BFD_ARCH
1516 #define CGEN_BFD_ARCH bfd_arch_mep
1519 if (arch
== bfd_arch_unknown
)
1520 arch
= CGEN_BFD_ARCH
;
1522 /* There's no standard way to compute the machine or isa number
1523 so we leave it to the target. */
1524 #ifdef CGEN_COMPUTE_MACH
1525 mach
= CGEN_COMPUTE_MACH (info
);
1530 #ifdef CGEN_COMPUTE_ISA
1532 static CGEN_BITSET
*permanent_isa
;
1535 permanent_isa
= cgen_bitset_create (MAX_ISAS
);
1536 isa
= permanent_isa
;
1537 cgen_bitset_clear (isa
);
1538 cgen_bitset_add (isa
, CGEN_COMPUTE_ISA (info
));
1541 isa
= info
->insn_sets
;
1544 /* If we've switched cpu's, try to find a handle we've used before */
1546 && (cgen_bitset_compare (isa
, prev_isa
) != 0
1547 || mach
!= prev_mach
1548 || endian
!= prev_endian
))
1551 for (cl
= cd_list
; cl
; cl
= cl
->next
)
1553 if (cgen_bitset_compare (cl
->isa
, isa
) == 0 &&
1555 cl
->endian
== endian
)
1558 prev_isa
= cd
->isas
;
1564 /* If we haven't initialized yet, initialize the opcode table. */
1567 const bfd_arch_info_type
*arch_type
= bfd_lookup_arch (arch
, mach
);
1568 const char *mach_name
;
1572 mach_name
= arch_type
->printable_name
;
1574 prev_isa
= cgen_bitset_copy (isa
);
1576 prev_endian
= endian
;
1577 cd
= mep_cgen_cpu_open (CGEN_CPU_OPEN_ISAS
, prev_isa
,
1578 CGEN_CPU_OPEN_BFDMACH
, mach_name
,
1579 CGEN_CPU_OPEN_ENDIAN
, prev_endian
,
1584 /* Save this away for future reference. */
1585 cl
= xmalloc (sizeof (struct cpu_desc_list
));
1589 cl
->endian
= endian
;
1593 mep_cgen_init_dis (cd
);
1596 /* We try to have as much common code as possible.
1597 But at this point some targets need to take over. */
1598 /* ??? Some targets may need a hook elsewhere. Try to avoid this,
1599 but if not possible try to move this hook elsewhere rather than
1601 length
= CGEN_PRINT_INSN (cd
, pc
, info
);
1607 (*info
->fprintf_func
) (info
->stream
, UNKNOWN_INSN_MSG
);
1608 return cd
->default_insn_bitsize
/ 8;