* dwarf.c (decode_location_expression, display_debug_frames): Move
[binutils.git] / opcodes / bfin-dis.c
blobebacd4618f9604dece3900f78ab3c1810cbcc648
1 /* Disassemble ADI Blackfin Instructions.
2 Copyright 2005, 2006, 2007, 2008, 2009, 2010 Free Software Foundation, Inc.
4 This file is part of libopcodes.
6 This library is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3, or (at your option)
9 any later version.
11 It is distributed in the hope that it will be useful, but WITHOUT
12 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
13 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
14 License for more details.
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
19 MA 02110-1301, USA. */
21 #include <stdio.h>
22 #include <stdlib.h>
23 #include <string.h>
25 #include "opcode/bfin.h"
27 #define M_S2RND 1
28 #define M_T 2
29 #define M_W32 3
30 #define M_FU 4
31 #define M_TFU 6
32 #define M_IS 8
33 #define M_ISS2 9
34 #define M_IH 11
35 #define M_IU 12
37 #ifndef PRINTF
38 #define PRINTF printf
39 #endif
41 #ifndef EXIT
42 #define EXIT exit
43 #endif
45 typedef long TIword;
47 #define HOST_LONG_WORD_SIZE (sizeof (long) * 8)
48 #define XFIELD(w,p,s) (((w) & ((1 << (s)) - 1) << (p)) >> (p))
49 #define SIGNEXTEND(v, n) ((v << (HOST_LONG_WORD_SIZE - (n))) >> (HOST_LONG_WORD_SIZE - (n)))
50 #define MASKBITS(val, bits) (val & ((1 << bits) - 1))
52 #include "dis-asm.h"
54 typedef unsigned int bu32;
56 static char comment = 0;
57 static char parallel = 0;
59 typedef enum
61 c_0, c_1, c_4, c_2, c_uimm2, c_uimm3, c_imm3, c_pcrel4,
62 c_imm4, c_uimm4s4, c_uimm4s4d, c_uimm4, c_uimm4s2, c_negimm5s4, c_imm5, c_imm5d, c_uimm5, c_imm6,
63 c_imm7, c_imm7d, c_imm8, c_uimm8, c_pcrel8, c_uimm8s4, c_pcrel8s4, c_lppcrel10, c_pcrel10,
64 c_pcrel12, c_imm16s4, c_luimm16, c_imm16, c_imm16d, c_huimm16, c_rimm16, c_imm16s2, c_uimm16s4,
65 c_uimm16s4d, c_uimm16, c_pcrel24, c_uimm32, c_imm32, c_huimm32, c_huimm32e,
66 } const_forms_t;
68 static const struct
70 const char *name;
71 const int nbits;
72 const char reloc;
73 const char issigned;
74 const char pcrel;
75 const char scale;
76 const char offset;
77 const char negative;
78 const char positive;
79 const char decimal;
80 const char leading;
81 const char exact;
82 } constant_formats[] =
84 { "0", 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
85 { "1", 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
86 { "4", 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
87 { "2", 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
88 { "uimm2", 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
89 { "uimm3", 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
90 { "imm3", 3, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
91 { "pcrel4", 4, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0},
92 { "imm4", 4, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
93 { "uimm4s4", 4, 0, 0, 0, 2, 0, 0, 1, 0, 0, 0},
94 { "uimm4s4d", 4, 0, 0, 0, 2, 0, 0, 1, 1, 0, 0},
95 { "uimm4", 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
96 { "uimm4s2", 4, 0, 0, 0, 1, 0, 0, 1, 0, 0, 0},
97 { "negimm5s4", 5, 0, 1, 0, 2, 0, 1, 0, 0, 0, 0},
98 { "imm5", 5, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
99 { "imm5d", 5, 0, 1, 0, 0, 0, 0, 0, 1, 0, 0},
100 { "uimm5", 5, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
101 { "imm6", 6, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
102 { "imm7", 7, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
103 { "imm7d", 7, 0, 1, 0, 0, 0, 0, 0, 1, 3, 0},
104 { "imm8", 8, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
105 { "uimm8", 8, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
106 { "pcrel8", 8, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0},
107 { "uimm8s4", 8, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0},
108 { "pcrel8s4", 8, 1, 1, 1, 2, 0, 0, 0, 0, 0, 0},
109 { "lppcrel10", 10, 1, 0, 1, 1, 0, 0, 0, 0, 0, 0},
110 { "pcrel10", 10, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0},
111 { "pcrel12", 12, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0},
112 { "imm16s4", 16, 0, 1, 0, 2, 0, 0, 0, 0, 0, 0},
113 { "luimm16", 16, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0},
114 { "imm16", 16, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0},
115 { "imm16d", 16, 0, 1, 0, 0, 0, 0, 0, 1, 3, 0},
116 { "huimm16", 16, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0},
117 { "rimm16", 16, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0},
118 { "imm16s2", 16, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0},
119 { "uimm16s4", 16, 0, 0, 0, 2, 0, 0, 0, 0, 0, 0},
120 { "uimm16s4d", 16, 0, 0, 0, 2, 0, 0, 0, 1, 0, 0},
121 { "uimm16", 16, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
122 { "pcrel24", 24, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0},
123 { "uimm32", 32, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0},
124 { "imm32", 32, 0, 1, 0, 0, 0, 0, 0, 1, 3, 0},
125 { "huimm32", 32, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0},
126 { "huimm32e", 32, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1},
129 static const char *
130 fmtconst (const_forms_t cf, TIword x, bfd_vma pc, disassemble_info *outf)
132 static char buf[60];
134 if (constant_formats[cf].reloc)
136 bfd_vma ea = (((constant_formats[cf].pcrel ? SIGNEXTEND (x, constant_formats[cf].nbits)
137 : x) + constant_formats[cf].offset) << constant_formats[cf].scale);
138 if (constant_formats[cf].pcrel)
139 ea += pc;
141 /* truncate to 32-bits for proper symbol lookup/matching */
142 ea = (bu32)ea;
144 if (outf->symbol_at_address_func (ea, outf) || !constant_formats[cf].exact)
146 outf->print_address_func (ea, outf);
147 return "";
149 else
151 sprintf (buf, "%lx", (unsigned long) x);
152 return buf;
156 /* Negative constants have an implied sign bit. */
157 if (constant_formats[cf].negative)
159 int nb = constant_formats[cf].nbits + 1;
161 x = x | (1 << constant_formats[cf].nbits);
162 x = SIGNEXTEND (x, nb);
164 else
165 x = constant_formats[cf].issigned ? SIGNEXTEND (x, constant_formats[cf].nbits) : x;
167 if (constant_formats[cf].offset)
168 x += constant_formats[cf].offset;
170 if (constant_formats[cf].scale)
171 x <<= constant_formats[cf].scale;
173 if (constant_formats[cf].decimal)
175 if (constant_formats[cf].leading)
177 char ps[10];
178 sprintf (ps, "%%%ii", constant_formats[cf].leading);
179 sprintf (buf, ps, x);
181 else
182 sprintf (buf, "%li", x);
184 else
186 if (constant_formats[cf].issigned && x < 0)
187 sprintf (buf, "-0x%x", abs (x));
188 else
189 sprintf (buf, "0x%lx", (unsigned long) x);
192 return buf;
195 static bu32
196 fmtconst_val (const_forms_t cf, unsigned int x, unsigned int pc)
198 if (0 && constant_formats[cf].reloc)
200 bu32 ea = (((constant_formats[cf].pcrel
201 ? SIGNEXTEND (x, constant_formats[cf].nbits)
202 : x) + constant_formats[cf].offset)
203 << constant_formats[cf].scale);
204 if (constant_formats[cf].pcrel)
205 ea += pc;
207 return ea;
210 /* Negative constants have an implied sign bit. */
211 if (constant_formats[cf].negative)
213 int nb = constant_formats[cf].nbits + 1;
214 x = x | (1 << constant_formats[cf].nbits);
215 x = SIGNEXTEND (x, nb);
217 else if (constant_formats[cf].issigned)
218 x = SIGNEXTEND (x, constant_formats[cf].nbits);
220 x += constant_formats[cf].offset;
221 x <<= constant_formats[cf].scale;
223 return x;
226 enum machine_registers
228 REG_RL0, REG_RL1, REG_RL2, REG_RL3, REG_RL4, REG_RL5, REG_RL6, REG_RL7,
229 REG_RH0, REG_RH1, REG_RH2, REG_RH3, REG_RH4, REG_RH5, REG_RH6, REG_RH7,
230 REG_R0, REG_R1, REG_R2, REG_R3, REG_R4, REG_R5, REG_R6, REG_R7,
231 REG_R1_0, REG_R3_2, REG_R5_4, REG_R7_6, REG_P0, REG_P1, REG_P2, REG_P3,
232 REG_P4, REG_P5, REG_SP, REG_FP, REG_A0x, REG_A1x, REG_A0w, REG_A1w,
233 REG_A0, REG_A1, REG_I0, REG_I1, REG_I2, REG_I3, REG_M0, REG_M1,
234 REG_M2, REG_M3, REG_B0, REG_B1, REG_B2, REG_B3, REG_L0, REG_L1,
235 REG_L2, REG_L3,
236 REG_AZ, REG_AN, REG_AC0, REG_AC1, REG_AV0, REG_AV1, REG_AV0S, REG_AV1S,
237 REG_AQ, REG_V, REG_VS,
238 REG_sftreset, REG_omode, REG_excause, REG_emucause, REG_idle_req, REG_hwerrcause, REG_CC, REG_LC0,
239 REG_LC1, REG_GP, REG_ASTAT, REG_RETS, REG_LT0, REG_LB0, REG_LT1, REG_LB1,
240 REG_CYCLES, REG_CYCLES2, REG_USP, REG_SEQSTAT, REG_SYSCFG, REG_RETI, REG_RETX, REG_RETN,
241 REG_RETE, REG_EMUDAT, REG_BR0, REG_BR1, REG_BR2, REG_BR3, REG_BR4, REG_BR5, REG_BR6,
242 REG_BR7, REG_PL0, REG_PL1, REG_PL2, REG_PL3, REG_PL4, REG_PL5, REG_SLP, REG_FLP,
243 REG_PH0, REG_PH1, REG_PH2, REG_PH3, REG_PH4, REG_PH5, REG_SHP, REG_FHP,
244 REG_IL0, REG_IL1, REG_IL2, REG_IL3, REG_ML0, REG_ML1, REG_ML2, REG_ML3,
245 REG_BL0, REG_BL1, REG_BL2, REG_BL3, REG_LL0, REG_LL1, REG_LL2, REG_LL3,
246 REG_IH0, REG_IH1, REG_IH2, REG_IH3, REG_MH0, REG_MH1, REG_MH2, REG_MH3,
247 REG_BH0, REG_BH1, REG_BH2, REG_BH3, REG_LH0, REG_LH1, REG_LH2, REG_LH3,
248 REG_AC0_COPY, REG_V_COPY, REG_RND_MOD,
249 REG_LASTREG,
252 enum reg_class
254 rc_dregs_lo, rc_dregs_hi, rc_dregs, rc_dregs_pair, rc_pregs, rc_spfp, rc_dregs_hilo, rc_accum_ext,
255 rc_accum_word, rc_accum, rc_iregs, rc_mregs, rc_bregs, rc_lregs, rc_dpregs, rc_gregs,
256 rc_regs, rc_statbits, rc_ignore_bits, rc_ccstat, rc_counters, rc_dregs2_sysregs1, rc_open, rc_sysregs2,
257 rc_sysregs3, rc_allregs,
258 LIM_REG_CLASSES
261 static const char *reg_names[] =
263 "R0.L", "R1.L", "R2.L", "R3.L", "R4.L", "R5.L", "R6.L", "R7.L",
264 "R0.H", "R1.H", "R2.H", "R3.H", "R4.H", "R5.H", "R6.H", "R7.H",
265 "R0", "R1", "R2", "R3", "R4", "R5", "R6", "R7",
266 "R1:0", "R3:2", "R5:4", "R7:6", "P0", "P1", "P2", "P3",
267 "P4", "P5", "SP", "FP", "A0.X", "A1.X", "A0.W", "A1.W",
268 "A0", "A1", "I0", "I1", "I2", "I3", "M0", "M1",
269 "M2", "M3", "B0", "B1", "B2", "B3", "L0", "L1",
270 "L2", "L3",
271 "AZ", "AN", "AC0", "AC1", "AV0", "AV1", "AV0S", "AV1S",
272 "AQ", "V", "VS",
273 "sftreset", "omode", "excause", "emucause", "idle_req", "hwerrcause", "CC", "LC0",
274 "LC1", "GP", "ASTAT", "RETS", "LT0", "LB0", "LT1", "LB1",
275 "CYCLES", "CYCLES2", "USP", "SEQSTAT", "SYSCFG", "RETI", "RETX", "RETN",
276 "RETE", "EMUDAT",
277 "R0.B", "R1.B", "R2.B", "R3.B", "R4.B", "R5.B", "R6.B", "R7.B",
278 "P0.L", "P1.L", "P2.L", "P3.L", "P4.L", "P5.L", "SP.L", "FP.L",
279 "P0.H", "P1.H", "P2.H", "P3.H", "P4.H", "P5.H", "SP.H", "FP.H",
280 "I0.L", "I1.L", "I2.L", "I3.L", "M0.L", "M1.L", "M2.L", "M3.L",
281 "B0.L", "B1.L", "B2.L", "B3.L", "L0.L", "L1.L", "L2.L", "L3.L",
282 "I0.H", "I1.H", "I2.H", "I3.H", "M0.H", "M1.H", "M2.H", "M3.H",
283 "B0.H", "B1.H", "B2.H", "B3.H", "L0.H", "L1.H", "L2.H", "L3.H",
284 "AC0_COPY", "V_COPY", "RND_MOD",
285 "LASTREG",
289 #define REGNAME(x) ((x) < REG_LASTREG ? (reg_names[x]) : "...... Illegal register .......")
291 /* RL(0..7). */
292 static enum machine_registers decode_dregs_lo[] =
294 REG_RL0, REG_RL1, REG_RL2, REG_RL3, REG_RL4, REG_RL5, REG_RL6, REG_RL7,
297 #define dregs_lo(x) REGNAME (decode_dregs_lo[(x) & 7])
299 /* RH(0..7). */
300 static enum machine_registers decode_dregs_hi[] =
302 REG_RH0, REG_RH1, REG_RH2, REG_RH3, REG_RH4, REG_RH5, REG_RH6, REG_RH7,
305 #define dregs_hi(x) REGNAME (decode_dregs_hi[(x) & 7])
307 /* R(0..7). */
308 static enum machine_registers decode_dregs[] =
310 REG_R0, REG_R1, REG_R2, REG_R3, REG_R4, REG_R5, REG_R6, REG_R7,
313 #define dregs(x) REGNAME (decode_dregs[(x) & 7])
315 /* R BYTE(0..7). */
316 static enum machine_registers decode_dregs_byte[] =
318 REG_BR0, REG_BR1, REG_BR2, REG_BR3, REG_BR4, REG_BR5, REG_BR6, REG_BR7,
321 #define dregs_byte(x) REGNAME (decode_dregs_byte[(x) & 7])
323 /* P(0..5) SP FP. */
324 static enum machine_registers decode_pregs[] =
326 REG_P0, REG_P1, REG_P2, REG_P3, REG_P4, REG_P5, REG_SP, REG_FP,
329 #define pregs(x) REGNAME (decode_pregs[(x) & 7])
330 #define spfp(x) REGNAME (decode_spfp[(x) & 1])
331 #define dregs_hilo(x,i) REGNAME (decode_dregs_hilo[((i) << 3)|x])
332 #define accum_ext(x) REGNAME (decode_accum_ext[(x) & 1])
333 #define accum_word(x) REGNAME (decode_accum_word[(x) & 1])
334 #define accum(x) REGNAME (decode_accum[(x) & 1])
336 /* I(0..3). */
337 static enum machine_registers decode_iregs[] =
339 REG_I0, REG_I1, REG_I2, REG_I3,
342 #define iregs(x) REGNAME (decode_iregs[(x) & 3])
344 /* M(0..3). */
345 static enum machine_registers decode_mregs[] =
347 REG_M0, REG_M1, REG_M2, REG_M3,
350 #define mregs(x) REGNAME (decode_mregs[(x) & 3])
351 #define bregs(x) REGNAME (decode_bregs[(x) & 3])
352 #define lregs(x) REGNAME (decode_lregs[(x) & 3])
354 /* dregs pregs. */
355 static enum machine_registers decode_dpregs[] =
357 REG_R0, REG_R1, REG_R2, REG_R3, REG_R4, REG_R5, REG_R6, REG_R7,
358 REG_P0, REG_P1, REG_P2, REG_P3, REG_P4, REG_P5, REG_SP, REG_FP,
361 #define dpregs(x) REGNAME (decode_dpregs[(x) & 15])
363 /* [dregs pregs]. */
364 static enum machine_registers decode_gregs[] =
366 REG_R0, REG_R1, REG_R2, REG_R3, REG_R4, REG_R5, REG_R6, REG_R7,
367 REG_P0, REG_P1, REG_P2, REG_P3, REG_P4, REG_P5, REG_SP, REG_FP,
370 #define gregs(x,i) REGNAME (decode_gregs[((i) << 3)|x])
372 /* [dregs pregs (iregs mregs) (bregs lregs)]. */
373 static enum machine_registers decode_regs[] =
375 REG_R0, REG_R1, REG_R2, REG_R3, REG_R4, REG_R5, REG_R6, REG_R7,
376 REG_P0, REG_P1, REG_P2, REG_P3, REG_P4, REG_P5, REG_SP, REG_FP,
377 REG_I0, REG_I1, REG_I2, REG_I3, REG_M0, REG_M1, REG_M2, REG_M3,
378 REG_B0, REG_B1, REG_B2, REG_B3, REG_L0, REG_L1, REG_L2, REG_L3,
381 #define regs(x,i) REGNAME (decode_regs[((i) << 3)|x])
383 /* [dregs pregs (iregs mregs) (bregs lregs) Low Half]. */
384 static enum machine_registers decode_regs_lo[] =
386 REG_RL0, REG_RL1, REG_RL2, REG_RL3, REG_RL4, REG_RL5, REG_RL6, REG_RL7,
387 REG_PL0, REG_PL1, REG_PL2, REG_PL3, REG_PL4, REG_PL5, REG_SLP, REG_FLP,
388 REG_IL0, REG_IL1, REG_IL2, REG_IL3, REG_ML0, REG_ML1, REG_ML2, REG_ML3,
389 REG_BL0, REG_BL1, REG_BL2, REG_BL3, REG_LL0, REG_LL1, REG_LL2, REG_LL3,
392 #define regs_lo(x,i) REGNAME (decode_regs_lo[((i) << 3)|x])
393 /* [dregs pregs (iregs mregs) (bregs lregs) High Half]. */
394 static enum machine_registers decode_regs_hi[] =
396 REG_RH0, REG_RH1, REG_RH2, REG_RH3, REG_RH4, REG_RH5, REG_RH6, REG_RH7,
397 REG_PH0, REG_PH1, REG_PH2, REG_PH3, REG_PH4, REG_PH5, REG_SHP, REG_FHP,
398 REG_IH0, REG_IH1, REG_IH2, REG_IH3, REG_MH0, REG_MH1, REG_MH2, REG_MH3,
399 REG_BH0, REG_BH1, REG_BH2, REG_BH3, REG_LH0, REG_LH1, REG_LH2, REG_LH3,
402 #define regs_hi(x,i) REGNAME (decode_regs_hi[((i) << 3)|x])
404 static enum machine_registers decode_statbits[] =
406 REG_AZ, REG_AN, REG_AC0_COPY, REG_V_COPY,
407 REG_LASTREG, REG_LASTREG, REG_AQ, REG_LASTREG,
408 REG_RND_MOD, REG_LASTREG, REG_LASTREG, REG_LASTREG,
409 REG_AC0, REG_AC1, REG_LASTREG, REG_LASTREG,
410 REG_AV0, REG_AV0S, REG_AV1, REG_AV1S,
411 REG_LASTREG, REG_LASTREG, REG_LASTREG, REG_LASTREG,
412 REG_V, REG_VS, REG_LASTREG, REG_LASTREG,
413 REG_LASTREG, REG_LASTREG, REG_LASTREG, REG_LASTREG,
416 #define statbits(x) REGNAME (decode_statbits[(x) & 31])
418 /* LC0 LC1. */
419 static enum machine_registers decode_counters[] =
421 REG_LC0, REG_LC1,
424 #define counters(x) REGNAME (decode_counters[(x) & 1])
425 #define dregs2_sysregs1(x) REGNAME (decode_dregs2_sysregs1[(x) & 7])
427 /* [dregs pregs (iregs mregs) (bregs lregs)
428 dregs2_sysregs1 open sysregs2 sysregs3]. */
429 static enum machine_registers decode_allregs[] =
431 REG_R0, REG_R1, REG_R2, REG_R3, REG_R4, REG_R5, REG_R6, REG_R7,
432 REG_P0, REG_P1, REG_P2, REG_P3, REG_P4, REG_P5, REG_SP, REG_FP,
433 REG_I0, REG_I1, REG_I2, REG_I3, REG_M0, REG_M1, REG_M2, REG_M3,
434 REG_B0, REG_B1, REG_B2, REG_B3, REG_L0, REG_L1, REG_L2, REG_L3,
435 REG_A0x, REG_A0w, REG_A1x, REG_A1w, REG_GP, REG_LASTREG, REG_ASTAT, REG_RETS,
436 REG_LASTREG, REG_LASTREG, REG_LASTREG, REG_LASTREG, REG_LASTREG, REG_LASTREG, REG_LASTREG, REG_LASTREG,
437 REG_LC0, REG_LT0, REG_LB0, REG_LC1, REG_LT1, REG_LB1, REG_CYCLES, REG_CYCLES2,
438 REG_USP, REG_SEQSTAT, REG_SYSCFG, REG_RETI, REG_RETX, REG_RETN, REG_RETE, REG_EMUDAT,
439 REG_LASTREG,
442 #define IS_DREG(g,r) ((g) == 0 && (r) < 8)
443 #define IS_PREG(g,r) ((g) == 1 && (r) < 8)
444 #define IS_AREG(g,r) ((g) == 4 && (r) >= 0 && (r) < 4)
445 #define IS_GENREG(g,r) ((((g) == 0 || (g) == 1) && (r) < 8) || IS_AREG (g, r))
446 #define IS_DAGREG(g,r) (((g) == 2 || (g) == 3) && (r) < 8)
447 #define IS_SYSREG(g,r) \
448 (((g) == 4 && ((r) == 6 || (r) == 7)) || (g) == 6 || (g) == 7)
449 #define IS_RESERVEDREG(g,r) \
450 (((r) > 7) || ((g) == 4 && ((r) == 4 || (r) == 5)) || (g) == 5)
452 #define allreg(r,g) (!IS_RESERVEDREG (g, r))
453 #define mostreg(r,g) (!(IS_DREG (g, r) || IS_PREG (g, r) || IS_RESERVEDREG (g, r)))
455 #define allregs(x,i) REGNAME (decode_allregs[((i) << 3) | x])
456 #define uimm16s4(x) fmtconst (c_uimm16s4, x, 0, outf)
457 #define uimm16s4d(x) fmtconst (c_uimm16s4d, x, 0, outf)
458 #define pcrel4(x) fmtconst (c_pcrel4, x, pc, outf)
459 #define pcrel8(x) fmtconst (c_pcrel8, x, pc, outf)
460 #define pcrel8s4(x) fmtconst (c_pcrel8s4, x, pc, outf)
461 #define pcrel10(x) fmtconst (c_pcrel10, x, pc, outf)
462 #define pcrel12(x) fmtconst (c_pcrel12, x, pc, outf)
463 #define negimm5s4(x) fmtconst (c_negimm5s4, x, 0, outf)
464 #define rimm16(x) fmtconst (c_rimm16, x, 0, outf)
465 #define huimm16(x) fmtconst (c_huimm16, x, 0, outf)
466 #define imm16(x) fmtconst (c_imm16, x, 0, outf)
467 #define imm16d(x) fmtconst (c_imm16d, x, 0, outf)
468 #define uimm2(x) fmtconst (c_uimm2, x, 0, outf)
469 #define uimm3(x) fmtconst (c_uimm3, x, 0, outf)
470 #define luimm16(x) fmtconst (c_luimm16, x, 0, outf)
471 #define uimm4(x) fmtconst (c_uimm4, x, 0, outf)
472 #define uimm5(x) fmtconst (c_uimm5, x, 0, outf)
473 #define imm16s2(x) fmtconst (c_imm16s2, x, 0, outf)
474 #define uimm8(x) fmtconst (c_uimm8, x, 0, outf)
475 #define imm16s4(x) fmtconst (c_imm16s4, x, 0, outf)
476 #define uimm4s2(x) fmtconst (c_uimm4s2, x, 0, outf)
477 #define uimm4s4(x) fmtconst (c_uimm4s4, x, 0, outf)
478 #define uimm4s4d(x) fmtconst (c_uimm4s4d, x, 0, outf)
479 #define lppcrel10(x) fmtconst (c_lppcrel10, x, pc, outf)
480 #define imm3(x) fmtconst (c_imm3, x, 0, outf)
481 #define imm4(x) fmtconst (c_imm4, x, 0, outf)
482 #define uimm8s4(x) fmtconst (c_uimm8s4, x, 0, outf)
483 #define imm5(x) fmtconst (c_imm5, x, 0, outf)
484 #define imm5d(x) fmtconst (c_imm5d, x, 0, outf)
485 #define imm6(x) fmtconst (c_imm6, x, 0, outf)
486 #define imm7(x) fmtconst (c_imm7, x, 0, outf)
487 #define imm7d(x) fmtconst (c_imm7d, x, 0, outf)
488 #define imm8(x) fmtconst (c_imm8, x, 0, outf)
489 #define pcrel24(x) fmtconst (c_pcrel24, x, pc, outf)
490 #define uimm16(x) fmtconst (c_uimm16, x, 0, outf)
491 #define uimm32(x) fmtconst (c_uimm32, x, 0, outf)
492 #define imm32(x) fmtconst (c_imm32, x, 0, outf)
493 #define huimm32(x) fmtconst (c_huimm32, x, 0, outf)
494 #define huimm32e(x) fmtconst (c_huimm32e, x, 0, outf)
495 #define imm7_val(x) fmtconst_val (c_imm7, x, 0)
496 #define imm16_val(x) fmtconst_val (c_uimm16, x, 0)
497 #define luimm16_val(x) fmtconst_val (c_luimm16, x, 0)
499 /* (arch.pm)arch_disassembler_functions. */
500 #ifndef OUTS
501 #define OUTS(p, txt) ((p) ? (((txt)[0]) ? (p->fprintf_func)(p->stream, "%s", txt) :0) :0)
502 #endif
504 static void
505 amod0 (int s0, int x0, disassemble_info *outf)
507 if (s0 == 1 && x0 == 0)
508 OUTS (outf, " (S)");
509 else if (s0 == 0 && x0 == 1)
510 OUTS (outf, " (CO)");
511 else if (s0 == 1 && x0 == 1)
512 OUTS (outf, " (SCO)");
515 static void
516 amod1 (int s0, int x0, disassemble_info *outf)
518 if (s0 == 0 && x0 == 0)
519 OUTS (outf, " (NS)");
520 else if (s0 == 1 && x0 == 0)
521 OUTS (outf, " (S)");
524 static void
525 amod0amod2 (int s0, int x0, int aop0, disassemble_info *outf)
527 if (s0 == 1 && x0 == 0 && aop0 == 0)
528 OUTS (outf, " (S)");
529 else if (s0 == 0 && x0 == 1 && aop0 == 0)
530 OUTS (outf, " (CO)");
531 else if (s0 == 1 && x0 == 1 && aop0 == 0)
532 OUTS (outf, " (SCO)");
533 else if (s0 == 0 && x0 == 0 && aop0 == 2)
534 OUTS (outf, " (ASR)");
535 else if (s0 == 1 && x0 == 0 && aop0 == 2)
536 OUTS (outf, " (S, ASR)");
537 else if (s0 == 0 && x0 == 1 && aop0 == 2)
538 OUTS (outf, " (CO, ASR)");
539 else if (s0 == 1 && x0 == 1 && aop0 == 2)
540 OUTS (outf, " (SCO, ASR)");
541 else if (s0 == 0 && x0 == 0 && aop0 == 3)
542 OUTS (outf, " (ASL)");
543 else if (s0 == 1 && x0 == 0 && aop0 == 3)
544 OUTS (outf, " (S, ASL)");
545 else if (s0 == 0 && x0 == 1 && aop0 == 3)
546 OUTS (outf, " (CO, ASL)");
547 else if (s0 == 1 && x0 == 1 && aop0 == 3)
548 OUTS (outf, " (SCO, ASL)");
551 static void
552 searchmod (int r0, disassemble_info *outf)
554 if (r0 == 0)
555 OUTS (outf, "GT");
556 else if (r0 == 1)
557 OUTS (outf, "GE");
558 else if (r0 == 2)
559 OUTS (outf, "LT");
560 else if (r0 == 3)
561 OUTS (outf, "LE");
564 static void
565 aligndir (int r0, disassemble_info *outf)
567 if (r0 == 1)
568 OUTS (outf, " (R)");
571 static int
572 decode_multfunc (int h0, int h1, int src0, int src1, disassemble_info * outf)
574 const char *s0, *s1;
576 if (h0)
577 s0 = dregs_hi (src0);
578 else
579 s0 = dregs_lo (src0);
581 if (h1)
582 s1 = dregs_hi (src1);
583 else
584 s1 = dregs_lo (src1);
586 OUTS (outf, s0);
587 OUTS (outf, " * ");
588 OUTS (outf, s1);
589 return 0;
592 static int
593 decode_macfunc (int which, int op, int h0, int h1, int src0, int src1, disassemble_info * outf)
595 const char *a;
596 const char *sop = "<unknown op>";
598 if (which)
599 a = "A1";
600 else
601 a = "A0";
603 if (op == 3)
605 OUTS (outf, a);
606 return 0;
609 switch (op)
611 case 0: sop = " = "; break;
612 case 1: sop = " += "; break;
613 case 2: sop = " -= "; break;
614 default: break;
617 OUTS (outf, a);
618 OUTS (outf, sop);
619 decode_multfunc (h0, h1, src0, src1, outf);
621 return 0;
624 static void
625 decode_optmode (int mod, int MM, disassemble_info *outf)
627 if (mod == 0 && MM == 0)
628 return;
630 OUTS (outf, " (");
632 if (MM && !mod)
634 OUTS (outf, "M)");
635 return;
638 if (MM)
639 OUTS (outf, "M, ");
641 if (mod == M_S2RND)
642 OUTS (outf, "S2RND");
643 else if (mod == M_T)
644 OUTS (outf, "T");
645 else if (mod == M_W32)
646 OUTS (outf, "W32");
647 else if (mod == M_FU)
648 OUTS (outf, "FU");
649 else if (mod == M_TFU)
650 OUTS (outf, "TFU");
651 else if (mod == M_IS)
652 OUTS (outf, "IS");
653 else if (mod == M_ISS2)
654 OUTS (outf, "ISS2");
655 else if (mod == M_IH)
656 OUTS (outf, "IH");
657 else if (mod == M_IU)
658 OUTS (outf, "IU");
659 else
660 abort ();
662 OUTS (outf, ")");
665 struct saved_state
667 bu32 dpregs[16], iregs[4], mregs[4], bregs[4], lregs[4];
668 bu32 a0x, a0w, a1x, a1w;
669 bu32 lt[2], lc[2], lb[2];
670 int ac0, ac0_copy, ac1, an, aq;
671 int av0, av0s, av1, av1s, az, cc, v, v_copy, vs;
672 int rnd_mod;
673 int v_internal;
674 bu32 pc, rets;
676 int ticks;
677 int insts;
679 int exception;
681 int end_of_registers;
683 int msize;
684 unsigned char *memory;
685 unsigned long bfd_mach;
686 } saved_state;
688 #define DREG(x) (saved_state.dpregs[x])
689 #define GREG(x,i) DPREG ((x) | (i << 3))
690 #define DPREG(x) (saved_state.dpregs[x])
691 #define DREG(x) (saved_state.dpregs[x])
692 #define PREG(x) (saved_state.dpregs[x + 8])
693 #define SPREG PREG (6)
694 #define FPREG PREG (7)
695 #define IREG(x) (saved_state.iregs[x])
696 #define MREG(x) (saved_state.mregs[x])
697 #define BREG(x) (saved_state.bregs[x])
698 #define LREG(x) (saved_state.lregs[x])
699 #define A0XREG (saved_state.a0x)
700 #define A0WREG (saved_state.a0w)
701 #define A1XREG (saved_state.a1x)
702 #define A1WREG (saved_state.a1w)
703 #define CCREG (saved_state.cc)
704 #define LC0REG (saved_state.lc[0])
705 #define LT0REG (saved_state.lt[0])
706 #define LB0REG (saved_state.lb[0])
707 #define LC1REG (saved_state.lc[1])
708 #define LT1REG (saved_state.lt[1])
709 #define LB1REG (saved_state.lb[1])
710 #define RETSREG (saved_state.rets)
711 #define PCREG (saved_state.pc)
713 static bu32 *
714 get_allreg (int grp, int reg)
716 int fullreg = (grp << 3) | reg;
717 /* REG_R0, REG_R1, REG_R2, REG_R3, REG_R4, REG_R5, REG_R6, REG_R7,
718 REG_P0, REG_P1, REG_P2, REG_P3, REG_P4, REG_P5, REG_SP, REG_FP,
719 REG_I0, REG_I1, REG_I2, REG_I3, REG_M0, REG_M1, REG_M2, REG_M3,
720 REG_B0, REG_B1, REG_B2, REG_B3, REG_L0, REG_L1, REG_L2, REG_L3,
721 REG_A0x, REG_A0w, REG_A1x, REG_A1w, , , REG_ASTAT, REG_RETS,
722 , , , , , , , ,
723 REG_LC0, REG_LT0, REG_LB0, REG_LC1, REG_LT1, REG_LB1, REG_CYCLES,
724 REG_CYCLES2,
725 REG_USP, REG_SEQSTAT, REG_SYSCFG, REG_RETI, REG_RETX, REG_RETN, REG_RETE,
726 REG_LASTREG */
727 switch (fullreg >> 2)
729 case 0: case 1: return &DREG (reg); break;
730 case 2: case 3: return &PREG (reg); break;
731 case 4: return &IREG (reg & 3); break;
732 case 5: return &MREG (reg & 3); break;
733 case 6: return &BREG (reg & 3); break;
734 case 7: return &LREG (reg & 3); break;
735 default:
736 switch (fullreg)
738 case 32: return &saved_state.a0x;
739 case 33: return &saved_state.a0w;
740 case 34: return &saved_state.a1x;
741 case 35: return &saved_state.a1w;
742 case 39: return &saved_state.rets;
743 case 48: return &LC0REG;
744 case 49: return &LT0REG;
745 case 50: return &LB0REG;
746 case 51: return &LC1REG;
747 case 52: return &LT1REG;
748 case 53: return &LB1REG;
750 return 0;
754 static int
755 decode_ProgCtrl_0 (TIword iw0, disassemble_info *outf)
757 /* ProgCtrl
758 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
759 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |.prgfunc.......|.poprnd........|
760 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
761 int poprnd = ((iw0 >> ProgCtrl_poprnd_bits) & ProgCtrl_poprnd_mask);
762 int prgfunc = ((iw0 >> ProgCtrl_prgfunc_bits) & ProgCtrl_prgfunc_mask);
764 if (prgfunc == 0 && poprnd == 0)
765 OUTS (outf, "NOP");
766 else if (parallel)
767 return 0;
768 else if (prgfunc == 1 && poprnd == 0)
769 OUTS (outf, "RTS");
770 else if (prgfunc == 1 && poprnd == 1)
771 OUTS (outf, "RTI");
772 else if (prgfunc == 1 && poprnd == 2)
773 OUTS (outf, "RTX");
774 else if (prgfunc == 1 && poprnd == 3)
775 OUTS (outf, "RTN");
776 else if (prgfunc == 1 && poprnd == 4)
777 OUTS (outf, "RTE");
778 else if (prgfunc == 2 && poprnd == 0)
779 OUTS (outf, "IDLE");
780 else if (prgfunc == 2 && poprnd == 3)
781 OUTS (outf, "CSYNC");
782 else if (prgfunc == 2 && poprnd == 4)
783 OUTS (outf, "SSYNC");
784 else if (prgfunc == 2 && poprnd == 5)
785 OUTS (outf, "EMUEXCPT");
786 else if (prgfunc == 3 && IS_DREG (0, poprnd))
788 OUTS (outf, "CLI ");
789 OUTS (outf, dregs (poprnd));
791 else if (prgfunc == 4 && IS_DREG (0, poprnd))
793 OUTS (outf, "STI ");
794 OUTS (outf, dregs (poprnd));
796 else if (prgfunc == 5 && IS_PREG (1, poprnd))
798 OUTS (outf, "JUMP (");
799 OUTS (outf, pregs (poprnd));
800 OUTS (outf, ")");
802 else if (prgfunc == 6 && IS_PREG (1, poprnd))
804 OUTS (outf, "CALL (");
805 OUTS (outf, pregs (poprnd));
806 OUTS (outf, ")");
808 else if (prgfunc == 7 && IS_PREG (1, poprnd))
810 OUTS (outf, "CALL (PC + ");
811 OUTS (outf, pregs (poprnd));
812 OUTS (outf, ")");
814 else if (prgfunc == 8 && IS_PREG (1, poprnd))
816 OUTS (outf, "JUMP (PC + ");
817 OUTS (outf, pregs (poprnd));
818 OUTS (outf, ")");
820 else if (prgfunc == 9)
822 OUTS (outf, "RAISE ");
823 OUTS (outf, uimm4 (poprnd));
825 else if (prgfunc == 10)
827 OUTS (outf, "EXCPT ");
828 OUTS (outf, uimm4 (poprnd));
830 else if (prgfunc == 11 && IS_PREG (1, poprnd) && poprnd <= 5)
832 OUTS (outf, "TESTSET (");
833 OUTS (outf, pregs (poprnd));
834 OUTS (outf, ")");
836 else
837 return 0;
838 return 2;
841 static int
842 decode_CaCTRL_0 (TIword iw0, disassemble_info *outf)
844 /* CaCTRL
845 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
846 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 |.a.|.op....|.reg.......|
847 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
848 int a = ((iw0 >> CaCTRL_a_bits) & CaCTRL_a_mask);
849 int op = ((iw0 >> CaCTRL_op_bits) & CaCTRL_op_mask);
850 int reg = ((iw0 >> CaCTRL_reg_bits) & CaCTRL_reg_mask);
852 if (parallel)
853 return 0;
855 if (a == 0 && op == 0)
857 OUTS (outf, "PREFETCH[");
858 OUTS (outf, pregs (reg));
859 OUTS (outf, "]");
861 else if (a == 0 && op == 1)
863 OUTS (outf, "FLUSHINV[");
864 OUTS (outf, pregs (reg));
865 OUTS (outf, "]");
867 else if (a == 0 && op == 2)
869 OUTS (outf, "FLUSH[");
870 OUTS (outf, pregs (reg));
871 OUTS (outf, "]");
873 else if (a == 0 && op == 3)
875 OUTS (outf, "IFLUSH[");
876 OUTS (outf, pregs (reg));
877 OUTS (outf, "]");
879 else if (a == 1 && op == 0)
881 OUTS (outf, "PREFETCH[");
882 OUTS (outf, pregs (reg));
883 OUTS (outf, "++]");
885 else if (a == 1 && op == 1)
887 OUTS (outf, "FLUSHINV[");
888 OUTS (outf, pregs (reg));
889 OUTS (outf, "++]");
891 else if (a == 1 && op == 2)
893 OUTS (outf, "FLUSH[");
894 OUTS (outf, pregs (reg));
895 OUTS (outf, "++]");
897 else if (a == 1 && op == 3)
899 OUTS (outf, "IFLUSH[");
900 OUTS (outf, pregs (reg));
901 OUTS (outf, "++]");
903 else
904 return 0;
905 return 2;
908 static int
909 decode_PushPopReg_0 (TIword iw0, disassemble_info *outf)
911 /* PushPopReg
912 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
913 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |.W.|.grp.......|.reg.......|
914 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
915 int W = ((iw0 >> PushPopReg_W_bits) & PushPopReg_W_mask);
916 int grp = ((iw0 >> PushPopReg_grp_bits) & PushPopReg_grp_mask);
917 int reg = ((iw0 >> PushPopReg_reg_bits) & PushPopReg_reg_mask);
919 if (parallel)
920 return 0;
922 if (W == 0 && mostreg (reg, grp))
924 OUTS (outf, allregs (reg, grp));
925 OUTS (outf, " = [SP++]");
927 else if (W == 1 && allreg (reg, grp) && !(grp == 1 && reg == 6))
929 OUTS (outf, "[--SP] = ");
930 OUTS (outf, allregs (reg, grp));
932 else
933 return 0;
934 return 2;
937 static int
938 decode_PushPopMultiple_0 (TIword iw0, disassemble_info *outf)
940 /* PushPopMultiple
941 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
942 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |.d.|.p.|.W.|.dr........|.pr........|
943 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
944 int p = ((iw0 >> PushPopMultiple_p_bits) & PushPopMultiple_p_mask);
945 int d = ((iw0 >> PushPopMultiple_d_bits) & PushPopMultiple_d_mask);
946 int W = ((iw0 >> PushPopMultiple_W_bits) & PushPopMultiple_W_mask);
947 int dr = ((iw0 >> PushPopMultiple_dr_bits) & PushPopMultiple_dr_mask);
948 int pr = ((iw0 >> PushPopMultiple_pr_bits) & PushPopMultiple_pr_mask);
950 if (parallel)
951 return 0;
953 if (pr > 5)
954 return 0;
956 if (W == 1 && d == 1 && p == 1)
958 OUTS (outf, "[--SP] = (R7:");
959 OUTS (outf, imm5d (dr));
960 OUTS (outf, ", P5:");
961 OUTS (outf, imm5d (pr));
962 OUTS (outf, ")");
964 else if (W == 1 && d == 1 && p == 0 && pr == 0)
966 OUTS (outf, "[--SP] = (R7:");
967 OUTS (outf, imm5d (dr));
968 OUTS (outf, ")");
970 else if (W == 1 && d == 0 && p == 1 && dr == 0)
972 OUTS (outf, "[--SP] = (P5:");
973 OUTS (outf, imm5d (pr));
974 OUTS (outf, ")");
976 else if (W == 0 && d == 1 && p == 1)
978 OUTS (outf, "(R7:");
979 OUTS (outf, imm5d (dr));
980 OUTS (outf, ", P5:");
981 OUTS (outf, imm5d (pr));
982 OUTS (outf, ") = [SP++]");
984 else if (W == 0 && d == 1 && p == 0 && pr == 0)
986 OUTS (outf, "(R7:");
987 OUTS (outf, imm5d (dr));
988 OUTS (outf, ") = [SP++]");
990 else if (W == 0 && d == 0 && p == 1 && dr == 0)
992 OUTS (outf, "(P5:");
993 OUTS (outf, imm5d (pr));
994 OUTS (outf, ") = [SP++]");
996 else
997 return 0;
998 return 2;
1001 static int
1002 decode_ccMV_0 (TIword iw0, disassemble_info *outf)
1004 /* ccMV
1005 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1006 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |.T.|.d.|.s.|.dst.......|.src.......|
1007 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1008 int s = ((iw0 >> CCmv_s_bits) & CCmv_s_mask);
1009 int d = ((iw0 >> CCmv_d_bits) & CCmv_d_mask);
1010 int T = ((iw0 >> CCmv_T_bits) & CCmv_T_mask);
1011 int src = ((iw0 >> CCmv_src_bits) & CCmv_src_mask);
1012 int dst = ((iw0 >> CCmv_dst_bits) & CCmv_dst_mask);
1014 if (parallel)
1015 return 0;
1017 if (T == 1)
1019 OUTS (outf, "IF CC ");
1020 OUTS (outf, gregs (dst, d));
1021 OUTS (outf, " = ");
1022 OUTS (outf, gregs (src, s));
1024 else if (T == 0)
1026 OUTS (outf, "IF !CC ");
1027 OUTS (outf, gregs (dst, d));
1028 OUTS (outf, " = ");
1029 OUTS (outf, gregs (src, s));
1031 else
1032 return 0;
1033 return 2;
1036 static int
1037 decode_CCflag_0 (TIword iw0, disassemble_info *outf)
1039 /* CCflag
1040 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1041 | 0 | 0 | 0 | 0 | 1 |.I.|.opc.......|.G.|.y.........|.x.........|
1042 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1043 int x = ((iw0 >> CCflag_x_bits) & CCflag_x_mask);
1044 int y = ((iw0 >> CCflag_y_bits) & CCflag_y_mask);
1045 int I = ((iw0 >> CCflag_I_bits) & CCflag_I_mask);
1046 int G = ((iw0 >> CCflag_G_bits) & CCflag_G_mask);
1047 int opc = ((iw0 >> CCflag_opc_bits) & CCflag_opc_mask);
1049 if (parallel)
1050 return 0;
1052 if (opc == 0 && I == 0 && G == 0)
1054 OUTS (outf, "CC = ");
1055 OUTS (outf, dregs (x));
1056 OUTS (outf, " == ");
1057 OUTS (outf, dregs (y));
1059 else if (opc == 1 && I == 0 && G == 0)
1061 OUTS (outf, "CC = ");
1062 OUTS (outf, dregs (x));
1063 OUTS (outf, " < ");
1064 OUTS (outf, dregs (y));
1066 else if (opc == 2 && I == 0 && G == 0)
1068 OUTS (outf, "CC = ");
1069 OUTS (outf, dregs (x));
1070 OUTS (outf, " <= ");
1071 OUTS (outf, dregs (y));
1073 else if (opc == 3 && I == 0 && G == 0)
1075 OUTS (outf, "CC = ");
1076 OUTS (outf, dregs (x));
1077 OUTS (outf, " < ");
1078 OUTS (outf, dregs (y));
1079 OUTS (outf, " (IU)");
1081 else if (opc == 4 && I == 0 && G == 0)
1083 OUTS (outf, "CC = ");
1084 OUTS (outf, dregs (x));
1085 OUTS (outf, " <= ");
1086 OUTS (outf, dregs (y));
1087 OUTS (outf, " (IU)");
1089 else if (opc == 0 && I == 1 && G == 0)
1091 OUTS (outf, "CC = ");
1092 OUTS (outf, dregs (x));
1093 OUTS (outf, " == ");
1094 OUTS (outf, imm3 (y));
1096 else if (opc == 1 && I == 1 && G == 0)
1098 OUTS (outf, "CC = ");
1099 OUTS (outf, dregs (x));
1100 OUTS (outf, " < ");
1101 OUTS (outf, imm3 (y));
1103 else if (opc == 2 && I == 1 && G == 0)
1105 OUTS (outf, "CC = ");
1106 OUTS (outf, dregs (x));
1107 OUTS (outf, " <= ");
1108 OUTS (outf, imm3 (y));
1110 else if (opc == 3 && I == 1 && G == 0)
1112 OUTS (outf, "CC = ");
1113 OUTS (outf, dregs (x));
1114 OUTS (outf, " < ");
1115 OUTS (outf, uimm3 (y));
1116 OUTS (outf, " (IU)");
1118 else if (opc == 4 && I == 1 && G == 0)
1120 OUTS (outf, "CC = ");
1121 OUTS (outf, dregs (x));
1122 OUTS (outf, " <= ");
1123 OUTS (outf, uimm3 (y));
1124 OUTS (outf, " (IU)");
1126 else if (opc == 0 && I == 0 && G == 1)
1128 OUTS (outf, "CC = ");
1129 OUTS (outf, pregs (x));
1130 OUTS (outf, " == ");
1131 OUTS (outf, pregs (y));
1133 else if (opc == 1 && I == 0 && G == 1)
1135 OUTS (outf, "CC = ");
1136 OUTS (outf, pregs (x));
1137 OUTS (outf, " < ");
1138 OUTS (outf, pregs (y));
1140 else if (opc == 2 && I == 0 && G == 1)
1142 OUTS (outf, "CC = ");
1143 OUTS (outf, pregs (x));
1144 OUTS (outf, " <= ");
1145 OUTS (outf, pregs (y));
1147 else if (opc == 3 && I == 0 && G == 1)
1149 OUTS (outf, "CC = ");
1150 OUTS (outf, pregs (x));
1151 OUTS (outf, " < ");
1152 OUTS (outf, pregs (y));
1153 OUTS (outf, " (IU)");
1155 else if (opc == 4 && I == 0 && G == 1)
1157 OUTS (outf, "CC = ");
1158 OUTS (outf, pregs (x));
1159 OUTS (outf, " <= ");
1160 OUTS (outf, pregs (y));
1161 OUTS (outf, " (IU)");
1163 else if (opc == 0 && I == 1 && G == 1)
1165 OUTS (outf, "CC = ");
1166 OUTS (outf, pregs (x));
1167 OUTS (outf, " == ");
1168 OUTS (outf, imm3 (y));
1170 else if (opc == 1 && I == 1 && G == 1)
1172 OUTS (outf, "CC = ");
1173 OUTS (outf, pregs (x));
1174 OUTS (outf, " < ");
1175 OUTS (outf, imm3 (y));
1177 else if (opc == 2 && I == 1 && G == 1)
1179 OUTS (outf, "CC = ");
1180 OUTS (outf, pregs (x));
1181 OUTS (outf, " <= ");
1182 OUTS (outf, imm3 (y));
1184 else if (opc == 3 && I == 1 && G == 1)
1186 OUTS (outf, "CC = ");
1187 OUTS (outf, pregs (x));
1188 OUTS (outf, " < ");
1189 OUTS (outf, uimm3 (y));
1190 OUTS (outf, " (IU)");
1192 else if (opc == 4 && I == 1 && G == 1)
1194 OUTS (outf, "CC = ");
1195 OUTS (outf, pregs (x));
1196 OUTS (outf, " <= ");
1197 OUTS (outf, uimm3 (y));
1198 OUTS (outf, " (IU)");
1200 else if (opc == 5 && I == 0 && G == 0 && x == 0 && y == 0)
1201 OUTS (outf, "CC = A0 == A1");
1203 else if (opc == 6 && I == 0 && G == 0 && x == 0 && y == 0)
1204 OUTS (outf, "CC = A0 < A1");
1206 else if (opc == 7 && I == 0 && G == 0 && x == 0 && y == 0)
1207 OUTS (outf, "CC = A0 <= A1");
1209 else
1210 return 0;
1211 return 2;
1214 static int
1215 decode_CC2dreg_0 (TIword iw0, disassemble_info *outf)
1217 /* CC2dreg
1218 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1219 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |.op....|.reg.......|
1220 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1221 int op = ((iw0 >> CC2dreg_op_bits) & CC2dreg_op_mask);
1222 int reg = ((iw0 >> CC2dreg_reg_bits) & CC2dreg_reg_mask);
1224 if (parallel)
1225 return 0;
1227 if (op == 0)
1229 OUTS (outf, dregs (reg));
1230 OUTS (outf, " = CC");
1232 else if (op == 1)
1234 OUTS (outf, "CC = ");
1235 OUTS (outf, dregs (reg));
1237 else if (op == 3 && reg == 0)
1238 OUTS (outf, "CC = !CC");
1239 else
1240 return 0;
1242 return 2;
1245 static int
1246 decode_CC2stat_0 (TIword iw0, disassemble_info *outf)
1248 /* CC2stat
1249 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1250 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |.D.|.op....|.cbit..............|
1251 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1252 int D = ((iw0 >> CC2stat_D_bits) & CC2stat_D_mask);
1253 int op = ((iw0 >> CC2stat_op_bits) & CC2stat_op_mask);
1254 int cbit = ((iw0 >> CC2stat_cbit_bits) & CC2stat_cbit_mask);
1256 const char *bitname = statbits (cbit);
1258 if (parallel)
1259 return 0;
1261 if (decode_statbits[cbit] == REG_LASTREG)
1263 /* All ASTAT bits except CC may be operated on in hardware, but may
1264 not have a dedicated insn, so still decode "valid" insns. */
1265 static char bitnames[64];
1266 if (cbit != 5)
1267 sprintf (bitnames, "ASTAT[%i /* unused bit */]", cbit);
1268 else
1269 return 0;
1271 bitname = bitnames;
1274 if (op == 0 && D == 0)
1276 OUTS (outf, "CC = ");
1277 OUTS (outf, bitname);
1279 else if (op == 1 && D == 0)
1281 OUTS (outf, "CC |= ");
1282 OUTS (outf, bitname);
1284 else if (op == 2 && D == 0)
1286 OUTS (outf, "CC &= ");
1287 OUTS (outf, bitname);
1289 else if (op == 3 && D == 0)
1291 OUTS (outf, "CC ^= ");
1292 OUTS (outf, bitname);
1294 else if (op == 0 && D == 1)
1296 OUTS (outf, bitname);
1297 OUTS (outf, " = CC");
1299 else if (op == 1 && D == 1)
1301 OUTS (outf, bitname);
1302 OUTS (outf, " |= CC");
1304 else if (op == 2 && D == 1)
1306 OUTS (outf, bitname);
1307 OUTS (outf, " &= CC");
1309 else if (op == 3 && D == 1)
1311 OUTS (outf, bitname);
1312 OUTS (outf, " ^= CC");
1314 else
1315 return 0;
1317 return 2;
1320 static int
1321 decode_BRCC_0 (TIword iw0, bfd_vma pc, disassemble_info *outf)
1323 /* BRCC
1324 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1325 | 0 | 0 | 0 | 1 |.T.|.B.|.offset................................|
1326 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1327 int B = ((iw0 >> BRCC_B_bits) & BRCC_B_mask);
1328 int T = ((iw0 >> BRCC_T_bits) & BRCC_T_mask);
1329 int offset = ((iw0 >> BRCC_offset_bits) & BRCC_offset_mask);
1331 if (parallel)
1332 return 0;
1334 if (T == 1 && B == 1)
1336 OUTS (outf, "IF CC JUMP 0x");
1337 OUTS (outf, pcrel10 (offset));
1338 OUTS (outf, " (BP)");
1340 else if (T == 0 && B == 1)
1342 OUTS (outf, "IF !CC JUMP 0x");
1343 OUTS (outf, pcrel10 (offset));
1344 OUTS (outf, " (BP)");
1346 else if (T == 1)
1348 OUTS (outf, "IF CC JUMP 0x");
1349 OUTS (outf, pcrel10 (offset));
1351 else if (T == 0)
1353 OUTS (outf, "IF !CC JUMP 0x");
1354 OUTS (outf, pcrel10 (offset));
1356 else
1357 return 0;
1359 return 2;
1362 static int
1363 decode_UJUMP_0 (TIword iw0, bfd_vma pc, disassemble_info *outf)
1365 /* UJUMP
1366 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1367 | 0 | 0 | 1 | 0 |.offset........................................|
1368 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1369 int offset = ((iw0 >> UJump_offset_bits) & UJump_offset_mask);
1371 if (parallel)
1372 return 0;
1374 OUTS (outf, "JUMP.S 0x");
1375 OUTS (outf, pcrel12 (offset));
1376 return 2;
1379 static int
1380 decode_REGMV_0 (TIword iw0, disassemble_info *outf)
1382 /* REGMV
1383 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1384 | 0 | 0 | 1 | 1 |.gd........|.gs........|.dst.......|.src.......|
1385 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1386 int gs = ((iw0 >> RegMv_gs_bits) & RegMv_gs_mask);
1387 int gd = ((iw0 >> RegMv_gd_bits) & RegMv_gd_mask);
1388 int src = ((iw0 >> RegMv_src_bits) & RegMv_src_mask);
1389 int dst = ((iw0 >> RegMv_dst_bits) & RegMv_dst_mask);
1391 /* Reserved slots cannot be a src/dst. */
1392 if (IS_RESERVEDREG (gs, src) || IS_RESERVEDREG (gd, dst))
1393 goto invalid_move;
1395 /* Standard register moves */
1396 if ((gs < 2) || /* Dregs/Pregs as source */
1397 (gd < 2) || /* Dregs/Pregs as dest */
1398 (gs == 4 && src < 4) || /* Accumulators as source */
1399 (gd == 4 && dst < 4 && (gs < 4)) || /* Accumulators as dest */
1400 (gs == 7 && src == 7 && !(gd == 4 && dst < 4)) || /* EMUDAT as src */
1401 (gd == 7 && dst == 7)) /* EMUDAT as dest */
1402 goto valid_move;
1404 /* dareg = dareg (IMBL) */
1405 if (gs < 4 && gd < 4)
1406 goto valid_move;
1408 /* USP can be src to sysregs, but not dagregs. */
1409 if ((gs == 7 && src == 0) && (gd >= 4))
1410 goto valid_move;
1412 /* USP can move between genregs (only check Accumulators). */
1413 if (((gs == 7 && src == 0) && (gd == 4 && dst < 4)) ||
1414 ((gd == 7 && dst == 0) && (gs == 4 && src < 4)))
1415 goto valid_move;
1417 /* Still here ? Invalid reg pair. */
1418 invalid_move:
1419 return 0;
1421 valid_move:
1422 OUTS (outf, allregs (dst, gd));
1423 OUTS (outf, " = ");
1424 OUTS (outf, allregs (src, gs));
1425 return 2;
1428 static int
1429 decode_ALU2op_0 (TIword iw0, disassemble_info *outf)
1431 /* ALU2op
1432 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1433 | 0 | 1 | 0 | 0 | 0 | 0 |.opc...........|.src.......|.dst.......|
1434 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1435 int src = ((iw0 >> ALU2op_src_bits) & ALU2op_src_mask);
1436 int opc = ((iw0 >> ALU2op_opc_bits) & ALU2op_opc_mask);
1437 int dst = ((iw0 >> ALU2op_dst_bits) & ALU2op_dst_mask);
1439 if (opc == 0)
1441 OUTS (outf, dregs (dst));
1442 OUTS (outf, " >>>= ");
1443 OUTS (outf, dregs (src));
1445 else if (opc == 1)
1447 OUTS (outf, dregs (dst));
1448 OUTS (outf, " >>= ");
1449 OUTS (outf, dregs (src));
1451 else if (opc == 2)
1453 OUTS (outf, dregs (dst));
1454 OUTS (outf, " <<= ");
1455 OUTS (outf, dregs (src));
1457 else if (opc == 3)
1459 OUTS (outf, dregs (dst));
1460 OUTS (outf, " *= ");
1461 OUTS (outf, dregs (src));
1463 else if (opc == 4)
1465 OUTS (outf, dregs (dst));
1466 OUTS (outf, " = (");
1467 OUTS (outf, dregs (dst));
1468 OUTS (outf, " + ");
1469 OUTS (outf, dregs (src));
1470 OUTS (outf, ") << 0x1");
1472 else if (opc == 5)
1474 OUTS (outf, dregs (dst));
1475 OUTS (outf, " = (");
1476 OUTS (outf, dregs (dst));
1477 OUTS (outf, " + ");
1478 OUTS (outf, dregs (src));
1479 OUTS (outf, ") << 0x2");
1481 else if (opc == 8)
1483 OUTS (outf, "DIVQ (");
1484 OUTS (outf, dregs (dst));
1485 OUTS (outf, ", ");
1486 OUTS (outf, dregs (src));
1487 OUTS (outf, ")");
1489 else if (opc == 9)
1491 OUTS (outf, "DIVS (");
1492 OUTS (outf, dregs (dst));
1493 OUTS (outf, ", ");
1494 OUTS (outf, dregs (src));
1495 OUTS (outf, ")");
1497 else if (opc == 10)
1499 OUTS (outf, dregs (dst));
1500 OUTS (outf, " = ");
1501 OUTS (outf, dregs_lo (src));
1502 OUTS (outf, " (X)");
1504 else if (opc == 11)
1506 OUTS (outf, dregs (dst));
1507 OUTS (outf, " = ");
1508 OUTS (outf, dregs_lo (src));
1509 OUTS (outf, " (Z)");
1511 else if (opc == 12)
1513 OUTS (outf, dregs (dst));
1514 OUTS (outf, " = ");
1515 OUTS (outf, dregs_byte (src));
1516 OUTS (outf, " (X)");
1518 else if (opc == 13)
1520 OUTS (outf, dregs (dst));
1521 OUTS (outf, " = ");
1522 OUTS (outf, dregs_byte (src));
1523 OUTS (outf, " (Z)");
1525 else if (opc == 14)
1527 OUTS (outf, dregs (dst));
1528 OUTS (outf, " = -");
1529 OUTS (outf, dregs (src));
1531 else if (opc == 15)
1533 OUTS (outf, dregs (dst));
1534 OUTS (outf, " =~ ");
1535 OUTS (outf, dregs (src));
1537 else
1538 return 0;
1540 return 2;
1543 static int
1544 decode_PTR2op_0 (TIword iw0, disassemble_info *outf)
1546 /* PTR2op
1547 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1548 | 0 | 1 | 0 | 0 | 0 | 1 | 0 |.opc.......|.src.......|.dst.......|
1549 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1550 int src = ((iw0 >> PTR2op_src_bits) & PTR2op_dst_mask);
1551 int opc = ((iw0 >> PTR2op_opc_bits) & PTR2op_opc_mask);
1552 int dst = ((iw0 >> PTR2op_dst_bits) & PTR2op_dst_mask);
1554 if (opc == 0)
1556 OUTS (outf, pregs (dst));
1557 OUTS (outf, " -= ");
1558 OUTS (outf, pregs (src));
1560 else if (opc == 1)
1562 OUTS (outf, pregs (dst));
1563 OUTS (outf, " = ");
1564 OUTS (outf, pregs (src));
1565 OUTS (outf, " << 0x2");
1567 else if (opc == 3)
1569 OUTS (outf, pregs (dst));
1570 OUTS (outf, " = ");
1571 OUTS (outf, pregs (src));
1572 OUTS (outf, " >> 0x2");
1574 else if (opc == 4)
1576 OUTS (outf, pregs (dst));
1577 OUTS (outf, " = ");
1578 OUTS (outf, pregs (src));
1579 OUTS (outf, " >> 0x1");
1581 else if (opc == 5)
1583 OUTS (outf, pregs (dst));
1584 OUTS (outf, " += ");
1585 OUTS (outf, pregs (src));
1586 OUTS (outf, " (BREV)");
1588 else if (opc == 6)
1590 OUTS (outf, pregs (dst));
1591 OUTS (outf, " = (");
1592 OUTS (outf, pregs (dst));
1593 OUTS (outf, " + ");
1594 OUTS (outf, pregs (src));
1595 OUTS (outf, ") << 0x1");
1597 else if (opc == 7)
1599 OUTS (outf, pregs (dst));
1600 OUTS (outf, " = (");
1601 OUTS (outf, pregs (dst));
1602 OUTS (outf, " + ");
1603 OUTS (outf, pregs (src));
1604 OUTS (outf, ") << 0x2");
1606 else
1607 return 0;
1609 return 2;
1612 static int
1613 decode_LOGI2op_0 (TIword iw0, disassemble_info *outf)
1615 /* LOGI2op
1616 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1617 | 0 | 1 | 0 | 0 | 1 |.opc.......|.src...............|.dst.......|
1618 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1619 int src = ((iw0 >> LOGI2op_src_bits) & LOGI2op_src_mask);
1620 int opc = ((iw0 >> LOGI2op_opc_bits) & LOGI2op_opc_mask);
1621 int dst = ((iw0 >> LOGI2op_dst_bits) & LOGI2op_dst_mask);
1623 if (parallel)
1624 return 0;
1626 if (opc == 0)
1628 OUTS (outf, "CC = !BITTST (");
1629 OUTS (outf, dregs (dst));
1630 OUTS (outf, ", ");
1631 OUTS (outf, uimm5 (src));
1632 OUTS (outf, ");\t\t/* bit");
1633 OUTS (outf, imm7d (src));
1634 OUTS (outf, " */");
1635 comment = 1;
1637 else if (opc == 1)
1639 OUTS (outf, "CC = BITTST (");
1640 OUTS (outf, dregs (dst));
1641 OUTS (outf, ", ");
1642 OUTS (outf, uimm5 (src));
1643 OUTS (outf, ");\t\t/* bit");
1644 OUTS (outf, imm7d (src));
1645 OUTS (outf, " */");
1646 comment = 1;
1648 else if (opc == 2)
1650 OUTS (outf, "BITSET (");
1651 OUTS (outf, dregs (dst));
1652 OUTS (outf, ", ");
1653 OUTS (outf, uimm5 (src));
1654 OUTS (outf, ");\t\t/* bit");
1655 OUTS (outf, imm7d (src));
1656 OUTS (outf, " */");
1657 comment = 1;
1659 else if (opc == 3)
1661 OUTS (outf, "BITTGL (");
1662 OUTS (outf, dregs (dst));
1663 OUTS (outf, ", ");
1664 OUTS (outf, uimm5 (src));
1665 OUTS (outf, ");\t\t/* bit");
1666 OUTS (outf, imm7d (src));
1667 OUTS (outf, " */");
1668 comment = 1;
1670 else if (opc == 4)
1672 OUTS (outf, "BITCLR (");
1673 OUTS (outf, dregs (dst));
1674 OUTS (outf, ", ");
1675 OUTS (outf, uimm5 (src));
1676 OUTS (outf, ");\t\t/* bit");
1677 OUTS (outf, imm7d (src));
1678 OUTS (outf, " */");
1679 comment = 1;
1681 else if (opc == 5)
1683 OUTS (outf, dregs (dst));
1684 OUTS (outf, " >>>= ");
1685 OUTS (outf, uimm5 (src));
1687 else if (opc == 6)
1689 OUTS (outf, dregs (dst));
1690 OUTS (outf, " >>= ");
1691 OUTS (outf, uimm5 (src));
1693 else if (opc == 7)
1695 OUTS (outf, dregs (dst));
1696 OUTS (outf, " <<= ");
1697 OUTS (outf, uimm5 (src));
1699 else
1700 return 0;
1702 return 2;
1705 static int
1706 decode_COMP3op_0 (TIword iw0, disassemble_info *outf)
1708 /* COMP3op
1709 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1710 | 0 | 1 | 0 | 1 |.opc.......|.dst.......|.src1......|.src0......|
1711 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1712 int opc = ((iw0 >> COMP3op_opc_bits) & COMP3op_opc_mask);
1713 int dst = ((iw0 >> COMP3op_dst_bits) & COMP3op_dst_mask);
1714 int src0 = ((iw0 >> COMP3op_src0_bits) & COMP3op_src0_mask);
1715 int src1 = ((iw0 >> COMP3op_src1_bits) & COMP3op_src1_mask);
1717 if (opc == 5 && src1 == src0)
1719 OUTS (outf, pregs (dst));
1720 OUTS (outf, " = ");
1721 OUTS (outf, pregs (src0));
1722 OUTS (outf, " << 0x1");
1724 else if (opc == 1)
1726 OUTS (outf, dregs (dst));
1727 OUTS (outf, " = ");
1728 OUTS (outf, dregs (src0));
1729 OUTS (outf, " - ");
1730 OUTS (outf, dregs (src1));
1732 else if (opc == 2)
1734 OUTS (outf, dregs (dst));
1735 OUTS (outf, " = ");
1736 OUTS (outf, dregs (src0));
1737 OUTS (outf, " & ");
1738 OUTS (outf, dregs (src1));
1740 else if (opc == 3)
1742 OUTS (outf, dregs (dst));
1743 OUTS (outf, " = ");
1744 OUTS (outf, dregs (src0));
1745 OUTS (outf, " | ");
1746 OUTS (outf, dregs (src1));
1748 else if (opc == 4)
1750 OUTS (outf, dregs (dst));
1751 OUTS (outf, " = ");
1752 OUTS (outf, dregs (src0));
1753 OUTS (outf, " ^ ");
1754 OUTS (outf, dregs (src1));
1756 else if (opc == 5)
1758 OUTS (outf, pregs (dst));
1759 OUTS (outf, " = ");
1760 OUTS (outf, pregs (src0));
1761 OUTS (outf, " + ");
1762 OUTS (outf, pregs (src1));
1764 else if (opc == 6)
1766 OUTS (outf, pregs (dst));
1767 OUTS (outf, " = ");
1768 OUTS (outf, pregs (src0));
1769 OUTS (outf, " + (");
1770 OUTS (outf, pregs (src1));
1771 OUTS (outf, " << 0x1)");
1773 else if (opc == 7)
1775 OUTS (outf, pregs (dst));
1776 OUTS (outf, " = ");
1777 OUTS (outf, pregs (src0));
1778 OUTS (outf, " + (");
1779 OUTS (outf, pregs (src1));
1780 OUTS (outf, " << 0x2)");
1782 else if (opc == 0)
1784 OUTS (outf, dregs (dst));
1785 OUTS (outf, " = ");
1786 OUTS (outf, dregs (src0));
1787 OUTS (outf, " + ");
1788 OUTS (outf, dregs (src1));
1790 else
1791 return 0;
1793 return 2;
1796 static int
1797 decode_COMPI2opD_0 (TIword iw0, disassemble_info *outf)
1799 /* COMPI2opD
1800 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1801 | 0 | 1 | 1 | 0 | 0 |.op|..src......................|.dst.......|
1802 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1803 int op = ((iw0 >> COMPI2opD_op_bits) & COMPI2opD_op_mask);
1804 int dst = ((iw0 >> COMPI2opD_dst_bits) & COMPI2opD_dst_mask);
1805 int src = ((iw0 >> COMPI2opD_src_bits) & COMPI2opD_src_mask);
1807 bu32 *pval = get_allreg (0, dst);
1809 if (parallel)
1810 return 0;
1812 /* Since we don't have 32-bit immediate loads, we allow the disassembler
1813 to combine them, so it prints out the right values.
1814 Here we keep track of the registers. */
1815 if (op == 0)
1817 *pval = imm7_val (src);
1818 if (src & 0x40)
1819 *pval |= 0xFFFFFF80;
1820 else
1821 *pval &= 0x7F;
1824 if (op == 0)
1826 OUTS (outf, dregs (dst));
1827 OUTS (outf, " = ");
1828 OUTS (outf, imm7 (src));
1829 OUTS (outf, " (X);\t\t/*\t\t");
1830 OUTS (outf, dregs (dst));
1831 OUTS (outf, "=");
1832 OUTS (outf, uimm32 (*pval));
1833 OUTS (outf, "(");
1834 OUTS (outf, imm32 (*pval));
1835 OUTS (outf, ") */");
1836 comment = 1;
1838 else if (op == 1)
1840 OUTS (outf, dregs (dst));
1841 OUTS (outf, " += ");
1842 OUTS (outf, imm7 (src));
1843 OUTS (outf, ";\t\t/* (");
1844 OUTS (outf, imm7d (src));
1845 OUTS (outf, ") */");
1846 comment = 1;
1848 else
1849 return 0;
1851 return 2;
1854 static int
1855 decode_COMPI2opP_0 (TIword iw0, disassemble_info *outf)
1857 /* COMPI2opP
1858 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1859 | 0 | 1 | 1 | 0 | 1 |.op|.src.......................|.dst.......|
1860 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1861 int op = ((iw0 >> COMPI2opP_op_bits) & COMPI2opP_op_mask);
1862 int src = ((iw0 >> COMPI2opP_src_bits) & COMPI2opP_src_mask);
1863 int dst = ((iw0 >> COMPI2opP_dst_bits) & COMPI2opP_dst_mask);
1865 bu32 *pval = get_allreg (1, dst);
1867 if (parallel)
1868 return 0;
1870 if (op == 0)
1872 *pval = imm7_val (src);
1873 if (src & 0x40)
1874 *pval |= 0xFFFFFF80;
1875 else
1876 *pval &= 0x7F;
1879 if (op == 0)
1881 OUTS (outf, pregs (dst));
1882 OUTS (outf, " = ");
1883 OUTS (outf, imm7 (src));
1884 OUTS (outf, " (X);\t\t/*\t\t");
1885 OUTS (outf, pregs (dst));
1886 OUTS (outf, "=");
1887 OUTS (outf, uimm32 (*pval));
1888 OUTS (outf, "(");
1889 OUTS (outf, imm32 (*pval));
1890 OUTS (outf, ") */");
1891 comment = 1;
1893 else if (op == 1)
1895 OUTS (outf, pregs (dst));
1896 OUTS (outf, " += ");
1897 OUTS (outf, imm7 (src));
1898 OUTS (outf, ";\t\t/* (");
1899 OUTS (outf, imm7d (src));
1900 OUTS (outf, ") */");
1901 comment = 1;
1903 else
1904 return 0;
1906 return 2;
1909 static int
1910 decode_LDSTpmod_0 (TIword iw0, disassemble_info *outf)
1912 /* LDSTpmod
1913 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
1914 | 1 | 0 | 0 | 0 |.W.|.aop...|.reg.......|.idx.......|.ptr.......|
1915 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
1916 int W = ((iw0 >> LDSTpmod_W_bits) & LDSTpmod_W_mask);
1917 int aop = ((iw0 >> LDSTpmod_aop_bits) & LDSTpmod_aop_mask);
1918 int idx = ((iw0 >> LDSTpmod_idx_bits) & LDSTpmod_idx_mask);
1919 int ptr = ((iw0 >> LDSTpmod_ptr_bits) & LDSTpmod_ptr_mask);
1920 int reg = ((iw0 >> LDSTpmod_reg_bits) & LDSTpmod_reg_mask);
1922 if (aop == 1 && W == 0 && idx == ptr)
1924 OUTS (outf, dregs_lo (reg));
1925 OUTS (outf, " = W[");
1926 OUTS (outf, pregs (ptr));
1927 OUTS (outf, "]");
1929 else if (aop == 2 && W == 0 && idx == ptr)
1931 OUTS (outf, dregs_hi (reg));
1932 OUTS (outf, " = W[");
1933 OUTS (outf, pregs (ptr));
1934 OUTS (outf, "]");
1936 else if (aop == 1 && W == 1 && idx == ptr)
1938 OUTS (outf, "W[");
1939 OUTS (outf, pregs (ptr));
1940 OUTS (outf, "] = ");
1941 OUTS (outf, dregs_lo (reg));
1943 else if (aop == 2 && W == 1 && idx == ptr)
1945 OUTS (outf, "W[");
1946 OUTS (outf, pregs (ptr));
1947 OUTS (outf, "] = ");
1948 OUTS (outf, dregs_hi (reg));
1950 else if (aop == 0 && W == 0)
1952 OUTS (outf, dregs (reg));
1953 OUTS (outf, " = [");
1954 OUTS (outf, pregs (ptr));
1955 OUTS (outf, " ++ ");
1956 OUTS (outf, pregs (idx));
1957 OUTS (outf, "]");
1959 else if (aop == 1 && W == 0)
1961 OUTS (outf, dregs_lo (reg));
1962 OUTS (outf, " = W[");
1963 OUTS (outf, pregs (ptr));
1964 OUTS (outf, " ++ ");
1965 OUTS (outf, pregs (idx));
1966 OUTS (outf, "]");
1968 else if (aop == 2 && W == 0)
1970 OUTS (outf, dregs_hi (reg));
1971 OUTS (outf, " = W[");
1972 OUTS (outf, pregs (ptr));
1973 OUTS (outf, " ++ ");
1974 OUTS (outf, pregs (idx));
1975 OUTS (outf, "]");
1977 else if (aop == 3 && W == 0)
1979 OUTS (outf, dregs (reg));
1980 OUTS (outf, " = W[");
1981 OUTS (outf, pregs (ptr));
1982 OUTS (outf, " ++ ");
1983 OUTS (outf, pregs (idx));
1984 OUTS (outf, "] (Z)");
1986 else if (aop == 3 && W == 1)
1988 OUTS (outf, dregs (reg));
1989 OUTS (outf, " = W[");
1990 OUTS (outf, pregs (ptr));
1991 OUTS (outf, " ++ ");
1992 OUTS (outf, pregs (idx));
1993 OUTS (outf, "] (X)");
1995 else if (aop == 0 && W == 1)
1997 OUTS (outf, "[");
1998 OUTS (outf, pregs (ptr));
1999 OUTS (outf, " ++ ");
2000 OUTS (outf, pregs (idx));
2001 OUTS (outf, "] = ");
2002 OUTS (outf, dregs (reg));
2004 else if (aop == 1 && W == 1)
2006 OUTS (outf, "W[");
2007 OUTS (outf, pregs (ptr));
2008 OUTS (outf, " ++ ");
2009 OUTS (outf, pregs (idx));
2010 OUTS (outf, "] = ");
2011 OUTS (outf, dregs_lo (reg));
2013 else if (aop == 2 && W == 1)
2015 OUTS (outf, "W[");
2016 OUTS (outf, pregs (ptr));
2017 OUTS (outf, " ++ ");
2018 OUTS (outf, pregs (idx));
2019 OUTS (outf, "] = ");
2020 OUTS (outf, dregs_hi (reg));
2022 else
2023 return 0;
2025 return 2;
2028 static int
2029 decode_dagMODim_0 (TIword iw0, disassemble_info *outf)
2031 /* dagMODim
2032 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2033 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 0 |.br| 1 | 1 |.op|.m.....|.i.....|
2034 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2035 int i = ((iw0 >> DagMODim_i_bits) & DagMODim_i_mask);
2036 int m = ((iw0 >> DagMODim_m_bits) & DagMODim_m_mask);
2037 int br = ((iw0 >> DagMODim_br_bits) & DagMODim_br_mask);
2038 int op = ((iw0 >> DagMODim_op_bits) & DagMODim_op_mask);
2040 if (op == 0 && br == 1)
2042 OUTS (outf, iregs (i));
2043 OUTS (outf, " += ");
2044 OUTS (outf, mregs (m));
2045 OUTS (outf, " (BREV)");
2047 else if (op == 0)
2049 OUTS (outf, iregs (i));
2050 OUTS (outf, " += ");
2051 OUTS (outf, mregs (m));
2053 else if (op == 1 && br == 0)
2055 OUTS (outf, iregs (i));
2056 OUTS (outf, " -= ");
2057 OUTS (outf, mregs (m));
2059 else
2060 return 0;
2062 return 2;
2065 static int
2066 decode_dagMODik_0 (TIword iw0, disassemble_info *outf)
2068 /* dagMODik
2069 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2070 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 0 |.op....|.i.....|
2071 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2072 int i = ((iw0 >> DagMODik_i_bits) & DagMODik_i_mask);
2073 int op = ((iw0 >> DagMODik_op_bits) & DagMODik_op_mask);
2075 if (op == 0)
2077 OUTS (outf, iregs (i));
2078 OUTS (outf, " += 0x2");
2080 else if (op == 1)
2082 OUTS (outf, iregs (i));
2083 OUTS (outf, " -= 0x2");
2085 else if (op == 2)
2087 OUTS (outf, iregs (i));
2088 OUTS (outf, " += 0x4");
2090 else if (op == 3)
2092 OUTS (outf, iregs (i));
2093 OUTS (outf, " -= 0x4");
2095 else
2096 return 0;
2098 if (! parallel )
2100 OUTS (outf, ";\t\t/* ( ");
2101 if (op == 0 || op == 1)
2102 OUTS (outf, "2");
2103 else if (op == 2 || op == 3)
2104 OUTS (outf, "4");
2105 OUTS (outf, ") */");
2106 comment = 1;
2109 return 2;
2112 static int
2113 decode_dspLDST_0 (TIword iw0, disassemble_info *outf)
2115 /* dspLDST
2116 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2117 | 1 | 0 | 0 | 1 | 1 | 1 |.W.|.aop...|.m.....|.i.....|.reg.......|
2118 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2119 int i = ((iw0 >> DspLDST_i_bits) & DspLDST_i_mask);
2120 int m = ((iw0 >> DspLDST_m_bits) & DspLDST_m_mask);
2121 int W = ((iw0 >> DspLDST_W_bits) & DspLDST_W_mask);
2122 int aop = ((iw0 >> DspLDST_aop_bits) & DspLDST_aop_mask);
2123 int reg = ((iw0 >> DspLDST_reg_bits) & DspLDST_reg_mask);
2125 if (aop == 0 && W == 0 && m == 0)
2127 OUTS (outf, dregs (reg));
2128 OUTS (outf, " = [");
2129 OUTS (outf, iregs (i));
2130 OUTS (outf, "++]");
2132 else if (aop == 0 && W == 0 && m == 1)
2134 OUTS (outf, dregs_lo (reg));
2135 OUTS (outf, " = W[");
2136 OUTS (outf, iregs (i));
2137 OUTS (outf, "++]");
2139 else if (aop == 0 && W == 0 && m == 2)
2141 OUTS (outf, dregs_hi (reg));
2142 OUTS (outf, " = W[");
2143 OUTS (outf, iregs (i));
2144 OUTS (outf, "++]");
2146 else if (aop == 1 && W == 0 && m == 0)
2148 OUTS (outf, dregs (reg));
2149 OUTS (outf, " = [");
2150 OUTS (outf, iregs (i));
2151 OUTS (outf, "--]");
2153 else if (aop == 1 && W == 0 && m == 1)
2155 OUTS (outf, dregs_lo (reg));
2156 OUTS (outf, " = W[");
2157 OUTS (outf, iregs (i));
2158 OUTS (outf, "--]");
2160 else if (aop == 1 && W == 0 && m == 2)
2162 OUTS (outf, dregs_hi (reg));
2163 OUTS (outf, " = W[");
2164 OUTS (outf, iregs (i));
2165 OUTS (outf, "--]");
2167 else if (aop == 2 && W == 0 && m == 0)
2169 OUTS (outf, dregs (reg));
2170 OUTS (outf, " = [");
2171 OUTS (outf, iregs (i));
2172 OUTS (outf, "]");
2174 else if (aop == 2 && W == 0 && m == 1)
2176 OUTS (outf, dregs_lo (reg));
2177 OUTS (outf, " = W[");
2178 OUTS (outf, iregs (i));
2179 OUTS (outf, "]");
2181 else if (aop == 2 && W == 0 && m == 2)
2183 OUTS (outf, dregs_hi (reg));
2184 OUTS (outf, " = W[");
2185 OUTS (outf, iregs (i));
2186 OUTS (outf, "]");
2188 else if (aop == 0 && W == 1 && m == 0)
2190 OUTS (outf, "[");
2191 OUTS (outf, iregs (i));
2192 OUTS (outf, "++] = ");
2193 OUTS (outf, dregs (reg));
2195 else if (aop == 0 && W == 1 && m == 1)
2197 OUTS (outf, "W[");
2198 OUTS (outf, iregs (i));
2199 OUTS (outf, "++] = ");
2200 OUTS (outf, dregs_lo (reg));
2202 else if (aop == 0 && W == 1 && m == 2)
2204 OUTS (outf, "W[");
2205 OUTS (outf, iregs (i));
2206 OUTS (outf, "++] = ");
2207 OUTS (outf, dregs_hi (reg));
2209 else if (aop == 1 && W == 1 && m == 0)
2211 OUTS (outf, "[");
2212 OUTS (outf, iregs (i));
2213 OUTS (outf, "--] = ");
2214 OUTS (outf, dregs (reg));
2216 else if (aop == 1 && W == 1 && m == 1)
2218 OUTS (outf, "W[");
2219 OUTS (outf, iregs (i));
2220 OUTS (outf, "--] = ");
2221 OUTS (outf, dregs_lo (reg));
2223 else if (aop == 1 && W == 1 && m == 2)
2225 OUTS (outf, "W[");
2226 OUTS (outf, iregs (i));
2227 OUTS (outf, "--] = ");
2228 OUTS (outf, dregs_hi (reg));
2230 else if (aop == 2 && W == 1 && m == 0)
2232 OUTS (outf, "[");
2233 OUTS (outf, iregs (i));
2234 OUTS (outf, "] = ");
2235 OUTS (outf, dregs (reg));
2237 else if (aop == 2 && W == 1 && m == 1)
2239 OUTS (outf, "W[");
2240 OUTS (outf, iregs (i));
2241 OUTS (outf, "] = ");
2242 OUTS (outf, dregs_lo (reg));
2244 else if (aop == 2 && W == 1 && m == 2)
2246 OUTS (outf, "W[");
2247 OUTS (outf, iregs (i));
2248 OUTS (outf, "] = ");
2249 OUTS (outf, dregs_hi (reg));
2251 else if (aop == 3 && W == 0)
2253 OUTS (outf, dregs (reg));
2254 OUTS (outf, " = [");
2255 OUTS (outf, iregs (i));
2256 OUTS (outf, " ++ ");
2257 OUTS (outf, mregs (m));
2258 OUTS (outf, "]");
2260 else if (aop == 3 && W == 1)
2262 OUTS (outf, "[");
2263 OUTS (outf, iregs (i));
2264 OUTS (outf, " ++ ");
2265 OUTS (outf, mregs (m));
2266 OUTS (outf, "] = ");
2267 OUTS (outf, dregs (reg));
2269 else
2270 return 0;
2272 return 2;
2275 static int
2276 decode_LDST_0 (TIword iw0, disassemble_info *outf)
2278 /* LDST
2279 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2280 | 1 | 0 | 0 | 1 |.sz....|.W.|.aop...|.Z.|.ptr.......|.reg.......|
2281 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2282 int Z = ((iw0 >> LDST_Z_bits) & LDST_Z_mask);
2283 int W = ((iw0 >> LDST_W_bits) & LDST_W_mask);
2284 int sz = ((iw0 >> LDST_sz_bits) & LDST_sz_mask);
2285 int aop = ((iw0 >> LDST_aop_bits) & LDST_aop_mask);
2286 int reg = ((iw0 >> LDST_reg_bits) & LDST_reg_mask);
2287 int ptr = ((iw0 >> LDST_ptr_bits) & LDST_ptr_mask);
2289 if (aop == 0 && sz == 0 && Z == 0 && W == 0)
2291 OUTS (outf, dregs (reg));
2292 OUTS (outf, " = [");
2293 OUTS (outf, pregs (ptr));
2294 OUTS (outf, "++]");
2296 else if (aop == 0 && sz == 0 && Z == 1 && W == 0 && reg != ptr)
2298 OUTS (outf, pregs (reg));
2299 OUTS (outf, " = [");
2300 OUTS (outf, pregs (ptr));
2301 OUTS (outf, "++]");
2303 else if (aop == 0 && sz == 1 && Z == 0 && W == 0)
2305 OUTS (outf, dregs (reg));
2306 OUTS (outf, " = W[");
2307 OUTS (outf, pregs (ptr));
2308 OUTS (outf, "++] (Z)");
2310 else if (aop == 0 && sz == 1 && Z == 1 && W == 0)
2312 OUTS (outf, dregs (reg));
2313 OUTS (outf, " = W[");
2314 OUTS (outf, pregs (ptr));
2315 OUTS (outf, "++] (X)");
2317 else if (aop == 0 && sz == 2 && Z == 0 && W == 0)
2319 OUTS (outf, dregs (reg));
2320 OUTS (outf, " = B[");
2321 OUTS (outf, pregs (ptr));
2322 OUTS (outf, "++] (Z)");
2324 else if (aop == 0 && sz == 2 && Z == 1 && W == 0)
2326 OUTS (outf, dregs (reg));
2327 OUTS (outf, " = B[");
2328 OUTS (outf, pregs (ptr));
2329 OUTS (outf, "++] (X)");
2331 else if (aop == 1 && sz == 0 && Z == 0 && W == 0)
2333 OUTS (outf, dregs (reg));
2334 OUTS (outf, " = [");
2335 OUTS (outf, pregs (ptr));
2336 OUTS (outf, "--]");
2338 else if (aop == 1 && sz == 0 && Z == 1 && W == 0 && reg != ptr)
2340 OUTS (outf, pregs (reg));
2341 OUTS (outf, " = [");
2342 OUTS (outf, pregs (ptr));
2343 OUTS (outf, "--]");
2345 else if (aop == 1 && sz == 1 && Z == 0 && W == 0)
2347 OUTS (outf, dregs (reg));
2348 OUTS (outf, " = W[");
2349 OUTS (outf, pregs (ptr));
2350 OUTS (outf, "--] (Z)");
2352 else if (aop == 1 && sz == 1 && Z == 1 && W == 0)
2354 OUTS (outf, dregs (reg));
2355 OUTS (outf, " = W[");
2356 OUTS (outf, pregs (ptr));
2357 OUTS (outf, "--] (X)");
2359 else if (aop == 1 && sz == 2 && Z == 0 && W == 0)
2361 OUTS (outf, dregs (reg));
2362 OUTS (outf, " = B[");
2363 OUTS (outf, pregs (ptr));
2364 OUTS (outf, "--] (Z)");
2366 else if (aop == 1 && sz == 2 && Z == 1 && W == 0)
2368 OUTS (outf, dregs (reg));
2369 OUTS (outf, " = B[");
2370 OUTS (outf, pregs (ptr));
2371 OUTS (outf, "--] (X)");
2373 else if (aop == 2 && sz == 0 && Z == 0 && W == 0)
2375 OUTS (outf, dregs (reg));
2376 OUTS (outf, " = [");
2377 OUTS (outf, pregs (ptr));
2378 OUTS (outf, "]");
2380 else if (aop == 2 && sz == 0 && Z == 1 && W == 0)
2382 OUTS (outf, pregs (reg));
2383 OUTS (outf, " = [");
2384 OUTS (outf, pregs (ptr));
2385 OUTS (outf, "]");
2387 else if (aop == 2 && sz == 1 && Z == 0 && W == 0)
2389 OUTS (outf, dregs (reg));
2390 OUTS (outf, " = W[");
2391 OUTS (outf, pregs (ptr));
2392 OUTS (outf, "] (Z)");
2394 else if (aop == 2 && sz == 1 && Z == 1 && W == 0)
2396 OUTS (outf, dregs (reg));
2397 OUTS (outf, " = W[");
2398 OUTS (outf, pregs (ptr));
2399 OUTS (outf, "] (X)");
2401 else if (aop == 2 && sz == 2 && Z == 0 && W == 0)
2403 OUTS (outf, dregs (reg));
2404 OUTS (outf, " = B[");
2405 OUTS (outf, pregs (ptr));
2406 OUTS (outf, "] (Z)");
2408 else if (aop == 2 && sz == 2 && Z == 1 && W == 0)
2410 OUTS (outf, dregs (reg));
2411 OUTS (outf, " = B[");
2412 OUTS (outf, pregs (ptr));
2413 OUTS (outf, "] (X)");
2415 else if (aop == 0 && sz == 0 && Z == 0 && W == 1)
2417 OUTS (outf, "[");
2418 OUTS (outf, pregs (ptr));
2419 OUTS (outf, "++] = ");
2420 OUTS (outf, dregs (reg));
2422 else if (aop == 0 && sz == 0 && Z == 1 && W == 1)
2424 OUTS (outf, "[");
2425 OUTS (outf, pregs (ptr));
2426 OUTS (outf, "++] = ");
2427 OUTS (outf, pregs (reg));
2429 else if (aop == 0 && sz == 1 && Z == 0 && W == 1)
2431 OUTS (outf, "W[");
2432 OUTS (outf, pregs (ptr));
2433 OUTS (outf, "++] = ");
2434 OUTS (outf, dregs (reg));
2436 else if (aop == 0 && sz == 2 && Z == 0 && W == 1)
2438 OUTS (outf, "B[");
2439 OUTS (outf, pregs (ptr));
2440 OUTS (outf, "++] = ");
2441 OUTS (outf, dregs (reg));
2443 else if (aop == 1 && sz == 0 && Z == 0 && W == 1)
2445 OUTS (outf, "[");
2446 OUTS (outf, pregs (ptr));
2447 OUTS (outf, "--] = ");
2448 OUTS (outf, dregs (reg));
2450 else if (aop == 1 && sz == 0 && Z == 1 && W == 1)
2452 OUTS (outf, "[");
2453 OUTS (outf, pregs (ptr));
2454 OUTS (outf, "--] = ");
2455 OUTS (outf, pregs (reg));
2457 else if (aop == 1 && sz == 1 && Z == 0 && W == 1)
2459 OUTS (outf, "W[");
2460 OUTS (outf, pregs (ptr));
2461 OUTS (outf, "--] = ");
2462 OUTS (outf, dregs (reg));
2464 else if (aop == 1 && sz == 2 && Z == 0 && W == 1)
2466 OUTS (outf, "B[");
2467 OUTS (outf, pregs (ptr));
2468 OUTS (outf, "--] = ");
2469 OUTS (outf, dregs (reg));
2471 else if (aop == 2 && sz == 0 && Z == 0 && W == 1)
2473 OUTS (outf, "[");
2474 OUTS (outf, pregs (ptr));
2475 OUTS (outf, "] = ");
2476 OUTS (outf, dregs (reg));
2478 else if (aop == 2 && sz == 0 && Z == 1 && W == 1)
2480 OUTS (outf, "[");
2481 OUTS (outf, pregs (ptr));
2482 OUTS (outf, "] = ");
2483 OUTS (outf, pregs (reg));
2485 else if (aop == 2 && sz == 1 && Z == 0 && W == 1)
2487 OUTS (outf, "W[");
2488 OUTS (outf, pregs (ptr));
2489 OUTS (outf, "] = ");
2490 OUTS (outf, dregs (reg));
2492 else if (aop == 2 && sz == 2 && Z == 0 && W == 1)
2494 OUTS (outf, "B[");
2495 OUTS (outf, pregs (ptr));
2496 OUTS (outf, "] = ");
2497 OUTS (outf, dregs (reg));
2499 else
2500 return 0;
2502 return 2;
2505 static int
2506 decode_LDSTiiFP_0 (TIword iw0, disassemble_info *outf)
2508 /* LDSTiiFP
2509 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2510 | 1 | 0 | 1 | 1 | 1 | 0 |.W.|.offset............|.reg...........|
2511 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2512 int reg = ((iw0 >> LDSTiiFP_reg_bits) & LDSTiiFP_reg_mask);
2513 int offset = ((iw0 >> LDSTiiFP_offset_bits) & LDSTiiFP_offset_mask);
2514 int W = ((iw0 >> LDSTiiFP_W_bits) & LDSTiiFP_W_mask);
2516 if (W == 0)
2518 OUTS (outf, dpregs (reg));
2519 OUTS (outf, " = [FP ");
2520 OUTS (outf, negimm5s4 (offset));
2521 OUTS (outf, "]");
2523 else if (W == 1)
2525 OUTS (outf, "[FP ");
2526 OUTS (outf, negimm5s4 (offset));
2527 OUTS (outf, "] = ");
2528 OUTS (outf, dpregs (reg));
2530 else
2531 return 0;
2533 return 2;
2536 static int
2537 decode_LDSTii_0 (TIword iw0, disassemble_info *outf)
2539 /* LDSTii
2540 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2541 | 1 | 0 | 1 |.W.|.op....|.offset........|.ptr.......|.reg.......|
2542 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2543 int reg = ((iw0 >> LDSTii_reg_bit) & LDSTii_reg_mask);
2544 int ptr = ((iw0 >> LDSTii_ptr_bit) & LDSTii_ptr_mask);
2545 int offset = ((iw0 >> LDSTii_offset_bit) & LDSTii_offset_mask);
2546 int op = ((iw0 >> LDSTii_op_bit) & LDSTii_op_mask);
2547 int W = ((iw0 >> LDSTii_W_bit) & LDSTii_W_mask);
2549 if (W == 0 && op == 0)
2551 OUTS (outf, dregs (reg));
2552 OUTS (outf, " = [");
2553 OUTS (outf, pregs (ptr));
2554 OUTS (outf, " + ");
2555 OUTS (outf, uimm4s4 (offset));
2556 OUTS (outf, "]");
2558 else if (W == 0 && op == 1)
2560 OUTS (outf, dregs (reg));
2561 OUTS (outf, " = W[");
2562 OUTS (outf, pregs (ptr));
2563 OUTS (outf, " + ");
2564 OUTS (outf, uimm4s2 (offset));
2565 OUTS (outf, "] (Z)");
2567 else if (W == 0 && op == 2)
2569 OUTS (outf, dregs (reg));
2570 OUTS (outf, " = W[");
2571 OUTS (outf, pregs (ptr));
2572 OUTS (outf, " + ");
2573 OUTS (outf, uimm4s2 (offset));
2574 OUTS (outf, "] (X)");
2576 else if (W == 0 && op == 3)
2578 OUTS (outf, pregs (reg));
2579 OUTS (outf, " = [");
2580 OUTS (outf, pregs (ptr));
2581 OUTS (outf, " + ");
2582 OUTS (outf, uimm4s4 (offset));
2583 OUTS (outf, "]");
2585 else if (W == 1 && op == 0)
2587 OUTS (outf, "[");
2588 OUTS (outf, pregs (ptr));
2589 OUTS (outf, " + ");
2590 OUTS (outf, uimm4s4 (offset));
2591 OUTS (outf, "] = ");
2592 OUTS (outf, dregs (reg));
2594 else if (W == 1 && op == 1)
2596 OUTS (outf, "W[");
2597 OUTS (outf, pregs (ptr));
2598 OUTS (outf, " + ");
2599 OUTS (outf, uimm4s2 (offset));
2600 OUTS (outf, "] = ");
2601 OUTS (outf, dregs (reg));
2603 else if (W == 1 && op == 3)
2605 OUTS (outf, "[");
2606 OUTS (outf, pregs (ptr));
2607 OUTS (outf, " + ");
2608 OUTS (outf, uimm4s4 (offset));
2609 OUTS (outf, "] = ");
2610 OUTS (outf, pregs (reg));
2612 else
2613 return 0;
2615 return 2;
2618 static int
2619 decode_LoopSetup_0 (TIword iw0, TIword iw1, bfd_vma pc, disassemble_info *outf)
2621 /* LoopSetup
2622 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2623 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 |.rop...|.c.|.soffset.......|
2624 |.reg...........| - | - |.eoffset...............................|
2625 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2626 int c = ((iw0 >> (LoopSetup_c_bits - 16)) & LoopSetup_c_mask);
2627 int reg = ((iw1 >> LoopSetup_reg_bits) & LoopSetup_reg_mask);
2628 int rop = ((iw0 >> (LoopSetup_rop_bits - 16)) & LoopSetup_rop_mask);
2629 int soffset = ((iw0 >> (LoopSetup_soffset_bits - 16)) & LoopSetup_soffset_mask);
2630 int eoffset = ((iw1 >> LoopSetup_eoffset_bits) & LoopSetup_eoffset_mask);
2632 if (parallel)
2633 return 0;
2635 if (rop == 0)
2637 OUTS (outf, "LSETUP");
2638 OUTS (outf, "(0x");
2639 OUTS (outf, pcrel4 (soffset));
2640 OUTS (outf, ", 0x");
2641 OUTS (outf, lppcrel10 (eoffset));
2642 OUTS (outf, ") ");
2643 OUTS (outf, counters (c));
2645 else if (rop == 1)
2647 OUTS (outf, "LSETUP");
2648 OUTS (outf, "(0x");
2649 OUTS (outf, pcrel4 (soffset));
2650 OUTS (outf, ", 0x");
2651 OUTS (outf, lppcrel10 (eoffset));
2652 OUTS (outf, ") ");
2653 OUTS (outf, counters (c));
2654 OUTS (outf, " = ");
2655 OUTS (outf, pregs (reg));
2657 else if (rop == 3)
2659 OUTS (outf, "LSETUP");
2660 OUTS (outf, "(0x");
2661 OUTS (outf, pcrel4 (soffset));
2662 OUTS (outf, ", 0x");
2663 OUTS (outf, lppcrel10 (eoffset));
2664 OUTS (outf, ") ");
2665 OUTS (outf, counters (c));
2666 OUTS (outf, " = ");
2667 OUTS (outf, pregs (reg));
2668 OUTS (outf, " >> 0x1");
2670 else
2671 return 0;
2673 return 4;
2676 static int
2677 decode_LDIMMhalf_0 (TIword iw0, TIword iw1, disassemble_info *outf)
2679 /* LDIMMhalf
2680 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2681 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 |.Z.|.H.|.S.|.grp...|.reg.......|
2682 |.hword.........................................................|
2683 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2684 int H = ((iw0 >> (LDIMMhalf_H_bits - 16)) & LDIMMhalf_H_mask);
2685 int Z = ((iw0 >> (LDIMMhalf_Z_bits - 16)) & LDIMMhalf_Z_mask);
2686 int S = ((iw0 >> (LDIMMhalf_S_bits - 16)) & LDIMMhalf_S_mask);
2687 int reg = ((iw0 >> (LDIMMhalf_reg_bits - 16)) & LDIMMhalf_reg_mask);
2688 int grp = ((iw0 >> (LDIMMhalf_grp_bits - 16)) & LDIMMhalf_grp_mask);
2689 int hword = ((iw1 >> LDIMMhalf_hword_bits) & LDIMMhalf_hword_mask);
2691 bu32 *pval = get_allreg (grp, reg);
2693 if (parallel)
2694 return 0;
2696 /* Since we don't have 32-bit immediate loads, we allow the disassembler
2697 to combine them, so it prints out the right values.
2698 Here we keep track of the registers. */
2699 if (H == 0 && S == 1 && Z == 0)
2701 /* regs = imm16 (x) */
2702 *pval = imm16_val (hword);
2703 if (hword & 0x8000)
2704 *pval |= 0xFFFF0000;
2705 else
2706 *pval &= 0xFFFF;
2708 else if (H == 0 && S == 0 && Z == 1)
2710 /* regs = luimm16 (Z) */
2711 *pval = luimm16_val (hword);
2712 *pval &= 0xFFFF;
2714 else if (H == 0 && S == 0 && Z == 0)
2716 /* regs_lo = luimm16 */
2717 *pval &= 0xFFFF0000;
2718 *pval |= luimm16_val (hword);
2720 else if (H == 1 && S == 0 && Z == 0)
2722 /* regs_hi = huimm16 */
2723 *pval &= 0xFFFF;
2724 *pval |= luimm16_val (hword) << 16;
2727 /* Here we do the disassembly */
2728 if (grp == 0 && H == 0 && S == 0 && Z == 0)
2730 OUTS (outf, dregs_lo (reg));
2731 OUTS (outf, " = ");
2732 OUTS (outf, uimm16 (hword));
2734 else if (grp == 0 && H == 1 && S == 0 && Z == 0)
2736 OUTS (outf, dregs_hi (reg));
2737 OUTS (outf, " = ");
2738 OUTS (outf, uimm16 (hword));
2740 else if (grp == 0 && H == 0 && S == 1 && Z == 0)
2742 OUTS (outf, dregs (reg));
2743 OUTS (outf, " = ");
2744 OUTS (outf, imm16 (hword));
2745 OUTS (outf, " (X)");
2747 else if (H == 0 && S == 1 && Z == 0)
2749 OUTS (outf, regs (reg, grp));
2750 OUTS (outf, " = ");
2751 OUTS (outf, imm16 (hword));
2752 OUTS (outf, " (X)");
2754 else if (H == 0 && S == 0 && Z == 1)
2756 OUTS (outf, regs (reg, grp));
2757 OUTS (outf, " = ");
2758 OUTS (outf, uimm16 (hword));
2759 OUTS (outf, " (Z)");
2761 else if (H == 0 && S == 0 && Z == 0)
2763 OUTS (outf, regs_lo (reg, grp));
2764 OUTS (outf, " = ");
2765 OUTS (outf, uimm16 (hword));
2767 else if (H == 1 && S == 0 && Z == 0)
2769 OUTS (outf, regs_hi (reg, grp));
2770 OUTS (outf, " = ");
2771 OUTS (outf, uimm16 (hword));
2773 else
2774 return 0;
2776 /* And we print out the 32-bit value if it is a pointer. */
2777 if (S == 0 && Z == 0)
2779 OUTS (outf, ";\t\t/* (");
2780 OUTS (outf, imm16d (hword));
2781 OUTS (outf, ")\t");
2783 /* If it is an MMR, don't print the symbol. */
2784 if (*pval < 0xFFC00000 && grp == 1)
2786 OUTS (outf, regs (reg, grp));
2787 OUTS (outf, "=0x");
2788 OUTS (outf, huimm32e (*pval));
2790 else
2792 OUTS (outf, regs (reg, grp));
2793 OUTS (outf, "=0x");
2794 OUTS (outf, huimm32e (*pval));
2795 OUTS (outf, "(");
2796 OUTS (outf, imm32 (*pval));
2797 OUTS (outf, ")");
2800 OUTS (outf, " */");
2801 comment = 1;
2803 if (S == 1 || Z == 1)
2805 OUTS (outf, ";\t\t/*\t\t");
2806 OUTS (outf, regs (reg, grp));
2807 OUTS (outf, "=0x");
2808 OUTS (outf, huimm32e (*pval));
2809 OUTS (outf, "(");
2810 OUTS (outf, imm32 (*pval));
2811 OUTS (outf, ") */");
2812 comment = 1;
2814 return 4;
2817 static int
2818 decode_CALLa_0 (TIword iw0, TIword iw1, bfd_vma pc, disassemble_info *outf)
2820 /* CALLa
2821 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2822 | 1 | 1 | 1 | 0 | 0 | 0 | 1 |.S.|.msw...........................|
2823 |.lsw...........................................................|
2824 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2825 int S = ((iw0 >> (CALLa_S_bits - 16)) & CALLa_S_mask);
2826 int lsw = ((iw1 >> 0) & 0xffff);
2827 int msw = ((iw0 >> 0) & 0xff);
2829 if (parallel)
2830 return 0;
2832 if (S == 1)
2833 OUTS (outf, "CALL 0x");
2834 else if (S == 0)
2835 OUTS (outf, "JUMP.L 0x");
2836 else
2837 return 0;
2839 OUTS (outf, pcrel24 (((msw) << 16) | (lsw)));
2840 return 4;
2843 static int
2844 decode_LDSTidxI_0 (TIword iw0, TIword iw1, disassemble_info *outf)
2846 /* LDSTidxI
2847 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2848 | 1 | 1 | 1 | 0 | 0 | 1 |.W.|.Z.|.sz....|.ptr.......|.reg.......|
2849 |.offset........................................................|
2850 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2851 int Z = ((iw0 >> (LDSTidxI_Z_bits - 16)) & LDSTidxI_Z_mask);
2852 int W = ((iw0 >> (LDSTidxI_W_bits - 16)) & LDSTidxI_W_mask);
2853 int sz = ((iw0 >> (LDSTidxI_sz_bits - 16)) & LDSTidxI_sz_mask);
2854 int reg = ((iw0 >> (LDSTidxI_reg_bits - 16)) & LDSTidxI_reg_mask);
2855 int ptr = ((iw0 >> (LDSTidxI_ptr_bits - 16)) & LDSTidxI_ptr_mask);
2856 int offset = ((iw1 >> LDSTidxI_offset_bits) & LDSTidxI_offset_mask);
2858 if (W == 0 && sz == 0 && Z == 0)
2860 OUTS (outf, dregs (reg));
2861 OUTS (outf, " = [");
2862 OUTS (outf, pregs (ptr));
2863 OUTS (outf, " + ");
2864 OUTS (outf, imm16s4 (offset));
2865 OUTS (outf, "]");
2867 else if (W == 0 && sz == 0 && Z == 1)
2869 OUTS (outf, pregs (reg));
2870 OUTS (outf, " = [");
2871 OUTS (outf, pregs (ptr));
2872 OUTS (outf, " + ");
2873 OUTS (outf, imm16s4 (offset));
2874 OUTS (outf, "]");
2876 else if (W == 0 && sz == 1 && Z == 0)
2878 OUTS (outf, dregs (reg));
2879 OUTS (outf, " = W[");
2880 OUTS (outf, pregs (ptr));
2881 OUTS (outf, " + ");
2882 OUTS (outf, imm16s2 (offset));
2883 OUTS (outf, "] (Z)");
2885 else if (W == 0 && sz == 1 && Z == 1)
2887 OUTS (outf, dregs (reg));
2888 OUTS (outf, " = W[");
2889 OUTS (outf, pregs (ptr));
2890 OUTS (outf, " + ");
2891 OUTS (outf, imm16s2 (offset));
2892 OUTS (outf, "] (X)");
2894 else if (W == 0 && sz == 2 && Z == 0)
2896 OUTS (outf, dregs (reg));
2897 OUTS (outf, " = B[");
2898 OUTS (outf, pregs (ptr));
2899 OUTS (outf, " + ");
2900 OUTS (outf, imm16 (offset));
2901 OUTS (outf, "] (Z)");
2903 else if (W == 0 && sz == 2 && Z == 1)
2905 OUTS (outf, dregs (reg));
2906 OUTS (outf, " = B[");
2907 OUTS (outf, pregs (ptr));
2908 OUTS (outf, " + ");
2909 OUTS (outf, imm16 (offset));
2910 OUTS (outf, "] (X)");
2912 else if (W == 1 && sz == 0 && Z == 0)
2914 OUTS (outf, "[");
2915 OUTS (outf, pregs (ptr));
2916 OUTS (outf, " + ");
2917 OUTS (outf, imm16s4 (offset));
2918 OUTS (outf, "] = ");
2919 OUTS (outf, dregs (reg));
2921 else if (W == 1 && sz == 0 && Z == 1)
2923 OUTS (outf, "[");
2924 OUTS (outf, pregs (ptr));
2925 OUTS (outf, " + ");
2926 OUTS (outf, imm16s4 (offset));
2927 OUTS (outf, "] = ");
2928 OUTS (outf, pregs (reg));
2930 else if (W == 1 && sz == 1 && Z == 0)
2932 OUTS (outf, "W[");
2933 OUTS (outf, pregs (ptr));
2934 OUTS (outf, " + ");
2935 OUTS (outf, imm16s2 (offset));
2936 OUTS (outf, "] = ");
2937 OUTS (outf, dregs (reg));
2939 else if (W == 1 && sz == 2 && Z == 0)
2941 OUTS (outf, "B[");
2942 OUTS (outf, pregs (ptr));
2943 OUTS (outf, " + ");
2944 OUTS (outf, imm16 (offset));
2945 OUTS (outf, "] = ");
2946 OUTS (outf, dregs (reg));
2948 else
2949 return 0;
2951 return 4;
2954 static int
2955 decode_linkage_0 (TIword iw0, TIword iw1, disassemble_info *outf)
2957 /* linkage
2958 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2959 | 1 | 1 | 1 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |.R.|
2960 |.framesize.....................................................|
2961 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2962 int R = ((iw0 >> (Linkage_R_bits - 16)) & Linkage_R_mask);
2963 int framesize = ((iw1 >> Linkage_framesize_bits) & Linkage_framesize_mask);
2965 if (parallel)
2966 return 0;
2968 if (R == 0)
2970 OUTS (outf, "LINK ");
2971 OUTS (outf, uimm16s4 (framesize));
2972 OUTS (outf, ";\t\t/* (");
2973 OUTS (outf, uimm16s4d (framesize));
2974 OUTS (outf, ") */");
2975 comment = 1;
2977 else if (R == 1)
2978 OUTS (outf, "UNLINK");
2979 else
2980 return 0;
2982 return 4;
2985 static int
2986 decode_dsp32mac_0 (TIword iw0, TIword iw1, disassemble_info *outf)
2988 /* dsp32mac
2989 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
2990 | 1 | 1 | 0 | 0 |.M.| 0 | 0 |.mmod..........|.MM|.P.|.w1|.op1...|
2991 |.h01|.h11|.w0|.op0...|.h00|.h10|.dst.......|.src0......|.src1..|
2992 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
2993 int op1 = ((iw0 >> (DSP32Mac_op1_bits - 16)) & DSP32Mac_op1_mask);
2994 int w1 = ((iw0 >> (DSP32Mac_w1_bits - 16)) & DSP32Mac_w1_mask);
2995 int P = ((iw0 >> (DSP32Mac_p_bits - 16)) & DSP32Mac_p_mask);
2996 int MM = ((iw0 >> (DSP32Mac_MM_bits - 16)) & DSP32Mac_MM_mask);
2997 int mmod = ((iw0 >> (DSP32Mac_mmod_bits - 16)) & DSP32Mac_mmod_mask);
2998 int w0 = ((iw1 >> DSP32Mac_w0_bits) & DSP32Mac_w0_mask);
2999 int src0 = ((iw1 >> DSP32Mac_src0_bits) & DSP32Mac_src0_mask);
3000 int src1 = ((iw1 >> DSP32Mac_src1_bits) & DSP32Mac_src1_mask);
3001 int dst = ((iw1 >> DSP32Mac_dst_bits) & DSP32Mac_dst_mask);
3002 int h10 = ((iw1 >> DSP32Mac_h10_bits) & DSP32Mac_h10_mask);
3003 int h00 = ((iw1 >> DSP32Mac_h00_bits) & DSP32Mac_h00_mask);
3004 int op0 = ((iw1 >> DSP32Mac_op0_bits) & DSP32Mac_op0_mask);
3005 int h11 = ((iw1 >> DSP32Mac_h11_bits) & DSP32Mac_h11_mask);
3006 int h01 = ((iw1 >> DSP32Mac_h01_bits) & DSP32Mac_h01_mask);
3008 if (w0 == 0 && w1 == 0 && op1 == 3 && op0 == 3)
3009 return 0;
3011 if (op1 == 3 && MM)
3012 return 0;
3014 if ((w1 || w0) && mmod == M_W32)
3015 return 0;
3017 if (((1 << mmod) & (P ? 0x131b : 0x1b5f)) == 0)
3018 return 0;
3020 if (w1 == 1 || op1 != 3)
3022 if (w1)
3023 OUTS (outf, P ? dregs (dst + 1) : dregs_hi (dst));
3025 if (op1 == 3)
3026 OUTS (outf, " = A1");
3027 else
3029 if (w1)
3030 OUTS (outf, " = (");
3031 decode_macfunc (1, op1, h01, h11, src0, src1, outf);
3032 if (w1)
3033 OUTS (outf, ")");
3036 if (w0 == 1 || op0 != 3)
3038 if (MM)
3039 OUTS (outf, " (M)");
3040 MM = 0;
3041 OUTS (outf, ", ");
3045 if (w0 == 1 || op0 != 3)
3047 if (w0)
3048 OUTS (outf, P ? dregs (dst) : dregs_lo (dst));
3050 if (op0 == 3)
3051 OUTS (outf, " = A0");
3052 else
3054 if (w0)
3055 OUTS (outf, " = (");
3056 decode_macfunc (0, op0, h00, h10, src0, src1, outf);
3057 if (w0)
3058 OUTS (outf, ")");
3062 decode_optmode (mmod, MM, outf);
3064 return 4;
3067 static int
3068 decode_dsp32mult_0 (TIword iw0, TIword iw1, disassemble_info *outf)
3070 /* dsp32mult
3071 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
3072 | 1 | 1 | 0 | 0 |.M.| 0 | 1 |.mmod..........|.MM|.P.|.w1|.op1...|
3073 |.h01|.h11|.w0|.op0...|.h00|.h10|.dst.......|.src0......|.src1..|
3074 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
3075 int w1 = ((iw0 >> (DSP32Mac_w1_bits - 16)) & DSP32Mac_w1_mask);
3076 int P = ((iw0 >> (DSP32Mac_p_bits - 16)) & DSP32Mac_p_mask);
3077 int MM = ((iw0 >> (DSP32Mac_MM_bits - 16)) & DSP32Mac_MM_mask);
3078 int mmod = ((iw0 >> (DSP32Mac_mmod_bits - 16)) & DSP32Mac_mmod_mask);
3079 int w0 = ((iw1 >> DSP32Mac_w0_bits) & DSP32Mac_w0_mask);
3080 int src0 = ((iw1 >> DSP32Mac_src0_bits) & DSP32Mac_src0_mask);
3081 int src1 = ((iw1 >> DSP32Mac_src1_bits) & DSP32Mac_src1_mask);
3082 int dst = ((iw1 >> DSP32Mac_dst_bits) & DSP32Mac_dst_mask);
3083 int h10 = ((iw1 >> DSP32Mac_h10_bits) & DSP32Mac_h10_mask);
3084 int h00 = ((iw1 >> DSP32Mac_h00_bits) & DSP32Mac_h00_mask);
3085 int h11 = ((iw1 >> DSP32Mac_h11_bits) & DSP32Mac_h11_mask);
3086 int h01 = ((iw1 >> DSP32Mac_h01_bits) & DSP32Mac_h01_mask);
3088 if (w1 == 0 && w0 == 0)
3089 return 0;
3091 if (((1 << mmod) & (P ? 0x313 : 0x1b57)) == 0)
3092 return 0;
3094 if (w1)
3096 OUTS (outf, P ? dregs (dst | 1) : dregs_hi (dst));
3097 OUTS (outf, " = ");
3098 decode_multfunc (h01, h11, src0, src1, outf);
3100 if (w0)
3102 if (MM)
3103 OUTS (outf, " (M)");
3104 MM = 0;
3105 OUTS (outf, ", ");
3109 if (w0)
3111 OUTS (outf, dregs (dst));
3112 OUTS (outf, " = ");
3113 decode_multfunc (h00, h10, src0, src1, outf);
3116 decode_optmode (mmod, MM, outf);
3117 return 4;
3120 static int
3121 decode_dsp32alu_0 (TIword iw0, TIword iw1, disassemble_info *outf)
3123 /* dsp32alu
3124 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
3125 | 1 | 1 | 0 | 0 |.M.| 1 | 0 | - | - | - |.HL|.aopcde............|
3126 |.aop...|.s.|.x.|.dst0......|.dst1......|.src0......|.src1......|
3127 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
3128 int s = ((iw1 >> DSP32Alu_s_bits) & DSP32Alu_s_mask);
3129 int x = ((iw1 >> DSP32Alu_x_bits) & DSP32Alu_x_mask);
3130 int aop = ((iw1 >> DSP32Alu_aop_bits) & DSP32Alu_aop_mask);
3131 int src0 = ((iw1 >> DSP32Alu_src0_bits) & DSP32Alu_src0_mask);
3132 int src1 = ((iw1 >> DSP32Alu_src1_bits) & DSP32Alu_src1_mask);
3133 int dst0 = ((iw1 >> DSP32Alu_dst0_bits) & DSP32Alu_dst0_mask);
3134 int dst1 = ((iw1 >> DSP32Alu_dst1_bits) & DSP32Alu_dst1_mask);
3135 int HL = ((iw0 >> (DSP32Alu_HL_bits - 16)) & DSP32Alu_HL_mask);
3136 int aopcde = ((iw0 >> (DSP32Alu_aopcde_bits - 16)) & DSP32Alu_aopcde_mask);
3138 if (aop == 0 && aopcde == 9 && HL == 0 && s == 0)
3140 OUTS (outf, "A0.L = ");
3141 OUTS (outf, dregs_lo (src0));
3143 else if (aop == 2 && aopcde == 9 && HL == 1 && s == 0)
3145 OUTS (outf, "A1.H = ");
3146 OUTS (outf, dregs_hi (src0));
3148 else if (aop == 2 && aopcde == 9 && HL == 0 && s == 0)
3150 OUTS (outf, "A1.L = ");
3151 OUTS (outf, dregs_lo (src0));
3153 else if (aop == 0 && aopcde == 9 && HL == 1 && s == 0)
3155 OUTS (outf, "A0.H = ");
3156 OUTS (outf, dregs_hi (src0));
3158 else if (x == 1 && HL == 1 && aop == 3 && aopcde == 5)
3160 OUTS (outf, dregs_hi (dst0));
3161 OUTS (outf, " = ");
3162 OUTS (outf, dregs (src0));
3163 OUTS (outf, " - ");
3164 OUTS (outf, dregs (src1));
3165 OUTS (outf, " (RND20)");
3167 else if (x == 1 && HL == 1 && aop == 2 && aopcde == 5)
3169 OUTS (outf, dregs_hi (dst0));
3170 OUTS (outf, " = ");
3171 OUTS (outf, dregs (src0));
3172 OUTS (outf, " + ");
3173 OUTS (outf, dregs (src1));
3174 OUTS (outf, " (RND20)");
3176 else if (x == 0 && HL == 0 && aop == 1 && aopcde == 5)
3178 OUTS (outf, dregs_lo (dst0));
3179 OUTS (outf, " = ");
3180 OUTS (outf, dregs (src0));
3181 OUTS (outf, " - ");
3182 OUTS (outf, dregs (src1));
3183 OUTS (outf, " (RND12)");
3185 else if (x == 0 && HL == 0 && aop == 0 && aopcde == 5)
3187 OUTS (outf, dregs_lo (dst0));
3188 OUTS (outf, " = ");
3189 OUTS (outf, dregs (src0));
3190 OUTS (outf, " + ");
3191 OUTS (outf, dregs (src1));
3192 OUTS (outf, " (RND12)");
3194 else if (x == 1 && HL == 0 && aop == 3 && aopcde == 5)
3196 OUTS (outf, dregs_lo (dst0));
3197 OUTS (outf, " = ");
3198 OUTS (outf, dregs (src0));
3199 OUTS (outf, " - ");
3200 OUTS (outf, dregs (src1));
3201 OUTS (outf, " (RND20)");
3203 else if (x == 0 && HL == 1 && aop == 0 && aopcde == 5)
3205 OUTS (outf, dregs_hi (dst0));
3206 OUTS (outf, " = ");
3207 OUTS (outf, dregs (src0));
3208 OUTS (outf, " + ");
3209 OUTS (outf, dregs (src1));
3210 OUTS (outf, " (RND12)");
3212 else if (x == 1 && HL == 0 && aop == 2 && aopcde == 5)
3214 OUTS (outf, dregs_lo (dst0));
3215 OUTS (outf, " = ");
3216 OUTS (outf, dregs (src0));
3217 OUTS (outf, " + ");
3218 OUTS (outf, dregs (src1));
3219 OUTS (outf, " (RND20)");
3221 else if (x == 0 && HL == 1 && aop == 1 && aopcde == 5)
3223 OUTS (outf, dregs_hi (dst0));
3224 OUTS (outf, " = ");
3225 OUTS (outf, dregs (src0));
3226 OUTS (outf, " - ");
3227 OUTS (outf, dregs (src1));
3228 OUTS (outf, " (RND12)");
3230 else if (HL == 1 && aop == 0 && aopcde == 2)
3232 OUTS (outf, dregs_hi (dst0));
3233 OUTS (outf, " = ");
3234 OUTS (outf, dregs_lo (src0));
3235 OUTS (outf, " + ");
3236 OUTS (outf, dregs_lo (src1));
3237 amod1 (s, x, outf);
3239 else if (HL == 1 && aop == 1 && aopcde == 2)
3241 OUTS (outf, dregs_hi (dst0));
3242 OUTS (outf, " = ");
3243 OUTS (outf, dregs_lo (src0));
3244 OUTS (outf, " + ");
3245 OUTS (outf, dregs_hi (src1));
3246 amod1 (s, x, outf);
3248 else if (HL == 1 && aop == 2 && aopcde == 2)
3250 OUTS (outf, dregs_hi (dst0));
3251 OUTS (outf, " = ");
3252 OUTS (outf, dregs_hi (src0));
3253 OUTS (outf, " + ");
3254 OUTS (outf, dregs_lo (src1));
3255 amod1 (s, x, outf);
3257 else if (HL == 1 && aop == 3 && aopcde == 2)
3259 OUTS (outf, dregs_hi (dst0));
3260 OUTS (outf, " = ");
3261 OUTS (outf, dregs_hi (src0));
3262 OUTS (outf, " + ");
3263 OUTS (outf, dregs_hi (src1));
3264 amod1 (s, x, outf);
3266 else if (HL == 0 && aop == 0 && aopcde == 3)
3268 OUTS (outf, dregs_lo (dst0));
3269 OUTS (outf, " = ");
3270 OUTS (outf, dregs_lo (src0));
3271 OUTS (outf, " - ");
3272 OUTS (outf, dregs_lo (src1));
3273 amod1 (s, x, outf);
3275 else if (HL == 0 && aop == 1 && aopcde == 3)
3277 OUTS (outf, dregs_lo (dst0));
3278 OUTS (outf, " = ");
3279 OUTS (outf, dregs_lo (src0));
3280 OUTS (outf, " - ");
3281 OUTS (outf, dregs_hi (src1));
3282 amod1 (s, x, outf);
3284 else if (HL == 0 && aop == 3 && aopcde == 2)
3286 OUTS (outf, dregs_lo (dst0));
3287 OUTS (outf, " = ");
3288 OUTS (outf, dregs_hi (src0));
3289 OUTS (outf, " + ");
3290 OUTS (outf, dregs_hi (src1));
3291 amod1 (s, x, outf);
3293 else if (HL == 1 && aop == 0 && aopcde == 3)
3295 OUTS (outf, dregs_hi (dst0));
3296 OUTS (outf, " = ");
3297 OUTS (outf, dregs_lo (src0));
3298 OUTS (outf, " - ");
3299 OUTS (outf, dregs_lo (src1));
3300 amod1 (s, x, outf);
3302 else if (HL == 1 && aop == 1 && aopcde == 3)
3304 OUTS (outf, dregs_hi (dst0));
3305 OUTS (outf, " = ");
3306 OUTS (outf, dregs_lo (src0));
3307 OUTS (outf, " - ");
3308 OUTS (outf, dregs_hi (src1));
3309 amod1 (s, x, outf);
3311 else if (HL == 1 && aop == 2 && aopcde == 3)
3313 OUTS (outf, dregs_hi (dst0));
3314 OUTS (outf, " = ");
3315 OUTS (outf, dregs_hi (src0));
3316 OUTS (outf, " - ");
3317 OUTS (outf, dregs_lo (src1));
3318 amod1 (s, x, outf);
3320 else if (HL == 1 && aop == 3 && aopcde == 3)
3322 OUTS (outf, dregs_hi (dst0));
3323 OUTS (outf, " = ");
3324 OUTS (outf, dregs_hi (src0));
3325 OUTS (outf, " - ");
3326 OUTS (outf, dregs_hi (src1));
3327 amod1 (s, x, outf);
3329 else if (HL == 0 && aop == 2 && aopcde == 2)
3331 OUTS (outf, dregs_lo (dst0));
3332 OUTS (outf, " = ");
3333 OUTS (outf, dregs_hi (src0));
3334 OUTS (outf, " + ");
3335 OUTS (outf, dregs_lo (src1));
3336 amod1 (s, x, outf);
3338 else if (HL == 0 && aop == 1 && aopcde == 2)
3340 OUTS (outf, dregs_lo (dst0));
3341 OUTS (outf, " = ");
3342 OUTS (outf, dregs_lo (src0));
3343 OUTS (outf, " + ");
3344 OUTS (outf, dregs_hi (src1));
3345 amod1 (s, x, outf);
3347 else if (HL == 0 && aop == 2 && aopcde == 3)
3349 OUTS (outf, dregs_lo (dst0));
3350 OUTS (outf, " = ");
3351 OUTS (outf, dregs_hi (src0));
3352 OUTS (outf, " - ");
3353 OUTS (outf, dregs_lo (src1));
3354 amod1 (s, x, outf);
3356 else if (HL == 0 && aop == 3 && aopcde == 3)
3358 OUTS (outf, dregs_lo (dst0));
3359 OUTS (outf, " = ");
3360 OUTS (outf, dregs_hi (src0));
3361 OUTS (outf, " - ");
3362 OUTS (outf, dregs_hi (src1));
3363 amod1 (s, x, outf);
3365 else if (HL == 0 && aop == 0 && aopcde == 2)
3367 OUTS (outf, dregs_lo (dst0));
3368 OUTS (outf, " = ");
3369 OUTS (outf, dregs_lo (src0));
3370 OUTS (outf, " + ");
3371 OUTS (outf, dregs_lo (src1));
3372 amod1 (s, x, outf);
3374 else if (aop == 0 && aopcde == 9 && s == 1)
3376 OUTS (outf, "A0 = ");
3377 OUTS (outf, dregs (src0));
3379 else if (aop == 3 && aopcde == 11 && s == 0)
3380 OUTS (outf, "A0 -= A1");
3382 else if (aop == 3 && aopcde == 11 && s == 1)
3383 OUTS (outf, "A0 -= A1 (W32)");
3385 else if (aop == 3 && aopcde == 22 && HL == 1)
3387 OUTS (outf, dregs (dst0));
3388 OUTS (outf, " = BYTEOP2M (");
3389 OUTS (outf, dregs (src0 + 1));
3390 OUTS (outf, ":");
3391 OUTS (outf, imm5d (src0));
3392 OUTS (outf, ", ");
3393 OUTS (outf, dregs (src1 + 1));
3394 OUTS (outf, ":");
3395 OUTS (outf, imm5d (src1));
3396 OUTS (outf, ") (TH");
3397 if (s == 1)
3398 OUTS (outf, ", R)");
3399 else
3400 OUTS (outf, ")");
3402 else if (aop == 3 && aopcde == 22 && HL == 0)
3404 OUTS (outf, dregs (dst0));
3405 OUTS (outf, " = BYTEOP2M (");
3406 OUTS (outf, dregs (src0 + 1));
3407 OUTS (outf, ":");
3408 OUTS (outf, imm5d (src0));
3409 OUTS (outf, ", ");
3410 OUTS (outf, dregs (src1 + 1));
3411 OUTS (outf, ":");
3412 OUTS (outf, imm5d (src1));
3413 OUTS (outf, ") (TL");
3414 if (s == 1)
3415 OUTS (outf, ", R)");
3416 else
3417 OUTS (outf, ")");
3419 else if (aop == 2 && aopcde == 22 && HL == 1)
3421 OUTS (outf, dregs (dst0));
3422 OUTS (outf, " = BYTEOP2M (");
3423 OUTS (outf, dregs (src0 + 1));
3424 OUTS (outf, ":");
3425 OUTS (outf, imm5d (src0));
3426 OUTS (outf, ", ");
3427 OUTS (outf, dregs (src1 + 1));
3428 OUTS (outf, ":");
3429 OUTS (outf, imm5d (src1));
3430 OUTS (outf, ") (RNDH");
3431 if (s == 1)
3432 OUTS (outf, ", R)");
3433 else
3434 OUTS (outf, ")");
3436 else if (aop == 2 && aopcde == 22 && HL == 0)
3438 OUTS (outf, dregs (dst0));
3439 OUTS (outf, " = BYTEOP2M (");
3440 OUTS (outf, dregs (src0 + 1));
3441 OUTS (outf, ":");
3442 OUTS (outf, imm5d (src0));
3443 OUTS (outf, ", ");
3444 OUTS (outf, dregs (src1 + 1));
3445 OUTS (outf, ":");
3446 OUTS (outf, imm5d (src1));
3447 OUTS (outf, ") (RNDL");
3448 if (s == 1)
3449 OUTS (outf, ", R)");
3450 else
3451 OUTS (outf, ")");
3453 else if (aop == 1 && aopcde == 22 && HL == 1)
3455 OUTS (outf, dregs (dst0));
3456 OUTS (outf, " = BYTEOP2P (");
3457 OUTS (outf, dregs (src0 + 1));
3458 OUTS (outf, ":");
3459 OUTS (outf, imm5d (src0));
3460 OUTS (outf, ", ");
3461 OUTS (outf, dregs (src1 + 1));
3462 OUTS (outf, ":");
3463 OUTS (outf, imm5d (src1));
3464 OUTS (outf, ") (TH");
3465 if (s == 1)
3466 OUTS (outf, ", R)");
3467 else
3468 OUTS (outf, ")");
3470 else if (aop == 1 && aopcde == 22 && HL == 0)
3472 OUTS (outf, dregs (dst0));
3473 OUTS (outf, " = BYTEOP2P (");
3474 OUTS (outf, dregs (src0 + 1));
3475 OUTS (outf, ":");
3476 OUTS (outf, imm5d (src0));
3477 OUTS (outf, ", ");
3478 OUTS (outf, dregs (src1 + 1));
3479 OUTS (outf, ":");
3480 OUTS (outf, imm5d (src1));
3481 OUTS (outf, ") (TL");
3482 if (s == 1)
3483 OUTS (outf, ", R)");
3484 else
3485 OUTS (outf, ")");
3487 else if (aop == 0 && aopcde == 22 && HL == 1)
3489 OUTS (outf, dregs (dst0));
3490 OUTS (outf, " = BYTEOP2P (");
3491 OUTS (outf, dregs (src0 + 1));
3492 OUTS (outf, ":");
3493 OUTS (outf, imm5d (src0));
3494 OUTS (outf, ", ");
3495 OUTS (outf, dregs (src1 + 1));
3496 OUTS (outf, ":");
3497 OUTS (outf, imm5d (src1));
3498 OUTS (outf, ") (RNDH");
3499 if (s == 1)
3500 OUTS (outf, ", R)");
3501 else
3502 OUTS (outf, ")");
3504 else if (aop == 0 && aopcde == 22 && HL == 0)
3506 OUTS (outf, dregs (dst0));
3507 OUTS (outf, " = BYTEOP2P (");
3508 OUTS (outf, dregs (src0 + 1));
3509 OUTS (outf, ":");
3510 OUTS (outf, imm5d (src0));
3511 OUTS (outf, ", ");
3512 OUTS (outf, dregs (src1 + 1));
3513 OUTS (outf, ":");
3514 OUTS (outf, imm5d (src1));
3515 OUTS (outf, ") (RNDL");
3516 if (s == 1)
3517 OUTS (outf, ", R)");
3518 else
3519 OUTS (outf, ")");
3521 else if (aop == 0 && s == 0 && aopcde == 8)
3522 OUTS (outf, "A0 = 0");
3524 else if (aop == 0 && s == 1 && aopcde == 8)
3525 OUTS (outf, "A0 = A0 (S)");
3527 else if (aop == 1 && s == 0 && aopcde == 8)
3528 OUTS (outf, "A1 = 0");
3530 else if (aop == 1 && s == 1 && aopcde == 8)
3531 OUTS (outf, "A1 = A1 (S)");
3533 else if (aop == 2 && s == 0 && aopcde == 8)
3534 OUTS (outf, "A1 = A0 = 0");
3536 else if (aop == 2 && s == 1 && aopcde == 8)
3537 OUTS (outf, "A1 = A1 (S), A0 = A0 (S)");
3539 else if (aop == 3 && s == 0 && aopcde == 8)
3540 OUTS (outf, "A0 = A1");
3542 else if (aop == 3 && s == 1 && aopcde == 8)
3543 OUTS (outf, "A1 = A0");
3545 else if (aop == 1 && aopcde == 9 && s == 0)
3547 OUTS (outf, "A0.X = ");
3548 OUTS (outf, dregs_lo (src0));
3550 else if (aop == 1 && HL == 0 && aopcde == 11)
3552 OUTS (outf, dregs_lo (dst0));
3553 OUTS (outf, " = (A0 += A1)");
3555 else if (aop == 3 && HL == 0 && aopcde == 16)
3556 OUTS (outf, "A1 = ABS A0, A0 = ABS A0");
3558 else if (aop == 0 && aopcde == 23 && HL == 1)
3560 OUTS (outf, dregs (dst0));
3561 OUTS (outf, " = BYTEOP3P (");
3562 OUTS (outf, dregs (src0 + 1));
3563 OUTS (outf, ":");
3564 OUTS (outf, imm5d (src0));
3565 OUTS (outf, ", ");
3566 OUTS (outf, dregs (src1 + 1));
3567 OUTS (outf, ":");
3568 OUTS (outf, imm5d (src1));
3569 OUTS (outf, ") (HI");
3570 if (s == 1)
3571 OUTS (outf, ", R)");
3572 else
3573 OUTS (outf, ")");
3575 else if (aop == 3 && aopcde == 9 && s == 0)
3577 OUTS (outf, "A1.X = ");
3578 OUTS (outf, dregs_lo (src0));
3580 else if (aop == 1 && HL == 1 && aopcde == 16)
3581 OUTS (outf, "A1 = ABS A1");
3583 else if (aop == 0 && HL == 1 && aopcde == 16)
3584 OUTS (outf, "A1 = ABS A0");
3586 else if (aop == 2 && aopcde == 9 && s == 1)
3588 OUTS (outf, "A1 = ");
3589 OUTS (outf, dregs (src0));
3591 else if (HL == 0 && aop == 3 && aopcde == 12)
3593 OUTS (outf, dregs_lo (dst0));
3594 OUTS (outf, " = ");
3595 OUTS (outf, dregs (src0));
3596 OUTS (outf, " (RND)");
3598 else if (aop == 1 && HL == 0 && aopcde == 16)
3599 OUTS (outf, "A0 = ABS A1");
3601 else if (aop == 0 && HL == 0 && aopcde == 16)
3602 OUTS (outf, "A0 = ABS A0");
3604 else if (aop == 3 && HL == 0 && aopcde == 15)
3606 OUTS (outf, dregs (dst0));
3607 OUTS (outf, " = -");
3608 OUTS (outf, dregs (src0));
3609 OUTS (outf, " (V)");
3611 else if (aop == 3 && s == 1 && HL == 0 && aopcde == 7)
3613 OUTS (outf, dregs (dst0));
3614 OUTS (outf, " = -");
3615 OUTS (outf, dregs (src0));
3616 OUTS (outf, " (S)");
3618 else if (aop == 3 && s == 0 && HL == 0 && aopcde == 7)
3620 OUTS (outf, dregs (dst0));
3621 OUTS (outf, " = -");
3622 OUTS (outf, dregs (src0));
3623 OUTS (outf, " (NS)");
3625 else if (aop == 1 && HL == 1 && aopcde == 11)
3627 OUTS (outf, dregs_hi (dst0));
3628 OUTS (outf, " = (A0 += A1)");
3630 else if (aop == 2 && aopcde == 11 && s == 0)
3631 OUTS (outf, "A0 += A1");
3633 else if (aop == 2 && aopcde == 11 && s == 1)
3634 OUTS (outf, "A0 += A1 (W32)");
3636 else if (aop == 3 && HL == 0 && aopcde == 14)
3637 OUTS (outf, "A1 = -A1, A0 = -A0");
3639 else if (HL == 1 && aop == 3 && aopcde == 12)
3641 OUTS (outf, dregs_hi (dst0));
3642 OUTS (outf, " = ");
3643 OUTS (outf, dregs (src0));
3644 OUTS (outf, " (RND)");
3646 else if (aop == 0 && aopcde == 23 && HL == 0)
3648 OUTS (outf, dregs (dst0));
3649 OUTS (outf, " = BYTEOP3P (");
3650 OUTS (outf, dregs (src0 + 1));
3651 OUTS (outf, ":");
3652 OUTS (outf, imm5d (src0));
3653 OUTS (outf, ", ");
3654 OUTS (outf, dregs (src1 + 1));
3655 OUTS (outf, ":");
3656 OUTS (outf, imm5d (src1));
3657 OUTS (outf, ") (LO");
3658 if (s == 1)
3659 OUTS (outf, ", R)");
3660 else
3661 OUTS (outf, ")");
3663 else if (aop == 0 && HL == 0 && aopcde == 14)
3664 OUTS (outf, "A0 = -A0");
3666 else if (aop == 1 && HL == 0 && aopcde == 14)
3667 OUTS (outf, "A0 = -A1");
3669 else if (aop == 0 && HL == 1 && aopcde == 14)
3670 OUTS (outf, "A1 = -A0");
3672 else if (aop == 1 && HL == 1 && aopcde == 14)
3673 OUTS (outf, "A1 = -A1");
3675 else if (aop == 0 && aopcde == 12)
3677 OUTS (outf, dregs_hi (dst0));
3678 OUTS (outf, " = ");
3679 OUTS (outf, dregs_lo (dst0));
3680 OUTS (outf, " = SIGN (");
3681 OUTS (outf, dregs_hi (src0));
3682 OUTS (outf, ") * ");
3683 OUTS (outf, dregs_hi (src1));
3684 OUTS (outf, " + SIGN (");
3685 OUTS (outf, dregs_lo (src0));
3686 OUTS (outf, ") * ");
3687 OUTS (outf, dregs_lo (src1));
3689 else if (aop == 2 && aopcde == 0)
3691 OUTS (outf, dregs (dst0));
3692 OUTS (outf, " = ");
3693 OUTS (outf, dregs (src0));
3694 OUTS (outf, " -|+ ");
3695 OUTS (outf, dregs (src1));
3696 amod0 (s, x, outf);
3698 else if (aop == 1 && aopcde == 12)
3700 OUTS (outf, dregs (dst1));
3701 OUTS (outf, " = A1.L + A1.H, ");
3702 OUTS (outf, dregs (dst0));
3703 OUTS (outf, " = A0.L + A0.H");
3705 else if (aop == 2 && aopcde == 4)
3707 OUTS (outf, dregs (dst1));
3708 OUTS (outf, " = ");
3709 OUTS (outf, dregs (src0));
3710 OUTS (outf, " + ");
3711 OUTS (outf, dregs (src1));
3712 OUTS (outf, ", ");
3713 OUTS (outf, dregs (dst0));
3714 OUTS (outf, " = ");
3715 OUTS (outf, dregs (src0));
3716 OUTS (outf, " - ");
3717 OUTS (outf, dregs (src1));
3718 amod1 (s, x, outf);
3720 else if (HL == 0 && aopcde == 1)
3722 OUTS (outf, dregs (dst1));
3723 OUTS (outf, " = ");
3724 OUTS (outf, dregs (src0));
3725 OUTS (outf, " +|+ ");
3726 OUTS (outf, dregs (src1));
3727 OUTS (outf, ", ");
3728 OUTS (outf, dregs (dst0));
3729 OUTS (outf, " = ");
3730 OUTS (outf, dregs (src0));
3731 OUTS (outf, " -|- ");
3732 OUTS (outf, dregs (src1));
3733 amod0amod2 (s, x, aop, outf);
3735 else if (aop == 0 && aopcde == 11)
3737 OUTS (outf, dregs (dst0));
3738 OUTS (outf, " = (A0 += A1)");
3740 else if (aop == 0 && aopcde == 10)
3742 OUTS (outf, dregs_lo (dst0));
3743 OUTS (outf, " = A0.X");
3745 else if (aop == 1 && aopcde == 10)
3747 OUTS (outf, dregs_lo (dst0));
3748 OUTS (outf, " = A1.X");
3750 else if (aop == 1 && aopcde == 0)
3752 OUTS (outf, dregs (dst0));
3753 OUTS (outf, " = ");
3754 OUTS (outf, dregs (src0));
3755 OUTS (outf, " +|- ");
3756 OUTS (outf, dregs (src1));
3757 amod0 (s, x, outf);
3759 else if (aop == 3 && aopcde == 0)
3761 OUTS (outf, dregs (dst0));
3762 OUTS (outf, " = ");
3763 OUTS (outf, dregs (src0));
3764 OUTS (outf, " -|- ");
3765 OUTS (outf, dregs (src1));
3766 amod0 (s, x, outf);
3768 else if (aop == 1 && aopcde == 4)
3770 OUTS (outf, dregs (dst0));
3771 OUTS (outf, " = ");
3772 OUTS (outf, dregs (src0));
3773 OUTS (outf, " - ");
3774 OUTS (outf, dregs (src1));
3775 amod1 (s, x, outf);
3777 else if (aop == 0 && aopcde == 17)
3779 OUTS (outf, dregs (dst1));
3780 OUTS (outf, " = A1 + A0, ");
3781 OUTS (outf, dregs (dst0));
3782 OUTS (outf, " = A1 - A0");
3783 amod1 (s, x, outf);
3785 else if (aop == 1 && aopcde == 17)
3787 OUTS (outf, dregs (dst1));
3788 OUTS (outf, " = A0 + A1, ");
3789 OUTS (outf, dregs (dst0));
3790 OUTS (outf, " = A0 - A1");
3791 amod1 (s, x, outf);
3793 else if (aop == 0 && aopcde == 18)
3795 OUTS (outf, "SAA (");
3796 OUTS (outf, dregs (src0 + 1));
3797 OUTS (outf, ":");
3798 OUTS (outf, imm5d (src0));
3799 OUTS (outf, ", ");
3800 OUTS (outf, dregs (src1 + 1));
3801 OUTS (outf, ":");
3802 OUTS (outf, imm5d (src1));
3803 OUTS (outf, ")");
3804 aligndir (s, outf);
3806 else if (aop == 3 && aopcde == 18)
3807 OUTS (outf, "DISALGNEXCPT");
3809 else if (aop == 0 && aopcde == 20)
3811 OUTS (outf, dregs (dst0));
3812 OUTS (outf, " = BYTEOP1P (");
3813 OUTS (outf, dregs (src0 + 1));
3814 OUTS (outf, ":");
3815 OUTS (outf, imm5d (src0));
3816 OUTS (outf, ", ");
3817 OUTS (outf, dregs (src1 + 1));
3818 OUTS (outf, ":");
3819 OUTS (outf, imm5d (src1));
3820 OUTS (outf, ")");
3821 aligndir (s, outf);
3823 else if (aop == 1 && aopcde == 20)
3825 OUTS (outf, dregs (dst0));
3826 OUTS (outf, " = BYTEOP1P (");
3827 OUTS (outf, dregs (src0 + 1));
3828 OUTS (outf, ":");
3829 OUTS (outf, imm5d (src0));
3830 OUTS (outf, ", ");
3831 OUTS (outf, dregs (src1 + 1));
3832 OUTS (outf, ":");
3833 OUTS (outf, imm5d (src1));
3834 OUTS (outf, ") (T");
3835 if (s == 1)
3836 OUTS (outf, ", R)");
3837 else
3838 OUTS (outf, ")");
3840 else if (aop == 0 && aopcde == 21)
3842 OUTS (outf, "(");
3843 OUTS (outf, dregs (dst1));
3844 OUTS (outf, ", ");
3845 OUTS (outf, dregs (dst0));
3846 OUTS (outf, ") = BYTEOP16P (");
3847 OUTS (outf, dregs (src0 + 1));
3848 OUTS (outf, ":");
3849 OUTS (outf, imm5d (src0));
3850 OUTS (outf, ", ");
3851 OUTS (outf, dregs (src1 + 1));
3852 OUTS (outf, ":");
3853 OUTS (outf, imm5d (src1));
3854 OUTS (outf, ")");
3855 aligndir (s, outf);
3857 else if (aop == 1 && aopcde == 21)
3859 OUTS (outf, "(");
3860 OUTS (outf, dregs (dst1));
3861 OUTS (outf, ", ");
3862 OUTS (outf, dregs (dst0));
3863 OUTS (outf, ") = BYTEOP16M (");
3864 OUTS (outf, dregs (src0 + 1));
3865 OUTS (outf, ":");
3866 OUTS (outf, imm5d (src0));
3867 OUTS (outf, ", ");
3868 OUTS (outf, dregs (src1 + 1));
3869 OUTS (outf, ":");
3870 OUTS (outf, imm5d (src1));
3871 OUTS (outf, ")");
3872 aligndir (s, outf);
3874 else if (aop == 2 && aopcde == 7)
3876 OUTS (outf, dregs (dst0));
3877 OUTS (outf, " = ABS ");
3878 OUTS (outf, dregs (src0));
3880 else if (aop == 1 && aopcde == 7)
3882 OUTS (outf, dregs (dst0));
3883 OUTS (outf, " = MIN (");
3884 OUTS (outf, dregs (src0));
3885 OUTS (outf, ", ");
3886 OUTS (outf, dregs (src1));
3887 OUTS (outf, ")");
3889 else if (aop == 0 && aopcde == 7)
3891 OUTS (outf, dregs (dst0));
3892 OUTS (outf, " = MAX (");
3893 OUTS (outf, dregs (src0));
3894 OUTS (outf, ", ");
3895 OUTS (outf, dregs (src1));
3896 OUTS (outf, ")");
3898 else if (aop == 2 && aopcde == 6)
3900 OUTS (outf, dregs (dst0));
3901 OUTS (outf, " = ABS ");
3902 OUTS (outf, dregs (src0));
3903 OUTS (outf, " (V)");
3905 else if (aop == 1 && aopcde == 6)
3907 OUTS (outf, dregs (dst0));
3908 OUTS (outf, " = MIN (");
3909 OUTS (outf, dregs (src0));
3910 OUTS (outf, ", ");
3911 OUTS (outf, dregs (src1));
3912 OUTS (outf, ") (V)");
3914 else if (aop == 0 && aopcde == 6)
3916 OUTS (outf, dregs (dst0));
3917 OUTS (outf, " = MAX (");
3918 OUTS (outf, dregs (src0));
3919 OUTS (outf, ", ");
3920 OUTS (outf, dregs (src1));
3921 OUTS (outf, ") (V)");
3923 else if (HL == 1 && aopcde == 1)
3925 OUTS (outf, dregs (dst1));
3926 OUTS (outf, " = ");
3927 OUTS (outf, dregs (src0));
3928 OUTS (outf, " +|- ");
3929 OUTS (outf, dregs (src1));
3930 OUTS (outf, ", ");
3931 OUTS (outf, dregs (dst0));
3932 OUTS (outf, " = ");
3933 OUTS (outf, dregs (src0));
3934 OUTS (outf, " -|+ ");
3935 OUTS (outf, dregs (src1));
3936 amod0amod2 (s, x, aop, outf);
3938 else if (aop == 0 && aopcde == 4)
3940 OUTS (outf, dregs (dst0));
3941 OUTS (outf, " = ");
3942 OUTS (outf, dregs (src0));
3943 OUTS (outf, " + ");
3944 OUTS (outf, dregs (src1));
3945 amod1 (s, x, outf);
3947 else if (aop == 0 && aopcde == 0)
3949 OUTS (outf, dregs (dst0));
3950 OUTS (outf, " = ");
3951 OUTS (outf, dregs (src0));
3952 OUTS (outf, " +|+ ");
3953 OUTS (outf, dregs (src1));
3954 amod0 (s, x, outf);
3956 else if (aop == 0 && aopcde == 24)
3958 OUTS (outf, dregs (dst0));
3959 OUTS (outf, " = BYTEPACK (");
3960 OUTS (outf, dregs (src0));
3961 OUTS (outf, ", ");
3962 OUTS (outf, dregs (src1));
3963 OUTS (outf, ")");
3965 else if (aop == 1 && aopcde == 24)
3967 OUTS (outf, "(");
3968 OUTS (outf, dregs (dst1));
3969 OUTS (outf, ", ");
3970 OUTS (outf, dregs (dst0));
3971 OUTS (outf, ") = BYTEUNPACK ");
3972 OUTS (outf, dregs (src0 + 1));
3973 OUTS (outf, ":");
3974 OUTS (outf, imm5d (src0));
3975 aligndir (s, outf);
3977 else if (aopcde == 13)
3979 OUTS (outf, "(");
3980 OUTS (outf, dregs (dst1));
3981 OUTS (outf, ", ");
3982 OUTS (outf, dregs (dst0));
3983 OUTS (outf, ") = SEARCH ");
3984 OUTS (outf, dregs (src0));
3985 OUTS (outf, " (");
3986 searchmod (aop, outf);
3987 OUTS (outf, ")");
3989 else
3990 return 0;
3992 return 4;
3995 static int
3996 decode_dsp32shift_0 (TIword iw0, TIword iw1, disassemble_info *outf)
3998 /* dsp32shift
3999 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
4000 | 1 | 1 | 0 | 0 |.M.| 1 | 1 | 0 | 0 | - | - |.sopcde............|
4001 |.sop...|.HLs...|.dst0......| - | - | - |.src0......|.src1......|
4002 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
4003 int HLs = ((iw1 >> DSP32Shift_HLs_bits) & DSP32Shift_HLs_mask);
4004 int sop = ((iw1 >> DSP32Shift_sop_bits) & DSP32Shift_sop_mask);
4005 int src0 = ((iw1 >> DSP32Shift_src0_bits) & DSP32Shift_src0_mask);
4006 int src1 = ((iw1 >> DSP32Shift_src1_bits) & DSP32Shift_src1_mask);
4007 int dst0 = ((iw1 >> DSP32Shift_dst0_bits) & DSP32Shift_dst0_mask);
4008 int sopcde = ((iw0 >> (DSP32Shift_sopcde_bits - 16)) & DSP32Shift_sopcde_mask);
4009 const char *acc01 = (HLs & 1) == 0 ? "A0" : "A1";
4011 if (HLs == 0 && sop == 0 && sopcde == 0)
4013 OUTS (outf, dregs_lo (dst0));
4014 OUTS (outf, " = ASHIFT ");
4015 OUTS (outf, dregs_lo (src1));
4016 OUTS (outf, " BY ");
4017 OUTS (outf, dregs_lo (src0));
4019 else if (HLs == 1 && sop == 0 && sopcde == 0)
4021 OUTS (outf, dregs_lo (dst0));
4022 OUTS (outf, " = ASHIFT ");
4023 OUTS (outf, dregs_hi (src1));
4024 OUTS (outf, " BY ");
4025 OUTS (outf, dregs_lo (src0));
4027 else if (HLs == 2 && sop == 0 && sopcde == 0)
4029 OUTS (outf, dregs_hi (dst0));
4030 OUTS (outf, " = ASHIFT ");
4031 OUTS (outf, dregs_lo (src1));
4032 OUTS (outf, " BY ");
4033 OUTS (outf, dregs_lo (src0));
4035 else if (HLs == 3 && sop == 0 && sopcde == 0)
4037 OUTS (outf, dregs_hi (dst0));
4038 OUTS (outf, " = ASHIFT ");
4039 OUTS (outf, dregs_hi (src1));
4040 OUTS (outf, " BY ");
4041 OUTS (outf, dregs_lo (src0));
4043 else if (HLs == 0 && sop == 1 && sopcde == 0)
4045 OUTS (outf, dregs_lo (dst0));
4046 OUTS (outf, " = ASHIFT ");
4047 OUTS (outf, dregs_lo (src1));
4048 OUTS (outf, " BY ");
4049 OUTS (outf, dregs_lo (src0));
4050 OUTS (outf, " (S)");
4052 else if (HLs == 1 && sop == 1 && sopcde == 0)
4054 OUTS (outf, dregs_lo (dst0));
4055 OUTS (outf, " = ASHIFT ");
4056 OUTS (outf, dregs_hi (src1));
4057 OUTS (outf, " BY ");
4058 OUTS (outf, dregs_lo (src0));
4059 OUTS (outf, " (S)");
4061 else if (HLs == 2 && sop == 1 && sopcde == 0)
4063 OUTS (outf, dregs_hi (dst0));
4064 OUTS (outf, " = ASHIFT ");
4065 OUTS (outf, dregs_lo (src1));
4066 OUTS (outf, " BY ");
4067 OUTS (outf, dregs_lo (src0));
4068 OUTS (outf, " (S)");
4070 else if (HLs == 3 && sop == 1 && sopcde == 0)
4072 OUTS (outf, dregs_hi (dst0));
4073 OUTS (outf, " = ASHIFT ");
4074 OUTS (outf, dregs_hi (src1));
4075 OUTS (outf, " BY ");
4076 OUTS (outf, dregs_lo (src0));
4077 OUTS (outf, " (S)");
4079 else if (sop == 2 && sopcde == 0)
4081 OUTS (outf, (HLs & 2) == 0 ? dregs_lo (dst0) : dregs_hi (dst0));
4082 OUTS (outf, " = LSHIFT ");
4083 OUTS (outf, (HLs & 1) == 0 ? dregs_lo (src1) : dregs_hi (src1));
4084 OUTS (outf, " BY ");
4085 OUTS (outf, dregs_lo (src0));
4087 else if (sop == 0 && sopcde == 3)
4089 OUTS (outf, acc01);
4090 OUTS (outf, " = ASHIFT ");
4091 OUTS (outf, acc01);
4092 OUTS (outf, " BY ");
4093 OUTS (outf, dregs_lo (src0));
4095 else if (sop == 1 && sopcde == 3)
4097 OUTS (outf, acc01);
4098 OUTS (outf, " = LSHIFT ");
4099 OUTS (outf, acc01);
4100 OUTS (outf, " BY ");
4101 OUTS (outf, dregs_lo (src0));
4103 else if (sop == 2 && sopcde == 3)
4105 OUTS (outf, acc01);
4106 OUTS (outf, " = ROT ");
4107 OUTS (outf, acc01);
4108 OUTS (outf, " BY ");
4109 OUTS (outf, dregs_lo (src0));
4111 else if (sop == 3 && sopcde == 3)
4113 OUTS (outf, dregs (dst0));
4114 OUTS (outf, " = ROT ");
4115 OUTS (outf, dregs (src1));
4116 OUTS (outf, " BY ");
4117 OUTS (outf, dregs_lo (src0));
4119 else if (sop == 1 && sopcde == 1)
4121 OUTS (outf, dregs (dst0));
4122 OUTS (outf, " = ASHIFT ");
4123 OUTS (outf, dregs (src1));
4124 OUTS (outf, " BY ");
4125 OUTS (outf, dregs_lo (src0));
4126 OUTS (outf, " (V, S)");
4128 else if (sop == 0 && sopcde == 1)
4130 OUTS (outf, dregs (dst0));
4131 OUTS (outf, " = ASHIFT ");
4132 OUTS (outf, dregs (src1));
4133 OUTS (outf, " BY ");
4134 OUTS (outf, dregs_lo (src0));
4135 OUTS (outf, " (V)");
4137 else if (sop == 0 && sopcde == 2)
4139 OUTS (outf, dregs (dst0));
4140 OUTS (outf, " = ASHIFT ");
4141 OUTS (outf, dregs (src1));
4142 OUTS (outf, " BY ");
4143 OUTS (outf, dregs_lo (src0));
4145 else if (sop == 1 && sopcde == 2)
4147 OUTS (outf, dregs (dst0));
4148 OUTS (outf, " = ASHIFT ");
4149 OUTS (outf, dregs (src1));
4150 OUTS (outf, " BY ");
4151 OUTS (outf, dregs_lo (src0));
4152 OUTS (outf, " (S)");
4154 else if (sop == 2 && sopcde == 2)
4156 OUTS (outf, dregs (dst0));
4157 OUTS (outf, " = LSHIFT ");
4158 OUTS (outf, dregs (src1));
4159 OUTS (outf, " BY ");
4160 OUTS (outf, dregs_lo (src0));
4162 else if (sop == 3 && sopcde == 2)
4164 OUTS (outf, dregs (dst0));
4165 OUTS (outf, " = ROT ");
4166 OUTS (outf, dregs (src1));
4167 OUTS (outf, " BY ");
4168 OUTS (outf, dregs_lo (src0));
4170 else if (sop == 2 && sopcde == 1)
4172 OUTS (outf, dregs (dst0));
4173 OUTS (outf, " = LSHIFT ");
4174 OUTS (outf, dregs (src1));
4175 OUTS (outf, " BY ");
4176 OUTS (outf, dregs_lo (src0));
4177 OUTS (outf, " (V)");
4179 else if (sop == 0 && sopcde == 4)
4181 OUTS (outf, dregs (dst0));
4182 OUTS (outf, " = PACK (");
4183 OUTS (outf, dregs_lo (src1));
4184 OUTS (outf, ", ");
4185 OUTS (outf, dregs_lo (src0));
4186 OUTS (outf, ")");
4188 else if (sop == 1 && sopcde == 4)
4190 OUTS (outf, dregs (dst0));
4191 OUTS (outf, " = PACK (");
4192 OUTS (outf, dregs_lo (src1));
4193 OUTS (outf, ", ");
4194 OUTS (outf, dregs_hi (src0));
4195 OUTS (outf, ")");
4197 else if (sop == 2 && sopcde == 4)
4199 OUTS (outf, dregs (dst0));
4200 OUTS (outf, " = PACK (");
4201 OUTS (outf, dregs_hi (src1));
4202 OUTS (outf, ", ");
4203 OUTS (outf, dregs_lo (src0));
4204 OUTS (outf, ")");
4206 else if (sop == 3 && sopcde == 4)
4208 OUTS (outf, dregs (dst0));
4209 OUTS (outf, " = PACK (");
4210 OUTS (outf, dregs_hi (src1));
4211 OUTS (outf, ", ");
4212 OUTS (outf, dregs_hi (src0));
4213 OUTS (outf, ")");
4215 else if (sop == 0 && sopcde == 5)
4217 OUTS (outf, dregs_lo (dst0));
4218 OUTS (outf, " = SIGNBITS ");
4219 OUTS (outf, dregs (src1));
4221 else if (sop == 1 && sopcde == 5)
4223 OUTS (outf, dregs_lo (dst0));
4224 OUTS (outf, " = SIGNBITS ");
4225 OUTS (outf, dregs_lo (src1));
4227 else if (sop == 2 && sopcde == 5)
4229 OUTS (outf, dregs_lo (dst0));
4230 OUTS (outf, " = SIGNBITS ");
4231 OUTS (outf, dregs_hi (src1));
4233 else if (sop == 0 && sopcde == 6)
4235 OUTS (outf, dregs_lo (dst0));
4236 OUTS (outf, " = SIGNBITS A0");
4238 else if (sop == 1 && sopcde == 6)
4240 OUTS (outf, dregs_lo (dst0));
4241 OUTS (outf, " = SIGNBITS A1");
4243 else if (sop == 3 && sopcde == 6)
4245 OUTS (outf, dregs_lo (dst0));
4246 OUTS (outf, " = ONES ");
4247 OUTS (outf, dregs (src1));
4249 else if (sop == 0 && sopcde == 7)
4251 OUTS (outf, dregs_lo (dst0));
4252 OUTS (outf, " = EXPADJ (");
4253 OUTS (outf, dregs (src1));
4254 OUTS (outf, ", ");
4255 OUTS (outf, dregs_lo (src0));
4256 OUTS (outf, ")");
4258 else if (sop == 1 && sopcde == 7)
4260 OUTS (outf, dregs_lo (dst0));
4261 OUTS (outf, " = EXPADJ (");
4262 OUTS (outf, dregs (src1));
4263 OUTS (outf, ", ");
4264 OUTS (outf, dregs_lo (src0));
4265 OUTS (outf, ") (V)");
4267 else if (sop == 2 && sopcde == 7)
4269 OUTS (outf, dregs_lo (dst0));
4270 OUTS (outf, " = EXPADJ (");
4271 OUTS (outf, dregs_lo (src1));
4272 OUTS (outf, ", ");
4273 OUTS (outf, dregs_lo (src0));
4274 OUTS (outf, ")");
4276 else if (sop == 3 && sopcde == 7)
4278 OUTS (outf, dregs_lo (dst0));
4279 OUTS (outf, " = EXPADJ (");
4280 OUTS (outf, dregs_hi (src1));
4281 OUTS (outf, ", ");
4282 OUTS (outf, dregs_lo (src0));
4283 OUTS (outf, ")");
4285 else if (sop == 0 && sopcde == 8)
4287 OUTS (outf, "BITMUX (");
4288 OUTS (outf, dregs (src0));
4289 OUTS (outf, ", ");
4290 OUTS (outf, dregs (src1));
4291 OUTS (outf, ", A0) (ASR)");
4293 else if (sop == 1 && sopcde == 8)
4295 OUTS (outf, "BITMUX (");
4296 OUTS (outf, dregs (src0));
4297 OUTS (outf, ", ");
4298 OUTS (outf, dregs (src1));
4299 OUTS (outf, ", A0) (ASL)");
4301 else if (sop == 0 && sopcde == 9)
4303 OUTS (outf, dregs_lo (dst0));
4304 OUTS (outf, " = VIT_MAX (");
4305 OUTS (outf, dregs (src1));
4306 OUTS (outf, ") (ASL)");
4308 else if (sop == 1 && sopcde == 9)
4310 OUTS (outf, dregs_lo (dst0));
4311 OUTS (outf, " = VIT_MAX (");
4312 OUTS (outf, dregs (src1));
4313 OUTS (outf, ") (ASR)");
4315 else if (sop == 2 && sopcde == 9)
4317 OUTS (outf, dregs (dst0));
4318 OUTS (outf, " = VIT_MAX (");
4319 OUTS (outf, dregs (src1));
4320 OUTS (outf, ", ");
4321 OUTS (outf, dregs (src0));
4322 OUTS (outf, ") (ASL)");
4324 else if (sop == 3 && sopcde == 9)
4326 OUTS (outf, dregs (dst0));
4327 OUTS (outf, " = VIT_MAX (");
4328 OUTS (outf, dregs (src1));
4329 OUTS (outf, ", ");
4330 OUTS (outf, dregs (src0));
4331 OUTS (outf, ") (ASR)");
4333 else if (sop == 0 && sopcde == 10)
4335 OUTS (outf, dregs (dst0));
4336 OUTS (outf, " = EXTRACT (");
4337 OUTS (outf, dregs (src1));
4338 OUTS (outf, ", ");
4339 OUTS (outf, dregs_lo (src0));
4340 OUTS (outf, ") (Z)");
4342 else if (sop == 1 && sopcde == 10)
4344 OUTS (outf, dregs (dst0));
4345 OUTS (outf, " = EXTRACT (");
4346 OUTS (outf, dregs (src1));
4347 OUTS (outf, ", ");
4348 OUTS (outf, dregs_lo (src0));
4349 OUTS (outf, ") (X)");
4351 else if (sop == 2 && sopcde == 10)
4353 OUTS (outf, dregs (dst0));
4354 OUTS (outf, " = DEPOSIT (");
4355 OUTS (outf, dregs (src1));
4356 OUTS (outf, ", ");
4357 OUTS (outf, dregs (src0));
4358 OUTS (outf, ")");
4360 else if (sop == 3 && sopcde == 10)
4362 OUTS (outf, dregs (dst0));
4363 OUTS (outf, " = DEPOSIT (");
4364 OUTS (outf, dregs (src1));
4365 OUTS (outf, ", ");
4366 OUTS (outf, dregs (src0));
4367 OUTS (outf, ") (X)");
4369 else if (sop == 0 && sopcde == 11)
4371 OUTS (outf, dregs_lo (dst0));
4372 OUTS (outf, " = CC = BXORSHIFT (A0, ");
4373 OUTS (outf, dregs (src0));
4374 OUTS (outf, ")");
4376 else if (sop == 1 && sopcde == 11)
4378 OUTS (outf, dregs_lo (dst0));
4379 OUTS (outf, " = CC = BXOR (A0, ");
4380 OUTS (outf, dregs (src0));
4381 OUTS (outf, ")");
4383 else if (sop == 0 && sopcde == 12)
4384 OUTS (outf, "A0 = BXORSHIFT (A0, A1, CC)");
4386 else if (sop == 1 && sopcde == 12)
4388 OUTS (outf, dregs_lo (dst0));
4389 OUTS (outf, " = CC = BXOR (A0, A1, CC)");
4391 else if (sop == 0 && sopcde == 13)
4393 OUTS (outf, dregs (dst0));
4394 OUTS (outf, " = ALIGN8 (");
4395 OUTS (outf, dregs (src1));
4396 OUTS (outf, ", ");
4397 OUTS (outf, dregs (src0));
4398 OUTS (outf, ")");
4400 else if (sop == 1 && sopcde == 13)
4402 OUTS (outf, dregs (dst0));
4403 OUTS (outf, " = ALIGN16 (");
4404 OUTS (outf, dregs (src1));
4405 OUTS (outf, ", ");
4406 OUTS (outf, dregs (src0));
4407 OUTS (outf, ")");
4409 else if (sop == 2 && sopcde == 13)
4411 OUTS (outf, dregs (dst0));
4412 OUTS (outf, " = ALIGN24 (");
4413 OUTS (outf, dregs (src1));
4414 OUTS (outf, ", ");
4415 OUTS (outf, dregs (src0));
4416 OUTS (outf, ")");
4418 else
4419 return 0;
4421 return 4;
4424 static int
4425 decode_dsp32shiftimm_0 (TIword iw0, TIword iw1, disassemble_info *outf)
4427 /* dsp32shiftimm
4428 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
4429 | 1 | 1 | 0 | 0 |.M.| 1 | 1 | 0 | 1 | - | - |.sopcde............|
4430 |.sop...|.HLs...|.dst0......|.immag.................|.src1......|
4431 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
4432 int src1 = ((iw1 >> DSP32ShiftImm_src1_bits) & DSP32ShiftImm_src1_mask);
4433 int sop = ((iw1 >> DSP32ShiftImm_sop_bits) & DSP32ShiftImm_sop_mask);
4434 int bit8 = ((iw1 >> 8) & 0x1);
4435 int immag = ((iw1 >> DSP32ShiftImm_immag_bits) & DSP32ShiftImm_immag_mask);
4436 int newimmag = (-(iw1 >> DSP32ShiftImm_immag_bits) & DSP32ShiftImm_immag_mask);
4437 int dst0 = ((iw1 >> DSP32ShiftImm_dst0_bits) & DSP32ShiftImm_dst0_mask);
4438 int sopcde = ((iw0 >> (DSP32ShiftImm_sopcde_bits - 16)) & DSP32ShiftImm_sopcde_mask);
4439 int HLs = ((iw1 >> DSP32ShiftImm_HLs_bits) & DSP32ShiftImm_HLs_mask);
4442 if (sop == 0 && sopcde == 0)
4444 OUTS (outf, (HLs & 2) ? dregs_hi (dst0) : dregs_lo (dst0));
4445 OUTS (outf, " = ");
4446 OUTS (outf, (HLs & 1) ? dregs_hi (src1) : dregs_lo (src1));
4447 OUTS (outf, " >>> ");
4448 OUTS (outf, uimm4 (newimmag));
4450 else if (sop == 1 && sopcde == 0 && bit8 == 0)
4452 OUTS (outf, (HLs & 2) ? dregs_hi (dst0) : dregs_lo (dst0));
4453 OUTS (outf, " = ");
4454 OUTS (outf, (HLs & 1) ? dregs_hi (src1) : dregs_lo (src1));
4455 OUTS (outf, " << ");
4456 OUTS (outf, uimm4 (immag));
4457 OUTS (outf, " (S)");
4459 else if (sop == 1 && sopcde == 0 && bit8 == 1)
4461 OUTS (outf, (HLs & 2) ? dregs_hi (dst0) : dregs_lo (dst0));
4462 OUTS (outf, " = ");
4463 OUTS (outf, (HLs & 1) ? dregs_hi (src1) : dregs_lo (src1));
4464 OUTS (outf, " >>> ");
4465 OUTS (outf, uimm4 (newimmag));
4466 OUTS (outf, " (S)");
4468 else if (sop == 2 && sopcde == 0 && bit8 == 0)
4470 OUTS (outf, (HLs & 2) ? dregs_hi (dst0) : dregs_lo (dst0));
4471 OUTS (outf, " = ");
4472 OUTS (outf, (HLs & 1) ? dregs_hi (src1) : dregs_lo (src1));
4473 OUTS (outf, " << ");
4474 OUTS (outf, uimm4 (immag));
4476 else if (sop == 2 && sopcde == 0 && bit8 == 1)
4478 OUTS (outf, (HLs & 2) ? dregs_hi (dst0) : dregs_lo (dst0));
4479 OUTS (outf, " = ");
4480 OUTS (outf, (HLs & 1) ? dregs_hi (src1) : dregs_lo (src1));
4481 OUTS (outf, " >> ");
4482 OUTS (outf, uimm4 (newimmag));
4484 else if (sop == 2 && sopcde == 3 && HLs == 1)
4486 OUTS (outf, "A1 = ROT A1 BY ");
4487 OUTS (outf, imm6 (immag));
4489 else if (sop == 0 && sopcde == 3 && HLs == 0 && bit8 == 0)
4491 OUTS (outf, "A0 = A0 << ");
4492 OUTS (outf, uimm5 (immag));
4494 else if (sop == 0 && sopcde == 3 && HLs == 0 && bit8 == 1)
4496 OUTS (outf, "A0 = A0 >>> ");
4497 OUTS (outf, uimm5 (newimmag));
4499 else if (sop == 0 && sopcde == 3 && HLs == 1 && bit8 == 0)
4501 OUTS (outf, "A1 = A1 << ");
4502 OUTS (outf, uimm5 (immag));
4504 else if (sop == 0 && sopcde == 3 && HLs == 1 && bit8 == 1)
4506 OUTS (outf, "A1 = A1 >>> ");
4507 OUTS (outf, uimm5 (newimmag));
4509 else if (sop == 1 && sopcde == 3 && HLs == 0)
4511 OUTS (outf, "A0 = A0 >> ");
4512 OUTS (outf, uimm5 (newimmag));
4514 else if (sop == 1 && sopcde == 3 && HLs == 1)
4516 OUTS (outf, "A1 = A1 >> ");
4517 OUTS (outf, uimm5 (newimmag));
4519 else if (sop == 2 && sopcde == 3 && HLs == 0)
4521 OUTS (outf, "A0 = ROT A0 BY ");
4522 OUTS (outf, imm6 (immag));
4524 else if (sop == 1 && sopcde == 1 && bit8 == 0)
4526 OUTS (outf, dregs (dst0));
4527 OUTS (outf, " = ");
4528 OUTS (outf, dregs (src1));
4529 OUTS (outf, " << ");
4530 OUTS (outf, uimm5 (immag));
4531 OUTS (outf, " (V, S)");
4533 else if (sop == 1 && sopcde == 1 && bit8 == 1)
4535 OUTS (outf, dregs (dst0));
4536 OUTS (outf, " = ");
4537 OUTS (outf, dregs (src1));
4538 OUTS (outf, " >>> ");
4539 OUTS (outf, imm5 (-immag));
4540 OUTS (outf, " (V, S)");
4542 else if (sop == 2 && sopcde == 1 && bit8 == 1)
4544 OUTS (outf, dregs (dst0));
4545 OUTS (outf, " = ");
4546 OUTS (outf, dregs (src1));
4547 OUTS (outf, " >> ");
4548 OUTS (outf, uimm5 (newimmag));
4549 OUTS (outf, " (V)");
4551 else if (sop == 2 && sopcde == 1 && bit8 == 0)
4553 OUTS (outf, dregs (dst0));
4554 OUTS (outf, " = ");
4555 OUTS (outf, dregs (src1));
4556 OUTS (outf, " << ");
4557 OUTS (outf, imm5 (immag));
4558 OUTS (outf, " (V)");
4560 else if (sop == 0 && sopcde == 1)
4562 OUTS (outf, dregs (dst0));
4563 OUTS (outf, " = ");
4564 OUTS (outf, dregs (src1));
4565 OUTS (outf, " >>> ");
4566 OUTS (outf, uimm5 (newimmag));
4567 OUTS (outf, " (V)");
4569 else if (sop == 1 && sopcde == 2)
4571 OUTS (outf, dregs (dst0));
4572 OUTS (outf, " = ");
4573 OUTS (outf, dregs (src1));
4574 OUTS (outf, " << ");
4575 OUTS (outf, uimm5 (immag));
4576 OUTS (outf, " (S)");
4578 else if (sop == 2 && sopcde == 2 && bit8 == 1)
4580 OUTS (outf, dregs (dst0));
4581 OUTS (outf, " = ");
4582 OUTS (outf, dregs (src1));
4583 OUTS (outf, " >> ");
4584 OUTS (outf, uimm5 (newimmag));
4586 else if (sop == 2 && sopcde == 2 && bit8 == 0)
4588 OUTS (outf, dregs (dst0));
4589 OUTS (outf, " = ");
4590 OUTS (outf, dregs (src1));
4591 OUTS (outf, " << ");
4592 OUTS (outf, uimm5 (immag));
4594 else if (sop == 3 && sopcde == 2)
4596 OUTS (outf, dregs (dst0));
4597 OUTS (outf, " = ROT ");
4598 OUTS (outf, dregs (src1));
4599 OUTS (outf, " BY ");
4600 OUTS (outf, imm6 (immag));
4602 else if (sop == 0 && sopcde == 2)
4604 OUTS (outf, dregs (dst0));
4605 OUTS (outf, " = ");
4606 OUTS (outf, dregs (src1));
4607 OUTS (outf, " >>> ");
4608 OUTS (outf, uimm5 (newimmag));
4610 else
4611 return 0;
4613 return 4;
4616 static int
4617 decode_pseudoDEBUG_0 (TIword iw0, disassemble_info *outf)
4619 /* pseudoDEBUG
4620 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
4621 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 0 |.fn....|.grp.......|.reg.......|
4622 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
4623 int fn = ((iw0 >> PseudoDbg_fn_bits) & PseudoDbg_fn_mask);
4624 int grp = ((iw0 >> PseudoDbg_grp_bits) & PseudoDbg_grp_mask);
4625 int reg = ((iw0 >> PseudoDbg_reg_bits) & PseudoDbg_reg_mask);
4627 if (parallel)
4628 return 0;
4630 if (reg == 0 && fn == 3)
4631 OUTS (outf, "DBG A0");
4633 else if (reg == 1 && fn == 3)
4634 OUTS (outf, "DBG A1");
4636 else if (reg == 3 && fn == 3)
4637 OUTS (outf, "ABORT");
4639 else if (reg == 4 && fn == 3)
4640 OUTS (outf, "HLT");
4642 else if (reg == 5 && fn == 3)
4643 OUTS (outf, "DBGHALT");
4645 else if (reg == 6 && fn == 3)
4647 OUTS (outf, "DBGCMPLX (");
4648 OUTS (outf, dregs (grp));
4649 OUTS (outf, ")");
4651 else if (reg == 7 && fn == 3)
4652 OUTS (outf, "DBG");
4654 else if (grp == 0 && fn == 2)
4656 OUTS (outf, "OUTC ");
4657 OUTS (outf, dregs (reg));
4659 else if (fn == 0)
4661 OUTS (outf, "DBG ");
4662 OUTS (outf, allregs (reg, grp));
4664 else if (fn == 1)
4666 OUTS (outf, "PRNT");
4667 OUTS (outf, allregs (reg, grp));
4669 else
4670 return 0;
4672 return 2;
4675 static int
4676 decode_pseudoOChar_0 (TIword iw0, disassemble_info *outf)
4678 /* psedoOChar
4679 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
4680 | 1 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |.ch............................|
4681 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
4682 int ch = ((iw0 >> PseudoChr_ch_bits) & PseudoChr_ch_mask);
4684 if (parallel)
4685 return 0;
4687 OUTS (outf, "OUTC ");
4688 OUTS (outf, uimm8 (ch));
4690 return 2;
4693 static int
4694 decode_pseudodbg_assert_0 (TIword iw0, TIword iw1, disassemble_info *outf)
4696 /* pseudodbg_assert
4697 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+
4698 | 1 | 1 | 1 | 1 | 0 | - | - | - | dbgop |.grp.......|.regtest...|
4699 |.expected......................................................|
4700 +---+---+---+---|---+---+---+---|---+---+---+---|---+---+---+---+ */
4701 int expected = ((iw1 >> PseudoDbg_Assert_expected_bits) & PseudoDbg_Assert_expected_mask);
4702 int dbgop = ((iw0 >> (PseudoDbg_Assert_dbgop_bits - 16)) & PseudoDbg_Assert_dbgop_mask);
4703 int grp = ((iw0 >> (PseudoDbg_Assert_grp_bits - 16)) & PseudoDbg_Assert_grp_mask);
4704 int regtest = ((iw0 >> (PseudoDbg_Assert_regtest_bits - 16)) & PseudoDbg_Assert_regtest_mask);
4706 if (parallel)
4707 return 0;
4709 if (dbgop == 0)
4711 OUTS (outf, "DBGA (");
4712 OUTS (outf, regs_lo (regtest, grp));
4713 OUTS (outf, ", ");
4714 OUTS (outf, uimm16 (expected));
4715 OUTS (outf, ")");
4717 else if (dbgop == 1)
4719 OUTS (outf, "DBGA (");
4720 OUTS (outf, regs_hi (regtest, grp));
4721 OUTS (outf, ", ");
4722 OUTS (outf, uimm16 (expected));
4723 OUTS (outf, ")");
4725 else if (dbgop == 2)
4727 OUTS (outf, "DBGAL (");
4728 OUTS (outf, allregs (regtest, grp));
4729 OUTS (outf, ", ");
4730 OUTS (outf, uimm16 (expected));
4731 OUTS (outf, ")");
4733 else if (dbgop == 3)
4735 OUTS (outf, "DBGAH (");
4736 OUTS (outf, allregs (regtest, grp));
4737 OUTS (outf, ", ");
4738 OUTS (outf, uimm16 (expected));
4739 OUTS (outf, ")");
4741 else
4742 return 0;
4743 return 4;
4746 static int
4747 _print_insn_bfin (bfd_vma pc, disassemble_info *outf)
4749 bfd_byte buf[4];
4750 TIword iw0;
4751 TIword iw1;
4752 int status;
4753 int rv = 0;
4755 status = (*outf->read_memory_func) (pc & ~0x1, buf, 2, outf);
4756 /* FIXME */
4757 (void) status;
4758 status = (*outf->read_memory_func) ((pc + 2) & ~0x1, buf + 2, 2, outf);
4759 /* FIXME */
4760 (void) status;
4762 iw0 = bfd_getl16 (buf);
4763 iw1 = bfd_getl16 (buf + 2);
4765 if ((iw0 & 0xf7ff) == 0xc003 && iw1 == 0x1800)
4767 if (parallel)
4769 OUTS (outf, "ILLEGAL");
4770 return 0;
4772 OUTS (outf, "MNOP");
4773 return 4;
4775 else if ((iw0 & 0xff00) == 0x0000)
4776 rv = decode_ProgCtrl_0 (iw0, outf);
4777 else if ((iw0 & 0xffc0) == 0x0240)
4778 rv = decode_CaCTRL_0 (iw0, outf);
4779 else if ((iw0 & 0xff80) == 0x0100)
4780 rv = decode_PushPopReg_0 (iw0, outf);
4781 else if ((iw0 & 0xfe00) == 0x0400)
4782 rv = decode_PushPopMultiple_0 (iw0, outf);
4783 else if ((iw0 & 0xfe00) == 0x0600)
4784 rv = decode_ccMV_0 (iw0, outf);
4785 else if ((iw0 & 0xf800) == 0x0800)
4786 rv = decode_CCflag_0 (iw0, outf);
4787 else if ((iw0 & 0xffe0) == 0x0200)
4788 rv = decode_CC2dreg_0 (iw0, outf);
4789 else if ((iw0 & 0xff00) == 0x0300)
4790 rv = decode_CC2stat_0 (iw0, outf);
4791 else if ((iw0 & 0xf000) == 0x1000)
4792 rv = decode_BRCC_0 (iw0, pc, outf);
4793 else if ((iw0 & 0xf000) == 0x2000)
4794 rv = decode_UJUMP_0 (iw0, pc, outf);
4795 else if ((iw0 & 0xf000) == 0x3000)
4796 rv = decode_REGMV_0 (iw0, outf);
4797 else if ((iw0 & 0xfc00) == 0x4000)
4798 rv = decode_ALU2op_0 (iw0, outf);
4799 else if ((iw0 & 0xfe00) == 0x4400)
4800 rv = decode_PTR2op_0 (iw0, outf);
4801 else if ((iw0 & 0xf800) == 0x4800)
4802 rv = decode_LOGI2op_0 (iw0, outf);
4803 else if ((iw0 & 0xf000) == 0x5000)
4804 rv = decode_COMP3op_0 (iw0, outf);
4805 else if ((iw0 & 0xf800) == 0x6000)
4806 rv = decode_COMPI2opD_0 (iw0, outf);
4807 else if ((iw0 & 0xf800) == 0x6800)
4808 rv = decode_COMPI2opP_0 (iw0, outf);
4809 else if ((iw0 & 0xf000) == 0x8000)
4810 rv = decode_LDSTpmod_0 (iw0, outf);
4811 else if ((iw0 & 0xff60) == 0x9e60)
4812 rv = decode_dagMODim_0 (iw0, outf);
4813 else if ((iw0 & 0xfff0) == 0x9f60)
4814 rv = decode_dagMODik_0 (iw0, outf);
4815 else if ((iw0 & 0xfc00) == 0x9c00)
4816 rv = decode_dspLDST_0 (iw0, outf);
4817 else if ((iw0 & 0xf000) == 0x9000)
4818 rv = decode_LDST_0 (iw0, outf);
4819 else if ((iw0 & 0xfc00) == 0xb800)
4820 rv = decode_LDSTiiFP_0 (iw0, outf);
4821 else if ((iw0 & 0xe000) == 0xA000)
4822 rv = decode_LDSTii_0 (iw0, outf);
4823 else if ((iw0 & 0xff80) == 0xe080 && (iw1 & 0x0C00) == 0x0000)
4824 rv = decode_LoopSetup_0 (iw0, iw1, pc, outf);
4825 else if ((iw0 & 0xff00) == 0xe100 && (iw1 & 0x0000) == 0x0000)
4826 rv = decode_LDIMMhalf_0 (iw0, iw1, outf);
4827 else if ((iw0 & 0xfe00) == 0xe200 && (iw1 & 0x0000) == 0x0000)
4828 rv = decode_CALLa_0 (iw0, iw1, pc, outf);
4829 else if ((iw0 & 0xfc00) == 0xe400 && (iw1 & 0x0000) == 0x0000)
4830 rv = decode_LDSTidxI_0 (iw0, iw1, outf);
4831 else if ((iw0 & 0xfffe) == 0xe800 && (iw1 & 0x0000) == 0x0000)
4832 rv = decode_linkage_0 (iw0, iw1, outf);
4833 else if ((iw0 & 0xf600) == 0xc000 && (iw1 & 0x0000) == 0x0000)
4834 rv = decode_dsp32mac_0 (iw0, iw1, outf);
4835 else if ((iw0 & 0xf600) == 0xc200 && (iw1 & 0x0000) == 0x0000)
4836 rv = decode_dsp32mult_0 (iw0, iw1, outf);
4837 else if ((iw0 & 0xf7c0) == 0xc400 && (iw1 & 0x0000) == 0x0000)
4838 rv = decode_dsp32alu_0 (iw0, iw1, outf);
4839 else if ((iw0 & 0xf780) == 0xc600 && (iw1 & 0x01c0) == 0x0000)
4840 rv = decode_dsp32shift_0 (iw0, iw1, outf);
4841 else if ((iw0 & 0xf780) == 0xc680 && (iw1 & 0x0000) == 0x0000)
4842 rv = decode_dsp32shiftimm_0 (iw0, iw1, outf);
4843 else if ((iw0 & 0xff00) == 0xf800)
4844 rv = decode_pseudoDEBUG_0 (iw0, outf);
4845 else if ((iw0 & 0xFF00) == 0xF900)
4846 rv = decode_pseudoOChar_0 (iw0, outf);
4847 else if ((iw0 & 0xFF00) == 0xf000 && (iw1 & 0x0000) == 0x0000)
4848 rv = decode_pseudodbg_assert_0 (iw0, iw1, outf);
4850 if (rv == 0)
4851 OUTS (outf, "ILLEGAL");
4853 return rv;
4858 print_insn_bfin (bfd_vma pc, disassemble_info *outf)
4860 bfd_byte buf[2];
4861 unsigned short iw0;
4862 int status;
4863 int count = 0;
4865 status = (*outf->read_memory_func) (pc & ~0x01, buf, 2, outf);
4866 /* FIXME */
4867 (void) status;
4868 iw0 = bfd_getl16 (buf);
4870 count += _print_insn_bfin (pc, outf);
4872 /* Proper display of multiple issue instructions. */
4874 if (count == 4 && (iw0 & 0xc000) == 0xc000 && (iw0 & BIT_MULTI_INS)
4875 && ((iw0 & 0xe800) != 0xe800 /* Not Linkage. */ ))
4877 int legal = 1;
4878 int len;
4880 parallel = 1;
4881 outf->fprintf_func (outf->stream, " || ");
4882 len = _print_insn_bfin (pc + 4, outf);
4883 outf->fprintf_func (outf->stream, " || ");
4884 if (len != 2)
4885 legal = 0;
4886 len = _print_insn_bfin (pc + 6, outf);
4887 if (len != 2)
4888 legal = 0;
4890 if (legal)
4891 count = 8;
4892 else
4894 outf->fprintf_func (outf->stream, ";\t\t/* ILLEGAL PARALLEL INSTRUCTION */");
4895 comment = 1;
4896 count = 0;
4898 parallel = 0;
4901 if (!comment)
4902 outf->fprintf_func (outf->stream, ";");
4904 if (count == 0)
4905 return 2;
4907 comment = 0;
4909 return count;