OpenCores
URL https://opencores.org/ocsvn/open8_urisc/open8_urisc/trunk

Subversion Repositories open8_urisc

[/] [open8_urisc/] [trunk/] [gnu/] [binutils/] [opcodes/] [m32c-ibld.c] - Blame information for rev 18

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 18 khays
/* Instruction building/extraction support for m32c. -*- C -*-
2
 
3
   THIS FILE IS MACHINE GENERATED WITH CGEN: Cpu tools GENerator.
4
   - the resultant file is machine generated, cgen-ibld.in isn't
5
 
6
   Copyright 1996, 1997, 1998, 1999, 2000, 2001, 2005, 2006, 2007,
7
   2008, 2010  Free Software Foundation, Inc.
8
 
9
   This file is part of libopcodes.
10
 
11
   This library is free software; you can redistribute it and/or modify
12
   it under the terms of the GNU General Public License as published by
13
   the Free Software Foundation; either version 3, or (at your option)
14
   any later version.
15
 
16
   It is distributed in the hope that it will be useful, but WITHOUT
17
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
18
   or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
19
   License for more details.
20
 
21
   You should have received a copy of the GNU General Public License
22
   along with this program; if not, write to the Free Software Foundation, Inc.,
23
   51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.  */
24
 
25
/* ??? Eventually more and more of this stuff can go to cpu-independent files.
26
   Keep that in mind.  */
27
 
28
#include "sysdep.h"
29
#include <stdio.h>
30
#include "ansidecl.h"
31
#include "dis-asm.h"
32
#include "bfd.h"
33
#include "symcat.h"
34
#include "m32c-desc.h"
35
#include "m32c-opc.h"
36
#include "cgen/basic-modes.h"
37
#include "opintl.h"
38
#include "safe-ctype.h"
39
 
40
#undef  min
41
#define min(a,b) ((a) < (b) ? (a) : (b))
42
#undef  max
43
#define max(a,b) ((a) > (b) ? (a) : (b))
44
 
45
/* Used by the ifield rtx function.  */
46
#define FLD(f) (fields->f)
47
 
48
static const char * insert_normal
49
  (CGEN_CPU_DESC, long, unsigned int, unsigned int, unsigned int,
50
   unsigned int, unsigned int, unsigned int, CGEN_INSN_BYTES_PTR);
51
static const char * insert_insn_normal
52
  (CGEN_CPU_DESC, const CGEN_INSN *,
53
   CGEN_FIELDS *, CGEN_INSN_BYTES_PTR, bfd_vma);
54
static int extract_normal
55
  (CGEN_CPU_DESC, CGEN_EXTRACT_INFO *, CGEN_INSN_INT,
56
   unsigned int, unsigned int, unsigned int, unsigned int,
57
   unsigned int, unsigned int, bfd_vma, long *);
58
static int extract_insn_normal
59
  (CGEN_CPU_DESC, const CGEN_INSN *, CGEN_EXTRACT_INFO *,
60
   CGEN_INSN_INT, CGEN_FIELDS *, bfd_vma);
61
#if CGEN_INT_INSN_P
62
static void put_insn_int_value
63
  (CGEN_CPU_DESC, CGEN_INSN_BYTES_PTR, int, int, CGEN_INSN_INT);
64
#endif
65
#if ! CGEN_INT_INSN_P
66
static CGEN_INLINE void insert_1
67
  (CGEN_CPU_DESC, unsigned long, int, int, int, unsigned char *);
68
static CGEN_INLINE int fill_cache
69
  (CGEN_CPU_DESC, CGEN_EXTRACT_INFO *,  int, int, bfd_vma);
70
static CGEN_INLINE long extract_1
71
  (CGEN_CPU_DESC, CGEN_EXTRACT_INFO *, int, int, int, unsigned char *, bfd_vma);
72
#endif
73
 
74
/* Operand insertion.  */
75
 
76
#if ! CGEN_INT_INSN_P
77
 
78
/* Subroutine of insert_normal.  */
79
 
80
static CGEN_INLINE void
81
insert_1 (CGEN_CPU_DESC cd,
82
          unsigned long value,
83
          int start,
84
          int length,
85
          int word_length,
86
          unsigned char *bufp)
87
{
88
  unsigned long x,mask;
89
  int shift;
90
 
91
  x = cgen_get_insn_value (cd, bufp, word_length);
92
 
93
  /* Written this way to avoid undefined behaviour.  */
94
  mask = (((1L << (length - 1)) - 1) << 1) | 1;
95
  if (CGEN_INSN_LSB0_P)
96
    shift = (start + 1) - length;
97
  else
98
    shift = (word_length - (start + length));
99
  x = (x & ~(mask << shift)) | ((value & mask) << shift);
100
 
101
  cgen_put_insn_value (cd, bufp, word_length, (bfd_vma) x);
102
}
103
 
104
#endif /* ! CGEN_INT_INSN_P */
105
 
106
/* Default insertion routine.
107
 
108
   ATTRS is a mask of the boolean attributes.
109
   WORD_OFFSET is the offset in bits from the start of the insn of the value.
110
   WORD_LENGTH is the length of the word in bits in which the value resides.
111
   START is the starting bit number in the word, architecture origin.
112
   LENGTH is the length of VALUE in bits.
113
   TOTAL_LENGTH is the total length of the insn in bits.
114
 
115
   The result is an error message or NULL if success.  */
116
 
117
/* ??? This duplicates functionality with bfd's howto table and
118
   bfd_install_relocation.  */
119
/* ??? This doesn't handle bfd_vma's.  Create another function when
120
   necessary.  */
121
 
122
static const char *
123
insert_normal (CGEN_CPU_DESC cd,
124
               long value,
125
               unsigned int attrs,
126
               unsigned int word_offset,
127
               unsigned int start,
128
               unsigned int length,
129
               unsigned int word_length,
130
               unsigned int total_length,
131
               CGEN_INSN_BYTES_PTR buffer)
132
{
133
  static char errbuf[100];
134
  /* Written this way to avoid undefined behaviour.  */
135
  unsigned long mask = (((1L << (length - 1)) - 1) << 1) | 1;
136
 
137
  /* If LENGTH is zero, this operand doesn't contribute to the value.  */
138
  if (length == 0)
139
    return NULL;
140
 
141
  if (word_length > 8 * sizeof (CGEN_INSN_INT))
142
    abort ();
143
 
144
  /* For architectures with insns smaller than the base-insn-bitsize,
145
     word_length may be too big.  */
146
  if (cd->min_insn_bitsize < cd->base_insn_bitsize)
147
    {
148
      if (word_offset == 0
149
          && word_length > total_length)
150
        word_length = total_length;
151
    }
152
 
153
  /* Ensure VALUE will fit.  */
154
  if (CGEN_BOOL_ATTR (attrs, CGEN_IFLD_SIGN_OPT))
155
    {
156
      long minval = - (1L << (length - 1));
157
      unsigned long maxval = mask;
158
 
159
      if ((value > 0 && (unsigned long) value > maxval)
160
          || value < minval)
161
        {
162
          /* xgettext:c-format */
163
          sprintf (errbuf,
164
                   _("operand out of range (%ld not between %ld and %lu)"),
165
                   value, minval, maxval);
166
          return errbuf;
167
        }
168
    }
169
  else if (! CGEN_BOOL_ATTR (attrs, CGEN_IFLD_SIGNED))
170
    {
171
      unsigned long maxval = mask;
172
      unsigned long val = (unsigned long) value;
173
 
174
      /* For hosts with a word size > 32 check to see if value has been sign
175
         extended beyond 32 bits.  If so then ignore these higher sign bits
176
         as the user is attempting to store a 32-bit signed value into an
177
         unsigned 32-bit field which is allowed.  */
178
      if (sizeof (unsigned long) > 4 && ((value >> 32) == -1))
179
        val &= 0xFFFFFFFF;
180
 
181
      if (val > maxval)
182
        {
183
          /* xgettext:c-format */
184
          sprintf (errbuf,
185
                   _("operand out of range (0x%lx not between 0 and 0x%lx)"),
186
                   val, maxval);
187
          return errbuf;
188
        }
189
    }
190
  else
191
    {
192
      if (! cgen_signed_overflow_ok_p (cd))
193
        {
194
          long minval = - (1L << (length - 1));
195
          long maxval =   (1L << (length - 1)) - 1;
196
 
197
          if (value < minval || value > maxval)
198
            {
199
              sprintf
200
                /* xgettext:c-format */
201
                (errbuf, _("operand out of range (%ld not between %ld and %ld)"),
202
                 value, minval, maxval);
203
              return errbuf;
204
            }
205
        }
206
    }
207
 
208
#if CGEN_INT_INSN_P
209
 
210
  {
211
    int shift;
212
 
213
    if (CGEN_INSN_LSB0_P)
214
      shift = (word_offset + start + 1) - length;
215
    else
216
      shift = total_length - (word_offset + start + length);
217
    *buffer = (*buffer & ~(mask << shift)) | ((value & mask) << shift);
218
  }
219
 
220
#else /* ! CGEN_INT_INSN_P */
221
 
222
  {
223
    unsigned char *bufp = (unsigned char *) buffer + word_offset / 8;
224
 
225
    insert_1 (cd, value, start, length, word_length, bufp);
226
  }
227
 
228
#endif /* ! CGEN_INT_INSN_P */
229
 
230
  return NULL;
231
}
232
 
233
/* Default insn builder (insert handler).
234
   The instruction is recorded in CGEN_INT_INSN_P byte order (meaning
235
   that if CGEN_INSN_BYTES_PTR is an int * and thus, the value is
236
   recorded in host byte order, otherwise BUFFER is an array of bytes
237
   and the value is recorded in target byte order).
238
   The result is an error message or NULL if success.  */
239
 
240
static const char *
241
insert_insn_normal (CGEN_CPU_DESC cd,
242
                    const CGEN_INSN * insn,
243
                    CGEN_FIELDS * fields,
244
                    CGEN_INSN_BYTES_PTR buffer,
245
                    bfd_vma pc)
246
{
247
  const CGEN_SYNTAX *syntax = CGEN_INSN_SYNTAX (insn);
248
  unsigned long value;
249
  const CGEN_SYNTAX_CHAR_TYPE * syn;
250
 
251
  CGEN_INIT_INSERT (cd);
252
  value = CGEN_INSN_BASE_VALUE (insn);
253
 
254
  /* If we're recording insns as numbers (rather than a string of bytes),
255
     target byte order handling is deferred until later.  */
256
 
257
#if CGEN_INT_INSN_P
258
 
259
  put_insn_int_value (cd, buffer, cd->base_insn_bitsize,
260
                      CGEN_FIELDS_BITSIZE (fields), value);
261
 
262
#else
263
 
264
  cgen_put_insn_value (cd, buffer, min ((unsigned) cd->base_insn_bitsize,
265
                                        (unsigned) CGEN_FIELDS_BITSIZE (fields)),
266
                       value);
267
 
268
#endif /* ! CGEN_INT_INSN_P */
269
 
270
  /* ??? It would be better to scan the format's fields.
271
     Still need to be able to insert a value based on the operand though;
272
     e.g. storing a branch displacement that got resolved later.
273
     Needs more thought first.  */
274
 
275
  for (syn = CGEN_SYNTAX_STRING (syntax); * syn; ++ syn)
276
    {
277
      const char *errmsg;
278
 
279
      if (CGEN_SYNTAX_CHAR_P (* syn))
280
        continue;
281
 
282
      errmsg = (* cd->insert_operand) (cd, CGEN_SYNTAX_FIELD (*syn),
283
                                       fields, buffer, pc);
284
      if (errmsg)
285
        return errmsg;
286
    }
287
 
288
  return NULL;
289
}
290
 
291
#if CGEN_INT_INSN_P
292
/* Cover function to store an insn value into an integral insn.  Must go here
293
   because it needs <prefix>-desc.h for CGEN_INT_INSN_P.  */
294
 
295
static void
296
put_insn_int_value (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
297
                    CGEN_INSN_BYTES_PTR buf,
298
                    int length,
299
                    int insn_length,
300
                    CGEN_INSN_INT value)
301
{
302
  /* For architectures with insns smaller than the base-insn-bitsize,
303
     length may be too big.  */
304
  if (length > insn_length)
305
    *buf = value;
306
  else
307
    {
308
      int shift = insn_length - length;
309
      /* Written this way to avoid undefined behaviour.  */
310
      CGEN_INSN_INT mask = (((1L << (length - 1)) - 1) << 1) | 1;
311
 
312
      *buf = (*buf & ~(mask << shift)) | ((value & mask) << shift);
313
    }
314
}
315
#endif
316
 
317
/* Operand extraction.  */
318
 
319
#if ! CGEN_INT_INSN_P
320
 
321
/* Subroutine of extract_normal.
322
   Ensure sufficient bytes are cached in EX_INFO.
323
   OFFSET is the offset in bytes from the start of the insn of the value.
324
   BYTES is the length of the needed value.
325
   Returns 1 for success, 0 for failure.  */
326
 
327
static CGEN_INLINE int
328
fill_cache (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
329
            CGEN_EXTRACT_INFO *ex_info,
330
            int offset,
331
            int bytes,
332
            bfd_vma pc)
333
{
334
  /* It's doubtful that the middle part has already been fetched so
335
     we don't optimize that case.  kiss.  */
336
  unsigned int mask;
337
  disassemble_info *info = (disassemble_info *) ex_info->dis_info;
338
 
339
  /* First do a quick check.  */
340
  mask = (1 << bytes) - 1;
341
  if (((ex_info->valid >> offset) & mask) == mask)
342
    return 1;
343
 
344
  /* Search for the first byte we need to read.  */
345
  for (mask = 1 << offset; bytes > 0; --bytes, ++offset, mask <<= 1)
346
    if (! (mask & ex_info->valid))
347
      break;
348
 
349
  if (bytes)
350
    {
351
      int status;
352
 
353
      pc += offset;
354
      status = (*info->read_memory_func)
355
        (pc, ex_info->insn_bytes + offset, bytes, info);
356
 
357
      if (status != 0)
358
        {
359
          (*info->memory_error_func) (status, pc, info);
360
          return 0;
361
        }
362
 
363
      ex_info->valid |= ((1 << bytes) - 1) << offset;
364
    }
365
 
366
  return 1;
367
}
368
 
369
/* Subroutine of extract_normal.  */
370
 
371
static CGEN_INLINE long
372
extract_1 (CGEN_CPU_DESC cd,
373
           CGEN_EXTRACT_INFO *ex_info ATTRIBUTE_UNUSED,
374
           int start,
375
           int length,
376
           int word_length,
377
           unsigned char *bufp,
378
           bfd_vma pc ATTRIBUTE_UNUSED)
379
{
380
  unsigned long x;
381
  int shift;
382
 
383
  x = cgen_get_insn_value (cd, bufp, word_length);
384
 
385
  if (CGEN_INSN_LSB0_P)
386
    shift = (start + 1) - length;
387
  else
388
    shift = (word_length - (start + length));
389
  return x >> shift;
390
}
391
 
392
#endif /* ! CGEN_INT_INSN_P */
393
 
394
/* Default extraction routine.
395
 
396
   INSN_VALUE is the first base_insn_bitsize bits of the insn in host order,
397
   or sometimes less for cases like the m32r where the base insn size is 32
398
   but some insns are 16 bits.
399
   ATTRS is a mask of the boolean attributes.  We only need `SIGNED',
400
   but for generality we take a bitmask of all of them.
401
   WORD_OFFSET is the offset in bits from the start of the insn of the value.
402
   WORD_LENGTH is the length of the word in bits in which the value resides.
403
   START is the starting bit number in the word, architecture origin.
404
   LENGTH is the length of VALUE in bits.
405
   TOTAL_LENGTH is the total length of the insn in bits.
406
 
407
   Returns 1 for success, 0 for failure.  */
408
 
409
/* ??? The return code isn't properly used.  wip.  */
410
 
411
/* ??? This doesn't handle bfd_vma's.  Create another function when
412
   necessary.  */
413
 
414
static int
415
extract_normal (CGEN_CPU_DESC cd,
416
#if ! CGEN_INT_INSN_P
417
                CGEN_EXTRACT_INFO *ex_info,
418
#else
419
                CGEN_EXTRACT_INFO *ex_info ATTRIBUTE_UNUSED,
420
#endif
421
                CGEN_INSN_INT insn_value,
422
                unsigned int attrs,
423
                unsigned int word_offset,
424
                unsigned int start,
425
                unsigned int length,
426
                unsigned int word_length,
427
                unsigned int total_length,
428
#if ! CGEN_INT_INSN_P
429
                bfd_vma pc,
430
#else
431
                bfd_vma pc ATTRIBUTE_UNUSED,
432
#endif
433
                long *valuep)
434
{
435
  long value, mask;
436
 
437
  /* If LENGTH is zero, this operand doesn't contribute to the value
438
     so give it a standard value of zero.  */
439
  if (length == 0)
440
    {
441
      *valuep = 0;
442
      return 1;
443
    }
444
 
445
  if (word_length > 8 * sizeof (CGEN_INSN_INT))
446
    abort ();
447
 
448
  /* For architectures with insns smaller than the insn-base-bitsize,
449
     word_length may be too big.  */
450
  if (cd->min_insn_bitsize < cd->base_insn_bitsize)
451
    {
452
      if (word_offset + word_length > total_length)
453
        word_length = total_length - word_offset;
454
    }
455
 
456
  /* Does the value reside in INSN_VALUE, and at the right alignment?  */
457
 
458
  if (CGEN_INT_INSN_P || (word_offset == 0 && word_length == total_length))
459
    {
460
      if (CGEN_INSN_LSB0_P)
461
        value = insn_value >> ((word_offset + start + 1) - length);
462
      else
463
        value = insn_value >> (total_length - ( word_offset + start + length));
464
    }
465
 
466
#if ! CGEN_INT_INSN_P
467
 
468
  else
469
    {
470
      unsigned char *bufp = ex_info->insn_bytes + word_offset / 8;
471
 
472
      if (word_length > 8 * sizeof (CGEN_INSN_INT))
473
        abort ();
474
 
475
      if (fill_cache (cd, ex_info, word_offset / 8, word_length / 8, pc) == 0)
476
        return 0;
477
 
478
      value = extract_1 (cd, ex_info, start, length, word_length, bufp, pc);
479
    }
480
 
481
#endif /* ! CGEN_INT_INSN_P */
482
 
483
  /* Written this way to avoid undefined behaviour.  */
484
  mask = (((1L << (length - 1)) - 1) << 1) | 1;
485
 
486
  value &= mask;
487
  /* sign extend? */
488
  if (CGEN_BOOL_ATTR (attrs, CGEN_IFLD_SIGNED)
489
      && (value & (1L << (length - 1))))
490
    value |= ~mask;
491
 
492
  *valuep = value;
493
 
494
  return 1;
495
}
496
 
497
/* Default insn extractor.
498
 
499
   INSN_VALUE is the first base_insn_bitsize bits, translated to host order.
500
   The extracted fields are stored in FIELDS.
501
   EX_INFO is used to handle reading variable length insns.
502
   Return the length of the insn in bits, or 0 if no match,
503
   or -1 if an error occurs fetching data (memory_error_func will have
504
   been called).  */
505
 
506
static int
507
extract_insn_normal (CGEN_CPU_DESC cd,
508
                     const CGEN_INSN *insn,
509
                     CGEN_EXTRACT_INFO *ex_info,
510
                     CGEN_INSN_INT insn_value,
511
                     CGEN_FIELDS *fields,
512
                     bfd_vma pc)
513
{
514
  const CGEN_SYNTAX *syntax = CGEN_INSN_SYNTAX (insn);
515
  const CGEN_SYNTAX_CHAR_TYPE *syn;
516
 
517
  CGEN_FIELDS_BITSIZE (fields) = CGEN_INSN_BITSIZE (insn);
518
 
519
  CGEN_INIT_EXTRACT (cd);
520
 
521
  for (syn = CGEN_SYNTAX_STRING (syntax); *syn; ++syn)
522
    {
523
      int length;
524
 
525
      if (CGEN_SYNTAX_CHAR_P (*syn))
526
        continue;
527
 
528
      length = (* cd->extract_operand) (cd, CGEN_SYNTAX_FIELD (*syn),
529
                                        ex_info, insn_value, fields, pc);
530
      if (length <= 0)
531
        return length;
532
    }
533
 
534
  /* We recognized and successfully extracted this insn.  */
535
  return CGEN_INSN_BITSIZE (insn);
536
}
537
 
538
/* Machine generated code added here.  */
539
 
540
const char * m32c_cgen_insert_operand
541
  (CGEN_CPU_DESC, int, CGEN_FIELDS *, CGEN_INSN_BYTES_PTR, bfd_vma);
542
 
543
/* Main entry point for operand insertion.
544
 
545
   This function is basically just a big switch statement.  Earlier versions
546
   used tables to look up the function to use, but
547
   - if the table contains both assembler and disassembler functions then
548
     the disassembler contains much of the assembler and vice-versa,
549
   - there's a lot of inlining possibilities as things grow,
550
   - using a switch statement avoids the function call overhead.
551
 
552
   This function could be moved into `parse_insn_normal', but keeping it
553
   separate makes clear the interface between `parse_insn_normal' and each of
554
   the handlers.  It's also needed by GAS to insert operands that couldn't be
555
   resolved during parsing.  */
556
 
557
const char *
558
m32c_cgen_insert_operand (CGEN_CPU_DESC cd,
559
                             int opindex,
560
                             CGEN_FIELDS * fields,
561
                             CGEN_INSN_BYTES_PTR buffer,
562
                             bfd_vma pc ATTRIBUTE_UNUSED)
563
{
564
  const char * errmsg = NULL;
565
  unsigned int total_length = CGEN_FIELDS_BITSIZE (fields);
566
 
567
  switch (opindex)
568
    {
569
    case M32C_OPERAND_A0 :
570
      break;
571
    case M32C_OPERAND_A1 :
572
      break;
573
    case M32C_OPERAND_AN16_PUSH_S :
574
      errmsg = insert_normal (cd, fields->f_4_1, 0, 0, 4, 1, 32, total_length, buffer);
575
      break;
576
    case M32C_OPERAND_BIT16AN :
577
      errmsg = insert_normal (cd, fields->f_dst16_an, 0, 0, 15, 1, 32, total_length, buffer);
578
      break;
579
    case M32C_OPERAND_BIT16RN :
580
      errmsg = insert_normal (cd, fields->f_dst16_rn, 0, 0, 14, 2, 32, total_length, buffer);
581
      break;
582
    case M32C_OPERAND_BIT3_S :
583
      {
584
{
585
  FLD (f_7_1) = ((((FLD (f_imm3_S)) - (1))) & (1));
586
  FLD (f_2_2) = ((((UINT) (((FLD (f_imm3_S)) - (1))) >> (1))) & (3));
587
}
588
        errmsg = insert_normal (cd, fields->f_2_2, 0, 0, 2, 2, 32, total_length, buffer);
589
        if (errmsg)
590
          break;
591
        errmsg = insert_normal (cd, fields->f_7_1, 0, 0, 7, 1, 32, total_length, buffer);
592
        if (errmsg)
593
          break;
594
      }
595
      break;
596
    case M32C_OPERAND_BIT32ANPREFIXED :
597
      errmsg = insert_normal (cd, fields->f_dst32_an_prefixed, 0, 0, 17, 1, 32, total_length, buffer);
598
      break;
599
    case M32C_OPERAND_BIT32ANUNPREFIXED :
600
      errmsg = insert_normal (cd, fields->f_dst32_an_unprefixed, 0, 0, 9, 1, 32, total_length, buffer);
601
      break;
602
    case M32C_OPERAND_BIT32RNPREFIXED :
603
      {
604
        long value = fields->f_dst32_rn_prefixed_QI;
605
        value = (((((((~ (value))) << (1))) & (2))) | (((((USI) (value) >> (1))) & (1))));
606
        errmsg = insert_normal (cd, value, 0, 0, 16, 2, 32, total_length, buffer);
607
      }
608
      break;
609
    case M32C_OPERAND_BIT32RNUNPREFIXED :
610
      {
611
        long value = fields->f_dst32_rn_unprefixed_QI;
612
        value = (((((((~ (value))) << (1))) & (2))) | (((((USI) (value) >> (1))) & (1))));
613
        errmsg = insert_normal (cd, value, 0, 0, 8, 2, 32, total_length, buffer);
614
      }
615
      break;
616
    case M32C_OPERAND_BITBASE16_16_S8 :
617
      errmsg = insert_normal (cd, fields->f_dsp_16_s8, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 8, 32, total_length, buffer);
618
      break;
619
    case M32C_OPERAND_BITBASE16_16_U16 :
620
      {
621
        long value = fields->f_dsp_16_u16;
622
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
623
        errmsg = insert_normal (cd, value, 0, 0, 16, 16, 32, total_length, buffer);
624
      }
625
      break;
626
    case M32C_OPERAND_BITBASE16_16_U8 :
627
      errmsg = insert_normal (cd, fields->f_dsp_16_u8, 0, 0, 16, 8, 32, total_length, buffer);
628
      break;
629
    case M32C_OPERAND_BITBASE16_8_U11_S :
630
      {
631
{
632
  FLD (f_bitno16_S) = ((FLD (f_bitbase16_u11_S)) & (7));
633
  FLD (f_dsp_8_u8) = ((((UINT) (FLD (f_bitbase16_u11_S)) >> (3))) & (255));
634
}
635
        errmsg = insert_normal (cd, fields->f_bitno16_S, 0, 0, 5, 3, 32, total_length, buffer);
636
        if (errmsg)
637
          break;
638
        errmsg = insert_normal (cd, fields->f_dsp_8_u8, 0, 0, 8, 8, 32, total_length, buffer);
639
        if (errmsg)
640
          break;
641
      }
642
      break;
643
    case M32C_OPERAND_BITBASE32_16_S11_UNPREFIXED :
644
      {
645
{
646
  FLD (f_bitno32_unprefixed) = ((FLD (f_bitbase32_16_s11_unprefixed)) & (7));
647
  FLD (f_dsp_16_s8) = ((INT) (FLD (f_bitbase32_16_s11_unprefixed)) >> (3));
648
}
649
        errmsg = insert_normal (cd, fields->f_bitno32_unprefixed, 0, 0, 13, 3, 32, total_length, buffer);
650
        if (errmsg)
651
          break;
652
        errmsg = insert_normal (cd, fields->f_dsp_16_s8, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 8, 32, total_length, buffer);
653
        if (errmsg)
654
          break;
655
      }
656
      break;
657
    case M32C_OPERAND_BITBASE32_16_S19_UNPREFIXED :
658
      {
659
{
660
  FLD (f_bitno32_unprefixed) = ((FLD (f_bitbase32_16_s19_unprefixed)) & (7));
661
  FLD (f_dsp_16_s16) = ((INT) (FLD (f_bitbase32_16_s19_unprefixed)) >> (3));
662
}
663
        errmsg = insert_normal (cd, fields->f_bitno32_unprefixed, 0, 0, 13, 3, 32, total_length, buffer);
664
        if (errmsg)
665
          break;
666
        {
667
        long value = fields->f_dsp_16_s16;
668
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
669
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 16, 32, total_length, buffer);
670
      }
671
        if (errmsg)
672
          break;
673
      }
674
      break;
675
    case M32C_OPERAND_BITBASE32_16_U11_UNPREFIXED :
676
      {
677
{
678
  FLD (f_bitno32_unprefixed) = ((FLD (f_bitbase32_16_u11_unprefixed)) & (7));
679
  FLD (f_dsp_16_u8) = ((((UINT) (FLD (f_bitbase32_16_u11_unprefixed)) >> (3))) & (255));
680
}
681
        errmsg = insert_normal (cd, fields->f_bitno32_unprefixed, 0, 0, 13, 3, 32, total_length, buffer);
682
        if (errmsg)
683
          break;
684
        errmsg = insert_normal (cd, fields->f_dsp_16_u8, 0, 0, 16, 8, 32, total_length, buffer);
685
        if (errmsg)
686
          break;
687
      }
688
      break;
689
    case M32C_OPERAND_BITBASE32_16_U19_UNPREFIXED :
690
      {
691
{
692
  FLD (f_bitno32_unprefixed) = ((FLD (f_bitbase32_16_u19_unprefixed)) & (7));
693
  FLD (f_dsp_16_u16) = ((((UINT) (FLD (f_bitbase32_16_u19_unprefixed)) >> (3))) & (65535));
694
}
695
        errmsg = insert_normal (cd, fields->f_bitno32_unprefixed, 0, 0, 13, 3, 32, total_length, buffer);
696
        if (errmsg)
697
          break;
698
        {
699
        long value = fields->f_dsp_16_u16;
700
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
701
        errmsg = insert_normal (cd, value, 0, 0, 16, 16, 32, total_length, buffer);
702
      }
703
        if (errmsg)
704
          break;
705
      }
706
      break;
707
    case M32C_OPERAND_BITBASE32_16_U27_UNPREFIXED :
708
      {
709
{
710
  FLD (f_bitno32_unprefixed) = ((FLD (f_bitbase32_16_u27_unprefixed)) & (7));
711
  FLD (f_dsp_16_u16) = ((((UINT) (FLD (f_bitbase32_16_u27_unprefixed)) >> (3))) & (65535));
712
  FLD (f_dsp_32_u8) = ((((UINT) (FLD (f_bitbase32_16_u27_unprefixed)) >> (19))) & (255));
713
}
714
        errmsg = insert_normal (cd, fields->f_bitno32_unprefixed, 0, 0, 13, 3, 32, total_length, buffer);
715
        if (errmsg)
716
          break;
717
        {
718
        long value = fields->f_dsp_16_u16;
719
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
720
        errmsg = insert_normal (cd, value, 0, 0, 16, 16, 32, total_length, buffer);
721
      }
722
        if (errmsg)
723
          break;
724
        errmsg = insert_normal (cd, fields->f_dsp_32_u8, 0, 32, 0, 8, 32, total_length, buffer);
725
        if (errmsg)
726
          break;
727
      }
728
      break;
729
    case M32C_OPERAND_BITBASE32_24_S11_PREFIXED :
730
      {
731
{
732
  FLD (f_bitno32_prefixed) = ((FLD (f_bitbase32_24_s11_prefixed)) & (7));
733
  FLD (f_dsp_24_s8) = ((INT) (FLD (f_bitbase32_24_s11_prefixed)) >> (3));
734
}
735
        errmsg = insert_normal (cd, fields->f_bitno32_prefixed, 0, 0, 21, 3, 32, total_length, buffer);
736
        if (errmsg)
737
          break;
738
        errmsg = insert_normal (cd, fields->f_dsp_24_s8, 0|(1<<CGEN_IFLD_SIGNED), 0, 24, 8, 32, total_length, buffer);
739
        if (errmsg)
740
          break;
741
      }
742
      break;
743
    case M32C_OPERAND_BITBASE32_24_S19_PREFIXED :
744
      {
745
{
746
  FLD (f_bitno32_prefixed) = ((FLD (f_bitbase32_24_s19_prefixed)) & (7));
747
  FLD (f_dsp_24_u8) = ((((UINT) (FLD (f_bitbase32_24_s19_prefixed)) >> (3))) & (255));
748
  FLD (f_dsp_32_s8) = ((INT) (FLD (f_bitbase32_24_s19_prefixed)) >> (11));
749
}
750
        errmsg = insert_normal (cd, fields->f_bitno32_prefixed, 0, 0, 21, 3, 32, total_length, buffer);
751
        if (errmsg)
752
          break;
753
        errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
754
        if (errmsg)
755
          break;
756
        errmsg = insert_normal (cd, fields->f_dsp_32_s8, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 8, 32, total_length, buffer);
757
        if (errmsg)
758
          break;
759
      }
760
      break;
761
    case M32C_OPERAND_BITBASE32_24_U11_PREFIXED :
762
      {
763
{
764
  FLD (f_bitno32_prefixed) = ((FLD (f_bitbase32_24_u11_prefixed)) & (7));
765
  FLD (f_dsp_24_u8) = ((((UINT) (FLD (f_bitbase32_24_u11_prefixed)) >> (3))) & (255));
766
}
767
        errmsg = insert_normal (cd, fields->f_bitno32_prefixed, 0, 0, 21, 3, 32, total_length, buffer);
768
        if (errmsg)
769
          break;
770
        errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
771
        if (errmsg)
772
          break;
773
      }
774
      break;
775
    case M32C_OPERAND_BITBASE32_24_U19_PREFIXED :
776
      {
777
{
778
  FLD (f_bitno32_prefixed) = ((FLD (f_bitbase32_24_u19_prefixed)) & (7));
779
  FLD (f_dsp_24_u8) = ((((UINT) (FLD (f_bitbase32_24_u19_prefixed)) >> (3))) & (255));
780
  FLD (f_dsp_32_u8) = ((((UINT) (FLD (f_bitbase32_24_u19_prefixed)) >> (11))) & (255));
781
}
782
        errmsg = insert_normal (cd, fields->f_bitno32_prefixed, 0, 0, 21, 3, 32, total_length, buffer);
783
        if (errmsg)
784
          break;
785
        errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
786
        if (errmsg)
787
          break;
788
        errmsg = insert_normal (cd, fields->f_dsp_32_u8, 0, 32, 0, 8, 32, total_length, buffer);
789
        if (errmsg)
790
          break;
791
      }
792
      break;
793
    case M32C_OPERAND_BITBASE32_24_U27_PREFIXED :
794
      {
795
{
796
  FLD (f_bitno32_prefixed) = ((FLD (f_bitbase32_24_u27_prefixed)) & (7));
797
  FLD (f_dsp_24_u8) = ((((UINT) (FLD (f_bitbase32_24_u27_prefixed)) >> (3))) & (255));
798
  FLD (f_dsp_32_u16) = ((((UINT) (FLD (f_bitbase32_24_u27_prefixed)) >> (11))) & (65535));
799
}
800
        errmsg = insert_normal (cd, fields->f_bitno32_prefixed, 0, 0, 21, 3, 32, total_length, buffer);
801
        if (errmsg)
802
          break;
803
        errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
804
        if (errmsg)
805
          break;
806
        {
807
        long value = fields->f_dsp_32_u16;
808
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
809
        errmsg = insert_normal (cd, value, 0, 32, 0, 16, 32, total_length, buffer);
810
      }
811
        if (errmsg)
812
          break;
813
      }
814
      break;
815
    case M32C_OPERAND_BITNO16R :
816
      errmsg = insert_normal (cd, fields->f_dsp_16_u8, 0, 0, 16, 8, 32, total_length, buffer);
817
      break;
818
    case M32C_OPERAND_BITNO32PREFIXED :
819
      errmsg = insert_normal (cd, fields->f_bitno32_prefixed, 0, 0, 21, 3, 32, total_length, buffer);
820
      break;
821
    case M32C_OPERAND_BITNO32UNPREFIXED :
822
      errmsg = insert_normal (cd, fields->f_bitno32_unprefixed, 0, 0, 13, 3, 32, total_length, buffer);
823
      break;
824
    case M32C_OPERAND_DSP_10_U6 :
825
      errmsg = insert_normal (cd, fields->f_dsp_10_u6, 0, 0, 10, 6, 32, total_length, buffer);
826
      break;
827
    case M32C_OPERAND_DSP_16_S16 :
828
      {
829
        long value = fields->f_dsp_16_s16;
830
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
831
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 16, 32, total_length, buffer);
832
      }
833
      break;
834
    case M32C_OPERAND_DSP_16_S8 :
835
      errmsg = insert_normal (cd, fields->f_dsp_16_s8, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 8, 32, total_length, buffer);
836
      break;
837
    case M32C_OPERAND_DSP_16_U16 :
838
      {
839
        long value = fields->f_dsp_16_u16;
840
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
841
        errmsg = insert_normal (cd, value, 0, 0, 16, 16, 32, total_length, buffer);
842
      }
843
      break;
844
    case M32C_OPERAND_DSP_16_U20 :
845
      {
846
{
847
  FLD (f_dsp_16_u16) = ((FLD (f_dsp_16_u24)) & (65535));
848
  FLD (f_dsp_32_u8) = ((((UINT) (FLD (f_dsp_16_u24)) >> (16))) & (255));
849
}
850
        {
851
        long value = fields->f_dsp_16_u16;
852
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
853
        errmsg = insert_normal (cd, value, 0, 0, 16, 16, 32, total_length, buffer);
854
      }
855
        if (errmsg)
856
          break;
857
        errmsg = insert_normal (cd, fields->f_dsp_32_u8, 0, 32, 0, 8, 32, total_length, buffer);
858
        if (errmsg)
859
          break;
860
      }
861
      break;
862
    case M32C_OPERAND_DSP_16_U24 :
863
      {
864
{
865
  FLD (f_dsp_16_u16) = ((FLD (f_dsp_16_u24)) & (65535));
866
  FLD (f_dsp_32_u8) = ((((UINT) (FLD (f_dsp_16_u24)) >> (16))) & (255));
867
}
868
        {
869
        long value = fields->f_dsp_16_u16;
870
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
871
        errmsg = insert_normal (cd, value, 0, 0, 16, 16, 32, total_length, buffer);
872
      }
873
        if (errmsg)
874
          break;
875
        errmsg = insert_normal (cd, fields->f_dsp_32_u8, 0, 32, 0, 8, 32, total_length, buffer);
876
        if (errmsg)
877
          break;
878
      }
879
      break;
880
    case M32C_OPERAND_DSP_16_U8 :
881
      errmsg = insert_normal (cd, fields->f_dsp_16_u8, 0, 0, 16, 8, 32, total_length, buffer);
882
      break;
883
    case M32C_OPERAND_DSP_24_S16 :
884
      {
885
{
886
  FLD (f_dsp_24_u8) = ((FLD (f_dsp_24_s16)) & (255));
887
  FLD (f_dsp_32_u8) = ((((UINT) (FLD (f_dsp_24_s16)) >> (8))) & (255));
888
}
889
        errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
890
        if (errmsg)
891
          break;
892
        errmsg = insert_normal (cd, fields->f_dsp_32_u8, 0, 32, 0, 8, 32, total_length, buffer);
893
        if (errmsg)
894
          break;
895
      }
896
      break;
897
    case M32C_OPERAND_DSP_24_S8 :
898
      errmsg = insert_normal (cd, fields->f_dsp_24_s8, 0|(1<<CGEN_IFLD_SIGNED), 0, 24, 8, 32, total_length, buffer);
899
      break;
900
    case M32C_OPERAND_DSP_24_U16 :
901
      {
902
{
903
  FLD (f_dsp_24_u8) = ((FLD (f_dsp_24_u16)) & (255));
904
  FLD (f_dsp_32_u8) = ((((UINT) (FLD (f_dsp_24_u16)) >> (8))) & (255));
905
}
906
        errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
907
        if (errmsg)
908
          break;
909
        errmsg = insert_normal (cd, fields->f_dsp_32_u8, 0, 32, 0, 8, 32, total_length, buffer);
910
        if (errmsg)
911
          break;
912
      }
913
      break;
914
    case M32C_OPERAND_DSP_24_U20 :
915
      {
916
{
917
  FLD (f_dsp_24_u8) = ((FLD (f_dsp_24_u24)) & (255));
918
  FLD (f_dsp_32_u16) = ((((UINT) (FLD (f_dsp_24_u24)) >> (8))) & (65535));
919
}
920
        errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
921
        if (errmsg)
922
          break;
923
        {
924
        long value = fields->f_dsp_32_u16;
925
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
926
        errmsg = insert_normal (cd, value, 0, 32, 0, 16, 32, total_length, buffer);
927
      }
928
        if (errmsg)
929
          break;
930
      }
931
      break;
932
    case M32C_OPERAND_DSP_24_U24 :
933
      {
934
{
935
  FLD (f_dsp_24_u8) = ((FLD (f_dsp_24_u24)) & (255));
936
  FLD (f_dsp_32_u16) = ((((UINT) (FLD (f_dsp_24_u24)) >> (8))) & (65535));
937
}
938
        errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
939
        if (errmsg)
940
          break;
941
        {
942
        long value = fields->f_dsp_32_u16;
943
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
944
        errmsg = insert_normal (cd, value, 0, 32, 0, 16, 32, total_length, buffer);
945
      }
946
        if (errmsg)
947
          break;
948
      }
949
      break;
950
    case M32C_OPERAND_DSP_24_U8 :
951
      errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
952
      break;
953
    case M32C_OPERAND_DSP_32_S16 :
954
      {
955
        long value = fields->f_dsp_32_s16;
956
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
957
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 16, 32, total_length, buffer);
958
      }
959
      break;
960
    case M32C_OPERAND_DSP_32_S8 :
961
      errmsg = insert_normal (cd, fields->f_dsp_32_s8, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 8, 32, total_length, buffer);
962
      break;
963
    case M32C_OPERAND_DSP_32_U16 :
964
      {
965
        long value = fields->f_dsp_32_u16;
966
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
967
        errmsg = insert_normal (cd, value, 0, 32, 0, 16, 32, total_length, buffer);
968
      }
969
      break;
970
    case M32C_OPERAND_DSP_32_U20 :
971
      {
972
        long value = fields->f_dsp_32_u24;
973
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (16711680))));
974
        errmsg = insert_normal (cd, value, 0, 32, 0, 24, 32, total_length, buffer);
975
      }
976
      break;
977
    case M32C_OPERAND_DSP_32_U24 :
978
      {
979
        long value = fields->f_dsp_32_u24;
980
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (16711680))));
981
        errmsg = insert_normal (cd, value, 0, 32, 0, 24, 32, total_length, buffer);
982
      }
983
      break;
984
    case M32C_OPERAND_DSP_32_U8 :
985
      errmsg = insert_normal (cd, fields->f_dsp_32_u8, 0, 32, 0, 8, 32, total_length, buffer);
986
      break;
987
    case M32C_OPERAND_DSP_40_S16 :
988
      {
989
        long value = fields->f_dsp_40_s16;
990
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
991
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 32, 8, 16, 32, total_length, buffer);
992
      }
993
      break;
994
    case M32C_OPERAND_DSP_40_S8 :
995
      errmsg = insert_normal (cd, fields->f_dsp_40_s8, 0|(1<<CGEN_IFLD_SIGNED), 32, 8, 8, 32, total_length, buffer);
996
      break;
997
    case M32C_OPERAND_DSP_40_U16 :
998
      {
999
        long value = fields->f_dsp_40_u16;
1000
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1001
        errmsg = insert_normal (cd, value, 0, 32, 8, 16, 32, total_length, buffer);
1002
      }
1003
      break;
1004
    case M32C_OPERAND_DSP_40_U20 :
1005
      {
1006
        long value = fields->f_dsp_40_u20;
1007
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (983040))));
1008
        errmsg = insert_normal (cd, value, 0, 32, 8, 20, 32, total_length, buffer);
1009
      }
1010
      break;
1011
    case M32C_OPERAND_DSP_40_U24 :
1012
      {
1013
        long value = fields->f_dsp_40_u24;
1014
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (16711680))));
1015
        errmsg = insert_normal (cd, value, 0, 32, 8, 24, 32, total_length, buffer);
1016
      }
1017
      break;
1018
    case M32C_OPERAND_DSP_40_U8 :
1019
      errmsg = insert_normal (cd, fields->f_dsp_40_u8, 0, 32, 8, 8, 32, total_length, buffer);
1020
      break;
1021
    case M32C_OPERAND_DSP_48_S16 :
1022
      {
1023
        long value = fields->f_dsp_48_s16;
1024
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
1025
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 32, 16, 16, 32, total_length, buffer);
1026
      }
1027
      break;
1028
    case M32C_OPERAND_DSP_48_S8 :
1029
      errmsg = insert_normal (cd, fields->f_dsp_48_s8, 0|(1<<CGEN_IFLD_SIGNED), 32, 16, 8, 32, total_length, buffer);
1030
      break;
1031
    case M32C_OPERAND_DSP_48_U16 :
1032
      {
1033
        long value = fields->f_dsp_48_u16;
1034
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1035
        errmsg = insert_normal (cd, value, 0, 32, 16, 16, 32, total_length, buffer);
1036
      }
1037
      break;
1038
    case M32C_OPERAND_DSP_48_U20 :
1039
      {
1040
{
1041
  FLD (f_dsp_64_u8) = ((((UINT) (FLD (f_dsp_48_u20)) >> (16))) & (15));
1042
  FLD (f_dsp_48_u16) = ((FLD (f_dsp_48_u20)) & (65535));
1043
}
1044
        {
1045
        long value = fields->f_dsp_48_u16;
1046
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1047
        errmsg = insert_normal (cd, value, 0, 32, 16, 16, 32, total_length, buffer);
1048
      }
1049
        if (errmsg)
1050
          break;
1051
        errmsg = insert_normal (cd, fields->f_dsp_64_u8, 0, 64, 0, 8, 32, total_length, buffer);
1052
        if (errmsg)
1053
          break;
1054
      }
1055
      break;
1056
    case M32C_OPERAND_DSP_48_U24 :
1057
      {
1058
{
1059
  FLD (f_dsp_64_u8) = ((((UINT) (FLD (f_dsp_48_u24)) >> (16))) & (255));
1060
  FLD (f_dsp_48_u16) = ((FLD (f_dsp_48_u24)) & (65535));
1061
}
1062
        {
1063
        long value = fields->f_dsp_48_u16;
1064
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1065
        errmsg = insert_normal (cd, value, 0, 32, 16, 16, 32, total_length, buffer);
1066
      }
1067
        if (errmsg)
1068
          break;
1069
        errmsg = insert_normal (cd, fields->f_dsp_64_u8, 0, 64, 0, 8, 32, total_length, buffer);
1070
        if (errmsg)
1071
          break;
1072
      }
1073
      break;
1074
    case M32C_OPERAND_DSP_48_U8 :
1075
      errmsg = insert_normal (cd, fields->f_dsp_48_u8, 0, 32, 16, 8, 32, total_length, buffer);
1076
      break;
1077
    case M32C_OPERAND_DSP_8_S24 :
1078
      {
1079
        long value = fields->f_dsp_8_s24;
1080
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((EXTQISI (TRUNCSIQI (((value) & (255))))) << (16))));
1081
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 24, 32, total_length, buffer);
1082
      }
1083
      break;
1084
    case M32C_OPERAND_DSP_8_S8 :
1085
      errmsg = insert_normal (cd, fields->f_dsp_8_s8, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 8, 32, total_length, buffer);
1086
      break;
1087
    case M32C_OPERAND_DSP_8_U16 :
1088
      {
1089
        long value = fields->f_dsp_8_u16;
1090
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1091
        errmsg = insert_normal (cd, value, 0, 0, 8, 16, 32, total_length, buffer);
1092
      }
1093
      break;
1094
    case M32C_OPERAND_DSP_8_U24 :
1095
      {
1096
        long value = fields->f_dsp_8_u24;
1097
        value = ((((((USI) (value) >> (16))) | (((value) & (65280))))) | (((((value) & (255))) << (16))));
1098
        errmsg = insert_normal (cd, value, 0, 0, 8, 24, 32, total_length, buffer);
1099
      }
1100
      break;
1101
    case M32C_OPERAND_DSP_8_U6 :
1102
      errmsg = insert_normal (cd, fields->f_dsp_8_u6, 0, 0, 8, 6, 32, total_length, buffer);
1103
      break;
1104
    case M32C_OPERAND_DSP_8_U8 :
1105
      errmsg = insert_normal (cd, fields->f_dsp_8_u8, 0, 0, 8, 8, 32, total_length, buffer);
1106
      break;
1107
    case M32C_OPERAND_DST16AN :
1108
      errmsg = insert_normal (cd, fields->f_dst16_an, 0, 0, 15, 1, 32, total_length, buffer);
1109
      break;
1110
    case M32C_OPERAND_DST16AN_S :
1111
      errmsg = insert_normal (cd, fields->f_dst16_an_s, 0, 0, 4, 1, 32, total_length, buffer);
1112
      break;
1113
    case M32C_OPERAND_DST16ANHI :
1114
      errmsg = insert_normal (cd, fields->f_dst16_an, 0, 0, 15, 1, 32, total_length, buffer);
1115
      break;
1116
    case M32C_OPERAND_DST16ANQI :
1117
      errmsg = insert_normal (cd, fields->f_dst16_an, 0, 0, 15, 1, 32, total_length, buffer);
1118
      break;
1119
    case M32C_OPERAND_DST16ANQI_S :
1120
      errmsg = insert_normal (cd, fields->f_dst16_rn_QI_s, 0, 0, 5, 1, 32, total_length, buffer);
1121
      break;
1122
    case M32C_OPERAND_DST16ANSI :
1123
      errmsg = insert_normal (cd, fields->f_dst16_an, 0, 0, 15, 1, 32, total_length, buffer);
1124
      break;
1125
    case M32C_OPERAND_DST16RNEXTQI :
1126
      errmsg = insert_normal (cd, fields->f_dst16_rn_ext, 0, 0, 14, 1, 32, total_length, buffer);
1127
      break;
1128
    case M32C_OPERAND_DST16RNHI :
1129
      errmsg = insert_normal (cd, fields->f_dst16_rn, 0, 0, 14, 2, 32, total_length, buffer);
1130
      break;
1131
    case M32C_OPERAND_DST16RNQI :
1132
      errmsg = insert_normal (cd, fields->f_dst16_rn, 0, 0, 14, 2, 32, total_length, buffer);
1133
      break;
1134
    case M32C_OPERAND_DST16RNQI_S :
1135
      errmsg = insert_normal (cd, fields->f_dst16_rn_QI_s, 0, 0, 5, 1, 32, total_length, buffer);
1136
      break;
1137
    case M32C_OPERAND_DST16RNSI :
1138
      errmsg = insert_normal (cd, fields->f_dst16_rn, 0, 0, 14, 2, 32, total_length, buffer);
1139
      break;
1140
    case M32C_OPERAND_DST32ANEXTUNPREFIXED :
1141
      errmsg = insert_normal (cd, fields->f_dst32_an_unprefixed, 0, 0, 9, 1, 32, total_length, buffer);
1142
      break;
1143
    case M32C_OPERAND_DST32ANPREFIXED :
1144
      errmsg = insert_normal (cd, fields->f_dst32_an_prefixed, 0, 0, 17, 1, 32, total_length, buffer);
1145
      break;
1146
    case M32C_OPERAND_DST32ANPREFIXEDHI :
1147
      errmsg = insert_normal (cd, fields->f_dst32_an_prefixed, 0, 0, 17, 1, 32, total_length, buffer);
1148
      break;
1149
    case M32C_OPERAND_DST32ANPREFIXEDQI :
1150
      errmsg = insert_normal (cd, fields->f_dst32_an_prefixed, 0, 0, 17, 1, 32, total_length, buffer);
1151
      break;
1152
    case M32C_OPERAND_DST32ANPREFIXEDSI :
1153
      errmsg = insert_normal (cd, fields->f_dst32_an_prefixed, 0, 0, 17, 1, 32, total_length, buffer);
1154
      break;
1155
    case M32C_OPERAND_DST32ANUNPREFIXED :
1156
      errmsg = insert_normal (cd, fields->f_dst32_an_unprefixed, 0, 0, 9, 1, 32, total_length, buffer);
1157
      break;
1158
    case M32C_OPERAND_DST32ANUNPREFIXEDHI :
1159
      errmsg = insert_normal (cd, fields->f_dst32_an_unprefixed, 0, 0, 9, 1, 32, total_length, buffer);
1160
      break;
1161
    case M32C_OPERAND_DST32ANUNPREFIXEDQI :
1162
      errmsg = insert_normal (cd, fields->f_dst32_an_unprefixed, 0, 0, 9, 1, 32, total_length, buffer);
1163
      break;
1164
    case M32C_OPERAND_DST32ANUNPREFIXEDSI :
1165
      errmsg = insert_normal (cd, fields->f_dst32_an_unprefixed, 0, 0, 9, 1, 32, total_length, buffer);
1166
      break;
1167
    case M32C_OPERAND_DST32R0HI_S :
1168
      break;
1169
    case M32C_OPERAND_DST32R0QI_S :
1170
      break;
1171
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDHI :
1172
      errmsg = insert_normal (cd, fields->f_dst32_rn_ext_unprefixed, 0, 0, 9, 1, 32, total_length, buffer);
1173
      break;
1174
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDQI :
1175
      errmsg = insert_normal (cd, fields->f_dst32_rn_ext_unprefixed, 0, 0, 9, 1, 32, total_length, buffer);
1176
      break;
1177
    case M32C_OPERAND_DST32RNPREFIXEDHI :
1178
      {
1179
        long value = fields->f_dst32_rn_prefixed_HI;
1180
        value = ((((value) + (2))) % (4));
1181
        errmsg = insert_normal (cd, value, 0, 0, 16, 2, 32, total_length, buffer);
1182
      }
1183
      break;
1184
    case M32C_OPERAND_DST32RNPREFIXEDQI :
1185
      {
1186
        long value = fields->f_dst32_rn_prefixed_QI;
1187
        value = (((((((~ (value))) << (1))) & (2))) | (((((USI) (value) >> (1))) & (1))));
1188
        errmsg = insert_normal (cd, value, 0, 0, 16, 2, 32, total_length, buffer);
1189
      }
1190
      break;
1191
    case M32C_OPERAND_DST32RNPREFIXEDSI :
1192
      {
1193
        long value = fields->f_dst32_rn_prefixed_SI;
1194
        value = ((value) + (2));
1195
        errmsg = insert_normal (cd, value, 0, 0, 16, 2, 32, total_length, buffer);
1196
      }
1197
      break;
1198
    case M32C_OPERAND_DST32RNUNPREFIXEDHI :
1199
      {
1200
        long value = fields->f_dst32_rn_unprefixed_HI;
1201
        value = ((((value) + (2))) % (4));
1202
        errmsg = insert_normal (cd, value, 0, 0, 8, 2, 32, total_length, buffer);
1203
      }
1204
      break;
1205
    case M32C_OPERAND_DST32RNUNPREFIXEDQI :
1206
      {
1207
        long value = fields->f_dst32_rn_unprefixed_QI;
1208
        value = (((((((~ (value))) << (1))) & (2))) | (((((USI) (value) >> (1))) & (1))));
1209
        errmsg = insert_normal (cd, value, 0, 0, 8, 2, 32, total_length, buffer);
1210
      }
1211
      break;
1212
    case M32C_OPERAND_DST32RNUNPREFIXEDSI :
1213
      {
1214
        long value = fields->f_dst32_rn_unprefixed_SI;
1215
        value = ((value) + (2));
1216
        errmsg = insert_normal (cd, value, 0, 0, 8, 2, 32, total_length, buffer);
1217
      }
1218
      break;
1219
    case M32C_OPERAND_G :
1220
      break;
1221
    case M32C_OPERAND_IMM_12_S4 :
1222
      errmsg = insert_normal (cd, fields->f_imm_12_s4, 0|(1<<CGEN_IFLD_SIGNED), 0, 12, 4, 32, total_length, buffer);
1223
      break;
1224
    case M32C_OPERAND_IMM_12_S4N :
1225
      errmsg = insert_normal (cd, fields->f_imm_12_s4, 0|(1<<CGEN_IFLD_SIGNED), 0, 12, 4, 32, total_length, buffer);
1226
      break;
1227
    case M32C_OPERAND_IMM_13_U3 :
1228
      errmsg = insert_normal (cd, fields->f_imm_13_u3, 0, 0, 13, 3, 32, total_length, buffer);
1229
      break;
1230
    case M32C_OPERAND_IMM_16_HI :
1231
      {
1232
        long value = fields->f_dsp_16_s16;
1233
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
1234
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 16, 32, total_length, buffer);
1235
      }
1236
      break;
1237
    case M32C_OPERAND_IMM_16_QI :
1238
      errmsg = insert_normal (cd, fields->f_dsp_16_s8, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 8, 32, total_length, buffer);
1239
      break;
1240
    case M32C_OPERAND_IMM_16_SI :
1241
      {
1242
{
1243
  FLD (f_dsp_32_u16) = ((((UINT) (FLD (f_dsp_16_s32)) >> (16))) & (65535));
1244
  FLD (f_dsp_16_u16) = ((FLD (f_dsp_16_s32)) & (65535));
1245
}
1246
        {
1247
        long value = fields->f_dsp_16_u16;
1248
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1249
        errmsg = insert_normal (cd, value, 0, 0, 16, 16, 32, total_length, buffer);
1250
      }
1251
        if (errmsg)
1252
          break;
1253
        {
1254
        long value = fields->f_dsp_32_u16;
1255
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1256
        errmsg = insert_normal (cd, value, 0, 32, 0, 16, 32, total_length, buffer);
1257
      }
1258
        if (errmsg)
1259
          break;
1260
      }
1261
      break;
1262
    case M32C_OPERAND_IMM_20_S4 :
1263
      errmsg = insert_normal (cd, fields->f_imm_20_s4, 0|(1<<CGEN_IFLD_SIGNED), 0, 20, 4, 32, total_length, buffer);
1264
      break;
1265
    case M32C_OPERAND_IMM_24_HI :
1266
      {
1267
{
1268
  FLD (f_dsp_24_u8) = ((FLD (f_dsp_24_s16)) & (255));
1269
  FLD (f_dsp_32_u8) = ((((UINT) (FLD (f_dsp_24_s16)) >> (8))) & (255));
1270
}
1271
        errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
1272
        if (errmsg)
1273
          break;
1274
        errmsg = insert_normal (cd, fields->f_dsp_32_u8, 0, 32, 0, 8, 32, total_length, buffer);
1275
        if (errmsg)
1276
          break;
1277
      }
1278
      break;
1279
    case M32C_OPERAND_IMM_24_QI :
1280
      errmsg = insert_normal (cd, fields->f_dsp_24_s8, 0|(1<<CGEN_IFLD_SIGNED), 0, 24, 8, 32, total_length, buffer);
1281
      break;
1282
    case M32C_OPERAND_IMM_24_SI :
1283
      {
1284
{
1285
  FLD (f_dsp_32_u24) = ((((UINT) (FLD (f_dsp_24_s32)) >> (8))) & (16777215));
1286
  FLD (f_dsp_24_u8) = ((FLD (f_dsp_24_s32)) & (255));
1287
}
1288
        errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
1289
        if (errmsg)
1290
          break;
1291
        {
1292
        long value = fields->f_dsp_32_u24;
1293
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (16711680))));
1294
        errmsg = insert_normal (cd, value, 0, 32, 0, 24, 32, total_length, buffer);
1295
      }
1296
        if (errmsg)
1297
          break;
1298
      }
1299
      break;
1300
    case M32C_OPERAND_IMM_32_HI :
1301
      {
1302
        long value = fields->f_dsp_32_s16;
1303
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
1304
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 16, 32, total_length, buffer);
1305
      }
1306
      break;
1307
    case M32C_OPERAND_IMM_32_QI :
1308
      errmsg = insert_normal (cd, fields->f_dsp_32_s8, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 8, 32, total_length, buffer);
1309
      break;
1310
    case M32C_OPERAND_IMM_32_SI :
1311
      {
1312
        long value = fields->f_dsp_32_s32;
1313
        value = EXTSISI (((((((((UINT) (value) >> (24))) & (255))) | (((((UINT) (value) >> (8))) & (65280))))) | (((((((value) << (8))) & (16711680))) | (((((value) << (24))) & (0xff000000)))))));
1314
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 32, 32, total_length, buffer);
1315
      }
1316
      break;
1317
    case M32C_OPERAND_IMM_40_HI :
1318
      {
1319
        long value = fields->f_dsp_40_s16;
1320
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
1321
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 32, 8, 16, 32, total_length, buffer);
1322
      }
1323
      break;
1324
    case M32C_OPERAND_IMM_40_QI :
1325
      errmsg = insert_normal (cd, fields->f_dsp_40_s8, 0|(1<<CGEN_IFLD_SIGNED), 32, 8, 8, 32, total_length, buffer);
1326
      break;
1327
    case M32C_OPERAND_IMM_40_SI :
1328
      {
1329
{
1330
  FLD (f_dsp_64_u8) = ((((UINT) (FLD (f_dsp_40_s32)) >> (24))) & (255));
1331
  FLD (f_dsp_40_u24) = ((FLD (f_dsp_40_s32)) & (16777215));
1332
}
1333
        {
1334
        long value = fields->f_dsp_40_u24;
1335
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (16711680))));
1336
        errmsg = insert_normal (cd, value, 0, 32, 8, 24, 32, total_length, buffer);
1337
      }
1338
        if (errmsg)
1339
          break;
1340
        errmsg = insert_normal (cd, fields->f_dsp_64_u8, 0, 64, 0, 8, 32, total_length, buffer);
1341
        if (errmsg)
1342
          break;
1343
      }
1344
      break;
1345
    case M32C_OPERAND_IMM_48_HI :
1346
      {
1347
        long value = fields->f_dsp_48_s16;
1348
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
1349
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 32, 16, 16, 32, total_length, buffer);
1350
      }
1351
      break;
1352
    case M32C_OPERAND_IMM_48_QI :
1353
      errmsg = insert_normal (cd, fields->f_dsp_48_s8, 0|(1<<CGEN_IFLD_SIGNED), 32, 16, 8, 32, total_length, buffer);
1354
      break;
1355
    case M32C_OPERAND_IMM_48_SI :
1356
      {
1357
{
1358
  FLD (f_dsp_64_u16) = ((((UINT) (FLD (f_dsp_48_s32)) >> (16))) & (65535));
1359
  FLD (f_dsp_48_u16) = ((FLD (f_dsp_48_s32)) & (65535));
1360
}
1361
        {
1362
        long value = fields->f_dsp_48_u16;
1363
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1364
        errmsg = insert_normal (cd, value, 0, 32, 16, 16, 32, total_length, buffer);
1365
      }
1366
        if (errmsg)
1367
          break;
1368
        {
1369
        long value = fields->f_dsp_64_u16;
1370
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1371
        errmsg = insert_normal (cd, value, 0, 64, 0, 16, 32, total_length, buffer);
1372
      }
1373
        if (errmsg)
1374
          break;
1375
      }
1376
      break;
1377
    case M32C_OPERAND_IMM_56_HI :
1378
      {
1379
{
1380
  FLD (f_dsp_56_u8) = ((FLD (f_dsp_56_s16)) & (255));
1381
  FLD (f_dsp_64_u8) = ((((UINT) (FLD (f_dsp_56_s16)) >> (8))) & (255));
1382
}
1383
        errmsg = insert_normal (cd, fields->f_dsp_56_u8, 0, 32, 24, 8, 32, total_length, buffer);
1384
        if (errmsg)
1385
          break;
1386
        errmsg = insert_normal (cd, fields->f_dsp_64_u8, 0, 64, 0, 8, 32, total_length, buffer);
1387
        if (errmsg)
1388
          break;
1389
      }
1390
      break;
1391
    case M32C_OPERAND_IMM_56_QI :
1392
      errmsg = insert_normal (cd, fields->f_dsp_56_s8, 0|(1<<CGEN_IFLD_SIGNED), 32, 24, 8, 32, total_length, buffer);
1393
      break;
1394
    case M32C_OPERAND_IMM_64_HI :
1395
      {
1396
        long value = fields->f_dsp_64_s16;
1397
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
1398
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 64, 0, 16, 32, total_length, buffer);
1399
      }
1400
      break;
1401
    case M32C_OPERAND_IMM_8_HI :
1402
      {
1403
        long value = fields->f_dsp_8_s16;
1404
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
1405
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 16, 32, total_length, buffer);
1406
      }
1407
      break;
1408
    case M32C_OPERAND_IMM_8_QI :
1409
      errmsg = insert_normal (cd, fields->f_dsp_8_s8, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 8, 32, total_length, buffer);
1410
      break;
1411
    case M32C_OPERAND_IMM_8_S4 :
1412
      errmsg = insert_normal (cd, fields->f_imm_8_s4, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 4, 32, total_length, buffer);
1413
      break;
1414
    case M32C_OPERAND_IMM_8_S4N :
1415
      errmsg = insert_normal (cd, fields->f_imm_8_s4, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 4, 32, total_length, buffer);
1416
      break;
1417
    case M32C_OPERAND_IMM_SH_12_S4 :
1418
      errmsg = insert_normal (cd, fields->f_imm_12_s4, 0|(1<<CGEN_IFLD_SIGNED), 0, 12, 4, 32, total_length, buffer);
1419
      break;
1420
    case M32C_OPERAND_IMM_SH_20_S4 :
1421
      errmsg = insert_normal (cd, fields->f_imm_20_s4, 0|(1<<CGEN_IFLD_SIGNED), 0, 20, 4, 32, total_length, buffer);
1422
      break;
1423
    case M32C_OPERAND_IMM_SH_8_S4 :
1424
      errmsg = insert_normal (cd, fields->f_imm_8_s4, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 4, 32, total_length, buffer);
1425
      break;
1426
    case M32C_OPERAND_IMM1_S :
1427
      {
1428
        long value = fields->f_imm1_S;
1429
        value = ((value) - (1));
1430
        errmsg = insert_normal (cd, value, 0, 0, 2, 1, 32, total_length, buffer);
1431
      }
1432
      break;
1433
    case M32C_OPERAND_IMM3_S :
1434
      {
1435
{
1436
  FLD (f_7_1) = ((((FLD (f_imm3_S)) - (1))) & (1));
1437
  FLD (f_2_2) = ((((UINT) (((FLD (f_imm3_S)) - (1))) >> (1))) & (3));
1438
}
1439
        errmsg = insert_normal (cd, fields->f_2_2, 0, 0, 2, 2, 32, total_length, buffer);
1440
        if (errmsg)
1441
          break;
1442
        errmsg = insert_normal (cd, fields->f_7_1, 0, 0, 7, 1, 32, total_length, buffer);
1443
        if (errmsg)
1444
          break;
1445
      }
1446
      break;
1447
    case M32C_OPERAND_LAB_16_8 :
1448
      {
1449
        long value = fields->f_lab_16_8;
1450
        value = ((value) - (((pc) + (2))));
1451
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED)|(1<<CGEN_IFLD_PCREL_ADDR), 0, 16, 8, 32, total_length, buffer);
1452
      }
1453
      break;
1454
    case M32C_OPERAND_LAB_24_8 :
1455
      {
1456
        long value = fields->f_lab_24_8;
1457
        value = ((value) - (((pc) + (2))));
1458
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED)|(1<<CGEN_IFLD_PCREL_ADDR), 0, 24, 8, 32, total_length, buffer);
1459
      }
1460
      break;
1461
    case M32C_OPERAND_LAB_32_8 :
1462
      {
1463
        long value = fields->f_lab_32_8;
1464
        value = ((value) - (((pc) + (2))));
1465
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED)|(1<<CGEN_IFLD_PCREL_ADDR), 32, 0, 8, 32, total_length, buffer);
1466
      }
1467
      break;
1468
    case M32C_OPERAND_LAB_40_8 :
1469
      {
1470
        long value = fields->f_lab_40_8;
1471
        value = ((value) - (((pc) + (2))));
1472
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED)|(1<<CGEN_IFLD_PCREL_ADDR), 32, 8, 8, 32, total_length, buffer);
1473
      }
1474
      break;
1475
    case M32C_OPERAND_LAB_5_3 :
1476
      {
1477
        long value = fields->f_lab_5_3;
1478
        value = ((value) - (((pc) + (2))));
1479
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_PCREL_ADDR), 0, 5, 3, 32, total_length, buffer);
1480
      }
1481
      break;
1482
    case M32C_OPERAND_LAB_8_16 :
1483
      {
1484
        long value = fields->f_lab_8_16;
1485
        value = ((((((((value) - (((pc) + (1))))) & (255))) << (8))) | (((USI) (((((value) - (((pc) + (1))))) & (65535))) >> (8))));
1486
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGN_OPT)|(1<<CGEN_IFLD_PCREL_ADDR), 0, 8, 16, 32, total_length, buffer);
1487
      }
1488
      break;
1489
    case M32C_OPERAND_LAB_8_24 :
1490
      {
1491
        long value = fields->f_lab_8_24;
1492
        value = ((((((USI) (value) >> (16))) | (((value) & (65280))))) | (((((value) & (255))) << (16))));
1493
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_ABS_ADDR), 0, 8, 24, 32, total_length, buffer);
1494
      }
1495
      break;
1496
    case M32C_OPERAND_LAB_8_8 :
1497
      {
1498
        long value = fields->f_lab_8_8;
1499
        value = ((value) - (((pc) + (1))));
1500
        errmsg = insert_normal (cd, value, 0|(1<<CGEN_IFLD_SIGNED)|(1<<CGEN_IFLD_PCREL_ADDR), 0, 8, 8, 32, total_length, buffer);
1501
      }
1502
      break;
1503
    case M32C_OPERAND_LAB32_JMP_S :
1504
      {
1505
{
1506
  SI tmp_val;
1507
  tmp_val = ((((FLD (f_lab32_jmp_s)) - (pc))) - (2));
1508
  FLD (f_7_1) = ((tmp_val) & (1));
1509
  FLD (f_2_2) = ((USI) (tmp_val) >> (1));
1510
}
1511
        errmsg = insert_normal (cd, fields->f_2_2, 0, 0, 2, 2, 32, total_length, buffer);
1512
        if (errmsg)
1513
          break;
1514
        errmsg = insert_normal (cd, fields->f_7_1, 0, 0, 7, 1, 32, total_length, buffer);
1515
        if (errmsg)
1516
          break;
1517
      }
1518
      break;
1519
    case M32C_OPERAND_Q :
1520
      break;
1521
    case M32C_OPERAND_R0 :
1522
      break;
1523
    case M32C_OPERAND_R0H :
1524
      break;
1525
    case M32C_OPERAND_R0L :
1526
      break;
1527
    case M32C_OPERAND_R1 :
1528
      break;
1529
    case M32C_OPERAND_R1R2R0 :
1530
      break;
1531
    case M32C_OPERAND_R2 :
1532
      break;
1533
    case M32C_OPERAND_R2R0 :
1534
      break;
1535
    case M32C_OPERAND_R3 :
1536
      break;
1537
    case M32C_OPERAND_R3R1 :
1538
      break;
1539
    case M32C_OPERAND_REGSETPOP :
1540
      errmsg = insert_normal (cd, fields->f_8_8, 0, 0, 8, 8, 32, total_length, buffer);
1541
      break;
1542
    case M32C_OPERAND_REGSETPUSH :
1543
      errmsg = insert_normal (cd, fields->f_8_8, 0, 0, 8, 8, 32, total_length, buffer);
1544
      break;
1545
    case M32C_OPERAND_RN16_PUSH_S :
1546
      errmsg = insert_normal (cd, fields->f_4_1, 0, 0, 4, 1, 32, total_length, buffer);
1547
      break;
1548
    case M32C_OPERAND_S :
1549
      break;
1550
    case M32C_OPERAND_SRC16AN :
1551
      errmsg = insert_normal (cd, fields->f_src16_an, 0, 0, 11, 1, 32, total_length, buffer);
1552
      break;
1553
    case M32C_OPERAND_SRC16ANHI :
1554
      errmsg = insert_normal (cd, fields->f_src16_an, 0, 0, 11, 1, 32, total_length, buffer);
1555
      break;
1556
    case M32C_OPERAND_SRC16ANQI :
1557
      errmsg = insert_normal (cd, fields->f_src16_an, 0, 0, 11, 1, 32, total_length, buffer);
1558
      break;
1559
    case M32C_OPERAND_SRC16RNHI :
1560
      errmsg = insert_normal (cd, fields->f_src16_rn, 0, 0, 10, 2, 32, total_length, buffer);
1561
      break;
1562
    case M32C_OPERAND_SRC16RNQI :
1563
      errmsg = insert_normal (cd, fields->f_src16_rn, 0, 0, 10, 2, 32, total_length, buffer);
1564
      break;
1565
    case M32C_OPERAND_SRC32ANPREFIXED :
1566
      errmsg = insert_normal (cd, fields->f_src32_an_prefixed, 0, 0, 19, 1, 32, total_length, buffer);
1567
      break;
1568
    case M32C_OPERAND_SRC32ANPREFIXEDHI :
1569
      errmsg = insert_normal (cd, fields->f_src32_an_prefixed, 0, 0, 19, 1, 32, total_length, buffer);
1570
      break;
1571
    case M32C_OPERAND_SRC32ANPREFIXEDQI :
1572
      errmsg = insert_normal (cd, fields->f_src32_an_prefixed, 0, 0, 19, 1, 32, total_length, buffer);
1573
      break;
1574
    case M32C_OPERAND_SRC32ANPREFIXEDSI :
1575
      errmsg = insert_normal (cd, fields->f_src32_an_prefixed, 0, 0, 19, 1, 32, total_length, buffer);
1576
      break;
1577
    case M32C_OPERAND_SRC32ANUNPREFIXED :
1578
      errmsg = insert_normal (cd, fields->f_src32_an_unprefixed, 0, 0, 11, 1, 32, total_length, buffer);
1579
      break;
1580
    case M32C_OPERAND_SRC32ANUNPREFIXEDHI :
1581
      errmsg = insert_normal (cd, fields->f_src32_an_unprefixed, 0, 0, 11, 1, 32, total_length, buffer);
1582
      break;
1583
    case M32C_OPERAND_SRC32ANUNPREFIXEDQI :
1584
      errmsg = insert_normal (cd, fields->f_src32_an_unprefixed, 0, 0, 11, 1, 32, total_length, buffer);
1585
      break;
1586
    case M32C_OPERAND_SRC32ANUNPREFIXEDSI :
1587
      errmsg = insert_normal (cd, fields->f_src32_an_unprefixed, 0, 0, 11, 1, 32, total_length, buffer);
1588
      break;
1589
    case M32C_OPERAND_SRC32RNPREFIXEDHI :
1590
      {
1591
        long value = fields->f_src32_rn_prefixed_HI;
1592
        value = ((((value) + (2))) % (4));
1593
        errmsg = insert_normal (cd, value, 0, 0, 18, 2, 32, total_length, buffer);
1594
      }
1595
      break;
1596
    case M32C_OPERAND_SRC32RNPREFIXEDQI :
1597
      {
1598
        long value = fields->f_src32_rn_prefixed_QI;
1599
        value = (((((((~ (value))) << (1))) & (2))) | (((((USI) (value) >> (1))) & (1))));
1600
        errmsg = insert_normal (cd, value, 0, 0, 18, 2, 32, total_length, buffer);
1601
      }
1602
      break;
1603
    case M32C_OPERAND_SRC32RNPREFIXEDSI :
1604
      {
1605
        long value = fields->f_src32_rn_prefixed_SI;
1606
        value = ((value) + (2));
1607
        errmsg = insert_normal (cd, value, 0, 0, 18, 2, 32, total_length, buffer);
1608
      }
1609
      break;
1610
    case M32C_OPERAND_SRC32RNUNPREFIXEDHI :
1611
      {
1612
        long value = fields->f_src32_rn_unprefixed_HI;
1613
        value = ((((value) + (2))) % (4));
1614
        errmsg = insert_normal (cd, value, 0, 0, 10, 2, 32, total_length, buffer);
1615
      }
1616
      break;
1617
    case M32C_OPERAND_SRC32RNUNPREFIXEDQI :
1618
      {
1619
        long value = fields->f_src32_rn_unprefixed_QI;
1620
        value = (((((((~ (value))) << (1))) & (2))) | (((((USI) (value) >> (1))) & (1))));
1621
        errmsg = insert_normal (cd, value, 0, 0, 10, 2, 32, total_length, buffer);
1622
      }
1623
      break;
1624
    case M32C_OPERAND_SRC32RNUNPREFIXEDSI :
1625
      {
1626
        long value = fields->f_src32_rn_unprefixed_SI;
1627
        value = ((value) + (2));
1628
        errmsg = insert_normal (cd, value, 0, 0, 10, 2, 32, total_length, buffer);
1629
      }
1630
      break;
1631
    case M32C_OPERAND_SRCDST16_R0L_R0H_S_NORMAL :
1632
      errmsg = insert_normal (cd, fields->f_5_1, 0, 0, 5, 1, 32, total_length, buffer);
1633
      break;
1634
    case M32C_OPERAND_X :
1635
      break;
1636
    case M32C_OPERAND_Z :
1637
      break;
1638
    case M32C_OPERAND_COND16_16 :
1639
      errmsg = insert_normal (cd, fields->f_dsp_16_u8, 0, 0, 16, 8, 32, total_length, buffer);
1640
      break;
1641
    case M32C_OPERAND_COND16_24 :
1642
      errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
1643
      break;
1644
    case M32C_OPERAND_COND16_32 :
1645
      errmsg = insert_normal (cd, fields->f_dsp_32_u8, 0, 32, 0, 8, 32, total_length, buffer);
1646
      break;
1647
    case M32C_OPERAND_COND16C :
1648
      errmsg = insert_normal (cd, fields->f_cond16, 0, 0, 12, 4, 32, total_length, buffer);
1649
      break;
1650
    case M32C_OPERAND_COND16J :
1651
      errmsg = insert_normal (cd, fields->f_cond16, 0, 0, 12, 4, 32, total_length, buffer);
1652
      break;
1653
    case M32C_OPERAND_COND16J5 :
1654
      errmsg = insert_normal (cd, fields->f_cond16j_5, 0, 0, 5, 3, 32, total_length, buffer);
1655
      break;
1656
    case M32C_OPERAND_COND32 :
1657
      {
1658
{
1659
  FLD (f_9_1) = ((((UINT) (FLD (f_cond32)) >> (3))) & (1));
1660
  FLD (f_13_3) = ((FLD (f_cond32)) & (7));
1661
}
1662
        errmsg = insert_normal (cd, fields->f_9_1, 0, 0, 9, 1, 32, total_length, buffer);
1663
        if (errmsg)
1664
          break;
1665
        errmsg = insert_normal (cd, fields->f_13_3, 0, 0, 13, 3, 32, total_length, buffer);
1666
        if (errmsg)
1667
          break;
1668
      }
1669
      break;
1670
    case M32C_OPERAND_COND32_16 :
1671
      errmsg = insert_normal (cd, fields->f_dsp_16_u8, 0, 0, 16, 8, 32, total_length, buffer);
1672
      break;
1673
    case M32C_OPERAND_COND32_24 :
1674
      errmsg = insert_normal (cd, fields->f_dsp_24_u8, 0, 0, 24, 8, 32, total_length, buffer);
1675
      break;
1676
    case M32C_OPERAND_COND32_32 :
1677
      errmsg = insert_normal (cd, fields->f_dsp_32_u8, 0, 32, 0, 8, 32, total_length, buffer);
1678
      break;
1679
    case M32C_OPERAND_COND32_40 :
1680
      errmsg = insert_normal (cd, fields->f_dsp_40_u8, 0, 32, 8, 8, 32, total_length, buffer);
1681
      break;
1682
    case M32C_OPERAND_COND32J :
1683
      {
1684
{
1685
  FLD (f_1_3) = ((((UINT) (FLD (f_cond32j)) >> (1))) & (7));
1686
  FLD (f_7_1) = ((FLD (f_cond32j)) & (1));
1687
}
1688
        errmsg = insert_normal (cd, fields->f_1_3, 0, 0, 1, 3, 32, total_length, buffer);
1689
        if (errmsg)
1690
          break;
1691
        errmsg = insert_normal (cd, fields->f_7_1, 0, 0, 7, 1, 32, total_length, buffer);
1692
        if (errmsg)
1693
          break;
1694
      }
1695
      break;
1696
    case M32C_OPERAND_CR1_PREFIXED_32 :
1697
      errmsg = insert_normal (cd, fields->f_21_3, 0, 0, 21, 3, 32, total_length, buffer);
1698
      break;
1699
    case M32C_OPERAND_CR1_UNPREFIXED_32 :
1700
      errmsg = insert_normal (cd, fields->f_13_3, 0, 0, 13, 3, 32, total_length, buffer);
1701
      break;
1702
    case M32C_OPERAND_CR16 :
1703
      errmsg = insert_normal (cd, fields->f_9_3, 0, 0, 9, 3, 32, total_length, buffer);
1704
      break;
1705
    case M32C_OPERAND_CR2_32 :
1706
      errmsg = insert_normal (cd, fields->f_13_3, 0, 0, 13, 3, 32, total_length, buffer);
1707
      break;
1708
    case M32C_OPERAND_CR3_PREFIXED_32 :
1709
      errmsg = insert_normal (cd, fields->f_21_3, 0, 0, 21, 3, 32, total_length, buffer);
1710
      break;
1711
    case M32C_OPERAND_CR3_UNPREFIXED_32 :
1712
      errmsg = insert_normal (cd, fields->f_13_3, 0, 0, 13, 3, 32, total_length, buffer);
1713
      break;
1714
    case M32C_OPERAND_FLAGS16 :
1715
      errmsg = insert_normal (cd, fields->f_9_3, 0, 0, 9, 3, 32, total_length, buffer);
1716
      break;
1717
    case M32C_OPERAND_FLAGS32 :
1718
      errmsg = insert_normal (cd, fields->f_13_3, 0, 0, 13, 3, 32, total_length, buffer);
1719
      break;
1720
    case M32C_OPERAND_SCCOND32 :
1721
      errmsg = insert_normal (cd, fields->f_cond16, 0, 0, 12, 4, 32, total_length, buffer);
1722
      break;
1723
    case M32C_OPERAND_SIZE :
1724
      break;
1725
 
1726
    default :
1727
      /* xgettext:c-format */
1728
      fprintf (stderr, _("Unrecognized field %d while building insn.\n"),
1729
               opindex);
1730
      abort ();
1731
  }
1732
 
1733
  return errmsg;
1734
}
1735
 
1736
int m32c_cgen_extract_operand
1737
  (CGEN_CPU_DESC, int, CGEN_EXTRACT_INFO *, CGEN_INSN_INT, CGEN_FIELDS *, bfd_vma);
1738
 
1739
/* Main entry point for operand extraction.
1740
   The result is <= 0 for error, >0 for success.
1741
   ??? Actual values aren't well defined right now.
1742
 
1743
   This function is basically just a big switch statement.  Earlier versions
1744
   used tables to look up the function to use, but
1745
   - if the table contains both assembler and disassembler functions then
1746
     the disassembler contains much of the assembler and vice-versa,
1747
   - there's a lot of inlining possibilities as things grow,
1748
   - using a switch statement avoids the function call overhead.
1749
 
1750
   This function could be moved into `print_insn_normal', but keeping it
1751
   separate makes clear the interface between `print_insn_normal' and each of
1752
   the handlers.  */
1753
 
1754
int
1755
m32c_cgen_extract_operand (CGEN_CPU_DESC cd,
1756
                             int opindex,
1757
                             CGEN_EXTRACT_INFO *ex_info,
1758
                             CGEN_INSN_INT insn_value,
1759
                             CGEN_FIELDS * fields,
1760
                             bfd_vma pc)
1761
{
1762
  /* Assume success (for those operands that are nops).  */
1763
  int length = 1;
1764
  unsigned int total_length = CGEN_FIELDS_BITSIZE (fields);
1765
 
1766
  switch (opindex)
1767
    {
1768
    case M32C_OPERAND_A0 :
1769
      break;
1770
    case M32C_OPERAND_A1 :
1771
      break;
1772
    case M32C_OPERAND_AN16_PUSH_S :
1773
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 4, 1, 32, total_length, pc, & fields->f_4_1);
1774
      break;
1775
    case M32C_OPERAND_BIT16AN :
1776
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 15, 1, 32, total_length, pc, & fields->f_dst16_an);
1777
      break;
1778
    case M32C_OPERAND_BIT16RN :
1779
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 14, 2, 32, total_length, pc, & fields->f_dst16_rn);
1780
      break;
1781
    case M32C_OPERAND_BIT3_S :
1782
      {
1783
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 2, 2, 32, total_length, pc, & fields->f_2_2);
1784
        if (length <= 0) break;
1785
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 7, 1, 32, total_length, pc, & fields->f_7_1);
1786
        if (length <= 0) break;
1787
{
1788
  FLD (f_imm3_S) = ((((((FLD (f_2_2)) << (1))) | (FLD (f_7_1)))) + (1));
1789
}
1790
      }
1791
      break;
1792
    case M32C_OPERAND_BIT32ANPREFIXED :
1793
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 17, 1, 32, total_length, pc, & fields->f_dst32_an_prefixed);
1794
      break;
1795
    case M32C_OPERAND_BIT32ANUNPREFIXED :
1796
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 9, 1, 32, total_length, pc, & fields->f_dst32_an_unprefixed);
1797
      break;
1798
    case M32C_OPERAND_BIT32RNPREFIXED :
1799
      {
1800
        long value;
1801
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 2, 32, total_length, pc, & value);
1802
        value = (((((~ (((USI) (value) >> (1))))) & (1))) | (((((value) << (1))) & (2))));
1803
        fields->f_dst32_rn_prefixed_QI = value;
1804
      }
1805
      break;
1806
    case M32C_OPERAND_BIT32RNUNPREFIXED :
1807
      {
1808
        long value;
1809
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 8, 2, 32, total_length, pc, & value);
1810
        value = (((((~ (((USI) (value) >> (1))))) & (1))) | (((((value) << (1))) & (2))));
1811
        fields->f_dst32_rn_unprefixed_QI = value;
1812
      }
1813
      break;
1814
    case M32C_OPERAND_BITBASE16_16_S8 :
1815
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 8, 32, total_length, pc, & fields->f_dsp_16_s8);
1816
      break;
1817
    case M32C_OPERAND_BITBASE16_16_U16 :
1818
      {
1819
        long value;
1820
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 16, 32, total_length, pc, & value);
1821
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1822
        fields->f_dsp_16_u16 = value;
1823
      }
1824
      break;
1825
    case M32C_OPERAND_BITBASE16_16_U8 :
1826
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 8, 32, total_length, pc, & fields->f_dsp_16_u8);
1827
      break;
1828
    case M32C_OPERAND_BITBASE16_8_U11_S :
1829
      {
1830
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 5, 3, 32, total_length, pc, & fields->f_bitno16_S);
1831
        if (length <= 0) break;
1832
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 8, 8, 32, total_length, pc, & fields->f_dsp_8_u8);
1833
        if (length <= 0) break;
1834
{
1835
  FLD (f_bitbase16_u11_S) = ((((FLD (f_dsp_8_u8)) << (3))) | (FLD (f_bitno16_S)));
1836
}
1837
      }
1838
      break;
1839
    case M32C_OPERAND_BITBASE32_16_S11_UNPREFIXED :
1840
      {
1841
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_bitno32_unprefixed);
1842
        if (length <= 0) break;
1843
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 8, 32, total_length, pc, & fields->f_dsp_16_s8);
1844
        if (length <= 0) break;
1845
{
1846
  FLD (f_bitbase32_16_s11_unprefixed) = ((((FLD (f_dsp_16_s8)) << (3))) | (FLD (f_bitno32_unprefixed)));
1847
}
1848
      }
1849
      break;
1850
    case M32C_OPERAND_BITBASE32_16_S19_UNPREFIXED :
1851
      {
1852
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_bitno32_unprefixed);
1853
        if (length <= 0) break;
1854
        {
1855
        long value;
1856
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 16, 32, total_length, pc, & value);
1857
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
1858
        fields->f_dsp_16_s16 = value;
1859
      }
1860
        if (length <= 0) break;
1861
{
1862
  FLD (f_bitbase32_16_s19_unprefixed) = ((((FLD (f_dsp_16_s16)) << (3))) | (FLD (f_bitno32_unprefixed)));
1863
}
1864
      }
1865
      break;
1866
    case M32C_OPERAND_BITBASE32_16_U11_UNPREFIXED :
1867
      {
1868
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_bitno32_unprefixed);
1869
        if (length <= 0) break;
1870
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 8, 32, total_length, pc, & fields->f_dsp_16_u8);
1871
        if (length <= 0) break;
1872
{
1873
  FLD (f_bitbase32_16_u11_unprefixed) = ((((FLD (f_dsp_16_u8)) << (3))) | (FLD (f_bitno32_unprefixed)));
1874
}
1875
      }
1876
      break;
1877
    case M32C_OPERAND_BITBASE32_16_U19_UNPREFIXED :
1878
      {
1879
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_bitno32_unprefixed);
1880
        if (length <= 0) break;
1881
        {
1882
        long value;
1883
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 16, 32, total_length, pc, & value);
1884
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1885
        fields->f_dsp_16_u16 = value;
1886
      }
1887
        if (length <= 0) break;
1888
{
1889
  FLD (f_bitbase32_16_u19_unprefixed) = ((((FLD (f_dsp_16_u16)) << (3))) | (FLD (f_bitno32_unprefixed)));
1890
}
1891
      }
1892
      break;
1893
    case M32C_OPERAND_BITBASE32_16_U27_UNPREFIXED :
1894
      {
1895
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_bitno32_unprefixed);
1896
        if (length <= 0) break;
1897
        {
1898
        long value;
1899
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 16, 32, total_length, pc, & value);
1900
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1901
        fields->f_dsp_16_u16 = value;
1902
      }
1903
        if (length <= 0) break;
1904
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_u8);
1905
        if (length <= 0) break;
1906
{
1907
  FLD (f_bitbase32_16_u27_unprefixed) = ((((FLD (f_dsp_16_u16)) << (3))) | (((((FLD (f_dsp_32_u8)) << (19))) | (FLD (f_bitno32_unprefixed)))));
1908
}
1909
      }
1910
      break;
1911
    case M32C_OPERAND_BITBASE32_24_S11_PREFIXED :
1912
      {
1913
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 21, 3, 32, total_length, pc, & fields->f_bitno32_prefixed);
1914
        if (length <= 0) break;
1915
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_s8);
1916
        if (length <= 0) break;
1917
{
1918
  FLD (f_bitbase32_24_s11_prefixed) = ((((FLD (f_dsp_24_s8)) << (3))) | (FLD (f_bitno32_prefixed)));
1919
}
1920
      }
1921
      break;
1922
    case M32C_OPERAND_BITBASE32_24_S19_PREFIXED :
1923
      {
1924
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 21, 3, 32, total_length, pc, & fields->f_bitno32_prefixed);
1925
        if (length <= 0) break;
1926
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
1927
        if (length <= 0) break;
1928
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_s8);
1929
        if (length <= 0) break;
1930
{
1931
  FLD (f_bitbase32_24_s19_prefixed) = ((((FLD (f_dsp_24_u8)) << (3))) | (((((FLD (f_dsp_32_s8)) << (11))) | (FLD (f_bitno32_prefixed)))));
1932
}
1933
      }
1934
      break;
1935
    case M32C_OPERAND_BITBASE32_24_U11_PREFIXED :
1936
      {
1937
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 21, 3, 32, total_length, pc, & fields->f_bitno32_prefixed);
1938
        if (length <= 0) break;
1939
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
1940
        if (length <= 0) break;
1941
{
1942
  FLD (f_bitbase32_24_u11_prefixed) = ((((FLD (f_dsp_24_u8)) << (3))) | (FLD (f_bitno32_prefixed)));
1943
}
1944
      }
1945
      break;
1946
    case M32C_OPERAND_BITBASE32_24_U19_PREFIXED :
1947
      {
1948
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 21, 3, 32, total_length, pc, & fields->f_bitno32_prefixed);
1949
        if (length <= 0) break;
1950
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
1951
        if (length <= 0) break;
1952
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_u8);
1953
        if (length <= 0) break;
1954
{
1955
  FLD (f_bitbase32_24_u19_prefixed) = ((((FLD (f_dsp_24_u8)) << (3))) | (((((FLD (f_dsp_32_u8)) << (11))) | (FLD (f_bitno32_prefixed)))));
1956
}
1957
      }
1958
      break;
1959
    case M32C_OPERAND_BITBASE32_24_U27_PREFIXED :
1960
      {
1961
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 21, 3, 32, total_length, pc, & fields->f_bitno32_prefixed);
1962
        if (length <= 0) break;
1963
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
1964
        if (length <= 0) break;
1965
        {
1966
        long value;
1967
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 16, 32, total_length, pc, & value);
1968
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
1969
        fields->f_dsp_32_u16 = value;
1970
      }
1971
        if (length <= 0) break;
1972
{
1973
  FLD (f_bitbase32_24_u27_prefixed) = ((((FLD (f_dsp_24_u8)) << (3))) | (((((FLD (f_dsp_32_u16)) << (11))) | (FLD (f_bitno32_prefixed)))));
1974
}
1975
      }
1976
      break;
1977
    case M32C_OPERAND_BITNO16R :
1978
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 8, 32, total_length, pc, & fields->f_dsp_16_u8);
1979
      break;
1980
    case M32C_OPERAND_BITNO32PREFIXED :
1981
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 21, 3, 32, total_length, pc, & fields->f_bitno32_prefixed);
1982
      break;
1983
    case M32C_OPERAND_BITNO32UNPREFIXED :
1984
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_bitno32_unprefixed);
1985
      break;
1986
    case M32C_OPERAND_DSP_10_U6 :
1987
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 10, 6, 32, total_length, pc, & fields->f_dsp_10_u6);
1988
      break;
1989
    case M32C_OPERAND_DSP_16_S16 :
1990
      {
1991
        long value;
1992
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 16, 32, total_length, pc, & value);
1993
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
1994
        fields->f_dsp_16_s16 = value;
1995
      }
1996
      break;
1997
    case M32C_OPERAND_DSP_16_S8 :
1998
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 8, 32, total_length, pc, & fields->f_dsp_16_s8);
1999
      break;
2000
    case M32C_OPERAND_DSP_16_U16 :
2001
      {
2002
        long value;
2003
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 16, 32, total_length, pc, & value);
2004
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2005
        fields->f_dsp_16_u16 = value;
2006
      }
2007
      break;
2008
    case M32C_OPERAND_DSP_16_U20 :
2009
      {
2010
        {
2011
        long value;
2012
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 16, 32, total_length, pc, & value);
2013
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2014
        fields->f_dsp_16_u16 = value;
2015
      }
2016
        if (length <= 0) break;
2017
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_u8);
2018
        if (length <= 0) break;
2019
{
2020
  FLD (f_dsp_16_u24) = ((((FLD (f_dsp_32_u8)) << (16))) | (FLD (f_dsp_16_u16)));
2021
}
2022
      }
2023
      break;
2024
    case M32C_OPERAND_DSP_16_U24 :
2025
      {
2026
        {
2027
        long value;
2028
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 16, 32, total_length, pc, & value);
2029
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2030
        fields->f_dsp_16_u16 = value;
2031
      }
2032
        if (length <= 0) break;
2033
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_u8);
2034
        if (length <= 0) break;
2035
{
2036
  FLD (f_dsp_16_u24) = ((((FLD (f_dsp_32_u8)) << (16))) | (FLD (f_dsp_16_u16)));
2037
}
2038
      }
2039
      break;
2040
    case M32C_OPERAND_DSP_16_U8 :
2041
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 8, 32, total_length, pc, & fields->f_dsp_16_u8);
2042
      break;
2043
    case M32C_OPERAND_DSP_24_S16 :
2044
      {
2045
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
2046
        if (length <= 0) break;
2047
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_u8);
2048
        if (length <= 0) break;
2049
{
2050
  FLD (f_dsp_24_s16) = EXTHISI (((HI) (UINT) (((((FLD (f_dsp_32_u8)) << (8))) | (FLD (f_dsp_24_u8))))));
2051
}
2052
      }
2053
      break;
2054
    case M32C_OPERAND_DSP_24_S8 :
2055
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_s8);
2056
      break;
2057
    case M32C_OPERAND_DSP_24_U16 :
2058
      {
2059
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
2060
        if (length <= 0) break;
2061
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_u8);
2062
        if (length <= 0) break;
2063
{
2064
  FLD (f_dsp_24_u16) = ((((FLD (f_dsp_32_u8)) << (8))) | (FLD (f_dsp_24_u8)));
2065
}
2066
      }
2067
      break;
2068
    case M32C_OPERAND_DSP_24_U20 :
2069
      {
2070
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
2071
        if (length <= 0) break;
2072
        {
2073
        long value;
2074
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 16, 32, total_length, pc, & value);
2075
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2076
        fields->f_dsp_32_u16 = value;
2077
      }
2078
        if (length <= 0) break;
2079
{
2080
  FLD (f_dsp_24_u24) = ((((FLD (f_dsp_32_u16)) << (8))) | (FLD (f_dsp_24_u8)));
2081
}
2082
      }
2083
      break;
2084
    case M32C_OPERAND_DSP_24_U24 :
2085
      {
2086
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
2087
        if (length <= 0) break;
2088
        {
2089
        long value;
2090
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 16, 32, total_length, pc, & value);
2091
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2092
        fields->f_dsp_32_u16 = value;
2093
      }
2094
        if (length <= 0) break;
2095
{
2096
  FLD (f_dsp_24_u24) = ((((FLD (f_dsp_32_u16)) << (8))) | (FLD (f_dsp_24_u8)));
2097
}
2098
      }
2099
      break;
2100
    case M32C_OPERAND_DSP_24_U8 :
2101
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
2102
      break;
2103
    case M32C_OPERAND_DSP_32_S16 :
2104
      {
2105
        long value;
2106
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 16, 32, total_length, pc, & value);
2107
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
2108
        fields->f_dsp_32_s16 = value;
2109
      }
2110
      break;
2111
    case M32C_OPERAND_DSP_32_S8 :
2112
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_s8);
2113
      break;
2114
    case M32C_OPERAND_DSP_32_U16 :
2115
      {
2116
        long value;
2117
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 16, 32, total_length, pc, & value);
2118
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2119
        fields->f_dsp_32_u16 = value;
2120
      }
2121
      break;
2122
    case M32C_OPERAND_DSP_32_U20 :
2123
      {
2124
        long value;
2125
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 24, 32, total_length, pc, & value);
2126
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (16711680))));
2127
        fields->f_dsp_32_u24 = value;
2128
      }
2129
      break;
2130
    case M32C_OPERAND_DSP_32_U24 :
2131
      {
2132
        long value;
2133
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 24, 32, total_length, pc, & value);
2134
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (16711680))));
2135
        fields->f_dsp_32_u24 = value;
2136
      }
2137
      break;
2138
    case M32C_OPERAND_DSP_32_U8 :
2139
      length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_u8);
2140
      break;
2141
    case M32C_OPERAND_DSP_40_S16 :
2142
      {
2143
        long value;
2144
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 8, 16, 32, total_length, pc, & value);
2145
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
2146
        fields->f_dsp_40_s16 = value;
2147
      }
2148
      break;
2149
    case M32C_OPERAND_DSP_40_S8 :
2150
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 8, 8, 32, total_length, pc, & fields->f_dsp_40_s8);
2151
      break;
2152
    case M32C_OPERAND_DSP_40_U16 :
2153
      {
2154
        long value;
2155
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 8, 16, 32, total_length, pc, & value);
2156
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2157
        fields->f_dsp_40_u16 = value;
2158
      }
2159
      break;
2160
    case M32C_OPERAND_DSP_40_U20 :
2161
      {
2162
        long value;
2163
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 8, 20, 32, total_length, pc, & value);
2164
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (983040))));
2165
        fields->f_dsp_40_u20 = value;
2166
      }
2167
      break;
2168
    case M32C_OPERAND_DSP_40_U24 :
2169
      {
2170
        long value;
2171
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 8, 24, 32, total_length, pc, & value);
2172
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (16711680))));
2173
        fields->f_dsp_40_u24 = value;
2174
      }
2175
      break;
2176
    case M32C_OPERAND_DSP_40_U8 :
2177
      length = extract_normal (cd, ex_info, insn_value, 0, 32, 8, 8, 32, total_length, pc, & fields->f_dsp_40_u8);
2178
      break;
2179
    case M32C_OPERAND_DSP_48_S16 :
2180
      {
2181
        long value;
2182
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 16, 16, 32, total_length, pc, & value);
2183
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
2184
        fields->f_dsp_48_s16 = value;
2185
      }
2186
      break;
2187
    case M32C_OPERAND_DSP_48_S8 :
2188
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 16, 8, 32, total_length, pc, & fields->f_dsp_48_s8);
2189
      break;
2190
    case M32C_OPERAND_DSP_48_U16 :
2191
      {
2192
        long value;
2193
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 16, 16, 32, total_length, pc, & value);
2194
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2195
        fields->f_dsp_48_u16 = value;
2196
      }
2197
      break;
2198
    case M32C_OPERAND_DSP_48_U20 :
2199
      {
2200
        {
2201
        long value;
2202
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 16, 16, 32, total_length, pc, & value);
2203
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2204
        fields->f_dsp_48_u16 = value;
2205
      }
2206
        if (length <= 0) break;
2207
        length = extract_normal (cd, ex_info, insn_value, 0, 64, 0, 8, 32, total_length, pc, & fields->f_dsp_64_u8);
2208
        if (length <= 0) break;
2209
{
2210
  FLD (f_dsp_48_u20) = ((((FLD (f_dsp_48_u16)) & (65535))) | (((((FLD (f_dsp_64_u8)) << (16))) & (983040))));
2211
}
2212
      }
2213
      break;
2214
    case M32C_OPERAND_DSP_48_U24 :
2215
      {
2216
        {
2217
        long value;
2218
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 16, 16, 32, total_length, pc, & value);
2219
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2220
        fields->f_dsp_48_u16 = value;
2221
      }
2222
        if (length <= 0) break;
2223
        length = extract_normal (cd, ex_info, insn_value, 0, 64, 0, 8, 32, total_length, pc, & fields->f_dsp_64_u8);
2224
        if (length <= 0) break;
2225
{
2226
  FLD (f_dsp_48_u24) = ((((FLD (f_dsp_48_u16)) & (65535))) | (((((FLD (f_dsp_64_u8)) << (16))) & (16711680))));
2227
}
2228
      }
2229
      break;
2230
    case M32C_OPERAND_DSP_48_U8 :
2231
      length = extract_normal (cd, ex_info, insn_value, 0, 32, 16, 8, 32, total_length, pc, & fields->f_dsp_48_u8);
2232
      break;
2233
    case M32C_OPERAND_DSP_8_S24 :
2234
      {
2235
        long value;
2236
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 24, 32, total_length, pc, & value);
2237
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((EXTQISI (TRUNCSIQI (((value) & (255))))) << (16))));
2238
        fields->f_dsp_8_s24 = value;
2239
      }
2240
      break;
2241
    case M32C_OPERAND_DSP_8_S8 :
2242
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 8, 32, total_length, pc, & fields->f_dsp_8_s8);
2243
      break;
2244
    case M32C_OPERAND_DSP_8_U16 :
2245
      {
2246
        long value;
2247
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 8, 16, 32, total_length, pc, & value);
2248
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2249
        fields->f_dsp_8_u16 = value;
2250
      }
2251
      break;
2252
    case M32C_OPERAND_DSP_8_U24 :
2253
      {
2254
        long value;
2255
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 8, 24, 32, total_length, pc, & value);
2256
        value = ((((((USI) (value) >> (16))) | (((value) & (65280))))) | (((((value) & (255))) << (16))));
2257
        fields->f_dsp_8_u24 = value;
2258
      }
2259
      break;
2260
    case M32C_OPERAND_DSP_8_U6 :
2261
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 8, 6, 32, total_length, pc, & fields->f_dsp_8_u6);
2262
      break;
2263
    case M32C_OPERAND_DSP_8_U8 :
2264
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 8, 8, 32, total_length, pc, & fields->f_dsp_8_u8);
2265
      break;
2266
    case M32C_OPERAND_DST16AN :
2267
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 15, 1, 32, total_length, pc, & fields->f_dst16_an);
2268
      break;
2269
    case M32C_OPERAND_DST16AN_S :
2270
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 4, 1, 32, total_length, pc, & fields->f_dst16_an_s);
2271
      break;
2272
    case M32C_OPERAND_DST16ANHI :
2273
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 15, 1, 32, total_length, pc, & fields->f_dst16_an);
2274
      break;
2275
    case M32C_OPERAND_DST16ANQI :
2276
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 15, 1, 32, total_length, pc, & fields->f_dst16_an);
2277
      break;
2278
    case M32C_OPERAND_DST16ANQI_S :
2279
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 5, 1, 32, total_length, pc, & fields->f_dst16_rn_QI_s);
2280
      break;
2281
    case M32C_OPERAND_DST16ANSI :
2282
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 15, 1, 32, total_length, pc, & fields->f_dst16_an);
2283
      break;
2284
    case M32C_OPERAND_DST16RNEXTQI :
2285
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 14, 1, 32, total_length, pc, & fields->f_dst16_rn_ext);
2286
      break;
2287
    case M32C_OPERAND_DST16RNHI :
2288
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 14, 2, 32, total_length, pc, & fields->f_dst16_rn);
2289
      break;
2290
    case M32C_OPERAND_DST16RNQI :
2291
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 14, 2, 32, total_length, pc, & fields->f_dst16_rn);
2292
      break;
2293
    case M32C_OPERAND_DST16RNQI_S :
2294
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 5, 1, 32, total_length, pc, & fields->f_dst16_rn_QI_s);
2295
      break;
2296
    case M32C_OPERAND_DST16RNSI :
2297
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 14, 2, 32, total_length, pc, & fields->f_dst16_rn);
2298
      break;
2299
    case M32C_OPERAND_DST32ANEXTUNPREFIXED :
2300
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 9, 1, 32, total_length, pc, & fields->f_dst32_an_unprefixed);
2301
      break;
2302
    case M32C_OPERAND_DST32ANPREFIXED :
2303
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 17, 1, 32, total_length, pc, & fields->f_dst32_an_prefixed);
2304
      break;
2305
    case M32C_OPERAND_DST32ANPREFIXEDHI :
2306
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 17, 1, 32, total_length, pc, & fields->f_dst32_an_prefixed);
2307
      break;
2308
    case M32C_OPERAND_DST32ANPREFIXEDQI :
2309
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 17, 1, 32, total_length, pc, & fields->f_dst32_an_prefixed);
2310
      break;
2311
    case M32C_OPERAND_DST32ANPREFIXEDSI :
2312
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 17, 1, 32, total_length, pc, & fields->f_dst32_an_prefixed);
2313
      break;
2314
    case M32C_OPERAND_DST32ANUNPREFIXED :
2315
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 9, 1, 32, total_length, pc, & fields->f_dst32_an_unprefixed);
2316
      break;
2317
    case M32C_OPERAND_DST32ANUNPREFIXEDHI :
2318
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 9, 1, 32, total_length, pc, & fields->f_dst32_an_unprefixed);
2319
      break;
2320
    case M32C_OPERAND_DST32ANUNPREFIXEDQI :
2321
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 9, 1, 32, total_length, pc, & fields->f_dst32_an_unprefixed);
2322
      break;
2323
    case M32C_OPERAND_DST32ANUNPREFIXEDSI :
2324
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 9, 1, 32, total_length, pc, & fields->f_dst32_an_unprefixed);
2325
      break;
2326
    case M32C_OPERAND_DST32R0HI_S :
2327
      break;
2328
    case M32C_OPERAND_DST32R0QI_S :
2329
      break;
2330
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDHI :
2331
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 9, 1, 32, total_length, pc, & fields->f_dst32_rn_ext_unprefixed);
2332
      break;
2333
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDQI :
2334
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 9, 1, 32, total_length, pc, & fields->f_dst32_rn_ext_unprefixed);
2335
      break;
2336
    case M32C_OPERAND_DST32RNPREFIXEDHI :
2337
      {
2338
        long value;
2339
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 2, 32, total_length, pc, & value);
2340
        value = ((((value) + (2))) % (4));
2341
        fields->f_dst32_rn_prefixed_HI = value;
2342
      }
2343
      break;
2344
    case M32C_OPERAND_DST32RNPREFIXEDQI :
2345
      {
2346
        long value;
2347
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 2, 32, total_length, pc, & value);
2348
        value = (((((~ (((USI) (value) >> (1))))) & (1))) | (((((value) << (1))) & (2))));
2349
        fields->f_dst32_rn_prefixed_QI = value;
2350
      }
2351
      break;
2352
    case M32C_OPERAND_DST32RNPREFIXEDSI :
2353
      {
2354
        long value;
2355
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 2, 32, total_length, pc, & value);
2356
        value = ((value) - (2));
2357
        fields->f_dst32_rn_prefixed_SI = value;
2358
      }
2359
      break;
2360
    case M32C_OPERAND_DST32RNUNPREFIXEDHI :
2361
      {
2362
        long value;
2363
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 8, 2, 32, total_length, pc, & value);
2364
        value = ((((value) + (2))) % (4));
2365
        fields->f_dst32_rn_unprefixed_HI = value;
2366
      }
2367
      break;
2368
    case M32C_OPERAND_DST32RNUNPREFIXEDQI :
2369
      {
2370
        long value;
2371
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 8, 2, 32, total_length, pc, & value);
2372
        value = (((((~ (((USI) (value) >> (1))))) & (1))) | (((((value) << (1))) & (2))));
2373
        fields->f_dst32_rn_unprefixed_QI = value;
2374
      }
2375
      break;
2376
    case M32C_OPERAND_DST32RNUNPREFIXEDSI :
2377
      {
2378
        long value;
2379
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 8, 2, 32, total_length, pc, & value);
2380
        value = ((value) - (2));
2381
        fields->f_dst32_rn_unprefixed_SI = value;
2382
      }
2383
      break;
2384
    case M32C_OPERAND_G :
2385
      break;
2386
    case M32C_OPERAND_IMM_12_S4 :
2387
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 12, 4, 32, total_length, pc, & fields->f_imm_12_s4);
2388
      break;
2389
    case M32C_OPERAND_IMM_12_S4N :
2390
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 12, 4, 32, total_length, pc, & fields->f_imm_12_s4);
2391
      break;
2392
    case M32C_OPERAND_IMM_13_U3 :
2393
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_imm_13_u3);
2394
      break;
2395
    case M32C_OPERAND_IMM_16_HI :
2396
      {
2397
        long value;
2398
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 16, 32, total_length, pc, & value);
2399
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
2400
        fields->f_dsp_16_s16 = value;
2401
      }
2402
      break;
2403
    case M32C_OPERAND_IMM_16_QI :
2404
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 16, 8, 32, total_length, pc, & fields->f_dsp_16_s8);
2405
      break;
2406
    case M32C_OPERAND_IMM_16_SI :
2407
      {
2408
        {
2409
        long value;
2410
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 16, 32, total_length, pc, & value);
2411
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2412
        fields->f_dsp_16_u16 = value;
2413
      }
2414
        if (length <= 0) break;
2415
        {
2416
        long value;
2417
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 16, 32, total_length, pc, & value);
2418
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2419
        fields->f_dsp_32_u16 = value;
2420
      }
2421
        if (length <= 0) break;
2422
{
2423
  FLD (f_dsp_16_s32) = ((((FLD (f_dsp_16_u16)) & (65535))) | (((((FLD (f_dsp_32_u16)) << (16))) & (0xffff0000))));
2424
}
2425
      }
2426
      break;
2427
    case M32C_OPERAND_IMM_20_S4 :
2428
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 20, 4, 32, total_length, pc, & fields->f_imm_20_s4);
2429
      break;
2430
    case M32C_OPERAND_IMM_24_HI :
2431
      {
2432
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
2433
        if (length <= 0) break;
2434
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_u8);
2435
        if (length <= 0) break;
2436
{
2437
  FLD (f_dsp_24_s16) = EXTHISI (((HI) (UINT) (((((FLD (f_dsp_32_u8)) << (8))) | (FLD (f_dsp_24_u8))))));
2438
}
2439
      }
2440
      break;
2441
    case M32C_OPERAND_IMM_24_QI :
2442
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_s8);
2443
      break;
2444
    case M32C_OPERAND_IMM_24_SI :
2445
      {
2446
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
2447
        if (length <= 0) break;
2448
        {
2449
        long value;
2450
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 24, 32, total_length, pc, & value);
2451
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (16711680))));
2452
        fields->f_dsp_32_u24 = value;
2453
      }
2454
        if (length <= 0) break;
2455
{
2456
  FLD (f_dsp_24_s32) = ((((FLD (f_dsp_24_u8)) & (255))) | (((((FLD (f_dsp_32_u24)) << (8))) & (0xffffff00))));
2457
}
2458
      }
2459
      break;
2460
    case M32C_OPERAND_IMM_32_HI :
2461
      {
2462
        long value;
2463
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 16, 32, total_length, pc, & value);
2464
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
2465
        fields->f_dsp_32_s16 = value;
2466
      }
2467
      break;
2468
    case M32C_OPERAND_IMM_32_QI :
2469
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_s8);
2470
      break;
2471
    case M32C_OPERAND_IMM_32_SI :
2472
      {
2473
        long value;
2474
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 0, 32, 32, total_length, pc, & value);
2475
        value = EXTSISI (((((((((UINT) (value) >> (24))) & (255))) | (((((UINT) (value) >> (8))) & (65280))))) | (((((((value) << (8))) & (16711680))) | (((((value) << (24))) & (0xff000000)))))));
2476
        fields->f_dsp_32_s32 = value;
2477
      }
2478
      break;
2479
    case M32C_OPERAND_IMM_40_HI :
2480
      {
2481
        long value;
2482
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 8, 16, 32, total_length, pc, & value);
2483
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
2484
        fields->f_dsp_40_s16 = value;
2485
      }
2486
      break;
2487
    case M32C_OPERAND_IMM_40_QI :
2488
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 8, 8, 32, total_length, pc, & fields->f_dsp_40_s8);
2489
      break;
2490
    case M32C_OPERAND_IMM_40_SI :
2491
      {
2492
        {
2493
        long value;
2494
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 8, 24, 32, total_length, pc, & value);
2495
        value = ((((((((USI) (value) >> (16))) & (255))) | (((value) & (65280))))) | (((((value) << (16))) & (16711680))));
2496
        fields->f_dsp_40_u24 = value;
2497
      }
2498
        if (length <= 0) break;
2499
        length = extract_normal (cd, ex_info, insn_value, 0, 64, 0, 8, 32, total_length, pc, & fields->f_dsp_64_u8);
2500
        if (length <= 0) break;
2501
{
2502
  FLD (f_dsp_40_s32) = ((((FLD (f_dsp_40_u24)) & (16777215))) | (((((FLD (f_dsp_64_u8)) << (24))) & (0xff000000))));
2503
}
2504
      }
2505
      break;
2506
    case M32C_OPERAND_IMM_48_HI :
2507
      {
2508
        long value;
2509
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 16, 16, 32, total_length, pc, & value);
2510
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
2511
        fields->f_dsp_48_s16 = value;
2512
      }
2513
      break;
2514
    case M32C_OPERAND_IMM_48_QI :
2515
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 16, 8, 32, total_length, pc, & fields->f_dsp_48_s8);
2516
      break;
2517
    case M32C_OPERAND_IMM_48_SI :
2518
      {
2519
        {
2520
        long value;
2521
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 16, 16, 32, total_length, pc, & value);
2522
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2523
        fields->f_dsp_48_u16 = value;
2524
      }
2525
        if (length <= 0) break;
2526
        {
2527
        long value;
2528
        length = extract_normal (cd, ex_info, insn_value, 0, 64, 0, 16, 32, total_length, pc, & value);
2529
        value = ((((((UHI) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280))));
2530
        fields->f_dsp_64_u16 = value;
2531
      }
2532
        if (length <= 0) break;
2533
{
2534
  FLD (f_dsp_48_s32) = ((((FLD (f_dsp_48_u16)) & (65535))) | (((((FLD (f_dsp_64_u16)) << (16))) & (0xffff0000))));
2535
}
2536
      }
2537
      break;
2538
    case M32C_OPERAND_IMM_56_HI :
2539
      {
2540
        length = extract_normal (cd, ex_info, insn_value, 0, 32, 24, 8, 32, total_length, pc, & fields->f_dsp_56_u8);
2541
        if (length <= 0) break;
2542
        length = extract_normal (cd, ex_info, insn_value, 0, 64, 0, 8, 32, total_length, pc, & fields->f_dsp_64_u8);
2543
        if (length <= 0) break;
2544
{
2545
  FLD (f_dsp_56_s16) = EXTHISI (((HI) (UINT) (((((FLD (f_dsp_64_u8)) << (8))) | (FLD (f_dsp_56_u8))))));
2546
}
2547
      }
2548
      break;
2549
    case M32C_OPERAND_IMM_56_QI :
2550
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 32, 24, 8, 32, total_length, pc, & fields->f_dsp_56_s8);
2551
      break;
2552
    case M32C_OPERAND_IMM_64_HI :
2553
      {
2554
        long value;
2555
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 64, 0, 16, 32, total_length, pc, & value);
2556
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
2557
        fields->f_dsp_64_s16 = value;
2558
      }
2559
      break;
2560
    case M32C_OPERAND_IMM_8_HI :
2561
      {
2562
        long value;
2563
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 16, 32, total_length, pc, & value);
2564
        value = EXTHISI (((HI) (INT) (((((((UINT) (value) >> (8))) & (255))) | (((((value) << (8))) & (65280)))))));
2565
        fields->f_dsp_8_s16 = value;
2566
      }
2567
      break;
2568
    case M32C_OPERAND_IMM_8_QI :
2569
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 8, 32, total_length, pc, & fields->f_dsp_8_s8);
2570
      break;
2571
    case M32C_OPERAND_IMM_8_S4 :
2572
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 4, 32, total_length, pc, & fields->f_imm_8_s4);
2573
      break;
2574
    case M32C_OPERAND_IMM_8_S4N :
2575
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 4, 32, total_length, pc, & fields->f_imm_8_s4);
2576
      break;
2577
    case M32C_OPERAND_IMM_SH_12_S4 :
2578
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 12, 4, 32, total_length, pc, & fields->f_imm_12_s4);
2579
      break;
2580
    case M32C_OPERAND_IMM_SH_20_S4 :
2581
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 20, 4, 32, total_length, pc, & fields->f_imm_20_s4);
2582
      break;
2583
    case M32C_OPERAND_IMM_SH_8_S4 :
2584
      length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED), 0, 8, 4, 32, total_length, pc, & fields->f_imm_8_s4);
2585
      break;
2586
    case M32C_OPERAND_IMM1_S :
2587
      {
2588
        long value;
2589
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 2, 1, 32, total_length, pc, & value);
2590
        value = ((value) + (1));
2591
        fields->f_imm1_S = value;
2592
      }
2593
      break;
2594
    case M32C_OPERAND_IMM3_S :
2595
      {
2596
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 2, 2, 32, total_length, pc, & fields->f_2_2);
2597
        if (length <= 0) break;
2598
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 7, 1, 32, total_length, pc, & fields->f_7_1);
2599
        if (length <= 0) break;
2600
{
2601
  FLD (f_imm3_S) = ((((((FLD (f_2_2)) << (1))) | (FLD (f_7_1)))) + (1));
2602
}
2603
      }
2604
      break;
2605
    case M32C_OPERAND_LAB_16_8 :
2606
      {
2607
        long value;
2608
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED)|(1<<CGEN_IFLD_PCREL_ADDR), 0, 16, 8, 32, total_length, pc, & value);
2609
        value = ((value) + (((pc) + (2))));
2610
        fields->f_lab_16_8 = value;
2611
      }
2612
      break;
2613
    case M32C_OPERAND_LAB_24_8 :
2614
      {
2615
        long value;
2616
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED)|(1<<CGEN_IFLD_PCREL_ADDR), 0, 24, 8, 32, total_length, pc, & value);
2617
        value = ((value) + (((pc) + (2))));
2618
        fields->f_lab_24_8 = value;
2619
      }
2620
      break;
2621
    case M32C_OPERAND_LAB_32_8 :
2622
      {
2623
        long value;
2624
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED)|(1<<CGEN_IFLD_PCREL_ADDR), 32, 0, 8, 32, total_length, pc, & value);
2625
        value = ((value) + (((pc) + (2))));
2626
        fields->f_lab_32_8 = value;
2627
      }
2628
      break;
2629
    case M32C_OPERAND_LAB_40_8 :
2630
      {
2631
        long value;
2632
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED)|(1<<CGEN_IFLD_PCREL_ADDR), 32, 8, 8, 32, total_length, pc, & value);
2633
        value = ((value) + (((pc) + (2))));
2634
        fields->f_lab_40_8 = value;
2635
      }
2636
      break;
2637
    case M32C_OPERAND_LAB_5_3 :
2638
      {
2639
        long value;
2640
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_PCREL_ADDR), 0, 5, 3, 32, total_length, pc, & value);
2641
        value = ((value) + (((pc) + (2))));
2642
        fields->f_lab_5_3 = value;
2643
      }
2644
      break;
2645
    case M32C_OPERAND_LAB_8_16 :
2646
      {
2647
        long value;
2648
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGN_OPT)|(1<<CGEN_IFLD_PCREL_ADDR), 0, 8, 16, 32, total_length, pc, & value);
2649
        value = ((((((USI) (((value) & (65535))) >> (8))) | (((SI) (((((value) & (255))) << (24))) >> (16))))) + (((pc) + (1))));
2650
        fields->f_lab_8_16 = value;
2651
      }
2652
      break;
2653
    case M32C_OPERAND_LAB_8_24 :
2654
      {
2655
        long value;
2656
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_ABS_ADDR), 0, 8, 24, 32, total_length, pc, & value);
2657
        value = ((((((USI) (value) >> (16))) | (((value) & (65280))))) | (((((value) & (255))) << (16))));
2658
        fields->f_lab_8_24 = value;
2659
      }
2660
      break;
2661
    case M32C_OPERAND_LAB_8_8 :
2662
      {
2663
        long value;
2664
        length = extract_normal (cd, ex_info, insn_value, 0|(1<<CGEN_IFLD_SIGNED)|(1<<CGEN_IFLD_PCREL_ADDR), 0, 8, 8, 32, total_length, pc, & value);
2665
        value = ((value) + (((pc) + (1))));
2666
        fields->f_lab_8_8 = value;
2667
      }
2668
      break;
2669
    case M32C_OPERAND_LAB32_JMP_S :
2670
      {
2671
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 2, 2, 32, total_length, pc, & fields->f_2_2);
2672
        if (length <= 0) break;
2673
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 7, 1, 32, total_length, pc, & fields->f_7_1);
2674
        if (length <= 0) break;
2675
{
2676
  FLD (f_lab32_jmp_s) = ((pc) + (((((((FLD (f_2_2)) << (1))) | (FLD (f_7_1)))) + (2))));
2677
}
2678
      }
2679
      break;
2680
    case M32C_OPERAND_Q :
2681
      break;
2682
    case M32C_OPERAND_R0 :
2683
      break;
2684
    case M32C_OPERAND_R0H :
2685
      break;
2686
    case M32C_OPERAND_R0L :
2687
      break;
2688
    case M32C_OPERAND_R1 :
2689
      break;
2690
    case M32C_OPERAND_R1R2R0 :
2691
      break;
2692
    case M32C_OPERAND_R2 :
2693
      break;
2694
    case M32C_OPERAND_R2R0 :
2695
      break;
2696
    case M32C_OPERAND_R3 :
2697
      break;
2698
    case M32C_OPERAND_R3R1 :
2699
      break;
2700
    case M32C_OPERAND_REGSETPOP :
2701
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 8, 8, 32, total_length, pc, & fields->f_8_8);
2702
      break;
2703
    case M32C_OPERAND_REGSETPUSH :
2704
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 8, 8, 32, total_length, pc, & fields->f_8_8);
2705
      break;
2706
    case M32C_OPERAND_RN16_PUSH_S :
2707
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 4, 1, 32, total_length, pc, & fields->f_4_1);
2708
      break;
2709
    case M32C_OPERAND_S :
2710
      break;
2711
    case M32C_OPERAND_SRC16AN :
2712
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 11, 1, 32, total_length, pc, & fields->f_src16_an);
2713
      break;
2714
    case M32C_OPERAND_SRC16ANHI :
2715
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 11, 1, 32, total_length, pc, & fields->f_src16_an);
2716
      break;
2717
    case M32C_OPERAND_SRC16ANQI :
2718
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 11, 1, 32, total_length, pc, & fields->f_src16_an);
2719
      break;
2720
    case M32C_OPERAND_SRC16RNHI :
2721
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 10, 2, 32, total_length, pc, & fields->f_src16_rn);
2722
      break;
2723
    case M32C_OPERAND_SRC16RNQI :
2724
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 10, 2, 32, total_length, pc, & fields->f_src16_rn);
2725
      break;
2726
    case M32C_OPERAND_SRC32ANPREFIXED :
2727
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 19, 1, 32, total_length, pc, & fields->f_src32_an_prefixed);
2728
      break;
2729
    case M32C_OPERAND_SRC32ANPREFIXEDHI :
2730
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 19, 1, 32, total_length, pc, & fields->f_src32_an_prefixed);
2731
      break;
2732
    case M32C_OPERAND_SRC32ANPREFIXEDQI :
2733
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 19, 1, 32, total_length, pc, & fields->f_src32_an_prefixed);
2734
      break;
2735
    case M32C_OPERAND_SRC32ANPREFIXEDSI :
2736
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 19, 1, 32, total_length, pc, & fields->f_src32_an_prefixed);
2737
      break;
2738
    case M32C_OPERAND_SRC32ANUNPREFIXED :
2739
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 11, 1, 32, total_length, pc, & fields->f_src32_an_unprefixed);
2740
      break;
2741
    case M32C_OPERAND_SRC32ANUNPREFIXEDHI :
2742
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 11, 1, 32, total_length, pc, & fields->f_src32_an_unprefixed);
2743
      break;
2744
    case M32C_OPERAND_SRC32ANUNPREFIXEDQI :
2745
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 11, 1, 32, total_length, pc, & fields->f_src32_an_unprefixed);
2746
      break;
2747
    case M32C_OPERAND_SRC32ANUNPREFIXEDSI :
2748
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 11, 1, 32, total_length, pc, & fields->f_src32_an_unprefixed);
2749
      break;
2750
    case M32C_OPERAND_SRC32RNPREFIXEDHI :
2751
      {
2752
        long value;
2753
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 18, 2, 32, total_length, pc, & value);
2754
        value = ((((value) + (2))) % (4));
2755
        fields->f_src32_rn_prefixed_HI = value;
2756
      }
2757
      break;
2758
    case M32C_OPERAND_SRC32RNPREFIXEDQI :
2759
      {
2760
        long value;
2761
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 18, 2, 32, total_length, pc, & value);
2762
        value = (((((~ (((USI) (value) >> (1))))) & (1))) | (((((value) << (1))) & (2))));
2763
        fields->f_src32_rn_prefixed_QI = value;
2764
      }
2765
      break;
2766
    case M32C_OPERAND_SRC32RNPREFIXEDSI :
2767
      {
2768
        long value;
2769
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 18, 2, 32, total_length, pc, & value);
2770
        value = ((value) - (2));
2771
        fields->f_src32_rn_prefixed_SI = value;
2772
      }
2773
      break;
2774
    case M32C_OPERAND_SRC32RNUNPREFIXEDHI :
2775
      {
2776
        long value;
2777
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 10, 2, 32, total_length, pc, & value);
2778
        value = ((((value) + (2))) % (4));
2779
        fields->f_src32_rn_unprefixed_HI = value;
2780
      }
2781
      break;
2782
    case M32C_OPERAND_SRC32RNUNPREFIXEDQI :
2783
      {
2784
        long value;
2785
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 10, 2, 32, total_length, pc, & value);
2786
        value = (((((~ (((USI) (value) >> (1))))) & (1))) | (((((value) << (1))) & (2))));
2787
        fields->f_src32_rn_unprefixed_QI = value;
2788
      }
2789
      break;
2790
    case M32C_OPERAND_SRC32RNUNPREFIXEDSI :
2791
      {
2792
        long value;
2793
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 10, 2, 32, total_length, pc, & value);
2794
        value = ((value) - (2));
2795
        fields->f_src32_rn_unprefixed_SI = value;
2796
      }
2797
      break;
2798
    case M32C_OPERAND_SRCDST16_R0L_R0H_S_NORMAL :
2799
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 5, 1, 32, total_length, pc, & fields->f_5_1);
2800
      break;
2801
    case M32C_OPERAND_X :
2802
      break;
2803
    case M32C_OPERAND_Z :
2804
      break;
2805
    case M32C_OPERAND_COND16_16 :
2806
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 8, 32, total_length, pc, & fields->f_dsp_16_u8);
2807
      break;
2808
    case M32C_OPERAND_COND16_24 :
2809
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
2810
      break;
2811
    case M32C_OPERAND_COND16_32 :
2812
      length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_u8);
2813
      break;
2814
    case M32C_OPERAND_COND16C :
2815
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 12, 4, 32, total_length, pc, & fields->f_cond16);
2816
      break;
2817
    case M32C_OPERAND_COND16J :
2818
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 12, 4, 32, total_length, pc, & fields->f_cond16);
2819
      break;
2820
    case M32C_OPERAND_COND16J5 :
2821
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 5, 3, 32, total_length, pc, & fields->f_cond16j_5);
2822
      break;
2823
    case M32C_OPERAND_COND32 :
2824
      {
2825
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 9, 1, 32, total_length, pc, & fields->f_9_1);
2826
        if (length <= 0) break;
2827
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_13_3);
2828
        if (length <= 0) break;
2829
{
2830
  FLD (f_cond32) = ((((FLD (f_9_1)) << (3))) | (FLD (f_13_3)));
2831
}
2832
      }
2833
      break;
2834
    case M32C_OPERAND_COND32_16 :
2835
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 16, 8, 32, total_length, pc, & fields->f_dsp_16_u8);
2836
      break;
2837
    case M32C_OPERAND_COND32_24 :
2838
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 24, 8, 32, total_length, pc, & fields->f_dsp_24_u8);
2839
      break;
2840
    case M32C_OPERAND_COND32_32 :
2841
      length = extract_normal (cd, ex_info, insn_value, 0, 32, 0, 8, 32, total_length, pc, & fields->f_dsp_32_u8);
2842
      break;
2843
    case M32C_OPERAND_COND32_40 :
2844
      length = extract_normal (cd, ex_info, insn_value, 0, 32, 8, 8, 32, total_length, pc, & fields->f_dsp_40_u8);
2845
      break;
2846
    case M32C_OPERAND_COND32J :
2847
      {
2848
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 1, 3, 32, total_length, pc, & fields->f_1_3);
2849
        if (length <= 0) break;
2850
        length = extract_normal (cd, ex_info, insn_value, 0, 0, 7, 1, 32, total_length, pc, & fields->f_7_1);
2851
        if (length <= 0) break;
2852
{
2853
  FLD (f_cond32j) = ((((FLD (f_1_3)) << (1))) | (FLD (f_7_1)));
2854
}
2855
      }
2856
      break;
2857
    case M32C_OPERAND_CR1_PREFIXED_32 :
2858
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 21, 3, 32, total_length, pc, & fields->f_21_3);
2859
      break;
2860
    case M32C_OPERAND_CR1_UNPREFIXED_32 :
2861
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_13_3);
2862
      break;
2863
    case M32C_OPERAND_CR16 :
2864
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 9, 3, 32, total_length, pc, & fields->f_9_3);
2865
      break;
2866
    case M32C_OPERAND_CR2_32 :
2867
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_13_3);
2868
      break;
2869
    case M32C_OPERAND_CR3_PREFIXED_32 :
2870
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 21, 3, 32, total_length, pc, & fields->f_21_3);
2871
      break;
2872
    case M32C_OPERAND_CR3_UNPREFIXED_32 :
2873
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_13_3);
2874
      break;
2875
    case M32C_OPERAND_FLAGS16 :
2876
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 9, 3, 32, total_length, pc, & fields->f_9_3);
2877
      break;
2878
    case M32C_OPERAND_FLAGS32 :
2879
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 13, 3, 32, total_length, pc, & fields->f_13_3);
2880
      break;
2881
    case M32C_OPERAND_SCCOND32 :
2882
      length = extract_normal (cd, ex_info, insn_value, 0, 0, 12, 4, 32, total_length, pc, & fields->f_cond16);
2883
      break;
2884
    case M32C_OPERAND_SIZE :
2885
      break;
2886
 
2887
    default :
2888
      /* xgettext:c-format */
2889
      fprintf (stderr, _("Unrecognized field %d while decoding insn.\n"),
2890
               opindex);
2891
      abort ();
2892
    }
2893
 
2894
  return length;
2895
}
2896
 
2897
cgen_insert_fn * const m32c_cgen_insert_handlers[] =
2898
{
2899
  insert_insn_normal,
2900
};
2901
 
2902
cgen_extract_fn * const m32c_cgen_extract_handlers[] =
2903
{
2904
  extract_insn_normal,
2905
};
2906
 
2907
int m32c_cgen_get_int_operand     (CGEN_CPU_DESC, int, const CGEN_FIELDS *);
2908
bfd_vma m32c_cgen_get_vma_operand (CGEN_CPU_DESC, int, const CGEN_FIELDS *);
2909
 
2910
/* Getting values from cgen_fields is handled by a collection of functions.
2911
   They are distinguished by the type of the VALUE argument they return.
2912
   TODO: floating point, inlining support, remove cases where result type
2913
   not appropriate.  */
2914
 
2915
int
2916
m32c_cgen_get_int_operand (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
2917
                             int opindex,
2918
                             const CGEN_FIELDS * fields)
2919
{
2920
  int value;
2921
 
2922
  switch (opindex)
2923
    {
2924
    case M32C_OPERAND_A0 :
2925
      value = 0;
2926
      break;
2927
    case M32C_OPERAND_A1 :
2928
      value = 0;
2929
      break;
2930
    case M32C_OPERAND_AN16_PUSH_S :
2931
      value = fields->f_4_1;
2932
      break;
2933
    case M32C_OPERAND_BIT16AN :
2934
      value = fields->f_dst16_an;
2935
      break;
2936
    case M32C_OPERAND_BIT16RN :
2937
      value = fields->f_dst16_rn;
2938
      break;
2939
    case M32C_OPERAND_BIT3_S :
2940
      value = fields->f_imm3_S;
2941
      break;
2942
    case M32C_OPERAND_BIT32ANPREFIXED :
2943
      value = fields->f_dst32_an_prefixed;
2944
      break;
2945
    case M32C_OPERAND_BIT32ANUNPREFIXED :
2946
      value = fields->f_dst32_an_unprefixed;
2947
      break;
2948
    case M32C_OPERAND_BIT32RNPREFIXED :
2949
      value = fields->f_dst32_rn_prefixed_QI;
2950
      break;
2951
    case M32C_OPERAND_BIT32RNUNPREFIXED :
2952
      value = fields->f_dst32_rn_unprefixed_QI;
2953
      break;
2954
    case M32C_OPERAND_BITBASE16_16_S8 :
2955
      value = fields->f_dsp_16_s8;
2956
      break;
2957
    case M32C_OPERAND_BITBASE16_16_U16 :
2958
      value = fields->f_dsp_16_u16;
2959
      break;
2960
    case M32C_OPERAND_BITBASE16_16_U8 :
2961
      value = fields->f_dsp_16_u8;
2962
      break;
2963
    case M32C_OPERAND_BITBASE16_8_U11_S :
2964
      value = fields->f_bitbase16_u11_S;
2965
      break;
2966
    case M32C_OPERAND_BITBASE32_16_S11_UNPREFIXED :
2967
      value = fields->f_bitbase32_16_s11_unprefixed;
2968
      break;
2969
    case M32C_OPERAND_BITBASE32_16_S19_UNPREFIXED :
2970
      value = fields->f_bitbase32_16_s19_unprefixed;
2971
      break;
2972
    case M32C_OPERAND_BITBASE32_16_U11_UNPREFIXED :
2973
      value = fields->f_bitbase32_16_u11_unprefixed;
2974
      break;
2975
    case M32C_OPERAND_BITBASE32_16_U19_UNPREFIXED :
2976
      value = fields->f_bitbase32_16_u19_unprefixed;
2977
      break;
2978
    case M32C_OPERAND_BITBASE32_16_U27_UNPREFIXED :
2979
      value = fields->f_bitbase32_16_u27_unprefixed;
2980
      break;
2981
    case M32C_OPERAND_BITBASE32_24_S11_PREFIXED :
2982
      value = fields->f_bitbase32_24_s11_prefixed;
2983
      break;
2984
    case M32C_OPERAND_BITBASE32_24_S19_PREFIXED :
2985
      value = fields->f_bitbase32_24_s19_prefixed;
2986
      break;
2987
    case M32C_OPERAND_BITBASE32_24_U11_PREFIXED :
2988
      value = fields->f_bitbase32_24_u11_prefixed;
2989
      break;
2990
    case M32C_OPERAND_BITBASE32_24_U19_PREFIXED :
2991
      value = fields->f_bitbase32_24_u19_prefixed;
2992
      break;
2993
    case M32C_OPERAND_BITBASE32_24_U27_PREFIXED :
2994
      value = fields->f_bitbase32_24_u27_prefixed;
2995
      break;
2996
    case M32C_OPERAND_BITNO16R :
2997
      value = fields->f_dsp_16_u8;
2998
      break;
2999
    case M32C_OPERAND_BITNO32PREFIXED :
3000
      value = fields->f_bitno32_prefixed;
3001
      break;
3002
    case M32C_OPERAND_BITNO32UNPREFIXED :
3003
      value = fields->f_bitno32_unprefixed;
3004
      break;
3005
    case M32C_OPERAND_DSP_10_U6 :
3006
      value = fields->f_dsp_10_u6;
3007
      break;
3008
    case M32C_OPERAND_DSP_16_S16 :
3009
      value = fields->f_dsp_16_s16;
3010
      break;
3011
    case M32C_OPERAND_DSP_16_S8 :
3012
      value = fields->f_dsp_16_s8;
3013
      break;
3014
    case M32C_OPERAND_DSP_16_U16 :
3015
      value = fields->f_dsp_16_u16;
3016
      break;
3017
    case M32C_OPERAND_DSP_16_U20 :
3018
      value = fields->f_dsp_16_u24;
3019
      break;
3020
    case M32C_OPERAND_DSP_16_U24 :
3021
      value = fields->f_dsp_16_u24;
3022
      break;
3023
    case M32C_OPERAND_DSP_16_U8 :
3024
      value = fields->f_dsp_16_u8;
3025
      break;
3026
    case M32C_OPERAND_DSP_24_S16 :
3027
      value = fields->f_dsp_24_s16;
3028
      break;
3029
    case M32C_OPERAND_DSP_24_S8 :
3030
      value = fields->f_dsp_24_s8;
3031
      break;
3032
    case M32C_OPERAND_DSP_24_U16 :
3033
      value = fields->f_dsp_24_u16;
3034
      break;
3035
    case M32C_OPERAND_DSP_24_U20 :
3036
      value = fields->f_dsp_24_u24;
3037
      break;
3038
    case M32C_OPERAND_DSP_24_U24 :
3039
      value = fields->f_dsp_24_u24;
3040
      break;
3041
    case M32C_OPERAND_DSP_24_U8 :
3042
      value = fields->f_dsp_24_u8;
3043
      break;
3044
    case M32C_OPERAND_DSP_32_S16 :
3045
      value = fields->f_dsp_32_s16;
3046
      break;
3047
    case M32C_OPERAND_DSP_32_S8 :
3048
      value = fields->f_dsp_32_s8;
3049
      break;
3050
    case M32C_OPERAND_DSP_32_U16 :
3051
      value = fields->f_dsp_32_u16;
3052
      break;
3053
    case M32C_OPERAND_DSP_32_U20 :
3054
      value = fields->f_dsp_32_u24;
3055
      break;
3056
    case M32C_OPERAND_DSP_32_U24 :
3057
      value = fields->f_dsp_32_u24;
3058
      break;
3059
    case M32C_OPERAND_DSP_32_U8 :
3060
      value = fields->f_dsp_32_u8;
3061
      break;
3062
    case M32C_OPERAND_DSP_40_S16 :
3063
      value = fields->f_dsp_40_s16;
3064
      break;
3065
    case M32C_OPERAND_DSP_40_S8 :
3066
      value = fields->f_dsp_40_s8;
3067
      break;
3068
    case M32C_OPERAND_DSP_40_U16 :
3069
      value = fields->f_dsp_40_u16;
3070
      break;
3071
    case M32C_OPERAND_DSP_40_U20 :
3072
      value = fields->f_dsp_40_u20;
3073
      break;
3074
    case M32C_OPERAND_DSP_40_U24 :
3075
      value = fields->f_dsp_40_u24;
3076
      break;
3077
    case M32C_OPERAND_DSP_40_U8 :
3078
      value = fields->f_dsp_40_u8;
3079
      break;
3080
    case M32C_OPERAND_DSP_48_S16 :
3081
      value = fields->f_dsp_48_s16;
3082
      break;
3083
    case M32C_OPERAND_DSP_48_S8 :
3084
      value = fields->f_dsp_48_s8;
3085
      break;
3086
    case M32C_OPERAND_DSP_48_U16 :
3087
      value = fields->f_dsp_48_u16;
3088
      break;
3089
    case M32C_OPERAND_DSP_48_U20 :
3090
      value = fields->f_dsp_48_u20;
3091
      break;
3092
    case M32C_OPERAND_DSP_48_U24 :
3093
      value = fields->f_dsp_48_u24;
3094
      break;
3095
    case M32C_OPERAND_DSP_48_U8 :
3096
      value = fields->f_dsp_48_u8;
3097
      break;
3098
    case M32C_OPERAND_DSP_8_S24 :
3099
      value = fields->f_dsp_8_s24;
3100
      break;
3101
    case M32C_OPERAND_DSP_8_S8 :
3102
      value = fields->f_dsp_8_s8;
3103
      break;
3104
    case M32C_OPERAND_DSP_8_U16 :
3105
      value = fields->f_dsp_8_u16;
3106
      break;
3107
    case M32C_OPERAND_DSP_8_U24 :
3108
      value = fields->f_dsp_8_u24;
3109
      break;
3110
    case M32C_OPERAND_DSP_8_U6 :
3111
      value = fields->f_dsp_8_u6;
3112
      break;
3113
    case M32C_OPERAND_DSP_8_U8 :
3114
      value = fields->f_dsp_8_u8;
3115
      break;
3116
    case M32C_OPERAND_DST16AN :
3117
      value = fields->f_dst16_an;
3118
      break;
3119
    case M32C_OPERAND_DST16AN_S :
3120
      value = fields->f_dst16_an_s;
3121
      break;
3122
    case M32C_OPERAND_DST16ANHI :
3123
      value = fields->f_dst16_an;
3124
      break;
3125
    case M32C_OPERAND_DST16ANQI :
3126
      value = fields->f_dst16_an;
3127
      break;
3128
    case M32C_OPERAND_DST16ANQI_S :
3129
      value = fields->f_dst16_rn_QI_s;
3130
      break;
3131
    case M32C_OPERAND_DST16ANSI :
3132
      value = fields->f_dst16_an;
3133
      break;
3134
    case M32C_OPERAND_DST16RNEXTQI :
3135
      value = fields->f_dst16_rn_ext;
3136
      break;
3137
    case M32C_OPERAND_DST16RNHI :
3138
      value = fields->f_dst16_rn;
3139
      break;
3140
    case M32C_OPERAND_DST16RNQI :
3141
      value = fields->f_dst16_rn;
3142
      break;
3143
    case M32C_OPERAND_DST16RNQI_S :
3144
      value = fields->f_dst16_rn_QI_s;
3145
      break;
3146
    case M32C_OPERAND_DST16RNSI :
3147
      value = fields->f_dst16_rn;
3148
      break;
3149
    case M32C_OPERAND_DST32ANEXTUNPREFIXED :
3150
      value = fields->f_dst32_an_unprefixed;
3151
      break;
3152
    case M32C_OPERAND_DST32ANPREFIXED :
3153
      value = fields->f_dst32_an_prefixed;
3154
      break;
3155
    case M32C_OPERAND_DST32ANPREFIXEDHI :
3156
      value = fields->f_dst32_an_prefixed;
3157
      break;
3158
    case M32C_OPERAND_DST32ANPREFIXEDQI :
3159
      value = fields->f_dst32_an_prefixed;
3160
      break;
3161
    case M32C_OPERAND_DST32ANPREFIXEDSI :
3162
      value = fields->f_dst32_an_prefixed;
3163
      break;
3164
    case M32C_OPERAND_DST32ANUNPREFIXED :
3165
      value = fields->f_dst32_an_unprefixed;
3166
      break;
3167
    case M32C_OPERAND_DST32ANUNPREFIXEDHI :
3168
      value = fields->f_dst32_an_unprefixed;
3169
      break;
3170
    case M32C_OPERAND_DST32ANUNPREFIXEDQI :
3171
      value = fields->f_dst32_an_unprefixed;
3172
      break;
3173
    case M32C_OPERAND_DST32ANUNPREFIXEDSI :
3174
      value = fields->f_dst32_an_unprefixed;
3175
      break;
3176
    case M32C_OPERAND_DST32R0HI_S :
3177
      value = 0;
3178
      break;
3179
    case M32C_OPERAND_DST32R0QI_S :
3180
      value = 0;
3181
      break;
3182
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDHI :
3183
      value = fields->f_dst32_rn_ext_unprefixed;
3184
      break;
3185
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDQI :
3186
      value = fields->f_dst32_rn_ext_unprefixed;
3187
      break;
3188
    case M32C_OPERAND_DST32RNPREFIXEDHI :
3189
      value = fields->f_dst32_rn_prefixed_HI;
3190
      break;
3191
    case M32C_OPERAND_DST32RNPREFIXEDQI :
3192
      value = fields->f_dst32_rn_prefixed_QI;
3193
      break;
3194
    case M32C_OPERAND_DST32RNPREFIXEDSI :
3195
      value = fields->f_dst32_rn_prefixed_SI;
3196
      break;
3197
    case M32C_OPERAND_DST32RNUNPREFIXEDHI :
3198
      value = fields->f_dst32_rn_unprefixed_HI;
3199
      break;
3200
    case M32C_OPERAND_DST32RNUNPREFIXEDQI :
3201
      value = fields->f_dst32_rn_unprefixed_QI;
3202
      break;
3203
    case M32C_OPERAND_DST32RNUNPREFIXEDSI :
3204
      value = fields->f_dst32_rn_unprefixed_SI;
3205
      break;
3206
    case M32C_OPERAND_G :
3207
      value = 0;
3208
      break;
3209
    case M32C_OPERAND_IMM_12_S4 :
3210
      value = fields->f_imm_12_s4;
3211
      break;
3212
    case M32C_OPERAND_IMM_12_S4N :
3213
      value = fields->f_imm_12_s4;
3214
      break;
3215
    case M32C_OPERAND_IMM_13_U3 :
3216
      value = fields->f_imm_13_u3;
3217
      break;
3218
    case M32C_OPERAND_IMM_16_HI :
3219
      value = fields->f_dsp_16_s16;
3220
      break;
3221
    case M32C_OPERAND_IMM_16_QI :
3222
      value = fields->f_dsp_16_s8;
3223
      break;
3224
    case M32C_OPERAND_IMM_16_SI :
3225
      value = fields->f_dsp_16_s32;
3226
      break;
3227
    case M32C_OPERAND_IMM_20_S4 :
3228
      value = fields->f_imm_20_s4;
3229
      break;
3230
    case M32C_OPERAND_IMM_24_HI :
3231
      value = fields->f_dsp_24_s16;
3232
      break;
3233
    case M32C_OPERAND_IMM_24_QI :
3234
      value = fields->f_dsp_24_s8;
3235
      break;
3236
    case M32C_OPERAND_IMM_24_SI :
3237
      value = fields->f_dsp_24_s32;
3238
      break;
3239
    case M32C_OPERAND_IMM_32_HI :
3240
      value = fields->f_dsp_32_s16;
3241
      break;
3242
    case M32C_OPERAND_IMM_32_QI :
3243
      value = fields->f_dsp_32_s8;
3244
      break;
3245
    case M32C_OPERAND_IMM_32_SI :
3246
      value = fields->f_dsp_32_s32;
3247
      break;
3248
    case M32C_OPERAND_IMM_40_HI :
3249
      value = fields->f_dsp_40_s16;
3250
      break;
3251
    case M32C_OPERAND_IMM_40_QI :
3252
      value = fields->f_dsp_40_s8;
3253
      break;
3254
    case M32C_OPERAND_IMM_40_SI :
3255
      value = fields->f_dsp_40_s32;
3256
      break;
3257
    case M32C_OPERAND_IMM_48_HI :
3258
      value = fields->f_dsp_48_s16;
3259
      break;
3260
    case M32C_OPERAND_IMM_48_QI :
3261
      value = fields->f_dsp_48_s8;
3262
      break;
3263
    case M32C_OPERAND_IMM_48_SI :
3264
      value = fields->f_dsp_48_s32;
3265
      break;
3266
    case M32C_OPERAND_IMM_56_HI :
3267
      value = fields->f_dsp_56_s16;
3268
      break;
3269
    case M32C_OPERAND_IMM_56_QI :
3270
      value = fields->f_dsp_56_s8;
3271
      break;
3272
    case M32C_OPERAND_IMM_64_HI :
3273
      value = fields->f_dsp_64_s16;
3274
      break;
3275
    case M32C_OPERAND_IMM_8_HI :
3276
      value = fields->f_dsp_8_s16;
3277
      break;
3278
    case M32C_OPERAND_IMM_8_QI :
3279
      value = fields->f_dsp_8_s8;
3280
      break;
3281
    case M32C_OPERAND_IMM_8_S4 :
3282
      value = fields->f_imm_8_s4;
3283
      break;
3284
    case M32C_OPERAND_IMM_8_S4N :
3285
      value = fields->f_imm_8_s4;
3286
      break;
3287
    case M32C_OPERAND_IMM_SH_12_S4 :
3288
      value = fields->f_imm_12_s4;
3289
      break;
3290
    case M32C_OPERAND_IMM_SH_20_S4 :
3291
      value = fields->f_imm_20_s4;
3292
      break;
3293
    case M32C_OPERAND_IMM_SH_8_S4 :
3294
      value = fields->f_imm_8_s4;
3295
      break;
3296
    case M32C_OPERAND_IMM1_S :
3297
      value = fields->f_imm1_S;
3298
      break;
3299
    case M32C_OPERAND_IMM3_S :
3300
      value = fields->f_imm3_S;
3301
      break;
3302
    case M32C_OPERAND_LAB_16_8 :
3303
      value = fields->f_lab_16_8;
3304
      break;
3305
    case M32C_OPERAND_LAB_24_8 :
3306
      value = fields->f_lab_24_8;
3307
      break;
3308
    case M32C_OPERAND_LAB_32_8 :
3309
      value = fields->f_lab_32_8;
3310
      break;
3311
    case M32C_OPERAND_LAB_40_8 :
3312
      value = fields->f_lab_40_8;
3313
      break;
3314
    case M32C_OPERAND_LAB_5_3 :
3315
      value = fields->f_lab_5_3;
3316
      break;
3317
    case M32C_OPERAND_LAB_8_16 :
3318
      value = fields->f_lab_8_16;
3319
      break;
3320
    case M32C_OPERAND_LAB_8_24 :
3321
      value = fields->f_lab_8_24;
3322
      break;
3323
    case M32C_OPERAND_LAB_8_8 :
3324
      value = fields->f_lab_8_8;
3325
      break;
3326
    case M32C_OPERAND_LAB32_JMP_S :
3327
      value = fields->f_lab32_jmp_s;
3328
      break;
3329
    case M32C_OPERAND_Q :
3330
      value = 0;
3331
      break;
3332
    case M32C_OPERAND_R0 :
3333
      value = 0;
3334
      break;
3335
    case M32C_OPERAND_R0H :
3336
      value = 0;
3337
      break;
3338
    case M32C_OPERAND_R0L :
3339
      value = 0;
3340
      break;
3341
    case M32C_OPERAND_R1 :
3342
      value = 0;
3343
      break;
3344
    case M32C_OPERAND_R1R2R0 :
3345
      value = 0;
3346
      break;
3347
    case M32C_OPERAND_R2 :
3348
      value = 0;
3349
      break;
3350
    case M32C_OPERAND_R2R0 :
3351
      value = 0;
3352
      break;
3353
    case M32C_OPERAND_R3 :
3354
      value = 0;
3355
      break;
3356
    case M32C_OPERAND_R3R1 :
3357
      value = 0;
3358
      break;
3359
    case M32C_OPERAND_REGSETPOP :
3360
      value = fields->f_8_8;
3361
      break;
3362
    case M32C_OPERAND_REGSETPUSH :
3363
      value = fields->f_8_8;
3364
      break;
3365
    case M32C_OPERAND_RN16_PUSH_S :
3366
      value = fields->f_4_1;
3367
      break;
3368
    case M32C_OPERAND_S :
3369
      value = 0;
3370
      break;
3371
    case M32C_OPERAND_SRC16AN :
3372
      value = fields->f_src16_an;
3373
      break;
3374
    case M32C_OPERAND_SRC16ANHI :
3375
      value = fields->f_src16_an;
3376
      break;
3377
    case M32C_OPERAND_SRC16ANQI :
3378
      value = fields->f_src16_an;
3379
      break;
3380
    case M32C_OPERAND_SRC16RNHI :
3381
      value = fields->f_src16_rn;
3382
      break;
3383
    case M32C_OPERAND_SRC16RNQI :
3384
      value = fields->f_src16_rn;
3385
      break;
3386
    case M32C_OPERAND_SRC32ANPREFIXED :
3387
      value = fields->f_src32_an_prefixed;
3388
      break;
3389
    case M32C_OPERAND_SRC32ANPREFIXEDHI :
3390
      value = fields->f_src32_an_prefixed;
3391
      break;
3392
    case M32C_OPERAND_SRC32ANPREFIXEDQI :
3393
      value = fields->f_src32_an_prefixed;
3394
      break;
3395
    case M32C_OPERAND_SRC32ANPREFIXEDSI :
3396
      value = fields->f_src32_an_prefixed;
3397
      break;
3398
    case M32C_OPERAND_SRC32ANUNPREFIXED :
3399
      value = fields->f_src32_an_unprefixed;
3400
      break;
3401
    case M32C_OPERAND_SRC32ANUNPREFIXEDHI :
3402
      value = fields->f_src32_an_unprefixed;
3403
      break;
3404
    case M32C_OPERAND_SRC32ANUNPREFIXEDQI :
3405
      value = fields->f_src32_an_unprefixed;
3406
      break;
3407
    case M32C_OPERAND_SRC32ANUNPREFIXEDSI :
3408
      value = fields->f_src32_an_unprefixed;
3409
      break;
3410
    case M32C_OPERAND_SRC32RNPREFIXEDHI :
3411
      value = fields->f_src32_rn_prefixed_HI;
3412
      break;
3413
    case M32C_OPERAND_SRC32RNPREFIXEDQI :
3414
      value = fields->f_src32_rn_prefixed_QI;
3415
      break;
3416
    case M32C_OPERAND_SRC32RNPREFIXEDSI :
3417
      value = fields->f_src32_rn_prefixed_SI;
3418
      break;
3419
    case M32C_OPERAND_SRC32RNUNPREFIXEDHI :
3420
      value = fields->f_src32_rn_unprefixed_HI;
3421
      break;
3422
    case M32C_OPERAND_SRC32RNUNPREFIXEDQI :
3423
      value = fields->f_src32_rn_unprefixed_QI;
3424
      break;
3425
    case M32C_OPERAND_SRC32RNUNPREFIXEDSI :
3426
      value = fields->f_src32_rn_unprefixed_SI;
3427
      break;
3428
    case M32C_OPERAND_SRCDST16_R0L_R0H_S_NORMAL :
3429
      value = fields->f_5_1;
3430
      break;
3431
    case M32C_OPERAND_X :
3432
      value = 0;
3433
      break;
3434
    case M32C_OPERAND_Z :
3435
      value = 0;
3436
      break;
3437
    case M32C_OPERAND_COND16_16 :
3438
      value = fields->f_dsp_16_u8;
3439
      break;
3440
    case M32C_OPERAND_COND16_24 :
3441
      value = fields->f_dsp_24_u8;
3442
      break;
3443
    case M32C_OPERAND_COND16_32 :
3444
      value = fields->f_dsp_32_u8;
3445
      break;
3446
    case M32C_OPERAND_COND16C :
3447
      value = fields->f_cond16;
3448
      break;
3449
    case M32C_OPERAND_COND16J :
3450
      value = fields->f_cond16;
3451
      break;
3452
    case M32C_OPERAND_COND16J5 :
3453
      value = fields->f_cond16j_5;
3454
      break;
3455
    case M32C_OPERAND_COND32 :
3456
      value = fields->f_cond32;
3457
      break;
3458
    case M32C_OPERAND_COND32_16 :
3459
      value = fields->f_dsp_16_u8;
3460
      break;
3461
    case M32C_OPERAND_COND32_24 :
3462
      value = fields->f_dsp_24_u8;
3463
      break;
3464
    case M32C_OPERAND_COND32_32 :
3465
      value = fields->f_dsp_32_u8;
3466
      break;
3467
    case M32C_OPERAND_COND32_40 :
3468
      value = fields->f_dsp_40_u8;
3469
      break;
3470
    case M32C_OPERAND_COND32J :
3471
      value = fields->f_cond32j;
3472
      break;
3473
    case M32C_OPERAND_CR1_PREFIXED_32 :
3474
      value = fields->f_21_3;
3475
      break;
3476
    case M32C_OPERAND_CR1_UNPREFIXED_32 :
3477
      value = fields->f_13_3;
3478
      break;
3479
    case M32C_OPERAND_CR16 :
3480
      value = fields->f_9_3;
3481
      break;
3482
    case M32C_OPERAND_CR2_32 :
3483
      value = fields->f_13_3;
3484
      break;
3485
    case M32C_OPERAND_CR3_PREFIXED_32 :
3486
      value = fields->f_21_3;
3487
      break;
3488
    case M32C_OPERAND_CR3_UNPREFIXED_32 :
3489
      value = fields->f_13_3;
3490
      break;
3491
    case M32C_OPERAND_FLAGS16 :
3492
      value = fields->f_9_3;
3493
      break;
3494
    case M32C_OPERAND_FLAGS32 :
3495
      value = fields->f_13_3;
3496
      break;
3497
    case M32C_OPERAND_SCCOND32 :
3498
      value = fields->f_cond16;
3499
      break;
3500
    case M32C_OPERAND_SIZE :
3501
      value = 0;
3502
      break;
3503
 
3504
    default :
3505
      /* xgettext:c-format */
3506
      fprintf (stderr, _("Unrecognized field %d while getting int operand.\n"),
3507
                       opindex);
3508
      abort ();
3509
  }
3510
 
3511
  return value;
3512
}
3513
 
3514
bfd_vma
3515
m32c_cgen_get_vma_operand (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
3516
                             int opindex,
3517
                             const CGEN_FIELDS * fields)
3518
{
3519
  bfd_vma value;
3520
 
3521
  switch (opindex)
3522
    {
3523
    case M32C_OPERAND_A0 :
3524
      value = 0;
3525
      break;
3526
    case M32C_OPERAND_A1 :
3527
      value = 0;
3528
      break;
3529
    case M32C_OPERAND_AN16_PUSH_S :
3530
      value = fields->f_4_1;
3531
      break;
3532
    case M32C_OPERAND_BIT16AN :
3533
      value = fields->f_dst16_an;
3534
      break;
3535
    case M32C_OPERAND_BIT16RN :
3536
      value = fields->f_dst16_rn;
3537
      break;
3538
    case M32C_OPERAND_BIT3_S :
3539
      value = fields->f_imm3_S;
3540
      break;
3541
    case M32C_OPERAND_BIT32ANPREFIXED :
3542
      value = fields->f_dst32_an_prefixed;
3543
      break;
3544
    case M32C_OPERAND_BIT32ANUNPREFIXED :
3545
      value = fields->f_dst32_an_unprefixed;
3546
      break;
3547
    case M32C_OPERAND_BIT32RNPREFIXED :
3548
      value = fields->f_dst32_rn_prefixed_QI;
3549
      break;
3550
    case M32C_OPERAND_BIT32RNUNPREFIXED :
3551
      value = fields->f_dst32_rn_unprefixed_QI;
3552
      break;
3553
    case M32C_OPERAND_BITBASE16_16_S8 :
3554
      value = fields->f_dsp_16_s8;
3555
      break;
3556
    case M32C_OPERAND_BITBASE16_16_U16 :
3557
      value = fields->f_dsp_16_u16;
3558
      break;
3559
    case M32C_OPERAND_BITBASE16_16_U8 :
3560
      value = fields->f_dsp_16_u8;
3561
      break;
3562
    case M32C_OPERAND_BITBASE16_8_U11_S :
3563
      value = fields->f_bitbase16_u11_S;
3564
      break;
3565
    case M32C_OPERAND_BITBASE32_16_S11_UNPREFIXED :
3566
      value = fields->f_bitbase32_16_s11_unprefixed;
3567
      break;
3568
    case M32C_OPERAND_BITBASE32_16_S19_UNPREFIXED :
3569
      value = fields->f_bitbase32_16_s19_unprefixed;
3570
      break;
3571
    case M32C_OPERAND_BITBASE32_16_U11_UNPREFIXED :
3572
      value = fields->f_bitbase32_16_u11_unprefixed;
3573
      break;
3574
    case M32C_OPERAND_BITBASE32_16_U19_UNPREFIXED :
3575
      value = fields->f_bitbase32_16_u19_unprefixed;
3576
      break;
3577
    case M32C_OPERAND_BITBASE32_16_U27_UNPREFIXED :
3578
      value = fields->f_bitbase32_16_u27_unprefixed;
3579
      break;
3580
    case M32C_OPERAND_BITBASE32_24_S11_PREFIXED :
3581
      value = fields->f_bitbase32_24_s11_prefixed;
3582
      break;
3583
    case M32C_OPERAND_BITBASE32_24_S19_PREFIXED :
3584
      value = fields->f_bitbase32_24_s19_prefixed;
3585
      break;
3586
    case M32C_OPERAND_BITBASE32_24_U11_PREFIXED :
3587
      value = fields->f_bitbase32_24_u11_prefixed;
3588
      break;
3589
    case M32C_OPERAND_BITBASE32_24_U19_PREFIXED :
3590
      value = fields->f_bitbase32_24_u19_prefixed;
3591
      break;
3592
    case M32C_OPERAND_BITBASE32_24_U27_PREFIXED :
3593
      value = fields->f_bitbase32_24_u27_prefixed;
3594
      break;
3595
    case M32C_OPERAND_BITNO16R :
3596
      value = fields->f_dsp_16_u8;
3597
      break;
3598
    case M32C_OPERAND_BITNO32PREFIXED :
3599
      value = fields->f_bitno32_prefixed;
3600
      break;
3601
    case M32C_OPERAND_BITNO32UNPREFIXED :
3602
      value = fields->f_bitno32_unprefixed;
3603
      break;
3604
    case M32C_OPERAND_DSP_10_U6 :
3605
      value = fields->f_dsp_10_u6;
3606
      break;
3607
    case M32C_OPERAND_DSP_16_S16 :
3608
      value = fields->f_dsp_16_s16;
3609
      break;
3610
    case M32C_OPERAND_DSP_16_S8 :
3611
      value = fields->f_dsp_16_s8;
3612
      break;
3613
    case M32C_OPERAND_DSP_16_U16 :
3614
      value = fields->f_dsp_16_u16;
3615
      break;
3616
    case M32C_OPERAND_DSP_16_U20 :
3617
      value = fields->f_dsp_16_u24;
3618
      break;
3619
    case M32C_OPERAND_DSP_16_U24 :
3620
      value = fields->f_dsp_16_u24;
3621
      break;
3622
    case M32C_OPERAND_DSP_16_U8 :
3623
      value = fields->f_dsp_16_u8;
3624
      break;
3625
    case M32C_OPERAND_DSP_24_S16 :
3626
      value = fields->f_dsp_24_s16;
3627
      break;
3628
    case M32C_OPERAND_DSP_24_S8 :
3629
      value = fields->f_dsp_24_s8;
3630
      break;
3631
    case M32C_OPERAND_DSP_24_U16 :
3632
      value = fields->f_dsp_24_u16;
3633
      break;
3634
    case M32C_OPERAND_DSP_24_U20 :
3635
      value = fields->f_dsp_24_u24;
3636
      break;
3637
    case M32C_OPERAND_DSP_24_U24 :
3638
      value = fields->f_dsp_24_u24;
3639
      break;
3640
    case M32C_OPERAND_DSP_24_U8 :
3641
      value = fields->f_dsp_24_u8;
3642
      break;
3643
    case M32C_OPERAND_DSP_32_S16 :
3644
      value = fields->f_dsp_32_s16;
3645
      break;
3646
    case M32C_OPERAND_DSP_32_S8 :
3647
      value = fields->f_dsp_32_s8;
3648
      break;
3649
    case M32C_OPERAND_DSP_32_U16 :
3650
      value = fields->f_dsp_32_u16;
3651
      break;
3652
    case M32C_OPERAND_DSP_32_U20 :
3653
      value = fields->f_dsp_32_u24;
3654
      break;
3655
    case M32C_OPERAND_DSP_32_U24 :
3656
      value = fields->f_dsp_32_u24;
3657
      break;
3658
    case M32C_OPERAND_DSP_32_U8 :
3659
      value = fields->f_dsp_32_u8;
3660
      break;
3661
    case M32C_OPERAND_DSP_40_S16 :
3662
      value = fields->f_dsp_40_s16;
3663
      break;
3664
    case M32C_OPERAND_DSP_40_S8 :
3665
      value = fields->f_dsp_40_s8;
3666
      break;
3667
    case M32C_OPERAND_DSP_40_U16 :
3668
      value = fields->f_dsp_40_u16;
3669
      break;
3670
    case M32C_OPERAND_DSP_40_U20 :
3671
      value = fields->f_dsp_40_u20;
3672
      break;
3673
    case M32C_OPERAND_DSP_40_U24 :
3674
      value = fields->f_dsp_40_u24;
3675
      break;
3676
    case M32C_OPERAND_DSP_40_U8 :
3677
      value = fields->f_dsp_40_u8;
3678
      break;
3679
    case M32C_OPERAND_DSP_48_S16 :
3680
      value = fields->f_dsp_48_s16;
3681
      break;
3682
    case M32C_OPERAND_DSP_48_S8 :
3683
      value = fields->f_dsp_48_s8;
3684
      break;
3685
    case M32C_OPERAND_DSP_48_U16 :
3686
      value = fields->f_dsp_48_u16;
3687
      break;
3688
    case M32C_OPERAND_DSP_48_U20 :
3689
      value = fields->f_dsp_48_u20;
3690
      break;
3691
    case M32C_OPERAND_DSP_48_U24 :
3692
      value = fields->f_dsp_48_u24;
3693
      break;
3694
    case M32C_OPERAND_DSP_48_U8 :
3695
      value = fields->f_dsp_48_u8;
3696
      break;
3697
    case M32C_OPERAND_DSP_8_S24 :
3698
      value = fields->f_dsp_8_s24;
3699
      break;
3700
    case M32C_OPERAND_DSP_8_S8 :
3701
      value = fields->f_dsp_8_s8;
3702
      break;
3703
    case M32C_OPERAND_DSP_8_U16 :
3704
      value = fields->f_dsp_8_u16;
3705
      break;
3706
    case M32C_OPERAND_DSP_8_U24 :
3707
      value = fields->f_dsp_8_u24;
3708
      break;
3709
    case M32C_OPERAND_DSP_8_U6 :
3710
      value = fields->f_dsp_8_u6;
3711
      break;
3712
    case M32C_OPERAND_DSP_8_U8 :
3713
      value = fields->f_dsp_8_u8;
3714
      break;
3715
    case M32C_OPERAND_DST16AN :
3716
      value = fields->f_dst16_an;
3717
      break;
3718
    case M32C_OPERAND_DST16AN_S :
3719
      value = fields->f_dst16_an_s;
3720
      break;
3721
    case M32C_OPERAND_DST16ANHI :
3722
      value = fields->f_dst16_an;
3723
      break;
3724
    case M32C_OPERAND_DST16ANQI :
3725
      value = fields->f_dst16_an;
3726
      break;
3727
    case M32C_OPERAND_DST16ANQI_S :
3728
      value = fields->f_dst16_rn_QI_s;
3729
      break;
3730
    case M32C_OPERAND_DST16ANSI :
3731
      value = fields->f_dst16_an;
3732
      break;
3733
    case M32C_OPERAND_DST16RNEXTQI :
3734
      value = fields->f_dst16_rn_ext;
3735
      break;
3736
    case M32C_OPERAND_DST16RNHI :
3737
      value = fields->f_dst16_rn;
3738
      break;
3739
    case M32C_OPERAND_DST16RNQI :
3740
      value = fields->f_dst16_rn;
3741
      break;
3742
    case M32C_OPERAND_DST16RNQI_S :
3743
      value = fields->f_dst16_rn_QI_s;
3744
      break;
3745
    case M32C_OPERAND_DST16RNSI :
3746
      value = fields->f_dst16_rn;
3747
      break;
3748
    case M32C_OPERAND_DST32ANEXTUNPREFIXED :
3749
      value = fields->f_dst32_an_unprefixed;
3750
      break;
3751
    case M32C_OPERAND_DST32ANPREFIXED :
3752
      value = fields->f_dst32_an_prefixed;
3753
      break;
3754
    case M32C_OPERAND_DST32ANPREFIXEDHI :
3755
      value = fields->f_dst32_an_prefixed;
3756
      break;
3757
    case M32C_OPERAND_DST32ANPREFIXEDQI :
3758
      value = fields->f_dst32_an_prefixed;
3759
      break;
3760
    case M32C_OPERAND_DST32ANPREFIXEDSI :
3761
      value = fields->f_dst32_an_prefixed;
3762
      break;
3763
    case M32C_OPERAND_DST32ANUNPREFIXED :
3764
      value = fields->f_dst32_an_unprefixed;
3765
      break;
3766
    case M32C_OPERAND_DST32ANUNPREFIXEDHI :
3767
      value = fields->f_dst32_an_unprefixed;
3768
      break;
3769
    case M32C_OPERAND_DST32ANUNPREFIXEDQI :
3770
      value = fields->f_dst32_an_unprefixed;
3771
      break;
3772
    case M32C_OPERAND_DST32ANUNPREFIXEDSI :
3773
      value = fields->f_dst32_an_unprefixed;
3774
      break;
3775
    case M32C_OPERAND_DST32R0HI_S :
3776
      value = 0;
3777
      break;
3778
    case M32C_OPERAND_DST32R0QI_S :
3779
      value = 0;
3780
      break;
3781
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDHI :
3782
      value = fields->f_dst32_rn_ext_unprefixed;
3783
      break;
3784
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDQI :
3785
      value = fields->f_dst32_rn_ext_unprefixed;
3786
      break;
3787
    case M32C_OPERAND_DST32RNPREFIXEDHI :
3788
      value = fields->f_dst32_rn_prefixed_HI;
3789
      break;
3790
    case M32C_OPERAND_DST32RNPREFIXEDQI :
3791
      value = fields->f_dst32_rn_prefixed_QI;
3792
      break;
3793
    case M32C_OPERAND_DST32RNPREFIXEDSI :
3794
      value = fields->f_dst32_rn_prefixed_SI;
3795
      break;
3796
    case M32C_OPERAND_DST32RNUNPREFIXEDHI :
3797
      value = fields->f_dst32_rn_unprefixed_HI;
3798
      break;
3799
    case M32C_OPERAND_DST32RNUNPREFIXEDQI :
3800
      value = fields->f_dst32_rn_unprefixed_QI;
3801
      break;
3802
    case M32C_OPERAND_DST32RNUNPREFIXEDSI :
3803
      value = fields->f_dst32_rn_unprefixed_SI;
3804
      break;
3805
    case M32C_OPERAND_G :
3806
      value = 0;
3807
      break;
3808
    case M32C_OPERAND_IMM_12_S4 :
3809
      value = fields->f_imm_12_s4;
3810
      break;
3811
    case M32C_OPERAND_IMM_12_S4N :
3812
      value = fields->f_imm_12_s4;
3813
      break;
3814
    case M32C_OPERAND_IMM_13_U3 :
3815
      value = fields->f_imm_13_u3;
3816
      break;
3817
    case M32C_OPERAND_IMM_16_HI :
3818
      value = fields->f_dsp_16_s16;
3819
      break;
3820
    case M32C_OPERAND_IMM_16_QI :
3821
      value = fields->f_dsp_16_s8;
3822
      break;
3823
    case M32C_OPERAND_IMM_16_SI :
3824
      value = fields->f_dsp_16_s32;
3825
      break;
3826
    case M32C_OPERAND_IMM_20_S4 :
3827
      value = fields->f_imm_20_s4;
3828
      break;
3829
    case M32C_OPERAND_IMM_24_HI :
3830
      value = fields->f_dsp_24_s16;
3831
      break;
3832
    case M32C_OPERAND_IMM_24_QI :
3833
      value = fields->f_dsp_24_s8;
3834
      break;
3835
    case M32C_OPERAND_IMM_24_SI :
3836
      value = fields->f_dsp_24_s32;
3837
      break;
3838
    case M32C_OPERAND_IMM_32_HI :
3839
      value = fields->f_dsp_32_s16;
3840
      break;
3841
    case M32C_OPERAND_IMM_32_QI :
3842
      value = fields->f_dsp_32_s8;
3843
      break;
3844
    case M32C_OPERAND_IMM_32_SI :
3845
      value = fields->f_dsp_32_s32;
3846
      break;
3847
    case M32C_OPERAND_IMM_40_HI :
3848
      value = fields->f_dsp_40_s16;
3849
      break;
3850
    case M32C_OPERAND_IMM_40_QI :
3851
      value = fields->f_dsp_40_s8;
3852
      break;
3853
    case M32C_OPERAND_IMM_40_SI :
3854
      value = fields->f_dsp_40_s32;
3855
      break;
3856
    case M32C_OPERAND_IMM_48_HI :
3857
      value = fields->f_dsp_48_s16;
3858
      break;
3859
    case M32C_OPERAND_IMM_48_QI :
3860
      value = fields->f_dsp_48_s8;
3861
      break;
3862
    case M32C_OPERAND_IMM_48_SI :
3863
      value = fields->f_dsp_48_s32;
3864
      break;
3865
    case M32C_OPERAND_IMM_56_HI :
3866
      value = fields->f_dsp_56_s16;
3867
      break;
3868
    case M32C_OPERAND_IMM_56_QI :
3869
      value = fields->f_dsp_56_s8;
3870
      break;
3871
    case M32C_OPERAND_IMM_64_HI :
3872
      value = fields->f_dsp_64_s16;
3873
      break;
3874
    case M32C_OPERAND_IMM_8_HI :
3875
      value = fields->f_dsp_8_s16;
3876
      break;
3877
    case M32C_OPERAND_IMM_8_QI :
3878
      value = fields->f_dsp_8_s8;
3879
      break;
3880
    case M32C_OPERAND_IMM_8_S4 :
3881
      value = fields->f_imm_8_s4;
3882
      break;
3883
    case M32C_OPERAND_IMM_8_S4N :
3884
      value = fields->f_imm_8_s4;
3885
      break;
3886
    case M32C_OPERAND_IMM_SH_12_S4 :
3887
      value = fields->f_imm_12_s4;
3888
      break;
3889
    case M32C_OPERAND_IMM_SH_20_S4 :
3890
      value = fields->f_imm_20_s4;
3891
      break;
3892
    case M32C_OPERAND_IMM_SH_8_S4 :
3893
      value = fields->f_imm_8_s4;
3894
      break;
3895
    case M32C_OPERAND_IMM1_S :
3896
      value = fields->f_imm1_S;
3897
      break;
3898
    case M32C_OPERAND_IMM3_S :
3899
      value = fields->f_imm3_S;
3900
      break;
3901
    case M32C_OPERAND_LAB_16_8 :
3902
      value = fields->f_lab_16_8;
3903
      break;
3904
    case M32C_OPERAND_LAB_24_8 :
3905
      value = fields->f_lab_24_8;
3906
      break;
3907
    case M32C_OPERAND_LAB_32_8 :
3908
      value = fields->f_lab_32_8;
3909
      break;
3910
    case M32C_OPERAND_LAB_40_8 :
3911
      value = fields->f_lab_40_8;
3912
      break;
3913
    case M32C_OPERAND_LAB_5_3 :
3914
      value = fields->f_lab_5_3;
3915
      break;
3916
    case M32C_OPERAND_LAB_8_16 :
3917
      value = fields->f_lab_8_16;
3918
      break;
3919
    case M32C_OPERAND_LAB_8_24 :
3920
      value = fields->f_lab_8_24;
3921
      break;
3922
    case M32C_OPERAND_LAB_8_8 :
3923
      value = fields->f_lab_8_8;
3924
      break;
3925
    case M32C_OPERAND_LAB32_JMP_S :
3926
      value = fields->f_lab32_jmp_s;
3927
      break;
3928
    case M32C_OPERAND_Q :
3929
      value = 0;
3930
      break;
3931
    case M32C_OPERAND_R0 :
3932
      value = 0;
3933
      break;
3934
    case M32C_OPERAND_R0H :
3935
      value = 0;
3936
      break;
3937
    case M32C_OPERAND_R0L :
3938
      value = 0;
3939
      break;
3940
    case M32C_OPERAND_R1 :
3941
      value = 0;
3942
      break;
3943
    case M32C_OPERAND_R1R2R0 :
3944
      value = 0;
3945
      break;
3946
    case M32C_OPERAND_R2 :
3947
      value = 0;
3948
      break;
3949
    case M32C_OPERAND_R2R0 :
3950
      value = 0;
3951
      break;
3952
    case M32C_OPERAND_R3 :
3953
      value = 0;
3954
      break;
3955
    case M32C_OPERAND_R3R1 :
3956
      value = 0;
3957
      break;
3958
    case M32C_OPERAND_REGSETPOP :
3959
      value = fields->f_8_8;
3960
      break;
3961
    case M32C_OPERAND_REGSETPUSH :
3962
      value = fields->f_8_8;
3963
      break;
3964
    case M32C_OPERAND_RN16_PUSH_S :
3965
      value = fields->f_4_1;
3966
      break;
3967
    case M32C_OPERAND_S :
3968
      value = 0;
3969
      break;
3970
    case M32C_OPERAND_SRC16AN :
3971
      value = fields->f_src16_an;
3972
      break;
3973
    case M32C_OPERAND_SRC16ANHI :
3974
      value = fields->f_src16_an;
3975
      break;
3976
    case M32C_OPERAND_SRC16ANQI :
3977
      value = fields->f_src16_an;
3978
      break;
3979
    case M32C_OPERAND_SRC16RNHI :
3980
      value = fields->f_src16_rn;
3981
      break;
3982
    case M32C_OPERAND_SRC16RNQI :
3983
      value = fields->f_src16_rn;
3984
      break;
3985
    case M32C_OPERAND_SRC32ANPREFIXED :
3986
      value = fields->f_src32_an_prefixed;
3987
      break;
3988
    case M32C_OPERAND_SRC32ANPREFIXEDHI :
3989
      value = fields->f_src32_an_prefixed;
3990
      break;
3991
    case M32C_OPERAND_SRC32ANPREFIXEDQI :
3992
      value = fields->f_src32_an_prefixed;
3993
      break;
3994
    case M32C_OPERAND_SRC32ANPREFIXEDSI :
3995
      value = fields->f_src32_an_prefixed;
3996
      break;
3997
    case M32C_OPERAND_SRC32ANUNPREFIXED :
3998
      value = fields->f_src32_an_unprefixed;
3999
      break;
4000
    case M32C_OPERAND_SRC32ANUNPREFIXEDHI :
4001
      value = fields->f_src32_an_unprefixed;
4002
      break;
4003
    case M32C_OPERAND_SRC32ANUNPREFIXEDQI :
4004
      value = fields->f_src32_an_unprefixed;
4005
      break;
4006
    case M32C_OPERAND_SRC32ANUNPREFIXEDSI :
4007
      value = fields->f_src32_an_unprefixed;
4008
      break;
4009
    case M32C_OPERAND_SRC32RNPREFIXEDHI :
4010
      value = fields->f_src32_rn_prefixed_HI;
4011
      break;
4012
    case M32C_OPERAND_SRC32RNPREFIXEDQI :
4013
      value = fields->f_src32_rn_prefixed_QI;
4014
      break;
4015
    case M32C_OPERAND_SRC32RNPREFIXEDSI :
4016
      value = fields->f_src32_rn_prefixed_SI;
4017
      break;
4018
    case M32C_OPERAND_SRC32RNUNPREFIXEDHI :
4019
      value = fields->f_src32_rn_unprefixed_HI;
4020
      break;
4021
    case M32C_OPERAND_SRC32RNUNPREFIXEDQI :
4022
      value = fields->f_src32_rn_unprefixed_QI;
4023
      break;
4024
    case M32C_OPERAND_SRC32RNUNPREFIXEDSI :
4025
      value = fields->f_src32_rn_unprefixed_SI;
4026
      break;
4027
    case M32C_OPERAND_SRCDST16_R0L_R0H_S_NORMAL :
4028
      value = fields->f_5_1;
4029
      break;
4030
    case M32C_OPERAND_X :
4031
      value = 0;
4032
      break;
4033
    case M32C_OPERAND_Z :
4034
      value = 0;
4035
      break;
4036
    case M32C_OPERAND_COND16_16 :
4037
      value = fields->f_dsp_16_u8;
4038
      break;
4039
    case M32C_OPERAND_COND16_24 :
4040
      value = fields->f_dsp_24_u8;
4041
      break;
4042
    case M32C_OPERAND_COND16_32 :
4043
      value = fields->f_dsp_32_u8;
4044
      break;
4045
    case M32C_OPERAND_COND16C :
4046
      value = fields->f_cond16;
4047
      break;
4048
    case M32C_OPERAND_COND16J :
4049
      value = fields->f_cond16;
4050
      break;
4051
    case M32C_OPERAND_COND16J5 :
4052
      value = fields->f_cond16j_5;
4053
      break;
4054
    case M32C_OPERAND_COND32 :
4055
      value = fields->f_cond32;
4056
      break;
4057
    case M32C_OPERAND_COND32_16 :
4058
      value = fields->f_dsp_16_u8;
4059
      break;
4060
    case M32C_OPERAND_COND32_24 :
4061
      value = fields->f_dsp_24_u8;
4062
      break;
4063
    case M32C_OPERAND_COND32_32 :
4064
      value = fields->f_dsp_32_u8;
4065
      break;
4066
    case M32C_OPERAND_COND32_40 :
4067
      value = fields->f_dsp_40_u8;
4068
      break;
4069
    case M32C_OPERAND_COND32J :
4070
      value = fields->f_cond32j;
4071
      break;
4072
    case M32C_OPERAND_CR1_PREFIXED_32 :
4073
      value = fields->f_21_3;
4074
      break;
4075
    case M32C_OPERAND_CR1_UNPREFIXED_32 :
4076
      value = fields->f_13_3;
4077
      break;
4078
    case M32C_OPERAND_CR16 :
4079
      value = fields->f_9_3;
4080
      break;
4081
    case M32C_OPERAND_CR2_32 :
4082
      value = fields->f_13_3;
4083
      break;
4084
    case M32C_OPERAND_CR3_PREFIXED_32 :
4085
      value = fields->f_21_3;
4086
      break;
4087
    case M32C_OPERAND_CR3_UNPREFIXED_32 :
4088
      value = fields->f_13_3;
4089
      break;
4090
    case M32C_OPERAND_FLAGS16 :
4091
      value = fields->f_9_3;
4092
      break;
4093
    case M32C_OPERAND_FLAGS32 :
4094
      value = fields->f_13_3;
4095
      break;
4096
    case M32C_OPERAND_SCCOND32 :
4097
      value = fields->f_cond16;
4098
      break;
4099
    case M32C_OPERAND_SIZE :
4100
      value = 0;
4101
      break;
4102
 
4103
    default :
4104
      /* xgettext:c-format */
4105
      fprintf (stderr, _("Unrecognized field %d while getting vma operand.\n"),
4106
                       opindex);
4107
      abort ();
4108
  }
4109
 
4110
  return value;
4111
}
4112
 
4113
void m32c_cgen_set_int_operand  (CGEN_CPU_DESC, int, CGEN_FIELDS *, int);
4114
void m32c_cgen_set_vma_operand  (CGEN_CPU_DESC, int, CGEN_FIELDS *, bfd_vma);
4115
 
4116
/* Stuffing values in cgen_fields is handled by a collection of functions.
4117
   They are distinguished by the type of the VALUE argument they accept.
4118
   TODO: floating point, inlining support, remove cases where argument type
4119
   not appropriate.  */
4120
 
4121
void
4122
m32c_cgen_set_int_operand (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
4123
                             int opindex,
4124
                             CGEN_FIELDS * fields,
4125
                             int value)
4126
{
4127
  switch (opindex)
4128
    {
4129
    case M32C_OPERAND_A0 :
4130
      break;
4131
    case M32C_OPERAND_A1 :
4132
      break;
4133
    case M32C_OPERAND_AN16_PUSH_S :
4134
      fields->f_4_1 = value;
4135
      break;
4136
    case M32C_OPERAND_BIT16AN :
4137
      fields->f_dst16_an = value;
4138
      break;
4139
    case M32C_OPERAND_BIT16RN :
4140
      fields->f_dst16_rn = value;
4141
      break;
4142
    case M32C_OPERAND_BIT3_S :
4143
      fields->f_imm3_S = value;
4144
      break;
4145
    case M32C_OPERAND_BIT32ANPREFIXED :
4146
      fields->f_dst32_an_prefixed = value;
4147
      break;
4148
    case M32C_OPERAND_BIT32ANUNPREFIXED :
4149
      fields->f_dst32_an_unprefixed = value;
4150
      break;
4151
    case M32C_OPERAND_BIT32RNPREFIXED :
4152
      fields->f_dst32_rn_prefixed_QI = value;
4153
      break;
4154
    case M32C_OPERAND_BIT32RNUNPREFIXED :
4155
      fields->f_dst32_rn_unprefixed_QI = value;
4156
      break;
4157
    case M32C_OPERAND_BITBASE16_16_S8 :
4158
      fields->f_dsp_16_s8 = value;
4159
      break;
4160
    case M32C_OPERAND_BITBASE16_16_U16 :
4161
      fields->f_dsp_16_u16 = value;
4162
      break;
4163
    case M32C_OPERAND_BITBASE16_16_U8 :
4164
      fields->f_dsp_16_u8 = value;
4165
      break;
4166
    case M32C_OPERAND_BITBASE16_8_U11_S :
4167
      fields->f_bitbase16_u11_S = value;
4168
      break;
4169
    case M32C_OPERAND_BITBASE32_16_S11_UNPREFIXED :
4170
      fields->f_bitbase32_16_s11_unprefixed = value;
4171
      break;
4172
    case M32C_OPERAND_BITBASE32_16_S19_UNPREFIXED :
4173
      fields->f_bitbase32_16_s19_unprefixed = value;
4174
      break;
4175
    case M32C_OPERAND_BITBASE32_16_U11_UNPREFIXED :
4176
      fields->f_bitbase32_16_u11_unprefixed = value;
4177
      break;
4178
    case M32C_OPERAND_BITBASE32_16_U19_UNPREFIXED :
4179
      fields->f_bitbase32_16_u19_unprefixed = value;
4180
      break;
4181
    case M32C_OPERAND_BITBASE32_16_U27_UNPREFIXED :
4182
      fields->f_bitbase32_16_u27_unprefixed = value;
4183
      break;
4184
    case M32C_OPERAND_BITBASE32_24_S11_PREFIXED :
4185
      fields->f_bitbase32_24_s11_prefixed = value;
4186
      break;
4187
    case M32C_OPERAND_BITBASE32_24_S19_PREFIXED :
4188
      fields->f_bitbase32_24_s19_prefixed = value;
4189
      break;
4190
    case M32C_OPERAND_BITBASE32_24_U11_PREFIXED :
4191
      fields->f_bitbase32_24_u11_prefixed = value;
4192
      break;
4193
    case M32C_OPERAND_BITBASE32_24_U19_PREFIXED :
4194
      fields->f_bitbase32_24_u19_prefixed = value;
4195
      break;
4196
    case M32C_OPERAND_BITBASE32_24_U27_PREFIXED :
4197
      fields->f_bitbase32_24_u27_prefixed = value;
4198
      break;
4199
    case M32C_OPERAND_BITNO16R :
4200
      fields->f_dsp_16_u8 = value;
4201
      break;
4202
    case M32C_OPERAND_BITNO32PREFIXED :
4203
      fields->f_bitno32_prefixed = value;
4204
      break;
4205
    case M32C_OPERAND_BITNO32UNPREFIXED :
4206
      fields->f_bitno32_unprefixed = value;
4207
      break;
4208
    case M32C_OPERAND_DSP_10_U6 :
4209
      fields->f_dsp_10_u6 = value;
4210
      break;
4211
    case M32C_OPERAND_DSP_16_S16 :
4212
      fields->f_dsp_16_s16 = value;
4213
      break;
4214
    case M32C_OPERAND_DSP_16_S8 :
4215
      fields->f_dsp_16_s8 = value;
4216
      break;
4217
    case M32C_OPERAND_DSP_16_U16 :
4218
      fields->f_dsp_16_u16 = value;
4219
      break;
4220
    case M32C_OPERAND_DSP_16_U20 :
4221
      fields->f_dsp_16_u24 = value;
4222
      break;
4223
    case M32C_OPERAND_DSP_16_U24 :
4224
      fields->f_dsp_16_u24 = value;
4225
      break;
4226
    case M32C_OPERAND_DSP_16_U8 :
4227
      fields->f_dsp_16_u8 = value;
4228
      break;
4229
    case M32C_OPERAND_DSP_24_S16 :
4230
      fields->f_dsp_24_s16 = value;
4231
      break;
4232
    case M32C_OPERAND_DSP_24_S8 :
4233
      fields->f_dsp_24_s8 = value;
4234
      break;
4235
    case M32C_OPERAND_DSP_24_U16 :
4236
      fields->f_dsp_24_u16 = value;
4237
      break;
4238
    case M32C_OPERAND_DSP_24_U20 :
4239
      fields->f_dsp_24_u24 = value;
4240
      break;
4241
    case M32C_OPERAND_DSP_24_U24 :
4242
      fields->f_dsp_24_u24 = value;
4243
      break;
4244
    case M32C_OPERAND_DSP_24_U8 :
4245
      fields->f_dsp_24_u8 = value;
4246
      break;
4247
    case M32C_OPERAND_DSP_32_S16 :
4248
      fields->f_dsp_32_s16 = value;
4249
      break;
4250
    case M32C_OPERAND_DSP_32_S8 :
4251
      fields->f_dsp_32_s8 = value;
4252
      break;
4253
    case M32C_OPERAND_DSP_32_U16 :
4254
      fields->f_dsp_32_u16 = value;
4255
      break;
4256
    case M32C_OPERAND_DSP_32_U20 :
4257
      fields->f_dsp_32_u24 = value;
4258
      break;
4259
    case M32C_OPERAND_DSP_32_U24 :
4260
      fields->f_dsp_32_u24 = value;
4261
      break;
4262
    case M32C_OPERAND_DSP_32_U8 :
4263
      fields->f_dsp_32_u8 = value;
4264
      break;
4265
    case M32C_OPERAND_DSP_40_S16 :
4266
      fields->f_dsp_40_s16 = value;
4267
      break;
4268
    case M32C_OPERAND_DSP_40_S8 :
4269
      fields->f_dsp_40_s8 = value;
4270
      break;
4271
    case M32C_OPERAND_DSP_40_U16 :
4272
      fields->f_dsp_40_u16 = value;
4273
      break;
4274
    case M32C_OPERAND_DSP_40_U20 :
4275
      fields->f_dsp_40_u20 = value;
4276
      break;
4277
    case M32C_OPERAND_DSP_40_U24 :
4278
      fields->f_dsp_40_u24 = value;
4279
      break;
4280
    case M32C_OPERAND_DSP_40_U8 :
4281
      fields->f_dsp_40_u8 = value;
4282
      break;
4283
    case M32C_OPERAND_DSP_48_S16 :
4284
      fields->f_dsp_48_s16 = value;
4285
      break;
4286
    case M32C_OPERAND_DSP_48_S8 :
4287
      fields->f_dsp_48_s8 = value;
4288
      break;
4289
    case M32C_OPERAND_DSP_48_U16 :
4290
      fields->f_dsp_48_u16 = value;
4291
      break;
4292
    case M32C_OPERAND_DSP_48_U20 :
4293
      fields->f_dsp_48_u20 = value;
4294
      break;
4295
    case M32C_OPERAND_DSP_48_U24 :
4296
      fields->f_dsp_48_u24 = value;
4297
      break;
4298
    case M32C_OPERAND_DSP_48_U8 :
4299
      fields->f_dsp_48_u8 = value;
4300
      break;
4301
    case M32C_OPERAND_DSP_8_S24 :
4302
      fields->f_dsp_8_s24 = value;
4303
      break;
4304
    case M32C_OPERAND_DSP_8_S8 :
4305
      fields->f_dsp_8_s8 = value;
4306
      break;
4307
    case M32C_OPERAND_DSP_8_U16 :
4308
      fields->f_dsp_8_u16 = value;
4309
      break;
4310
    case M32C_OPERAND_DSP_8_U24 :
4311
      fields->f_dsp_8_u24 = value;
4312
      break;
4313
    case M32C_OPERAND_DSP_8_U6 :
4314
      fields->f_dsp_8_u6 = value;
4315
      break;
4316
    case M32C_OPERAND_DSP_8_U8 :
4317
      fields->f_dsp_8_u8 = value;
4318
      break;
4319
    case M32C_OPERAND_DST16AN :
4320
      fields->f_dst16_an = value;
4321
      break;
4322
    case M32C_OPERAND_DST16AN_S :
4323
      fields->f_dst16_an_s = value;
4324
      break;
4325
    case M32C_OPERAND_DST16ANHI :
4326
      fields->f_dst16_an = value;
4327
      break;
4328
    case M32C_OPERAND_DST16ANQI :
4329
      fields->f_dst16_an = value;
4330
      break;
4331
    case M32C_OPERAND_DST16ANQI_S :
4332
      fields->f_dst16_rn_QI_s = value;
4333
      break;
4334
    case M32C_OPERAND_DST16ANSI :
4335
      fields->f_dst16_an = value;
4336
      break;
4337
    case M32C_OPERAND_DST16RNEXTQI :
4338
      fields->f_dst16_rn_ext = value;
4339
      break;
4340
    case M32C_OPERAND_DST16RNHI :
4341
      fields->f_dst16_rn = value;
4342
      break;
4343
    case M32C_OPERAND_DST16RNQI :
4344
      fields->f_dst16_rn = value;
4345
      break;
4346
    case M32C_OPERAND_DST16RNQI_S :
4347
      fields->f_dst16_rn_QI_s = value;
4348
      break;
4349
    case M32C_OPERAND_DST16RNSI :
4350
      fields->f_dst16_rn = value;
4351
      break;
4352
    case M32C_OPERAND_DST32ANEXTUNPREFIXED :
4353
      fields->f_dst32_an_unprefixed = value;
4354
      break;
4355
    case M32C_OPERAND_DST32ANPREFIXED :
4356
      fields->f_dst32_an_prefixed = value;
4357
      break;
4358
    case M32C_OPERAND_DST32ANPREFIXEDHI :
4359
      fields->f_dst32_an_prefixed = value;
4360
      break;
4361
    case M32C_OPERAND_DST32ANPREFIXEDQI :
4362
      fields->f_dst32_an_prefixed = value;
4363
      break;
4364
    case M32C_OPERAND_DST32ANPREFIXEDSI :
4365
      fields->f_dst32_an_prefixed = value;
4366
      break;
4367
    case M32C_OPERAND_DST32ANUNPREFIXED :
4368
      fields->f_dst32_an_unprefixed = value;
4369
      break;
4370
    case M32C_OPERAND_DST32ANUNPREFIXEDHI :
4371
      fields->f_dst32_an_unprefixed = value;
4372
      break;
4373
    case M32C_OPERAND_DST32ANUNPREFIXEDQI :
4374
      fields->f_dst32_an_unprefixed = value;
4375
      break;
4376
    case M32C_OPERAND_DST32ANUNPREFIXEDSI :
4377
      fields->f_dst32_an_unprefixed = value;
4378
      break;
4379
    case M32C_OPERAND_DST32R0HI_S :
4380
      break;
4381
    case M32C_OPERAND_DST32R0QI_S :
4382
      break;
4383
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDHI :
4384
      fields->f_dst32_rn_ext_unprefixed = value;
4385
      break;
4386
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDQI :
4387
      fields->f_dst32_rn_ext_unprefixed = value;
4388
      break;
4389
    case M32C_OPERAND_DST32RNPREFIXEDHI :
4390
      fields->f_dst32_rn_prefixed_HI = value;
4391
      break;
4392
    case M32C_OPERAND_DST32RNPREFIXEDQI :
4393
      fields->f_dst32_rn_prefixed_QI = value;
4394
      break;
4395
    case M32C_OPERAND_DST32RNPREFIXEDSI :
4396
      fields->f_dst32_rn_prefixed_SI = value;
4397
      break;
4398
    case M32C_OPERAND_DST32RNUNPREFIXEDHI :
4399
      fields->f_dst32_rn_unprefixed_HI = value;
4400
      break;
4401
    case M32C_OPERAND_DST32RNUNPREFIXEDQI :
4402
      fields->f_dst32_rn_unprefixed_QI = value;
4403
      break;
4404
    case M32C_OPERAND_DST32RNUNPREFIXEDSI :
4405
      fields->f_dst32_rn_unprefixed_SI = value;
4406
      break;
4407
    case M32C_OPERAND_G :
4408
      break;
4409
    case M32C_OPERAND_IMM_12_S4 :
4410
      fields->f_imm_12_s4 = value;
4411
      break;
4412
    case M32C_OPERAND_IMM_12_S4N :
4413
      fields->f_imm_12_s4 = value;
4414
      break;
4415
    case M32C_OPERAND_IMM_13_U3 :
4416
      fields->f_imm_13_u3 = value;
4417
      break;
4418
    case M32C_OPERAND_IMM_16_HI :
4419
      fields->f_dsp_16_s16 = value;
4420
      break;
4421
    case M32C_OPERAND_IMM_16_QI :
4422
      fields->f_dsp_16_s8 = value;
4423
      break;
4424
    case M32C_OPERAND_IMM_16_SI :
4425
      fields->f_dsp_16_s32 = value;
4426
      break;
4427
    case M32C_OPERAND_IMM_20_S4 :
4428
      fields->f_imm_20_s4 = value;
4429
      break;
4430
    case M32C_OPERAND_IMM_24_HI :
4431
      fields->f_dsp_24_s16 = value;
4432
      break;
4433
    case M32C_OPERAND_IMM_24_QI :
4434
      fields->f_dsp_24_s8 = value;
4435
      break;
4436
    case M32C_OPERAND_IMM_24_SI :
4437
      fields->f_dsp_24_s32 = value;
4438
      break;
4439
    case M32C_OPERAND_IMM_32_HI :
4440
      fields->f_dsp_32_s16 = value;
4441
      break;
4442
    case M32C_OPERAND_IMM_32_QI :
4443
      fields->f_dsp_32_s8 = value;
4444
      break;
4445
    case M32C_OPERAND_IMM_32_SI :
4446
      fields->f_dsp_32_s32 = value;
4447
      break;
4448
    case M32C_OPERAND_IMM_40_HI :
4449
      fields->f_dsp_40_s16 = value;
4450
      break;
4451
    case M32C_OPERAND_IMM_40_QI :
4452
      fields->f_dsp_40_s8 = value;
4453
      break;
4454
    case M32C_OPERAND_IMM_40_SI :
4455
      fields->f_dsp_40_s32 = value;
4456
      break;
4457
    case M32C_OPERAND_IMM_48_HI :
4458
      fields->f_dsp_48_s16 = value;
4459
      break;
4460
    case M32C_OPERAND_IMM_48_QI :
4461
      fields->f_dsp_48_s8 = value;
4462
      break;
4463
    case M32C_OPERAND_IMM_48_SI :
4464
      fields->f_dsp_48_s32 = value;
4465
      break;
4466
    case M32C_OPERAND_IMM_56_HI :
4467
      fields->f_dsp_56_s16 = value;
4468
      break;
4469
    case M32C_OPERAND_IMM_56_QI :
4470
      fields->f_dsp_56_s8 = value;
4471
      break;
4472
    case M32C_OPERAND_IMM_64_HI :
4473
      fields->f_dsp_64_s16 = value;
4474
      break;
4475
    case M32C_OPERAND_IMM_8_HI :
4476
      fields->f_dsp_8_s16 = value;
4477
      break;
4478
    case M32C_OPERAND_IMM_8_QI :
4479
      fields->f_dsp_8_s8 = value;
4480
      break;
4481
    case M32C_OPERAND_IMM_8_S4 :
4482
      fields->f_imm_8_s4 = value;
4483
      break;
4484
    case M32C_OPERAND_IMM_8_S4N :
4485
      fields->f_imm_8_s4 = value;
4486
      break;
4487
    case M32C_OPERAND_IMM_SH_12_S4 :
4488
      fields->f_imm_12_s4 = value;
4489
      break;
4490
    case M32C_OPERAND_IMM_SH_20_S4 :
4491
      fields->f_imm_20_s4 = value;
4492
      break;
4493
    case M32C_OPERAND_IMM_SH_8_S4 :
4494
      fields->f_imm_8_s4 = value;
4495
      break;
4496
    case M32C_OPERAND_IMM1_S :
4497
      fields->f_imm1_S = value;
4498
      break;
4499
    case M32C_OPERAND_IMM3_S :
4500
      fields->f_imm3_S = value;
4501
      break;
4502
    case M32C_OPERAND_LAB_16_8 :
4503
      fields->f_lab_16_8 = value;
4504
      break;
4505
    case M32C_OPERAND_LAB_24_8 :
4506
      fields->f_lab_24_8 = value;
4507
      break;
4508
    case M32C_OPERAND_LAB_32_8 :
4509
      fields->f_lab_32_8 = value;
4510
      break;
4511
    case M32C_OPERAND_LAB_40_8 :
4512
      fields->f_lab_40_8 = value;
4513
      break;
4514
    case M32C_OPERAND_LAB_5_3 :
4515
      fields->f_lab_5_3 = value;
4516
      break;
4517
    case M32C_OPERAND_LAB_8_16 :
4518
      fields->f_lab_8_16 = value;
4519
      break;
4520
    case M32C_OPERAND_LAB_8_24 :
4521
      fields->f_lab_8_24 = value;
4522
      break;
4523
    case M32C_OPERAND_LAB_8_8 :
4524
      fields->f_lab_8_8 = value;
4525
      break;
4526
    case M32C_OPERAND_LAB32_JMP_S :
4527
      fields->f_lab32_jmp_s = value;
4528
      break;
4529
    case M32C_OPERAND_Q :
4530
      break;
4531
    case M32C_OPERAND_R0 :
4532
      break;
4533
    case M32C_OPERAND_R0H :
4534
      break;
4535
    case M32C_OPERAND_R0L :
4536
      break;
4537
    case M32C_OPERAND_R1 :
4538
      break;
4539
    case M32C_OPERAND_R1R2R0 :
4540
      break;
4541
    case M32C_OPERAND_R2 :
4542
      break;
4543
    case M32C_OPERAND_R2R0 :
4544
      break;
4545
    case M32C_OPERAND_R3 :
4546
      break;
4547
    case M32C_OPERAND_R3R1 :
4548
      break;
4549
    case M32C_OPERAND_REGSETPOP :
4550
      fields->f_8_8 = value;
4551
      break;
4552
    case M32C_OPERAND_REGSETPUSH :
4553
      fields->f_8_8 = value;
4554
      break;
4555
    case M32C_OPERAND_RN16_PUSH_S :
4556
      fields->f_4_1 = value;
4557
      break;
4558
    case M32C_OPERAND_S :
4559
      break;
4560
    case M32C_OPERAND_SRC16AN :
4561
      fields->f_src16_an = value;
4562
      break;
4563
    case M32C_OPERAND_SRC16ANHI :
4564
      fields->f_src16_an = value;
4565
      break;
4566
    case M32C_OPERAND_SRC16ANQI :
4567
      fields->f_src16_an = value;
4568
      break;
4569
    case M32C_OPERAND_SRC16RNHI :
4570
      fields->f_src16_rn = value;
4571
      break;
4572
    case M32C_OPERAND_SRC16RNQI :
4573
      fields->f_src16_rn = value;
4574
      break;
4575
    case M32C_OPERAND_SRC32ANPREFIXED :
4576
      fields->f_src32_an_prefixed = value;
4577
      break;
4578
    case M32C_OPERAND_SRC32ANPREFIXEDHI :
4579
      fields->f_src32_an_prefixed = value;
4580
      break;
4581
    case M32C_OPERAND_SRC32ANPREFIXEDQI :
4582
      fields->f_src32_an_prefixed = value;
4583
      break;
4584
    case M32C_OPERAND_SRC32ANPREFIXEDSI :
4585
      fields->f_src32_an_prefixed = value;
4586
      break;
4587
    case M32C_OPERAND_SRC32ANUNPREFIXED :
4588
      fields->f_src32_an_unprefixed = value;
4589
      break;
4590
    case M32C_OPERAND_SRC32ANUNPREFIXEDHI :
4591
      fields->f_src32_an_unprefixed = value;
4592
      break;
4593
    case M32C_OPERAND_SRC32ANUNPREFIXEDQI :
4594
      fields->f_src32_an_unprefixed = value;
4595
      break;
4596
    case M32C_OPERAND_SRC32ANUNPREFIXEDSI :
4597
      fields->f_src32_an_unprefixed = value;
4598
      break;
4599
    case M32C_OPERAND_SRC32RNPREFIXEDHI :
4600
      fields->f_src32_rn_prefixed_HI = value;
4601
      break;
4602
    case M32C_OPERAND_SRC32RNPREFIXEDQI :
4603
      fields->f_src32_rn_prefixed_QI = value;
4604
      break;
4605
    case M32C_OPERAND_SRC32RNPREFIXEDSI :
4606
      fields->f_src32_rn_prefixed_SI = value;
4607
      break;
4608
    case M32C_OPERAND_SRC32RNUNPREFIXEDHI :
4609
      fields->f_src32_rn_unprefixed_HI = value;
4610
      break;
4611
    case M32C_OPERAND_SRC32RNUNPREFIXEDQI :
4612
      fields->f_src32_rn_unprefixed_QI = value;
4613
      break;
4614
    case M32C_OPERAND_SRC32RNUNPREFIXEDSI :
4615
      fields->f_src32_rn_unprefixed_SI = value;
4616
      break;
4617
    case M32C_OPERAND_SRCDST16_R0L_R0H_S_NORMAL :
4618
      fields->f_5_1 = value;
4619
      break;
4620
    case M32C_OPERAND_X :
4621
      break;
4622
    case M32C_OPERAND_Z :
4623
      break;
4624
    case M32C_OPERAND_COND16_16 :
4625
      fields->f_dsp_16_u8 = value;
4626
      break;
4627
    case M32C_OPERAND_COND16_24 :
4628
      fields->f_dsp_24_u8 = value;
4629
      break;
4630
    case M32C_OPERAND_COND16_32 :
4631
      fields->f_dsp_32_u8 = value;
4632
      break;
4633
    case M32C_OPERAND_COND16C :
4634
      fields->f_cond16 = value;
4635
      break;
4636
    case M32C_OPERAND_COND16J :
4637
      fields->f_cond16 = value;
4638
      break;
4639
    case M32C_OPERAND_COND16J5 :
4640
      fields->f_cond16j_5 = value;
4641
      break;
4642
    case M32C_OPERAND_COND32 :
4643
      fields->f_cond32 = value;
4644
      break;
4645
    case M32C_OPERAND_COND32_16 :
4646
      fields->f_dsp_16_u8 = value;
4647
      break;
4648
    case M32C_OPERAND_COND32_24 :
4649
      fields->f_dsp_24_u8 = value;
4650
      break;
4651
    case M32C_OPERAND_COND32_32 :
4652
      fields->f_dsp_32_u8 = value;
4653
      break;
4654
    case M32C_OPERAND_COND32_40 :
4655
      fields->f_dsp_40_u8 = value;
4656
      break;
4657
    case M32C_OPERAND_COND32J :
4658
      fields->f_cond32j = value;
4659
      break;
4660
    case M32C_OPERAND_CR1_PREFIXED_32 :
4661
      fields->f_21_3 = value;
4662
      break;
4663
    case M32C_OPERAND_CR1_UNPREFIXED_32 :
4664
      fields->f_13_3 = value;
4665
      break;
4666
    case M32C_OPERAND_CR16 :
4667
      fields->f_9_3 = value;
4668
      break;
4669
    case M32C_OPERAND_CR2_32 :
4670
      fields->f_13_3 = value;
4671
      break;
4672
    case M32C_OPERAND_CR3_PREFIXED_32 :
4673
      fields->f_21_3 = value;
4674
      break;
4675
    case M32C_OPERAND_CR3_UNPREFIXED_32 :
4676
      fields->f_13_3 = value;
4677
      break;
4678
    case M32C_OPERAND_FLAGS16 :
4679
      fields->f_9_3 = value;
4680
      break;
4681
    case M32C_OPERAND_FLAGS32 :
4682
      fields->f_13_3 = value;
4683
      break;
4684
    case M32C_OPERAND_SCCOND32 :
4685
      fields->f_cond16 = value;
4686
      break;
4687
    case M32C_OPERAND_SIZE :
4688
      break;
4689
 
4690
    default :
4691
      /* xgettext:c-format */
4692
      fprintf (stderr, _("Unrecognized field %d while setting int operand.\n"),
4693
                       opindex);
4694
      abort ();
4695
  }
4696
}
4697
 
4698
void
4699
m32c_cgen_set_vma_operand (CGEN_CPU_DESC cd ATTRIBUTE_UNUSED,
4700
                             int opindex,
4701
                             CGEN_FIELDS * fields,
4702
                             bfd_vma value)
4703
{
4704
  switch (opindex)
4705
    {
4706
    case M32C_OPERAND_A0 :
4707
      break;
4708
    case M32C_OPERAND_A1 :
4709
      break;
4710
    case M32C_OPERAND_AN16_PUSH_S :
4711
      fields->f_4_1 = value;
4712
      break;
4713
    case M32C_OPERAND_BIT16AN :
4714
      fields->f_dst16_an = value;
4715
      break;
4716
    case M32C_OPERAND_BIT16RN :
4717
      fields->f_dst16_rn = value;
4718
      break;
4719
    case M32C_OPERAND_BIT3_S :
4720
      fields->f_imm3_S = value;
4721
      break;
4722
    case M32C_OPERAND_BIT32ANPREFIXED :
4723
      fields->f_dst32_an_prefixed = value;
4724
      break;
4725
    case M32C_OPERAND_BIT32ANUNPREFIXED :
4726
      fields->f_dst32_an_unprefixed = value;
4727
      break;
4728
    case M32C_OPERAND_BIT32RNPREFIXED :
4729
      fields->f_dst32_rn_prefixed_QI = value;
4730
      break;
4731
    case M32C_OPERAND_BIT32RNUNPREFIXED :
4732
      fields->f_dst32_rn_unprefixed_QI = value;
4733
      break;
4734
    case M32C_OPERAND_BITBASE16_16_S8 :
4735
      fields->f_dsp_16_s8 = value;
4736
      break;
4737
    case M32C_OPERAND_BITBASE16_16_U16 :
4738
      fields->f_dsp_16_u16 = value;
4739
      break;
4740
    case M32C_OPERAND_BITBASE16_16_U8 :
4741
      fields->f_dsp_16_u8 = value;
4742
      break;
4743
    case M32C_OPERAND_BITBASE16_8_U11_S :
4744
      fields->f_bitbase16_u11_S = value;
4745
      break;
4746
    case M32C_OPERAND_BITBASE32_16_S11_UNPREFIXED :
4747
      fields->f_bitbase32_16_s11_unprefixed = value;
4748
      break;
4749
    case M32C_OPERAND_BITBASE32_16_S19_UNPREFIXED :
4750
      fields->f_bitbase32_16_s19_unprefixed = value;
4751
      break;
4752
    case M32C_OPERAND_BITBASE32_16_U11_UNPREFIXED :
4753
      fields->f_bitbase32_16_u11_unprefixed = value;
4754
      break;
4755
    case M32C_OPERAND_BITBASE32_16_U19_UNPREFIXED :
4756
      fields->f_bitbase32_16_u19_unprefixed = value;
4757
      break;
4758
    case M32C_OPERAND_BITBASE32_16_U27_UNPREFIXED :
4759
      fields->f_bitbase32_16_u27_unprefixed = value;
4760
      break;
4761
    case M32C_OPERAND_BITBASE32_24_S11_PREFIXED :
4762
      fields->f_bitbase32_24_s11_prefixed = value;
4763
      break;
4764
    case M32C_OPERAND_BITBASE32_24_S19_PREFIXED :
4765
      fields->f_bitbase32_24_s19_prefixed = value;
4766
      break;
4767
    case M32C_OPERAND_BITBASE32_24_U11_PREFIXED :
4768
      fields->f_bitbase32_24_u11_prefixed = value;
4769
      break;
4770
    case M32C_OPERAND_BITBASE32_24_U19_PREFIXED :
4771
      fields->f_bitbase32_24_u19_prefixed = value;
4772
      break;
4773
    case M32C_OPERAND_BITBASE32_24_U27_PREFIXED :
4774
      fields->f_bitbase32_24_u27_prefixed = value;
4775
      break;
4776
    case M32C_OPERAND_BITNO16R :
4777
      fields->f_dsp_16_u8 = value;
4778
      break;
4779
    case M32C_OPERAND_BITNO32PREFIXED :
4780
      fields->f_bitno32_prefixed = value;
4781
      break;
4782
    case M32C_OPERAND_BITNO32UNPREFIXED :
4783
      fields->f_bitno32_unprefixed = value;
4784
      break;
4785
    case M32C_OPERAND_DSP_10_U6 :
4786
      fields->f_dsp_10_u6 = value;
4787
      break;
4788
    case M32C_OPERAND_DSP_16_S16 :
4789
      fields->f_dsp_16_s16 = value;
4790
      break;
4791
    case M32C_OPERAND_DSP_16_S8 :
4792
      fields->f_dsp_16_s8 = value;
4793
      break;
4794
    case M32C_OPERAND_DSP_16_U16 :
4795
      fields->f_dsp_16_u16 = value;
4796
      break;
4797
    case M32C_OPERAND_DSP_16_U20 :
4798
      fields->f_dsp_16_u24 = value;
4799
      break;
4800
    case M32C_OPERAND_DSP_16_U24 :
4801
      fields->f_dsp_16_u24 = value;
4802
      break;
4803
    case M32C_OPERAND_DSP_16_U8 :
4804
      fields->f_dsp_16_u8 = value;
4805
      break;
4806
    case M32C_OPERAND_DSP_24_S16 :
4807
      fields->f_dsp_24_s16 = value;
4808
      break;
4809
    case M32C_OPERAND_DSP_24_S8 :
4810
      fields->f_dsp_24_s8 = value;
4811
      break;
4812
    case M32C_OPERAND_DSP_24_U16 :
4813
      fields->f_dsp_24_u16 = value;
4814
      break;
4815
    case M32C_OPERAND_DSP_24_U20 :
4816
      fields->f_dsp_24_u24 = value;
4817
      break;
4818
    case M32C_OPERAND_DSP_24_U24 :
4819
      fields->f_dsp_24_u24 = value;
4820
      break;
4821
    case M32C_OPERAND_DSP_24_U8 :
4822
      fields->f_dsp_24_u8 = value;
4823
      break;
4824
    case M32C_OPERAND_DSP_32_S16 :
4825
      fields->f_dsp_32_s16 = value;
4826
      break;
4827
    case M32C_OPERAND_DSP_32_S8 :
4828
      fields->f_dsp_32_s8 = value;
4829
      break;
4830
    case M32C_OPERAND_DSP_32_U16 :
4831
      fields->f_dsp_32_u16 = value;
4832
      break;
4833
    case M32C_OPERAND_DSP_32_U20 :
4834
      fields->f_dsp_32_u24 = value;
4835
      break;
4836
    case M32C_OPERAND_DSP_32_U24 :
4837
      fields->f_dsp_32_u24 = value;
4838
      break;
4839
    case M32C_OPERAND_DSP_32_U8 :
4840
      fields->f_dsp_32_u8 = value;
4841
      break;
4842
    case M32C_OPERAND_DSP_40_S16 :
4843
      fields->f_dsp_40_s16 = value;
4844
      break;
4845
    case M32C_OPERAND_DSP_40_S8 :
4846
      fields->f_dsp_40_s8 = value;
4847
      break;
4848
    case M32C_OPERAND_DSP_40_U16 :
4849
      fields->f_dsp_40_u16 = value;
4850
      break;
4851
    case M32C_OPERAND_DSP_40_U20 :
4852
      fields->f_dsp_40_u20 = value;
4853
      break;
4854
    case M32C_OPERAND_DSP_40_U24 :
4855
      fields->f_dsp_40_u24 = value;
4856
      break;
4857
    case M32C_OPERAND_DSP_40_U8 :
4858
      fields->f_dsp_40_u8 = value;
4859
      break;
4860
    case M32C_OPERAND_DSP_48_S16 :
4861
      fields->f_dsp_48_s16 = value;
4862
      break;
4863
    case M32C_OPERAND_DSP_48_S8 :
4864
      fields->f_dsp_48_s8 = value;
4865
      break;
4866
    case M32C_OPERAND_DSP_48_U16 :
4867
      fields->f_dsp_48_u16 = value;
4868
      break;
4869
    case M32C_OPERAND_DSP_48_U20 :
4870
      fields->f_dsp_48_u20 = value;
4871
      break;
4872
    case M32C_OPERAND_DSP_48_U24 :
4873
      fields->f_dsp_48_u24 = value;
4874
      break;
4875
    case M32C_OPERAND_DSP_48_U8 :
4876
      fields->f_dsp_48_u8 = value;
4877
      break;
4878
    case M32C_OPERAND_DSP_8_S24 :
4879
      fields->f_dsp_8_s24 = value;
4880
      break;
4881
    case M32C_OPERAND_DSP_8_S8 :
4882
      fields->f_dsp_8_s8 = value;
4883
      break;
4884
    case M32C_OPERAND_DSP_8_U16 :
4885
      fields->f_dsp_8_u16 = value;
4886
      break;
4887
    case M32C_OPERAND_DSP_8_U24 :
4888
      fields->f_dsp_8_u24 = value;
4889
      break;
4890
    case M32C_OPERAND_DSP_8_U6 :
4891
      fields->f_dsp_8_u6 = value;
4892
      break;
4893
    case M32C_OPERAND_DSP_8_U8 :
4894
      fields->f_dsp_8_u8 = value;
4895
      break;
4896
    case M32C_OPERAND_DST16AN :
4897
      fields->f_dst16_an = value;
4898
      break;
4899
    case M32C_OPERAND_DST16AN_S :
4900
      fields->f_dst16_an_s = value;
4901
      break;
4902
    case M32C_OPERAND_DST16ANHI :
4903
      fields->f_dst16_an = value;
4904
      break;
4905
    case M32C_OPERAND_DST16ANQI :
4906
      fields->f_dst16_an = value;
4907
      break;
4908
    case M32C_OPERAND_DST16ANQI_S :
4909
      fields->f_dst16_rn_QI_s = value;
4910
      break;
4911
    case M32C_OPERAND_DST16ANSI :
4912
      fields->f_dst16_an = value;
4913
      break;
4914
    case M32C_OPERAND_DST16RNEXTQI :
4915
      fields->f_dst16_rn_ext = value;
4916
      break;
4917
    case M32C_OPERAND_DST16RNHI :
4918
      fields->f_dst16_rn = value;
4919
      break;
4920
    case M32C_OPERAND_DST16RNQI :
4921
      fields->f_dst16_rn = value;
4922
      break;
4923
    case M32C_OPERAND_DST16RNQI_S :
4924
      fields->f_dst16_rn_QI_s = value;
4925
      break;
4926
    case M32C_OPERAND_DST16RNSI :
4927
      fields->f_dst16_rn = value;
4928
      break;
4929
    case M32C_OPERAND_DST32ANEXTUNPREFIXED :
4930
      fields->f_dst32_an_unprefixed = value;
4931
      break;
4932
    case M32C_OPERAND_DST32ANPREFIXED :
4933
      fields->f_dst32_an_prefixed = value;
4934
      break;
4935
    case M32C_OPERAND_DST32ANPREFIXEDHI :
4936
      fields->f_dst32_an_prefixed = value;
4937
      break;
4938
    case M32C_OPERAND_DST32ANPREFIXEDQI :
4939
      fields->f_dst32_an_prefixed = value;
4940
      break;
4941
    case M32C_OPERAND_DST32ANPREFIXEDSI :
4942
      fields->f_dst32_an_prefixed = value;
4943
      break;
4944
    case M32C_OPERAND_DST32ANUNPREFIXED :
4945
      fields->f_dst32_an_unprefixed = value;
4946
      break;
4947
    case M32C_OPERAND_DST32ANUNPREFIXEDHI :
4948
      fields->f_dst32_an_unprefixed = value;
4949
      break;
4950
    case M32C_OPERAND_DST32ANUNPREFIXEDQI :
4951
      fields->f_dst32_an_unprefixed = value;
4952
      break;
4953
    case M32C_OPERAND_DST32ANUNPREFIXEDSI :
4954
      fields->f_dst32_an_unprefixed = value;
4955
      break;
4956
    case M32C_OPERAND_DST32R0HI_S :
4957
      break;
4958
    case M32C_OPERAND_DST32R0QI_S :
4959
      break;
4960
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDHI :
4961
      fields->f_dst32_rn_ext_unprefixed = value;
4962
      break;
4963
    case M32C_OPERAND_DST32RNEXTUNPREFIXEDQI :
4964
      fields->f_dst32_rn_ext_unprefixed = value;
4965
      break;
4966
    case M32C_OPERAND_DST32RNPREFIXEDHI :
4967
      fields->f_dst32_rn_prefixed_HI = value;
4968
      break;
4969
    case M32C_OPERAND_DST32RNPREFIXEDQI :
4970
      fields->f_dst32_rn_prefixed_QI = value;
4971
      break;
4972
    case M32C_OPERAND_DST32RNPREFIXEDSI :
4973
      fields->f_dst32_rn_prefixed_SI = value;
4974
      break;
4975
    case M32C_OPERAND_DST32RNUNPREFIXEDHI :
4976
      fields->f_dst32_rn_unprefixed_HI = value;
4977
      break;
4978
    case M32C_OPERAND_DST32RNUNPREFIXEDQI :
4979
      fields->f_dst32_rn_unprefixed_QI = value;
4980
      break;
4981
    case M32C_OPERAND_DST32RNUNPREFIXEDSI :
4982
      fields->f_dst32_rn_unprefixed_SI = value;
4983
      break;
4984
    case M32C_OPERAND_G :
4985
      break;
4986
    case M32C_OPERAND_IMM_12_S4 :
4987
      fields->f_imm_12_s4 = value;
4988
      break;
4989
    case M32C_OPERAND_IMM_12_S4N :
4990
      fields->f_imm_12_s4 = value;
4991
      break;
4992
    case M32C_OPERAND_IMM_13_U3 :
4993
      fields->f_imm_13_u3 = value;
4994
      break;
4995
    case M32C_OPERAND_IMM_16_HI :
4996
      fields->f_dsp_16_s16 = value;
4997
      break;
4998
    case M32C_OPERAND_IMM_16_QI :
4999
      fields->f_dsp_16_s8 = value;
5000
      break;
5001
    case M32C_OPERAND_IMM_16_SI :
5002
      fields->f_dsp_16_s32 = value;
5003
      break;
5004
    case M32C_OPERAND_IMM_20_S4 :
5005
      fields->f_imm_20_s4 = value;
5006
      break;
5007
    case M32C_OPERAND_IMM_24_HI :
5008
      fields->f_dsp_24_s16 = value;
5009
      break;
5010
    case M32C_OPERAND_IMM_24_QI :
5011
      fields->f_dsp_24_s8 = value;
5012
      break;
5013
    case M32C_OPERAND_IMM_24_SI :
5014
      fields->f_dsp_24_s32 = value;
5015
      break;
5016
    case M32C_OPERAND_IMM_32_HI :
5017
      fields->f_dsp_32_s16 = value;
5018
      break;
5019
    case M32C_OPERAND_IMM_32_QI :
5020
      fields->f_dsp_32_s8 = value;
5021
      break;
5022
    case M32C_OPERAND_IMM_32_SI :
5023
      fields->f_dsp_32_s32 = value;
5024
      break;
5025
    case M32C_OPERAND_IMM_40_HI :
5026
      fields->f_dsp_40_s16 = value;
5027
      break;
5028
    case M32C_OPERAND_IMM_40_QI :
5029
      fields->f_dsp_40_s8 = value;
5030
      break;
5031
    case M32C_OPERAND_IMM_40_SI :
5032
      fields->f_dsp_40_s32 = value;
5033
      break;
5034
    case M32C_OPERAND_IMM_48_HI :
5035
      fields->f_dsp_48_s16 = value;
5036
      break;
5037
    case M32C_OPERAND_IMM_48_QI :
5038
      fields->f_dsp_48_s8 = value;
5039
      break;
5040
    case M32C_OPERAND_IMM_48_SI :
5041
      fields->f_dsp_48_s32 = value;
5042
      break;
5043
    case M32C_OPERAND_IMM_56_HI :
5044
      fields->f_dsp_56_s16 = value;
5045
      break;
5046
    case M32C_OPERAND_IMM_56_QI :
5047
      fields->f_dsp_56_s8 = value;
5048
      break;
5049
    case M32C_OPERAND_IMM_64_HI :
5050
      fields->f_dsp_64_s16 = value;
5051
      break;
5052
    case M32C_OPERAND_IMM_8_HI :
5053
      fields->f_dsp_8_s16 = value;
5054
      break;
5055
    case M32C_OPERAND_IMM_8_QI :
5056
      fields->f_dsp_8_s8 = value;
5057
      break;
5058
    case M32C_OPERAND_IMM_8_S4 :
5059
      fields->f_imm_8_s4 = value;
5060
      break;
5061
    case M32C_OPERAND_IMM_8_S4N :
5062
      fields->f_imm_8_s4 = value;
5063
      break;
5064
    case M32C_OPERAND_IMM_SH_12_S4 :
5065
      fields->f_imm_12_s4 = value;
5066
      break;
5067
    case M32C_OPERAND_IMM_SH_20_S4 :
5068
      fields->f_imm_20_s4 = value;
5069
      break;
5070
    case M32C_OPERAND_IMM_SH_8_S4 :
5071
      fields->f_imm_8_s4 = value;
5072
      break;
5073
    case M32C_OPERAND_IMM1_S :
5074
      fields->f_imm1_S = value;
5075
      break;
5076
    case M32C_OPERAND_IMM3_S :
5077
      fields->f_imm3_S = value;
5078
      break;
5079
    case M32C_OPERAND_LAB_16_8 :
5080
      fields->f_lab_16_8 = value;
5081
      break;
5082
    case M32C_OPERAND_LAB_24_8 :
5083
      fields->f_lab_24_8 = value;
5084
      break;
5085
    case M32C_OPERAND_LAB_32_8 :
5086
      fields->f_lab_32_8 = value;
5087
      break;
5088
    case M32C_OPERAND_LAB_40_8 :
5089
      fields->f_lab_40_8 = value;
5090
      break;
5091
    case M32C_OPERAND_LAB_5_3 :
5092
      fields->f_lab_5_3 = value;
5093
      break;
5094
    case M32C_OPERAND_LAB_8_16 :
5095
      fields->f_lab_8_16 = value;
5096
      break;
5097
    case M32C_OPERAND_LAB_8_24 :
5098
      fields->f_lab_8_24 = value;
5099
      break;
5100
    case M32C_OPERAND_LAB_8_8 :
5101
      fields->f_lab_8_8 = value;
5102
      break;
5103
    case M32C_OPERAND_LAB32_JMP_S :
5104
      fields->f_lab32_jmp_s = value;
5105
      break;
5106
    case M32C_OPERAND_Q :
5107
      break;
5108
    case M32C_OPERAND_R0 :
5109
      break;
5110
    case M32C_OPERAND_R0H :
5111
      break;
5112
    case M32C_OPERAND_R0L :
5113
      break;
5114
    case M32C_OPERAND_R1 :
5115
      break;
5116
    case M32C_OPERAND_R1R2R0 :
5117
      break;
5118
    case M32C_OPERAND_R2 :
5119
      break;
5120
    case M32C_OPERAND_R2R0 :
5121
      break;
5122
    case M32C_OPERAND_R3 :
5123
      break;
5124
    case M32C_OPERAND_R3R1 :
5125
      break;
5126
    case M32C_OPERAND_REGSETPOP :
5127
      fields->f_8_8 = value;
5128
      break;
5129
    case M32C_OPERAND_REGSETPUSH :
5130
      fields->f_8_8 = value;
5131
      break;
5132
    case M32C_OPERAND_RN16_PUSH_S :
5133
      fields->f_4_1 = value;
5134
      break;
5135
    case M32C_OPERAND_S :
5136
      break;
5137
    case M32C_OPERAND_SRC16AN :
5138
      fields->f_src16_an = value;
5139
      break;
5140
    case M32C_OPERAND_SRC16ANHI :
5141
      fields->f_src16_an = value;
5142
      break;
5143
    case M32C_OPERAND_SRC16ANQI :
5144
      fields->f_src16_an = value;
5145
      break;
5146
    case M32C_OPERAND_SRC16RNHI :
5147
      fields->f_src16_rn = value;
5148
      break;
5149
    case M32C_OPERAND_SRC16RNQI :
5150
      fields->f_src16_rn = value;
5151
      break;
5152
    case M32C_OPERAND_SRC32ANPREFIXED :
5153
      fields->f_src32_an_prefixed = value;
5154
      break;
5155
    case M32C_OPERAND_SRC32ANPREFIXEDHI :
5156
      fields->f_src32_an_prefixed = value;
5157
      break;
5158
    case M32C_OPERAND_SRC32ANPREFIXEDQI :
5159
      fields->f_src32_an_prefixed = value;
5160
      break;
5161
    case M32C_OPERAND_SRC32ANPREFIXEDSI :
5162
      fields->f_src32_an_prefixed = value;
5163
      break;
5164
    case M32C_OPERAND_SRC32ANUNPREFIXED :
5165
      fields->f_src32_an_unprefixed = value;
5166
      break;
5167
    case M32C_OPERAND_SRC32ANUNPREFIXEDHI :
5168
      fields->f_src32_an_unprefixed = value;
5169
      break;
5170
    case M32C_OPERAND_SRC32ANUNPREFIXEDQI :
5171
      fields->f_src32_an_unprefixed = value;
5172
      break;
5173
    case M32C_OPERAND_SRC32ANUNPREFIXEDSI :
5174
      fields->f_src32_an_unprefixed = value;
5175
      break;
5176
    case M32C_OPERAND_SRC32RNPREFIXEDHI :
5177
      fields->f_src32_rn_prefixed_HI = value;
5178
      break;
5179
    case M32C_OPERAND_SRC32RNPREFIXEDQI :
5180
      fields->f_src32_rn_prefixed_QI = value;
5181
      break;
5182
    case M32C_OPERAND_SRC32RNPREFIXEDSI :
5183
      fields->f_src32_rn_prefixed_SI = value;
5184
      break;
5185
    case M32C_OPERAND_SRC32RNUNPREFIXEDHI :
5186
      fields->f_src32_rn_unprefixed_HI = value;
5187
      break;
5188
    case M32C_OPERAND_SRC32RNUNPREFIXEDQI :
5189
      fields->f_src32_rn_unprefixed_QI = value;
5190
      break;
5191
    case M32C_OPERAND_SRC32RNUNPREFIXEDSI :
5192
      fields->f_src32_rn_unprefixed_SI = value;
5193
      break;
5194
    case M32C_OPERAND_SRCDST16_R0L_R0H_S_NORMAL :
5195
      fields->f_5_1 = value;
5196
      break;
5197
    case M32C_OPERAND_X :
5198
      break;
5199
    case M32C_OPERAND_Z :
5200
      break;
5201
    case M32C_OPERAND_COND16_16 :
5202
      fields->f_dsp_16_u8 = value;
5203
      break;
5204
    case M32C_OPERAND_COND16_24 :
5205
      fields->f_dsp_24_u8 = value;
5206
      break;
5207
    case M32C_OPERAND_COND16_32 :
5208
      fields->f_dsp_32_u8 = value;
5209
      break;
5210
    case M32C_OPERAND_COND16C :
5211
      fields->f_cond16 = value;
5212
      break;
5213
    case M32C_OPERAND_COND16J :
5214
      fields->f_cond16 = value;
5215
      break;
5216
    case M32C_OPERAND_COND16J5 :
5217
      fields->f_cond16j_5 = value;
5218
      break;
5219
    case M32C_OPERAND_COND32 :
5220
      fields->f_cond32 = value;
5221
      break;
5222
    case M32C_OPERAND_COND32_16 :
5223
      fields->f_dsp_16_u8 = value;
5224
      break;
5225
    case M32C_OPERAND_COND32_24 :
5226
      fields->f_dsp_24_u8 = value;
5227
      break;
5228
    case M32C_OPERAND_COND32_32 :
5229
      fields->f_dsp_32_u8 = value;
5230
      break;
5231
    case M32C_OPERAND_COND32_40 :
5232
      fields->f_dsp_40_u8 = value;
5233
      break;
5234
    case M32C_OPERAND_COND32J :
5235
      fields->f_cond32j = value;
5236
      break;
5237
    case M32C_OPERAND_CR1_PREFIXED_32 :
5238
      fields->f_21_3 = value;
5239
      break;
5240
    case M32C_OPERAND_CR1_UNPREFIXED_32 :
5241
      fields->f_13_3 = value;
5242
      break;
5243
    case M32C_OPERAND_CR16 :
5244
      fields->f_9_3 = value;
5245
      break;
5246
    case M32C_OPERAND_CR2_32 :
5247
      fields->f_13_3 = value;
5248
      break;
5249
    case M32C_OPERAND_CR3_PREFIXED_32 :
5250
      fields->f_21_3 = value;
5251
      break;
5252
    case M32C_OPERAND_CR3_UNPREFIXED_32 :
5253
      fields->f_13_3 = value;
5254
      break;
5255
    case M32C_OPERAND_FLAGS16 :
5256
      fields->f_9_3 = value;
5257
      break;
5258
    case M32C_OPERAND_FLAGS32 :
5259
      fields->f_13_3 = value;
5260
      break;
5261
    case M32C_OPERAND_SCCOND32 :
5262
      fields->f_cond16 = value;
5263
      break;
5264
    case M32C_OPERAND_SIZE :
5265
      break;
5266
 
5267
    default :
5268
      /* xgettext:c-format */
5269
      fprintf (stderr, _("Unrecognized field %d while setting vma operand.\n"),
5270
                       opindex);
5271
      abort ();
5272
  }
5273
}
5274
 
5275
/* Function to call before using the instruction builder tables.  */
5276
 
5277
void
5278
m32c_cgen_init_ibld_table (CGEN_CPU_DESC cd)
5279
{
5280
  cd->insert_handlers = & m32c_cgen_insert_handlers[0];
5281
  cd->extract_handlers = & m32c_cgen_extract_handlers[0];
5282
 
5283
  cd->insert_operand = m32c_cgen_insert_operand;
5284
  cd->extract_operand = m32c_cgen_extract_operand;
5285
 
5286
  cd->get_int_operand = m32c_cgen_get_int_operand;
5287
  cd->set_int_operand = m32c_cgen_set_int_operand;
5288
  cd->get_vma_operand = m32c_cgen_get_vma_operand;
5289
  cd->set_vma_operand = m32c_cgen_set_vma_operand;
5290
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.