]>
git.ipfire.org Git - thirdparty/binutils-gdb.git/blob - sim/m32r/cpu.h
1 /* CPU family header for m32r.
3 This file is machine generated with CGEN.
5 Copyright (C) 1996, 1997, 1998 Free Software Foundation, Inc.
7 This file is part of the GNU Simulators.
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
11 the Free Software Foundation; either version 2, or (at your option)
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
19 You should have received a copy of the GNU General Public License along
20 with this program; if not, write to the Free Software Foundation, Inc.,
21 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
28 /* Maximum number of instructions that are fetched at a time.
29 This is for LIW type instructions sets (e.g. m32r). */
30 #define MAX_LIW_INSNS 2
32 /* Maximum number of instructions that can be executed in parallel. */
33 #define MAX_PARALLEL_INSNS 1
35 /* CPU state information. */
37 /* Hardware elements. */
41 #define GET_H_PC() CPU (h_pc)
42 #define SET_H_PC(x) (CPU (h_pc) = (x))
43 /* general registers */
45 #define GET_H_GR(a1) CPU (h_gr)[a1]
46 #define SET_H_GR(a1, x) (CPU (h_gr)[a1] = (x))
47 /* control registers */
49 #define GET_H_CR(a1) CPU (h_cr)[a1]
50 #define SET_H_CR(a1, x) (CPU (h_cr)[a1] = (x))
53 #define GET_H_ACCUM() CPU (h_accum)
54 #define SET_H_ACCUM(x) (CPU (h_accum) = (x))
55 /* start-sanitize-m32rx */
58 /* end-sanitize-m32rx */
59 #define GET_H_ACCUMS(a1) CPU (h_accums)[a1]
60 #define SET_H_ACCUMS(a1, x) (CPU (h_accums)[a1] = (x))
61 /* start-sanitize-m32rx */
64 /* end-sanitize-m32rx */
65 #define GET_H_ABORT() CPU (h_abort)
66 #define SET_H_ABORT(x) (CPU (h_abort) = (x))
69 #define GET_H_COND() CPU (h_cond)
70 #define SET_H_COND(x) (CPU (h_cond) = (x))
73 #define GET_H_SM() CPU (h_sm)
74 #define SET_H_SM(x) (CPU (h_sm) = (x))
77 #define GET_H_BSM() CPU (h_bsm)
78 #define SET_H_BSM(x) (CPU (h_bsm) = (x))
81 #define GET_H_IE() CPU (h_ie)
82 #define SET_H_IE(x) (CPU (h_ie) = (x))
85 #define GET_H_BIE() CPU (h_bie)
86 #define SET_H_BIE(x) (CPU (h_bie) = (x))
89 #define GET_H_BCOND() CPU (h_bcond)
90 #define SET_H_BCOND(x) (CPU (h_bcond) = (x))
93 #define GET_H_BPC() CPU (h_bpc)
94 #define SET_H_BPC(x) (CPU (h_bpc) = (x))
97 #define GET_H_LOCK() CPU (h_lock)
98 #define SET_H_LOCK(x) (CPU (h_lock) = (x))
100 #define CPU_CGEN_HW(cpu) (& (cpu)->cpu_data.hardware)
101 /* CPU profiling state information. */
103 /* general registers */
106 #define CPU_CGEN_PROFILE(cpu) (& (cpu)->cpu_data.profile)
109 USI
m32r_h_pc_get (SIM_CPU
*);
110 void m32r_h_pc_set (SIM_CPU
*, USI
);
111 SI
m32r_h_gr_get (SIM_CPU
*, UINT
);
112 void m32r_h_gr_set (SIM_CPU
*, UINT
, SI
);
113 USI
m32r_h_cr_get (SIM_CPU
*, UINT
);
114 void m32r_h_cr_set (SIM_CPU
*, UINT
, USI
);
115 DI
m32r_h_accum_get (SIM_CPU
*);
116 void m32r_h_accum_set (SIM_CPU
*, DI
);
117 DI
m32r_h_accums_get (SIM_CPU
*, UINT
);
118 void m32r_h_accums_set (SIM_CPU
*, UINT
, DI
);
119 UBI
m32r_h_abort_get (SIM_CPU
*);
120 void m32r_h_abort_set (SIM_CPU
*, UBI
);
121 UBI
m32r_h_cond_get (SIM_CPU
*);
122 void m32r_h_cond_set (SIM_CPU
*, UBI
);
123 UBI
m32r_h_sm_get (SIM_CPU
*);
124 void m32r_h_sm_set (SIM_CPU
*, UBI
);
125 UBI
m32r_h_bsm_get (SIM_CPU
*);
126 void m32r_h_bsm_set (SIM_CPU
*, UBI
);
127 UBI
m32r_h_ie_get (SIM_CPU
*);
128 void m32r_h_ie_set (SIM_CPU
*, UBI
);
129 UBI
m32r_h_bie_get (SIM_CPU
*);
130 void m32r_h_bie_set (SIM_CPU
*, UBI
);
131 UBI
m32r_h_bcond_get (SIM_CPU
*);
132 void m32r_h_bcond_set (SIM_CPU
*, UBI
);
133 SI
m32r_h_bpc_get (SIM_CPU
*);
134 void m32r_h_bpc_set (SIM_CPU
*, SI
);
135 UBI
m32r_h_lock_get (SIM_CPU
*);
136 void m32r_h_lock_set (SIM_CPU
*, UBI
);
137 extern DECODE
*m32r_decode (SIM_CPU
*, PCADDR
, insn_t
);
139 /* The ARGBUF struct. */
141 /* These are the baseclass definitions. */
144 const struct cgen_insn
*opcode
;
145 #if ! defined (SCACHE_P)
148 /* cpu specific data follows */
150 struct { /* e.g. add $dr,$sr */
154 struct { /* e.g. add3 $dr,$sr,#$slo16 */
159 struct { /* e.g. and3 $dr,$sr,#$uimm16 */
164 struct { /* e.g. or3 $dr,$sr,#$ulo16 */
169 struct { /* e.g. addi $dr,#$simm8 */
173 struct { /* e.g. addv $dr,$sr */
177 struct { /* e.g. addv3 $dr,$sr,#$simm16 */
182 struct { /* e.g. addx $dr,$sr */
186 struct { /* e.g. bc $disp8 */
189 struct { /* e.g. bc $disp24 */
192 struct { /* e.g. beq $src1,$src2,$disp16 */
197 struct { /* e.g. beqz $src2,$disp16 */
201 struct { /* e.g. bl $disp8 */
204 struct { /* e.g. bl $disp24 */
207 struct { /* e.g. bra $disp8 */
210 struct { /* e.g. bra $disp24 */
213 struct { /* e.g. cmp $src1,$src2 */
217 struct { /* e.g. cmpi $src2,#$simm16 */
221 struct { /* e.g. cmpui $src2,#$uimm16 */
225 struct { /* e.g. div $dr,$sr */
229 struct { /* e.g. jl $sr */
232 struct { /* e.g. jmp $sr */
235 struct { /* e.g. ld $dr,@$sr */
239 struct { /* e.g. ld $dr,@($slo16,$sr) */
244 struct { /* e.g. ldb $dr,@$sr */
248 struct { /* e.g. ldb $dr,@($slo16,$sr) */
253 struct { /* e.g. ldh $dr,@$sr */
257 struct { /* e.g. ldh $dr,@($slo16,$sr) */
262 struct { /* e.g. ld $dr,@$sr+ */
266 struct { /* e.g. ld24 $dr,#$uimm24 */
270 struct { /* e.g. ldi $dr,#$simm8 */
274 struct { /* e.g. ldi $dr,$slo16 */
278 struct { /* e.g. lock $dr,@$sr */
282 struct { /* e.g. machi $src1,$src2 */
286 struct { /* e.g. mulhi $src1,$src2 */
290 struct { /* e.g. mv $dr,$sr */
294 struct { /* e.g. mvfachi $dr */
297 struct { /* e.g. mvfc $dr,$scr */
301 struct { /* e.g. mvtachi $src1 */
304 struct { /* e.g. mvtc $sr,$dcr */
308 struct { /* e.g. nop */
311 struct { /* e.g. rac */
314 struct { /* e.g. rte */
317 struct { /* e.g. seth $dr,#$hi16 */
321 struct { /* e.g. sll3 $dr,$sr,#$simm16 */
326 struct { /* e.g. slli $dr,#$uimm5 */
330 struct { /* e.g. st $src1,@$src2 */
334 struct { /* e.g. st $src1,@($slo16,$src2) */
339 struct { /* e.g. stb $src1,@$src2 */
343 struct { /* e.g. stb $src1,@($slo16,$src2) */
348 struct { /* e.g. sth $src1,@$src2 */
352 struct { /* e.g. sth $src1,@($slo16,$src2) */
357 struct { /* e.g. st $src1,@+$src2 */
361 struct { /* e.g. trap #$uimm4 */
364 struct { /* e.g. unlock $src1,@$src2 */
369 #if 1 || WITH_PROFILE_MODEL_P /*FIXME:wip*/
370 unsigned long h_gr_get
;
371 unsigned long h_gr_set
;
376 This is currently also used in the non-scache case. In this situation we
377 assume the cache size is 1, and do a few things a little differently. */
378 /* FIXME: non-scache version to be redone. */
383 #if ! WITH_SEM_SWITCH_FULL
386 #if ! WITH_SEM_SWITCH_FAST
387 SEMANTIC_FN
*sem_fast_fn
;
389 #if WITH_SEM_SWITCH_FULL || WITH_SEM_SWITCH_FAST
397 struct argbuf argbuf
;
400 /* Macros to simplify extraction, reading and semantic code.
401 These define and assign the local vars that contain the insn's fields. */
403 #define EXTRACT_FMT_0_ADD_VARS \
404 /* Instruction fields. */ \
410 #define EXTRACT_FMT_0_ADD_CODE \
412 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
413 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
414 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
415 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
417 #define EXTRACT_FMT_1_ADD3_VARS \
418 /* Instruction fields. */ \
425 #define EXTRACT_FMT_1_ADD3_CODE \
427 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
428 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
429 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
430 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
431 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
433 #define EXTRACT_FMT_2_AND3_VARS \
434 /* Instruction fields. */ \
441 #define EXTRACT_FMT_2_AND3_CODE \
443 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
444 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
445 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
446 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
447 f_uimm16 = EXTRACT_UNSIGNED (insn, 32, 16, 16); \
449 #define EXTRACT_FMT_3_OR3_VARS \
450 /* Instruction fields. */ \
457 #define EXTRACT_FMT_3_OR3_CODE \
459 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
460 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
461 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
462 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
463 f_uimm16 = EXTRACT_UNSIGNED (insn, 32, 16, 16); \
465 #define EXTRACT_FMT_4_ADDI_VARS \
466 /* Instruction fields. */ \
471 #define EXTRACT_FMT_4_ADDI_CODE \
473 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
474 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
475 f_simm8 = EXTRACT_SIGNED (insn, 16, 8, 8); \
477 #define EXTRACT_FMT_5_ADDV_VARS \
478 /* Instruction fields. */ \
484 #define EXTRACT_FMT_5_ADDV_CODE \
486 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
487 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
488 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
489 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
491 #define EXTRACT_FMT_6_ADDV3_VARS \
492 /* Instruction fields. */ \
499 #define EXTRACT_FMT_6_ADDV3_CODE \
501 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
502 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
503 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
504 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
505 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
507 #define EXTRACT_FMT_7_ADDX_VARS \
508 /* Instruction fields. */ \
514 #define EXTRACT_FMT_7_ADDX_CODE \
516 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
517 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
518 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
519 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
521 #define EXTRACT_FMT_8_BC8_VARS \
522 /* Instruction fields. */ \
527 #define EXTRACT_FMT_8_BC8_CODE \
529 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
530 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
531 f_disp8 = ((EXTRACT_SIGNED (insn, 16, 8, 8)) << (2)); \
533 #define EXTRACT_FMT_9_BC24_VARS \
534 /* Instruction fields. */ \
539 #define EXTRACT_FMT_9_BC24_CODE \
541 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
542 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
543 f_disp24 = ((EXTRACT_SIGNED (insn, 32, 8, 24)) << (2)); \
545 #define EXTRACT_FMT_10_BEQ_VARS \
546 /* Instruction fields. */ \
553 #define EXTRACT_FMT_10_BEQ_CODE \
555 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
556 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
557 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
558 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
559 f_disp16 = ((EXTRACT_SIGNED (insn, 32, 16, 16)) << (2)); \
561 #define EXTRACT_FMT_11_BEQZ_VARS \
562 /* Instruction fields. */ \
569 #define EXTRACT_FMT_11_BEQZ_CODE \
571 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
572 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
573 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
574 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
575 f_disp16 = ((EXTRACT_SIGNED (insn, 32, 16, 16)) << (2)); \
577 #define EXTRACT_FMT_12_BL8_VARS \
578 /* Instruction fields. */ \
583 #define EXTRACT_FMT_12_BL8_CODE \
585 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
586 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
587 f_disp8 = ((EXTRACT_SIGNED (insn, 16, 8, 8)) << (2)); \
589 #define EXTRACT_FMT_13_BL24_VARS \
590 /* Instruction fields. */ \
595 #define EXTRACT_FMT_13_BL24_CODE \
597 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
598 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
599 f_disp24 = ((EXTRACT_SIGNED (insn, 32, 8, 24)) << (2)); \
601 #define EXTRACT_FMT_14_BRA8_VARS \
602 /* Instruction fields. */ \
607 #define EXTRACT_FMT_14_BRA8_CODE \
609 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
610 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
611 f_disp8 = ((EXTRACT_SIGNED (insn, 16, 8, 8)) << (2)); \
613 #define EXTRACT_FMT_15_BRA24_VARS \
614 /* Instruction fields. */ \
619 #define EXTRACT_FMT_15_BRA24_CODE \
621 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
622 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
623 f_disp24 = ((EXTRACT_SIGNED (insn, 32, 8, 24)) << (2)); \
625 #define EXTRACT_FMT_16_CMP_VARS \
626 /* Instruction fields. */ \
632 #define EXTRACT_FMT_16_CMP_CODE \
634 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
635 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
636 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
637 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
639 #define EXTRACT_FMT_17_CMPI_VARS \
640 /* Instruction fields. */ \
647 #define EXTRACT_FMT_17_CMPI_CODE \
649 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
650 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
651 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
652 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
653 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
655 #define EXTRACT_FMT_18_CMPUI_VARS \
656 /* Instruction fields. */ \
663 #define EXTRACT_FMT_18_CMPUI_CODE \
665 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
666 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
667 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
668 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
669 f_uimm16 = EXTRACT_UNSIGNED (insn, 32, 16, 16); \
671 #define EXTRACT_FMT_19_DIV_VARS \
672 /* Instruction fields. */ \
679 #define EXTRACT_FMT_19_DIV_CODE \
681 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
682 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
683 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
684 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
685 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
687 #define EXTRACT_FMT_20_JL_VARS \
688 /* Instruction fields. */ \
694 #define EXTRACT_FMT_20_JL_CODE \
696 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
697 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
698 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
699 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
701 #define EXTRACT_FMT_21_JMP_VARS \
702 /* Instruction fields. */ \
708 #define EXTRACT_FMT_21_JMP_CODE \
710 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
711 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
712 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
713 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
715 #define EXTRACT_FMT_22_LD_VARS \
716 /* Instruction fields. */ \
722 #define EXTRACT_FMT_22_LD_CODE \
724 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
725 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
726 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
727 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
729 #define EXTRACT_FMT_23_LD_D_VARS \
730 /* Instruction fields. */ \
737 #define EXTRACT_FMT_23_LD_D_CODE \
739 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
740 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
741 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
742 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
743 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
745 #define EXTRACT_FMT_24_LDB_VARS \
746 /* Instruction fields. */ \
752 #define EXTRACT_FMT_24_LDB_CODE \
754 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
755 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
756 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
757 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
759 #define EXTRACT_FMT_25_LDB_D_VARS \
760 /* Instruction fields. */ \
767 #define EXTRACT_FMT_25_LDB_D_CODE \
769 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
770 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
771 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
772 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
773 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
775 #define EXTRACT_FMT_26_LDH_VARS \
776 /* Instruction fields. */ \
782 #define EXTRACT_FMT_26_LDH_CODE \
784 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
785 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
786 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
787 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
789 #define EXTRACT_FMT_27_LDH_D_VARS \
790 /* Instruction fields. */ \
797 #define EXTRACT_FMT_27_LDH_D_CODE \
799 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
800 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
801 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
802 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
803 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
805 #define EXTRACT_FMT_28_LD_PLUS_VARS \
806 /* Instruction fields. */ \
812 #define EXTRACT_FMT_28_LD_PLUS_CODE \
814 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
815 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
816 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
817 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
819 #define EXTRACT_FMT_29_LD24_VARS \
820 /* Instruction fields. */ \
825 #define EXTRACT_FMT_29_LD24_CODE \
827 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
828 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
829 f_uimm24 = EXTRACT_UNSIGNED (insn, 32, 8, 24); \
831 #define EXTRACT_FMT_30_LDI8_VARS \
832 /* Instruction fields. */ \
837 #define EXTRACT_FMT_30_LDI8_CODE \
839 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
840 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
841 f_simm8 = EXTRACT_SIGNED (insn, 16, 8, 8); \
843 #define EXTRACT_FMT_31_LDI16_VARS \
844 /* Instruction fields. */ \
851 #define EXTRACT_FMT_31_LDI16_CODE \
853 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
854 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
855 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
856 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
857 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
859 #define EXTRACT_FMT_32_LOCK_VARS \
860 /* Instruction fields. */ \
866 #define EXTRACT_FMT_32_LOCK_CODE \
868 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
869 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
870 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
871 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
873 #define EXTRACT_FMT_33_MACHI_VARS \
874 /* Instruction fields. */ \
880 #define EXTRACT_FMT_33_MACHI_CODE \
882 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
883 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
884 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
885 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
887 #define EXTRACT_FMT_34_MULHI_VARS \
888 /* Instruction fields. */ \
894 #define EXTRACT_FMT_34_MULHI_CODE \
896 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
897 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
898 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
899 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
901 #define EXTRACT_FMT_35_MV_VARS \
902 /* Instruction fields. */ \
908 #define EXTRACT_FMT_35_MV_CODE \
910 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
911 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
912 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
913 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
915 #define EXTRACT_FMT_36_MVFACHI_VARS \
916 /* Instruction fields. */ \
922 #define EXTRACT_FMT_36_MVFACHI_CODE \
924 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
925 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
926 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
927 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
929 #define EXTRACT_FMT_37_MVFC_VARS \
930 /* Instruction fields. */ \
936 #define EXTRACT_FMT_37_MVFC_CODE \
938 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
939 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
940 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
941 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
943 #define EXTRACT_FMT_38_MVTACHI_VARS \
944 /* Instruction fields. */ \
950 #define EXTRACT_FMT_38_MVTACHI_CODE \
952 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
953 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
954 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
955 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
957 #define EXTRACT_FMT_39_MVTC_VARS \
958 /* Instruction fields. */ \
964 #define EXTRACT_FMT_39_MVTC_CODE \
966 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
967 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
968 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
969 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
971 #define EXTRACT_FMT_40_NOP_VARS \
972 /* Instruction fields. */ \
978 #define EXTRACT_FMT_40_NOP_CODE \
980 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
981 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
982 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
983 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
985 #define EXTRACT_FMT_41_RAC_VARS \
986 /* Instruction fields. */ \
992 #define EXTRACT_FMT_41_RAC_CODE \
994 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
995 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
996 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
997 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
999 #define EXTRACT_FMT_42_RTE_VARS \
1000 /* Instruction fields. */ \
1005 unsigned int length;
1006 #define EXTRACT_FMT_42_RTE_CODE \
1008 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
1009 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
1010 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
1011 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
1013 #define EXTRACT_FMT_43_SETH_VARS \
1014 /* Instruction fields. */ \
1020 unsigned int length;
1021 #define EXTRACT_FMT_43_SETH_CODE \
1023 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
1024 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
1025 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
1026 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
1027 f_hi16 = EXTRACT_UNSIGNED (insn, 32, 16, 16); \
1029 #define EXTRACT_FMT_44_SLL3_VARS \
1030 /* Instruction fields. */ \
1036 unsigned int length;
1037 #define EXTRACT_FMT_44_SLL3_CODE \
1039 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
1040 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
1041 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
1042 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
1043 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
1045 #define EXTRACT_FMT_45_SLLI_VARS \
1046 /* Instruction fields. */ \
1051 unsigned int length;
1052 #define EXTRACT_FMT_45_SLLI_CODE \
1054 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
1055 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
1056 f_shift_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 3); \
1057 f_uimm5 = EXTRACT_UNSIGNED (insn, 16, 11, 5); \
1059 #define EXTRACT_FMT_46_ST_VARS \
1060 /* Instruction fields. */ \
1065 unsigned int length;
1066 #define EXTRACT_FMT_46_ST_CODE \
1068 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
1069 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
1070 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
1071 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
1073 #define EXTRACT_FMT_47_ST_D_VARS \
1074 /* Instruction fields. */ \
1080 unsigned int length;
1081 #define EXTRACT_FMT_47_ST_D_CODE \
1083 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
1084 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
1085 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
1086 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
1087 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
1089 #define EXTRACT_FMT_48_STB_VARS \
1090 /* Instruction fields. */ \
1095 unsigned int length;
1096 #define EXTRACT_FMT_48_STB_CODE \
1098 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
1099 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
1100 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
1101 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
1103 #define EXTRACT_FMT_49_STB_D_VARS \
1104 /* Instruction fields. */ \
1110 unsigned int length;
1111 #define EXTRACT_FMT_49_STB_D_CODE \
1113 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
1114 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
1115 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
1116 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
1117 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
1119 #define EXTRACT_FMT_50_STH_VARS \
1120 /* Instruction fields. */ \
1125 unsigned int length;
1126 #define EXTRACT_FMT_50_STH_CODE \
1128 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
1129 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
1130 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
1131 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
1133 #define EXTRACT_FMT_51_STH_D_VARS \
1134 /* Instruction fields. */ \
1140 unsigned int length;
1141 #define EXTRACT_FMT_51_STH_D_CODE \
1143 f_op1 = EXTRACT_UNSIGNED (insn, 32, 0, 4); \
1144 f_r1 = EXTRACT_UNSIGNED (insn, 32, 4, 4); \
1145 f_op2 = EXTRACT_UNSIGNED (insn, 32, 8, 4); \
1146 f_r2 = EXTRACT_UNSIGNED (insn, 32, 12, 4); \
1147 f_simm16 = EXTRACT_SIGNED (insn, 32, 16, 16); \
1149 #define EXTRACT_FMT_52_ST_PLUS_VARS \
1150 /* Instruction fields. */ \
1155 unsigned int length;
1156 #define EXTRACT_FMT_52_ST_PLUS_CODE \
1158 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
1159 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
1160 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
1161 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
1163 #define EXTRACT_FMT_53_TRAP_VARS \
1164 /* Instruction fields. */ \
1169 unsigned int length;
1170 #define EXTRACT_FMT_53_TRAP_CODE \
1172 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
1173 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
1174 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
1175 f_uimm4 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
1177 #define EXTRACT_FMT_54_UNLOCK_VARS \
1178 /* Instruction fields. */ \
1183 unsigned int length;
1184 #define EXTRACT_FMT_54_UNLOCK_CODE \
1186 f_op1 = EXTRACT_UNSIGNED (insn, 16, 0, 4); \
1187 f_r1 = EXTRACT_UNSIGNED (insn, 16, 4, 4); \
1188 f_op2 = EXTRACT_UNSIGNED (insn, 16, 8, 4); \
1189 f_r2 = EXTRACT_UNSIGNED (insn, 16, 12, 4); \
1191 #endif /* CPU_M32R_H */