1 /* Disassembler interface for targets using CGEN. -*- C -*-
2 CGEN: Cpu tools GENerator
4 THIS FILE IS MACHINE GENERATED WITH CGEN.
5 - the resultant file is machine generated, cgen-dis.in isn't
7 Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2005, 2007,
8 2008 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.
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
)
542 /* At this time we're not supporting internally parallel
543 coprocessors, so cop2buflength will always be 0. */
546 /* Read in 64 bits. */
547 buflength
= 8; /* VLIW insn spans 8 bytes. */
548 status
= (*info
->read_memory_func
) (pc
, buf
, buflength
, info
);
552 (*info
->memory_error_func
) (status
, pc
, info
);
556 if (info
->endian
== BFD_ENDIAN_LITTLE
)
561 if (((unsigned char)buf
[0^e
] & 0xf0) < 0xc0)
563 /* <--00--><--11--><--22--><--33--><--44--><--55--><--66--><--77--> */
564 /* V1 [-----core-----][--------p0s-------][------------p1------------] */
566 print_insn (cd
, pc
, info
, buf
, 2);
569 insn
[1^e
] = buf
[2^e
];
570 insn
[2^e
] = buf
[3^e
];
571 insn
[3^e
] = buf
[4^e
] & 0xf0;
572 (*info
->fprintf_func
) (info
->stream
, " + ");
573 print_slot_insn (cd
, pc
, info
, SLOTS_P0S
, insn
);
575 insn
[0^e
] = buf
[4^e
] << 4 | buf
[5^e
] >> 4;
576 insn
[1^e
] = buf
[5^e
] << 4 | buf
[6^e
] >> 4;
577 insn
[2^e
] = buf
[6^e
] << 4 | buf
[7^e
] >> 4;
578 insn
[3^e
] = buf
[7^e
] << 4;
579 (*info
->fprintf_func
) (info
->stream
, " + ");
580 print_slot_insn (cd
, pc
, info
, SLOTS_P1
, insn
);
582 else if ((buf
[0^e
] & 0xf0) == 0xf0 && (buf
[1^e
] & 0x0f) == 0x07)
584 /* <--00--><--11--><--22--><--33--><--44--><--55--><--66--><--77--> */
585 /* V3 1111[--p0--]0111[--------p0--------][------------p1------------] */
586 /* 00000000111111112222222233333333 */
588 insn
[0^e
] = buf
[0^e
] << 4 | buf
[1^e
] >> 4;
589 insn
[1^e
] = buf
[2^e
];
590 insn
[2^e
] = buf
[3^e
];
591 insn
[3^e
] = buf
[4^e
] & 0xf0;
592 print_slot_insn (cd
, pc
, info
, SLOTS_P0
, insn
);
594 insn
[0^e
] = buf
[4^e
] << 4 | buf
[5^e
] >> 4;
595 insn
[1^e
] = buf
[5^e
] << 4 | buf
[6^e
] >> 4;
596 insn
[2^e
] = buf
[6^e
] << 4 | buf
[7^e
] >> 4;
597 insn
[3^e
] = buf
[7^e
] << 4;
598 (*info
->fprintf_func
) (info
->stream
, " + ");
599 print_slot_insn (cd
, pc
, info
, SLOTS_P1
, insn
);
603 /* <--00--><--11--><--22--><--33--><--44--><--55--><--66--><--77--> */
604 /* V2 [-------------core-------------]xxxx[------------p1------------] */
605 print_insn (cd
, pc
, info
, buf
, 4);
607 insn
[0^e
] = buf
[4^e
] << 4 | buf
[5^e
] >> 4;
608 insn
[1^e
] = buf
[5^e
] << 4 | buf
[6^e
] >> 4;
609 insn
[2^e
] = buf
[6^e
] << 4 | buf
[7^e
] >> 4;
610 insn
[3^e
] = buf
[7^e
] << 4;
611 (*info
->fprintf_func
) (info
->stream
, " + ");
612 print_slot_insn (cd
, pc
, info
, SLOTS_P1
, insn
);
618 #endif /* MEP_IVC2_SUPPORTED */
620 /* This is a hack. SID calls this to update the disassembler as the
621 CPU changes modes. */
622 static int mep_ivc2_disassemble_p
= 0;
623 static int mep_ivc2_vliw_disassemble_p
= 0;
626 mep_print_insn_set_ivc2_mode (int ivc2_p
, int vliw_p
, int cfg_idx
);
628 mep_print_insn_set_ivc2_mode (int ivc2_p
, int vliw_p
, int cfg_idx
)
630 mep_ivc2_disassemble_p
= ivc2_p
;
631 mep_ivc2_vliw_disassemble_p
= vliw_p
;
632 mep_config_index
= cfg_idx
;
636 mep_print_insn (CGEN_CPU_DESC cd
, bfd_vma pc
, disassemble_info
*info
)
641 static CGEN_ATTR_VALUE_BITSET_TYPE
*ivc2_core_isa
= NULL
;
643 if (ivc2_core_isa
== NULL
)
645 /* IVC2 has some core-only coprocessor instructions. We
646 use COP32 to flag those, and COP64 for the VLIW ones,
647 since they have the same names. */
648 ivc2_core_isa
= cgen_bitset_create (MAX_ISAS
);
651 /* Extract and adapt to configuration number, if available. */
652 if (info
->section
&& info
->section
->owner
)
654 bfd
*abfd
= info
->section
->owner
;
655 mep_config_index
= abfd
->tdata
.elf_obj_data
->elf_header
->e_flags
& EF_MEP_INDEX_MASK
;
656 /* This instantly redefines MEP_CONFIG, MEP_OMASK, .... MEP_VLIW64 */
658 cop_type
= abfd
->tdata
.elf_obj_data
->elf_header
->e_flags
& EF_MEP_COP_MASK
;
659 if (cop_type
== EF_MEP_COP_IVC2
)
663 /* Picking the right ISA bitmask for the current context is tricky. */
666 if (info
->section
->flags
& SEC_MEP_VLIW
)
668 #ifdef MEP_IVC2_SUPPORTED
671 /* ivc2 has its own way of selecting its functions. */
672 cd
->isas
= & MEP_CORE_ISA
;
673 status
= mep_examine_ivc2_insns (cd
, pc
, info
);
677 /* Are we in 32 or 64 bit vliw mode? */
679 status
= mep_examine_vliw64_insns (cd
, pc
, info
);
681 status
= mep_examine_vliw32_insns (cd
, pc
, info
);
682 /* Both the above branches set their own isa bitmasks. */
688 cgen_bitset_clear (ivc2_core_isa
);
689 cgen_bitset_union (ivc2_core_isa
, &MEP_CORE_ISA
, ivc2_core_isa
);
690 cgen_bitset_union (ivc2_core_isa
, &MEP_COP32_ISA
, ivc2_core_isa
);
691 cd
->isas
= ivc2_core_isa
;
694 cd
->isas
= & MEP_CORE_ISA
;
695 status
= default_print_insn (cd
, pc
, info
);
698 else /* sid or gdb */
700 #ifdef MEP_IVC2_SUPPORTED
701 if (mep_ivc2_disassemble_p
)
703 if (mep_ivc2_vliw_disassemble_p
)
705 cd
->isas
= & MEP_CORE_ISA
;
706 status
= mep_examine_ivc2_insns (cd
, pc
, info
);
712 cd
->isas
= ivc2_core_isa
;
717 status
= default_print_insn (cd
, pc
, info
);
726 void mep_cgen_print_operand
727 (CGEN_CPU_DESC
, int, PTR
, CGEN_FIELDS
*, void const *, bfd_vma
, int);
729 /* Main entry point for printing operands.
730 XINFO is a `void *' and not a `disassemble_info *' to not put a requirement
731 of dis-asm.h on cgen.h.
733 This function is basically just a big switch statement. Earlier versions
734 used tables to look up the function to use, but
735 - if the table contains both assembler and disassembler functions then
736 the disassembler contains much of the assembler and vice-versa,
737 - there's a lot of inlining possibilities as things grow,
738 - using a switch statement avoids the function call overhead.
740 This function could be moved into `print_insn_normal', but keeping it
741 separate makes clear the interface between `print_insn_normal' and each of
745 mep_cgen_print_operand (CGEN_CPU_DESC cd
,
749 void const *attrs ATTRIBUTE_UNUSED
,
753 disassemble_info
*info
= (disassemble_info
*) xinfo
;
757 case MEP_OPERAND_ADDR24A4
:
758 print_normal (cd
, info
, fields
->f_24u8a4n
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
760 case MEP_OPERAND_C5RMUIMM20
:
761 print_normal (cd
, info
, fields
->f_c5_rmuimm20
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
763 case MEP_OPERAND_C5RNMUIMM24
:
764 print_normal (cd
, info
, fields
->f_c5_rnmuimm24
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
766 case MEP_OPERAND_CALLNUM
:
767 print_normal (cd
, info
, fields
->f_callnum
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
769 case MEP_OPERAND_CCCC
:
770 print_normal (cd
, info
, fields
->f_rm
, 0, pc
, length
);
772 case MEP_OPERAND_CCRN
:
773 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr
, fields
->f_ccrn
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
775 case MEP_OPERAND_CDISP10
:
776 print_normal (cd
, info
, fields
->f_cdisp10
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
778 case MEP_OPERAND_CDISP10A2
:
779 print_normal (cd
, info
, fields
->f_cdisp10
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
781 case MEP_OPERAND_CDISP10A4
:
782 print_normal (cd
, info
, fields
->f_cdisp10
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
784 case MEP_OPERAND_CDISP10A8
:
785 print_normal (cd
, info
, fields
->f_cdisp10
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
787 case MEP_OPERAND_CDISP12
:
788 print_normal (cd
, info
, fields
->f_12s20
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
790 case MEP_OPERAND_CIMM4
:
791 print_normal (cd
, info
, fields
->f_rn
, 0, pc
, length
);
793 case MEP_OPERAND_CIMM5
:
794 print_normal (cd
, info
, fields
->f_5u24
, 0, pc
, length
);
796 case MEP_OPERAND_CODE16
:
797 print_normal (cd
, info
, fields
->f_16u16
, 0, pc
, length
);
799 case MEP_OPERAND_CODE24
:
800 print_normal (cd
, info
, fields
->f_24u4n
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
802 case MEP_OPERAND_CP_FLAG
:
803 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr
, 0, 0);
805 case MEP_OPERAND_CRN
:
806 print_keyword (cd
, info
, & mep_cgen_opval_h_cr
, fields
->f_crn
, 0);
808 case MEP_OPERAND_CRN64
:
809 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_crn
, 0);
811 case MEP_OPERAND_CRNX
:
812 print_keyword (cd
, info
, & mep_cgen_opval_h_cr
, fields
->f_crnx
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
814 case MEP_OPERAND_CRNX64
:
815 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_crnx
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
817 case MEP_OPERAND_CROC
:
818 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u7
, 0);
820 case MEP_OPERAND_CROP
:
821 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u23
, 0);
823 case MEP_OPERAND_CRPC
:
824 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u26
, 0);
826 case MEP_OPERAND_CRPP
:
827 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u18
, 0);
829 case MEP_OPERAND_CRQC
:
830 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u21
, 0);
832 case MEP_OPERAND_CRQP
:
833 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_5u13
, 0);
835 case MEP_OPERAND_CSRN
:
836 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, fields
->f_csrn
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
838 case MEP_OPERAND_CSRN_IDX
:
839 print_normal (cd
, info
, fields
->f_csrn
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
841 case MEP_OPERAND_DBG
:
842 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
844 case MEP_OPERAND_DEPC
:
845 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
847 case MEP_OPERAND_EPC
:
848 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
850 case MEP_OPERAND_EXC
:
851 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
853 case MEP_OPERAND_HI
:
854 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
856 case MEP_OPERAND_IMM16P0
:
857 print_normal (cd
, info
, fields
->f_ivc2_imm16p0
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
859 case MEP_OPERAND_IMM3P12
:
860 print_normal (cd
, info
, fields
->f_ivc2_3u12
, 0, pc
, length
);
862 case MEP_OPERAND_IMM3P25
:
863 print_normal (cd
, info
, fields
->f_ivc2_3u25
, 0, pc
, length
);
865 case MEP_OPERAND_IMM3P4
:
866 print_normal (cd
, info
, fields
->f_ivc2_3u4
, 0, pc
, length
);
868 case MEP_OPERAND_IMM3P5
:
869 print_normal (cd
, info
, fields
->f_ivc2_3u5
, 0, pc
, length
);
871 case MEP_OPERAND_IMM3P9
:
872 print_normal (cd
, info
, fields
->f_ivc2_3u9
, 0, pc
, length
);
874 case MEP_OPERAND_IMM4P10
:
875 print_normal (cd
, info
, fields
->f_ivc2_4u10
, 0, pc
, length
);
877 case MEP_OPERAND_IMM4P4
:
878 print_normal (cd
, info
, fields
->f_ivc2_4u4
, 0, pc
, length
);
880 case MEP_OPERAND_IMM4P8
:
881 print_normal (cd
, info
, fields
->f_ivc2_4u8
, 0, pc
, length
);
883 case MEP_OPERAND_IMM5P23
:
884 print_normal (cd
, info
, fields
->f_ivc2_5u23
, 0, pc
, length
);
886 case MEP_OPERAND_IMM5P3
:
887 print_normal (cd
, info
, fields
->f_ivc2_5u3
, 0, pc
, length
);
889 case MEP_OPERAND_IMM5P7
:
890 print_normal (cd
, info
, fields
->f_ivc2_5u7
, 0, pc
, length
);
892 case MEP_OPERAND_IMM5P8
:
893 print_normal (cd
, info
, fields
->f_ivc2_5u8
, 0, pc
, length
);
895 case MEP_OPERAND_IMM6P2
:
896 print_normal (cd
, info
, fields
->f_ivc2_6u2
, 0, pc
, length
);
898 case MEP_OPERAND_IMM6P6
:
899 print_normal (cd
, info
, fields
->f_ivc2_6u6
, 0, pc
, length
);
901 case MEP_OPERAND_IMM8P0
:
902 print_normal (cd
, info
, fields
->f_ivc2_8u0
, 0, pc
, length
);
904 case MEP_OPERAND_IMM8P20
:
905 print_normal (cd
, info
, fields
->f_ivc2_8u20
, 0, pc
, length
);
907 case MEP_OPERAND_IMM8P4
:
908 print_normal (cd
, info
, fields
->f_ivc2_8u4
, 0, pc
, length
);
910 case MEP_OPERAND_IVC_X_0_2
:
911 print_normal (cd
, info
, fields
->f_ivc2_2u0
, 0, pc
, length
);
913 case MEP_OPERAND_IVC_X_0_3
:
914 print_normal (cd
, info
, fields
->f_ivc2_3u0
, 0, pc
, length
);
916 case MEP_OPERAND_IVC_X_0_4
:
917 print_normal (cd
, info
, fields
->f_ivc2_4u0
, 0, pc
, length
);
919 case MEP_OPERAND_IVC_X_0_5
:
920 print_normal (cd
, info
, fields
->f_ivc2_5u0
, 0, pc
, length
);
922 case MEP_OPERAND_IVC_X_6_1
:
923 print_normal (cd
, info
, fields
->f_ivc2_1u6
, 0, pc
, length
);
925 case MEP_OPERAND_IVC_X_6_2
:
926 print_normal (cd
, info
, fields
->f_ivc2_2u6
, 0, pc
, length
);
928 case MEP_OPERAND_IVC_X_6_3
:
929 print_normal (cd
, info
, fields
->f_ivc2_3u6
, 0, pc
, length
);
931 case MEP_OPERAND_IVC2_ACC0_0
:
932 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
934 case MEP_OPERAND_IVC2_ACC0_1
:
935 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
937 case MEP_OPERAND_IVC2_ACC0_2
:
938 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
940 case MEP_OPERAND_IVC2_ACC0_3
:
941 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
943 case MEP_OPERAND_IVC2_ACC0_4
:
944 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
946 case MEP_OPERAND_IVC2_ACC0_5
:
947 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
949 case MEP_OPERAND_IVC2_ACC0_6
:
950 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
952 case MEP_OPERAND_IVC2_ACC0_7
:
953 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
955 case MEP_OPERAND_IVC2_ACC1_0
:
956 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
958 case MEP_OPERAND_IVC2_ACC1_1
:
959 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
961 case MEP_OPERAND_IVC2_ACC1_2
:
962 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
964 case MEP_OPERAND_IVC2_ACC1_3
:
965 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
967 case MEP_OPERAND_IVC2_ACC1_4
:
968 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
970 case MEP_OPERAND_IVC2_ACC1_5
:
971 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
973 case MEP_OPERAND_IVC2_ACC1_6
:
974 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
976 case MEP_OPERAND_IVC2_ACC1_7
:
977 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
979 case MEP_OPERAND_IVC2_CC
:
980 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
982 case MEP_OPERAND_IVC2_COFA0
:
983 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
985 case MEP_OPERAND_IVC2_COFA1
:
986 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
988 case MEP_OPERAND_IVC2_COFR0
:
989 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
991 case MEP_OPERAND_IVC2_COFR1
:
992 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
994 case MEP_OPERAND_IVC2_CSAR0
:
995 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
997 case MEP_OPERAND_IVC2_CSAR1
:
998 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, 0, 0);
1000 case MEP_OPERAND_IVC2C3CCRN
:
1001 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, fields
->f_ivc2_ccrn_c3
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
1003 case MEP_OPERAND_IVC2CCRN
:
1004 print_keyword (cd
, info
, & mep_cgen_opval_h_ccr_ivc2
, fields
->f_ivc2_ccrn
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
1006 case MEP_OPERAND_IVC2CRN
:
1007 print_keyword (cd
, info
, & mep_cgen_opval_h_cr64
, fields
->f_ivc2_crnx
, 0|(1<<CGEN_OPERAND_VIRTUAL
));
1009 case MEP_OPERAND_IVC2RM
:
1010 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_ivc2_crm
, 0);
1012 case MEP_OPERAND_LO
:
1013 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1015 case MEP_OPERAND_LP
:
1016 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1018 case MEP_OPERAND_MB0
:
1019 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1021 case MEP_OPERAND_MB1
:
1022 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1024 case MEP_OPERAND_ME0
:
1025 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1027 case MEP_OPERAND_ME1
:
1028 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1030 case MEP_OPERAND_NPC
:
1031 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1033 case MEP_OPERAND_OPT
:
1034 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1036 case MEP_OPERAND_PCABS24A2
:
1037 print_address (cd
, info
, fields
->f_24u5a2n
, 0|(1<<CGEN_OPERAND_ABS_ADDR
)|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
1039 case MEP_OPERAND_PCREL12A2
:
1040 print_address (cd
, info
, fields
->f_12s4a2
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_RELAX
)|(1<<CGEN_OPERAND_PCREL_ADDR
), pc
, length
);
1042 case MEP_OPERAND_PCREL17A2
:
1043 print_address (cd
, info
, fields
->f_17s16a2
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_RELAX
)|(1<<CGEN_OPERAND_PCREL_ADDR
), pc
, length
);
1045 case MEP_OPERAND_PCREL24A2
:
1046 print_address (cd
, info
, fields
->f_24s5a2n
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_PCREL_ADDR
)|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
1048 case MEP_OPERAND_PCREL8A2
:
1049 print_address (cd
, info
, fields
->f_8s8a2
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_RELAX
)|(1<<CGEN_OPERAND_PCREL_ADDR
), pc
, length
);
1051 case MEP_OPERAND_PSW
:
1052 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1054 case MEP_OPERAND_R0
:
1055 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1057 case MEP_OPERAND_R1
:
1058 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1060 case MEP_OPERAND_RL
:
1061 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rl
, 0);
1063 case MEP_OPERAND_RL5
:
1064 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rl5
, 0);
1066 case MEP_OPERAND_RM
:
1067 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rm
, 0);
1069 case MEP_OPERAND_RMA
:
1070 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rm
, 0);
1072 case MEP_OPERAND_RN
:
1073 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1075 case MEP_OPERAND_RN3
:
1076 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1078 case MEP_OPERAND_RN3C
:
1079 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1081 case MEP_OPERAND_RN3L
:
1082 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1084 case MEP_OPERAND_RN3S
:
1085 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1087 case MEP_OPERAND_RN3UC
:
1088 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1090 case MEP_OPERAND_RN3UL
:
1091 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1093 case MEP_OPERAND_RN3US
:
1094 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn3
, 0);
1096 case MEP_OPERAND_RNC
:
1097 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1099 case MEP_OPERAND_RNL
:
1100 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1102 case MEP_OPERAND_RNS
:
1103 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1105 case MEP_OPERAND_RNUC
:
1106 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1108 case MEP_OPERAND_RNUL
:
1109 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1111 case MEP_OPERAND_RNUS
:
1112 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, fields
->f_rn
, 0);
1114 case MEP_OPERAND_SAR
:
1115 print_keyword (cd
, info
, & mep_cgen_opval_h_csr
, 0, 0);
1117 case MEP_OPERAND_SDISP16
:
1118 print_normal (cd
, info
, fields
->f_16s16
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1120 case MEP_OPERAND_SIMM16
:
1121 print_normal (cd
, info
, fields
->f_16s16
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1123 case MEP_OPERAND_SIMM16P0
:
1124 print_normal (cd
, info
, fields
->f_ivc2_simm16p0
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
1126 case MEP_OPERAND_SIMM6
:
1127 print_normal (cd
, info
, fields
->f_6s8
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1129 case MEP_OPERAND_SIMM8
:
1130 print_normal (cd
, info
, fields
->f_8s8
, 0|(1<<CGEN_OPERAND_SIGNED
)|(1<<CGEN_OPERAND_RELOC_IMPLIES_OVERFLOW
), pc
, length
);
1132 case MEP_OPERAND_SIMM8P0
:
1133 print_normal (cd
, info
, fields
->f_ivc2_8s0
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1135 case MEP_OPERAND_SIMM8P20
:
1136 print_normal (cd
, info
, fields
->f_ivc2_8s20
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1138 case MEP_OPERAND_SIMM8P4
:
1139 print_normal (cd
, info
, fields
->f_ivc2_8s4
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1141 case MEP_OPERAND_SP
:
1142 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1144 case MEP_OPERAND_SPR
:
1145 print_spreg (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1147 case MEP_OPERAND_TP
:
1148 print_keyword (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1150 case MEP_OPERAND_TPR
:
1151 print_tpreg (cd
, info
, & mep_cgen_opval_h_gpr
, 0, 0);
1153 case MEP_OPERAND_UDISP2
:
1154 print_normal (cd
, info
, fields
->f_2u6
, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1156 case MEP_OPERAND_UDISP7
:
1157 print_normal (cd
, info
, fields
->f_7u9
, 0, pc
, length
);
1159 case MEP_OPERAND_UDISP7A2
:
1160 print_normal (cd
, info
, fields
->f_7u9a2
, 0, pc
, length
);
1162 case MEP_OPERAND_UDISP7A4
:
1163 print_normal (cd
, info
, fields
->f_7u9a4
, 0, pc
, length
);
1165 case MEP_OPERAND_UIMM16
:
1166 print_normal (cd
, info
, fields
->f_16u16
, 0, pc
, length
);
1168 case MEP_OPERAND_UIMM2
:
1169 print_normal (cd
, info
, fields
->f_2u10
, 0, pc
, length
);
1171 case MEP_OPERAND_UIMM24
:
1172 print_normal (cd
, info
, fields
->f_24u8n
, 0|(1<<CGEN_OPERAND_VIRTUAL
), pc
, length
);
1174 case MEP_OPERAND_UIMM3
:
1175 print_normal (cd
, info
, fields
->f_3u5
, 0, pc
, length
);
1177 case MEP_OPERAND_UIMM4
:
1178 print_normal (cd
, info
, fields
->f_4u8
, 0, pc
, length
);
1180 case MEP_OPERAND_UIMM5
:
1181 print_normal (cd
, info
, fields
->f_5u8
, 0, pc
, length
);
1183 case MEP_OPERAND_UIMM7A4
:
1184 print_normal (cd
, info
, fields
->f_7u9a4
, 0, pc
, length
);
1186 case MEP_OPERAND_ZERO
:
1187 print_normal (cd
, info
, 0, 0|(1<<CGEN_OPERAND_SIGNED
), pc
, length
);
1191 /* xgettext:c-format */
1192 fprintf (stderr
, _("Unrecognized field %d while printing insn.\n"),
1198 cgen_print_fn
* const mep_cgen_print_handlers
[] =
1205 mep_cgen_init_dis (CGEN_CPU_DESC cd
)
1207 mep_cgen_init_opcode_table (cd
);
1208 mep_cgen_init_ibld_table (cd
);
1209 cd
->print_handlers
= & mep_cgen_print_handlers
[0];
1210 cd
->print_operand
= mep_cgen_print_operand
;
1214 /* Default print handler. */
1217 print_normal (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED
,
1221 bfd_vma pc ATTRIBUTE_UNUSED
,
1222 int length ATTRIBUTE_UNUSED
)
1224 disassemble_info
*info
= (disassemble_info
*) dis_info
;
1226 #ifdef CGEN_PRINT_NORMAL
1227 CGEN_PRINT_NORMAL (cd
, info
, value
, attrs
, pc
, length
);
1230 /* Print the operand as directed by the attributes. */
1231 if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_SEM_ONLY
))
1232 ; /* nothing to do */
1233 else if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_SIGNED
))
1234 (*info
->fprintf_func
) (info
->stream
, "%ld", value
);
1236 (*info
->fprintf_func
) (info
->stream
, "0x%lx", value
);
1239 /* Default address handler. */
1242 print_address (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED
,
1246 bfd_vma pc ATTRIBUTE_UNUSED
,
1247 int length ATTRIBUTE_UNUSED
)
1249 disassemble_info
*info
= (disassemble_info
*) dis_info
;
1251 #ifdef CGEN_PRINT_ADDRESS
1252 CGEN_PRINT_ADDRESS (cd
, info
, value
, attrs
, pc
, length
);
1255 /* Print the operand as directed by the attributes. */
1256 if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_SEM_ONLY
))
1257 ; /* Nothing to do. */
1258 else if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_PCREL_ADDR
))
1259 (*info
->print_address_func
) (value
, info
);
1260 else if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_ABS_ADDR
))
1261 (*info
->print_address_func
) (value
, info
);
1262 else if (CGEN_BOOL_ATTR (attrs
, CGEN_OPERAND_SIGNED
))
1263 (*info
->fprintf_func
) (info
->stream
, "%ld", (long) value
);
1265 (*info
->fprintf_func
) (info
->stream
, "0x%lx", (long) value
);
1268 /* Keyword print handler. */
1271 print_keyword (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED
,
1273 CGEN_KEYWORD
*keyword_table
,
1275 unsigned int attrs ATTRIBUTE_UNUSED
)
1277 disassemble_info
*info
= (disassemble_info
*) dis_info
;
1278 const CGEN_KEYWORD_ENTRY
*ke
;
1280 ke
= cgen_keyword_lookup_value (keyword_table
, value
);
1282 (*info
->fprintf_func
) (info
->stream
, "%s", ke
->name
);
1284 (*info
->fprintf_func
) (info
->stream
, "???");
1287 /* Default insn printer.
1289 DIS_INFO is defined as `void *' so the disassembler needn't know anything
1290 about disassemble_info. */
1293 print_insn_normal (CGEN_CPU_DESC cd
,
1295 const CGEN_INSN
*insn
,
1296 CGEN_FIELDS
*fields
,
1300 const CGEN_SYNTAX
*syntax
= CGEN_INSN_SYNTAX (insn
);
1301 disassemble_info
*info
= (disassemble_info
*) dis_info
;
1302 const CGEN_SYNTAX_CHAR_TYPE
*syn
;
1304 CGEN_INIT_PRINT (cd
);
1306 for (syn
= CGEN_SYNTAX_STRING (syntax
); *syn
; ++syn
)
1308 if (CGEN_SYNTAX_MNEMONIC_P (*syn
))
1310 (*info
->fprintf_func
) (info
->stream
, "%s", CGEN_INSN_MNEMONIC (insn
));
1313 if (CGEN_SYNTAX_CHAR_P (*syn
))
1315 (*info
->fprintf_func
) (info
->stream
, "%c", CGEN_SYNTAX_CHAR (*syn
));
1319 /* We have an operand. */
1320 mep_cgen_print_operand (cd
, CGEN_SYNTAX_FIELD (*syn
), info
,
1321 fields
, CGEN_INSN_ATTRS (insn
), pc
, length
);
1325 /* Subroutine of print_insn. Reads an insn into the given buffers and updates
1327 Returns 0 if all is well, non-zero otherwise. */
1330 read_insn (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED
,
1332 disassemble_info
*info
,
1335 CGEN_EXTRACT_INFO
*ex_info
,
1336 unsigned long *insn_value
)
1338 int status
= (*info
->read_memory_func
) (pc
, buf
, buflen
, info
);
1342 (*info
->memory_error_func
) (status
, pc
, info
);
1346 ex_info
->dis_info
= info
;
1347 ex_info
->valid
= (1 << buflen
) - 1;
1348 ex_info
->insn_bytes
= buf
;
1350 *insn_value
= bfd_get_bits (buf
, buflen
* 8, info
->endian
== BFD_ENDIAN_BIG
);
1354 /* Utility to print an insn.
1355 BUF is the base part of the insn, target byte order, BUFLEN bytes long.
1356 The result is the size of the insn in bytes or zero for an unknown insn
1357 or -1 if an error occurs fetching data (memory_error_func will have
1361 print_insn (CGEN_CPU_DESC cd
,
1363 disassemble_info
*info
,
1365 unsigned int buflen
)
1367 CGEN_INSN_INT insn_value
;
1368 const CGEN_INSN_LIST
*insn_list
;
1369 CGEN_EXTRACT_INFO ex_info
;
1372 /* Extract base part of instruction, just in case CGEN_DIS_* uses it. */
1373 basesize
= cd
->base_insn_bitsize
< buflen
* 8 ?
1374 cd
->base_insn_bitsize
: buflen
* 8;
1375 insn_value
= cgen_get_insn_value (cd
, buf
, basesize
);
1378 /* Fill in ex_info fields like read_insn would. Don't actually call
1379 read_insn, since the incoming buffer is already read (and possibly
1380 modified a la m32r). */
1381 ex_info
.valid
= (1 << buflen
) - 1;
1382 ex_info
.dis_info
= info
;
1383 ex_info
.insn_bytes
= buf
;
1385 /* The instructions are stored in hash lists.
1386 Pick the first one and keep trying until we find the right one. */
1388 insn_list
= CGEN_DIS_LOOKUP_INSN (cd
, (char *) buf
, insn_value
);
1389 while (insn_list
!= NULL
)
1391 const CGEN_INSN
*insn
= insn_list
->insn
;
1394 unsigned long insn_value_cropped
;
1396 #ifdef CGEN_VALIDATE_INSN_SUPPORTED
1397 /* Not needed as insn shouldn't be in hash lists if not supported. */
1398 /* Supported by this cpu? */
1399 if (! mep_cgen_insn_supported (cd
, insn
))
1401 insn_list
= CGEN_DIS_NEXT_INSN (insn_list
);
1406 /* Basic bit mask must be correct. */
1407 /* ??? May wish to allow target to defer this check until the extract
1410 /* Base size may exceed this instruction's size. Extract the
1411 relevant part from the buffer. */
1412 if ((unsigned) (CGEN_INSN_BITSIZE (insn
) / 8) < buflen
&&
1413 (unsigned) (CGEN_INSN_BITSIZE (insn
) / 8) <= sizeof (unsigned long))
1414 insn_value_cropped
= bfd_get_bits (buf
, CGEN_INSN_BITSIZE (insn
),
1415 info
->endian
== BFD_ENDIAN_BIG
);
1417 insn_value_cropped
= insn_value
;
1419 if ((insn_value_cropped
& CGEN_INSN_BASE_MASK (insn
))
1420 == CGEN_INSN_BASE_VALUE (insn
))
1422 /* Printing is handled in two passes. The first pass parses the
1423 machine insn and extracts the fields. The second pass prints
1426 /* Make sure the entire insn is loaded into insn_value, if it
1428 if (((unsigned) CGEN_INSN_BITSIZE (insn
) > cd
->base_insn_bitsize
) &&
1429 (unsigned) (CGEN_INSN_BITSIZE (insn
) / 8) <= sizeof (unsigned long))
1431 unsigned long full_insn_value
;
1432 int rc
= read_insn (cd
, pc
, info
, buf
,
1433 CGEN_INSN_BITSIZE (insn
) / 8,
1434 & ex_info
, & full_insn_value
);
1437 length
= CGEN_EXTRACT_FN (cd
, insn
)
1438 (cd
, insn
, &ex_info
, full_insn_value
, &fields
, pc
);
1441 length
= CGEN_EXTRACT_FN (cd
, insn
)
1442 (cd
, insn
, &ex_info
, insn_value_cropped
, &fields
, pc
);
1444 /* Length < 0 -> error. */
1449 CGEN_PRINT_FN (cd
, insn
) (cd
, info
, insn
, &fields
, pc
, length
);
1450 /* Length is in bits, result is in bytes. */
1455 insn_list
= CGEN_DIS_NEXT_INSN (insn_list
);
1461 /* Default value for CGEN_PRINT_INSN.
1462 The result is the size of the insn in bytes or zero for an unknown insn
1463 or -1 if an error occured fetching bytes. */
1465 #ifndef CGEN_PRINT_INSN
1466 #define CGEN_PRINT_INSN default_print_insn
1470 default_print_insn (CGEN_CPU_DESC cd
, bfd_vma pc
, disassemble_info
*info
)
1472 bfd_byte buf
[CGEN_MAX_INSN_SIZE
];
1476 /* Attempt to read the base part of the insn. */
1477 buflen
= cd
->base_insn_bitsize
/ 8;
1478 status
= (*info
->read_memory_func
) (pc
, buf
, buflen
, info
);
1480 /* Try again with the minimum part, if min < base. */
1481 if (status
!= 0 && (cd
->min_insn_bitsize
< cd
->base_insn_bitsize
))
1483 buflen
= cd
->min_insn_bitsize
/ 8;
1484 status
= (*info
->read_memory_func
) (pc
, buf
, buflen
, info
);
1489 (*info
->memory_error_func
) (status
, pc
, info
);
1493 return print_insn (cd
, pc
, info
, buf
, buflen
);
1496 /* Main entry point.
1497 Print one instruction from PC on INFO->STREAM.
1498 Return the size of the instruction (in bytes). */
1500 typedef struct cpu_desc_list
1502 struct cpu_desc_list
*next
;
1510 print_insn_mep (bfd_vma pc
, disassemble_info
*info
)
1512 static cpu_desc_list
*cd_list
= 0;
1513 cpu_desc_list
*cl
= 0;
1514 static CGEN_CPU_DESC cd
= 0;
1515 static CGEN_BITSET
*prev_isa
;
1516 static int prev_mach
;
1517 static int prev_endian
;
1521 int endian
= (info
->endian
== BFD_ENDIAN_BIG
1523 : CGEN_ENDIAN_LITTLE
);
1524 enum bfd_architecture arch
;
1526 /* ??? gdb will set mach but leave the architecture as "unknown" */
1527 #ifndef CGEN_BFD_ARCH
1528 #define CGEN_BFD_ARCH bfd_arch_mep
1531 if (arch
== bfd_arch_unknown
)
1532 arch
= CGEN_BFD_ARCH
;
1534 /* There's no standard way to compute the machine or isa number
1535 so we leave it to the target. */
1536 #ifdef CGEN_COMPUTE_MACH
1537 mach
= CGEN_COMPUTE_MACH (info
);
1542 #ifdef CGEN_COMPUTE_ISA
1544 static CGEN_BITSET
*permanent_isa
;
1547 permanent_isa
= cgen_bitset_create (MAX_ISAS
);
1548 isa
= permanent_isa
;
1549 cgen_bitset_clear (isa
);
1550 cgen_bitset_add (isa
, CGEN_COMPUTE_ISA (info
));
1553 isa
= info
->insn_sets
;
1556 /* If we've switched cpu's, try to find a handle we've used before */
1558 && (cgen_bitset_compare (isa
, prev_isa
) != 0
1559 || mach
!= prev_mach
1560 || endian
!= prev_endian
))
1563 for (cl
= cd_list
; cl
; cl
= cl
->next
)
1565 if (cgen_bitset_compare (cl
->isa
, isa
) == 0 &&
1567 cl
->endian
== endian
)
1570 prev_isa
= cd
->isas
;
1576 /* If we haven't initialized yet, initialize the opcode table. */
1579 const bfd_arch_info_type
*arch_type
= bfd_lookup_arch (arch
, mach
);
1580 const char *mach_name
;
1584 mach_name
= arch_type
->printable_name
;
1586 prev_isa
= cgen_bitset_copy (isa
);
1588 prev_endian
= endian
;
1589 cd
= mep_cgen_cpu_open (CGEN_CPU_OPEN_ISAS
, prev_isa
,
1590 CGEN_CPU_OPEN_BFDMACH
, mach_name
,
1591 CGEN_CPU_OPEN_ENDIAN
, prev_endian
,
1596 /* Save this away for future reference. */
1597 cl
= xmalloc (sizeof (struct cpu_desc_list
));
1601 cl
->endian
= endian
;
1605 mep_cgen_init_dis (cd
);
1608 /* We try to have as much common code as possible.
1609 But at this point some targets need to take over. */
1610 /* ??? Some targets may need a hook elsewhere. Try to avoid this,
1611 but if not possible try to move this hook elsewhere rather than
1613 length
= CGEN_PRINT_INSN (cd
, pc
, info
);
1619 (*info
->fprintf_func
) (info
->stream
, UNKNOWN_INSN_MSG
);
1620 return cd
->default_insn_bitsize
/ 8;