1 /* Simulator header for frv.
3 THIS FILE IS MACHINE GENERATED WITH CGEN.
5 Copyright (C) 1996-2024 Free Software Foundation, Inc.
7 This file is part of the GNU simulators.
9 This file 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 3, or (at your option)
14 It is distributed in the hope that it will be useful, but WITHOUT
15 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
16 or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
17 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 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
28 #define TARGET_BIG_ENDIAN 1
36 /* Enum declaration for model types. */
37 typedef enum model_type
{
38 MODEL_FRV
, MODEL_FR550
, MODEL_FR500
, MODEL_TOMCAT
39 , MODEL_FR400
, MODEL_FR450
, MODEL_SIMPLE
, MODEL_MAX
42 #define MAX_MODELS ((int) MODEL_MAX)
44 /* Enum declaration for unit types. */
45 typedef enum unit_type
{
46 UNIT_NONE
, UNIT_FRV_U_EXEC
, UNIT_FR550_U_MEDIA_4_QUAD
, UNIT_FR550_U_MEDIA_4_ADD_SUB_DUAL
47 , UNIT_FR550_U_MEDIA_4_ADD_SUB
, UNIT_FR550_U_MEDIA_4_ACC_DUAL
, UNIT_FR550_U_MEDIA_4_ACC
, UNIT_FR550_U_MEDIA_4
48 , UNIT_FR550_U_MEDIA_SET
, UNIT_FR550_U_MEDIA_3_MCLRACC
, UNIT_FR550_U_MEDIA_3_WTACC
, UNIT_FR550_U_MEDIA_3_ACC_DUAL
49 , UNIT_FR550_U_MEDIA_3_ACC
, UNIT_FR550_U_MEDIA_3_DUAL
, UNIT_FR550_U_MEDIA_DUAL_EXPAND
, UNIT_FR550_U_MEDIA_QUAD
50 , UNIT_FR550_U_MEDIA
, UNIT_FR550_U_FLOAT_CONVERT
, UNIT_FR550_U_COMMIT
, UNIT_FR550_U_DCUL
51 , UNIT_FR550_U_ICUL
, UNIT_FR550_U_DCPL
, UNIT_FR550_U_ICPL
, UNIT_FR550_U_DCF
52 , UNIT_FR550_U_DCI
, UNIT_FR550_U_ICI
, UNIT_FR550_U_CLRFR
, UNIT_FR550_U_CLRGR
53 , UNIT_FR550_U_FR2FR
, UNIT_FR550_U_SWAP
, UNIT_FR550_U_FR_STORE
, UNIT_FR550_U_FR_LOAD
54 , UNIT_FR550_U_GR_STORE
, UNIT_FR550_U_GR_LOAD
, UNIT_FR550_U_SET_HILO
, UNIT_FR550_U_GR2SPR
55 , UNIT_FR550_U_SPR2GR
, UNIT_FR550_U_GR2FR
, UNIT_FR550_U_FR2GR
, UNIT_FR550_U_FLOAT_DUAL_COMPARE
56 , UNIT_FR550_U_FLOAT_COMPARE
, UNIT_FR550_U_FLOAT_SQRT
, UNIT_FR550_U_FLOAT_DIV
, UNIT_FR550_U_FLOAT_DUAL_ARITH
57 , UNIT_FR550_U_FLOAT_ARITH
, UNIT_FR550_U_CHECK
, UNIT_FR550_U_TRAP
, UNIT_FR550_U_BRANCH
58 , UNIT_FR550_U_IDIV
, UNIT_FR550_U_IMUL
, UNIT_FR550_U_INTEGER
, UNIT_FR550_U_EXEC
59 , UNIT_FR500_U_COMMIT
, UNIT_FR500_U_DCUL
, UNIT_FR500_U_ICUL
, UNIT_FR500_U_DCPL
60 , UNIT_FR500_U_ICPL
, UNIT_FR500_U_DCF
, UNIT_FR500_U_DCI
, UNIT_FR500_U_ICI
61 , UNIT_FR500_U_MEMBAR
, UNIT_FR500_U_BARRIER
, UNIT_FR500_U_MEDIA_DUAL_BTOHE
, UNIT_FR500_U_MEDIA_DUAL_HTOB
62 , UNIT_FR500_U_MEDIA_DUAL_BTOH
, UNIT_FR500_U_MEDIA_DUAL_UNPACK
, UNIT_FR500_U_MEDIA_DUAL_EXPAND
, UNIT_FR500_U_MEDIA_QUAD_COMPLEX
63 , UNIT_FR500_U_MEDIA_QUAD_MUL
, UNIT_FR500_U_MEDIA_DUAL_MUL
, UNIT_FR500_U_MEDIA_QUAD_ARITH
, UNIT_FR500_U_MEDIA
64 , UNIT_FR500_U_FLOAT_DUAL_CONVERT
, UNIT_FR500_U_FLOAT_CONVERT
, UNIT_FR500_U_FLOAT_DUAL_COMPARE
, UNIT_FR500_U_FLOAT_COMPARE
65 , UNIT_FR500_U_FLOAT_DUAL_SQRT
, UNIT_FR500_U_FLOAT_SQRT
, UNIT_FR500_U_FLOAT_DIV
, UNIT_FR500_U_FLOAT_DUAL_ARITH
66 , UNIT_FR500_U_FLOAT_ARITH
, UNIT_FR500_U_GR2SPR
, UNIT_FR500_U_GR2FR
, UNIT_FR500_U_SPR2GR
67 , UNIT_FR500_U_FR2GR
, UNIT_FR500_U_FR2FR
, UNIT_FR500_U_SWAP
, UNIT_FR500_U_FR_R_STORE
68 , UNIT_FR500_U_FR_STORE
, UNIT_FR500_U_FR_LOAD
, UNIT_FR500_U_GR_R_STORE
, UNIT_FR500_U_GR_STORE
69 , UNIT_FR500_U_GR_LOAD
, UNIT_FR500_U_SET_HILO
, UNIT_FR500_U_CLRFR
, UNIT_FR500_U_CLRGR
70 , UNIT_FR500_U_CHECK
, UNIT_FR500_U_TRAP
, UNIT_FR500_U_BRANCH
, UNIT_FR500_U_IDIV
71 , UNIT_FR500_U_IMUL
, UNIT_FR500_U_INTEGER
, UNIT_FR500_U_EXEC
, UNIT_TOMCAT_U_EXEC
72 , UNIT_FR400_U_DCUL
, UNIT_FR400_U_ICUL
, UNIT_FR400_U_DCPL
, UNIT_FR400_U_ICPL
73 , UNIT_FR400_U_DCF
, UNIT_FR400_U_DCI
, UNIT_FR400_U_ICI
, UNIT_FR400_U_MEMBAR
74 , UNIT_FR400_U_BARRIER
, UNIT_FR400_U_MEDIA_DUAL_HTOB
, UNIT_FR400_U_MEDIA_DUAL_EXPAND
, UNIT_FR400_U_MEDIA_7
75 , UNIT_FR400_U_MEDIA_6
, UNIT_FR400_U_MEDIA_4_ACC_DUAL
, UNIT_FR400_U_MEDIA_4_ACCG
, UNIT_FR400_U_MEDIA_4
76 , UNIT_FR400_U_MEDIA_3_QUAD
, UNIT_FR400_U_MEDIA_3_DUAL
, UNIT_FR400_U_MEDIA_3
, UNIT_FR400_U_MEDIA_2_ADD_SUB_DUAL
77 , UNIT_FR400_U_MEDIA_2_ADD_SUB
, UNIT_FR400_U_MEDIA_2_ACC_DUAL
, UNIT_FR400_U_MEDIA_2_ACC
, UNIT_FR400_U_MEDIA_2_QUAD
78 , UNIT_FR400_U_MEDIA_2
, UNIT_FR400_U_MEDIA_HILO
, UNIT_FR400_U_MEDIA_1_QUAD
, UNIT_FR400_U_MEDIA_1
79 , UNIT_FR400_U_GR2SPR
, UNIT_FR400_U_GR2FR
, UNIT_FR400_U_SPR2GR
, UNIT_FR400_U_FR2GR
80 , UNIT_FR400_U_SWAP
, UNIT_FR400_U_FR_STORE
, UNIT_FR400_U_FR_LOAD
, UNIT_FR400_U_GR_STORE
81 , UNIT_FR400_U_GR_LOAD
, UNIT_FR400_U_SET_HILO
, UNIT_FR400_U_CHECK
, UNIT_FR400_U_TRAP
82 , UNIT_FR400_U_BRANCH
, UNIT_FR400_U_IDIV
, UNIT_FR400_U_IMUL
, UNIT_FR400_U_INTEGER
83 , UNIT_FR400_U_EXEC
, UNIT_FR450_U_DCUL
, UNIT_FR450_U_ICUL
, UNIT_FR450_U_DCPL
84 , UNIT_FR450_U_ICPL
, UNIT_FR450_U_DCF
, UNIT_FR450_U_DCI
, UNIT_FR450_U_ICI
85 , UNIT_FR450_U_MEMBAR
, UNIT_FR450_U_BARRIER
, UNIT_FR450_U_MEDIA_DUAL_HTOB
, UNIT_FR450_U_MEDIA_DUAL_EXPAND
86 , UNIT_FR450_U_MEDIA_7
, UNIT_FR450_U_MEDIA_6
, UNIT_FR450_U_MEDIA_4_MCLRACCA
, UNIT_FR450_U_MEDIA_4_ACC_DUAL
87 , UNIT_FR450_U_MEDIA_4_ACCG
, UNIT_FR450_U_MEDIA_4
, UNIT_FR450_U_MEDIA_3_QUAD
, UNIT_FR450_U_MEDIA_3_DUAL
88 , UNIT_FR450_U_MEDIA_3
, UNIT_FR450_U_MEDIA_2_ADD_SUB_DUAL
, UNIT_FR450_U_MEDIA_2_ADD_SUB
, UNIT_FR450_U_MEDIA_2_ACC_DUAL
89 , UNIT_FR450_U_MEDIA_2_ACC
, UNIT_FR450_U_MEDIA_2_QUAD
, UNIT_FR450_U_MEDIA_2
, UNIT_FR450_U_MEDIA_HILO
90 , UNIT_FR450_U_MEDIA_1_QUAD
, UNIT_FR450_U_MEDIA_1
, UNIT_FR450_U_GR2SPR
, UNIT_FR450_U_GR2FR
91 , UNIT_FR450_U_SPR2GR
, UNIT_FR450_U_FR2GR
, UNIT_FR450_U_SWAP
, UNIT_FR450_U_FR_STORE
92 , UNIT_FR450_U_FR_LOAD
, UNIT_FR450_U_GR_STORE
, UNIT_FR450_U_GR_LOAD
, UNIT_FR450_U_SET_HILO
93 , UNIT_FR450_U_CHECK
, UNIT_FR450_U_TRAP
, UNIT_FR450_U_BRANCH
, UNIT_FR450_U_IDIV
94 , UNIT_FR450_U_IMUL
, UNIT_FR450_U_INTEGER
, UNIT_FR450_U_EXEC
, UNIT_SIMPLE_U_EXEC
100 #endif /* FRV_ARCH_H */