1 /* Simulator header for frv.
3 THIS FILE IS MACHINE GENERATED WITH CGEN.
5 Copyright 1996-2019 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, see <http://www.gnu.org/licenses/>.
27 /* Enum declaration for model types. */
28 typedef enum model_type
{
29 MODEL_FRV
, MODEL_FR550
, MODEL_FR500
, MODEL_TOMCAT
30 , MODEL_FR400
, MODEL_FR450
, MODEL_SIMPLE
, MODEL_MAX
33 #define MAX_MODELS ((int) MODEL_MAX)
35 /* Enum declaration for unit types. */
36 typedef enum unit_type
{
37 UNIT_NONE
, UNIT_FRV_U_EXEC
, UNIT_FR550_U_MEDIA_4_QUAD
, UNIT_FR550_U_MEDIA_4_ADD_SUB_DUAL
38 , 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
39 , UNIT_FR550_U_MEDIA_SET
, UNIT_FR550_U_MEDIA_3_MCLRACC
, UNIT_FR550_U_MEDIA_3_WTACC
, UNIT_FR550_U_MEDIA_3_ACC_DUAL
40 , UNIT_FR550_U_MEDIA_3_ACC
, UNIT_FR550_U_MEDIA_3_DUAL
, UNIT_FR550_U_MEDIA_DUAL_EXPAND
, UNIT_FR550_U_MEDIA_QUAD
41 , UNIT_FR550_U_MEDIA
, UNIT_FR550_U_FLOAT_CONVERT
, UNIT_FR550_U_COMMIT
, UNIT_FR550_U_DCUL
42 , UNIT_FR550_U_ICUL
, UNIT_FR550_U_DCPL
, UNIT_FR550_U_ICPL
, UNIT_FR550_U_DCF
43 , UNIT_FR550_U_DCI
, UNIT_FR550_U_ICI
, UNIT_FR550_U_CLRFR
, UNIT_FR550_U_CLRGR
44 , UNIT_FR550_U_FR2FR
, UNIT_FR550_U_SWAP
, UNIT_FR550_U_FR_STORE
, UNIT_FR550_U_FR_LOAD
45 , UNIT_FR550_U_GR_STORE
, UNIT_FR550_U_GR_LOAD
, UNIT_FR550_U_SET_HILO
, UNIT_FR550_U_GR2SPR
46 , UNIT_FR550_U_SPR2GR
, UNIT_FR550_U_GR2FR
, UNIT_FR550_U_FR2GR
, UNIT_FR550_U_FLOAT_DUAL_COMPARE
47 , UNIT_FR550_U_FLOAT_COMPARE
, UNIT_FR550_U_FLOAT_SQRT
, UNIT_FR550_U_FLOAT_DIV
, UNIT_FR550_U_FLOAT_DUAL_ARITH
48 , UNIT_FR550_U_FLOAT_ARITH
, UNIT_FR550_U_CHECK
, UNIT_FR550_U_TRAP
, UNIT_FR550_U_BRANCH
49 , UNIT_FR550_U_IDIV
, UNIT_FR550_U_IMUL
, UNIT_FR550_U_INTEGER
, UNIT_FR550_U_EXEC
50 , UNIT_FR500_U_COMMIT
, UNIT_FR500_U_DCUL
, UNIT_FR500_U_ICUL
, UNIT_FR500_U_DCPL
51 , UNIT_FR500_U_ICPL
, UNIT_FR500_U_DCF
, UNIT_FR500_U_DCI
, UNIT_FR500_U_ICI
52 , UNIT_FR500_U_MEMBAR
, UNIT_FR500_U_BARRIER
, UNIT_FR500_U_MEDIA_DUAL_BTOHE
, UNIT_FR500_U_MEDIA_DUAL_HTOB
53 , UNIT_FR500_U_MEDIA_DUAL_BTOH
, UNIT_FR500_U_MEDIA_DUAL_UNPACK
, UNIT_FR500_U_MEDIA_DUAL_EXPAND
, UNIT_FR500_U_MEDIA_QUAD_COMPLEX
54 , UNIT_FR500_U_MEDIA_QUAD_MUL
, UNIT_FR500_U_MEDIA_DUAL_MUL
, UNIT_FR500_U_MEDIA_QUAD_ARITH
, UNIT_FR500_U_MEDIA
55 , UNIT_FR500_U_FLOAT_DUAL_CONVERT
, UNIT_FR500_U_FLOAT_CONVERT
, UNIT_FR500_U_FLOAT_DUAL_COMPARE
, UNIT_FR500_U_FLOAT_COMPARE
56 , UNIT_FR500_U_FLOAT_DUAL_SQRT
, UNIT_FR500_U_FLOAT_SQRT
, UNIT_FR500_U_FLOAT_DIV
, UNIT_FR500_U_FLOAT_DUAL_ARITH
57 , UNIT_FR500_U_FLOAT_ARITH
, UNIT_FR500_U_GR2SPR
, UNIT_FR500_U_GR2FR
, UNIT_FR500_U_SPR2GR
58 , UNIT_FR500_U_FR2GR
, UNIT_FR500_U_FR2FR
, UNIT_FR500_U_SWAP
, UNIT_FR500_U_FR_R_STORE
59 , UNIT_FR500_U_FR_STORE
, UNIT_FR500_U_FR_LOAD
, UNIT_FR500_U_GR_R_STORE
, UNIT_FR500_U_GR_STORE
60 , UNIT_FR500_U_GR_LOAD
, UNIT_FR500_U_SET_HILO
, UNIT_FR500_U_CLRFR
, UNIT_FR500_U_CLRGR
61 , UNIT_FR500_U_CHECK
, UNIT_FR500_U_TRAP
, UNIT_FR500_U_BRANCH
, UNIT_FR500_U_IDIV
62 , UNIT_FR500_U_IMUL
, UNIT_FR500_U_INTEGER
, UNIT_FR500_U_EXEC
, UNIT_TOMCAT_U_EXEC
63 , UNIT_FR400_U_DCUL
, UNIT_FR400_U_ICUL
, UNIT_FR400_U_DCPL
, UNIT_FR400_U_ICPL
64 , UNIT_FR400_U_DCF
, UNIT_FR400_U_DCI
, UNIT_FR400_U_ICI
, UNIT_FR400_U_MEMBAR
65 , UNIT_FR400_U_BARRIER
, UNIT_FR400_U_MEDIA_DUAL_HTOB
, UNIT_FR400_U_MEDIA_DUAL_EXPAND
, UNIT_FR400_U_MEDIA_7
66 , UNIT_FR400_U_MEDIA_6
, UNIT_FR400_U_MEDIA_4_ACC_DUAL
, UNIT_FR400_U_MEDIA_4_ACCG
, UNIT_FR400_U_MEDIA_4
67 , 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
68 , 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
69 , UNIT_FR400_U_MEDIA_2
, UNIT_FR400_U_MEDIA_HILO
, UNIT_FR400_U_MEDIA_1_QUAD
, UNIT_FR400_U_MEDIA_1
70 , UNIT_FR400_U_GR2SPR
, UNIT_FR400_U_GR2FR
, UNIT_FR400_U_SPR2GR
, UNIT_FR400_U_FR2GR
71 , UNIT_FR400_U_SWAP
, UNIT_FR400_U_FR_STORE
, UNIT_FR400_U_FR_LOAD
, UNIT_FR400_U_GR_STORE
72 , UNIT_FR400_U_GR_LOAD
, UNIT_FR400_U_SET_HILO
, UNIT_FR400_U_CHECK
, UNIT_FR400_U_TRAP
73 , UNIT_FR400_U_BRANCH
, UNIT_FR400_U_IDIV
, UNIT_FR400_U_IMUL
, UNIT_FR400_U_INTEGER
74 , UNIT_FR400_U_EXEC
, UNIT_FR450_U_DCUL
, UNIT_FR450_U_ICUL
, UNIT_FR450_U_DCPL
75 , UNIT_FR450_U_ICPL
, UNIT_FR450_U_DCF
, UNIT_FR450_U_DCI
, UNIT_FR450_U_ICI
76 , UNIT_FR450_U_MEMBAR
, UNIT_FR450_U_BARRIER
, UNIT_FR450_U_MEDIA_DUAL_HTOB
, UNIT_FR450_U_MEDIA_DUAL_EXPAND
77 , UNIT_FR450_U_MEDIA_7
, UNIT_FR450_U_MEDIA_6
, UNIT_FR450_U_MEDIA_4_MCLRACCA
, UNIT_FR450_U_MEDIA_4_ACC_DUAL
78 , UNIT_FR450_U_MEDIA_4_ACCG
, UNIT_FR450_U_MEDIA_4
, UNIT_FR450_U_MEDIA_3_QUAD
, UNIT_FR450_U_MEDIA_3_DUAL
79 , 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
80 , UNIT_FR450_U_MEDIA_2_ACC
, UNIT_FR450_U_MEDIA_2_QUAD
, UNIT_FR450_U_MEDIA_2
, UNIT_FR450_U_MEDIA_HILO
81 , UNIT_FR450_U_MEDIA_1_QUAD
, UNIT_FR450_U_MEDIA_1
, UNIT_FR450_U_GR2SPR
, UNIT_FR450_U_GR2FR
82 , UNIT_FR450_U_SPR2GR
, UNIT_FR450_U_FR2GR
, UNIT_FR450_U_SWAP
, UNIT_FR450_U_FR_STORE
83 , UNIT_FR450_U_FR_LOAD
, UNIT_FR450_U_GR_STORE
, UNIT_FR450_U_GR_LOAD
, UNIT_FR450_U_SET_HILO
84 , UNIT_FR450_U_CHECK
, UNIT_FR450_U_TRAP
, UNIT_FR450_U_BRANCH
, UNIT_FR450_U_IDIV
85 , UNIT_FR450_U_IMUL
, UNIT_FR450_U_INTEGER
, UNIT_FR450_U_EXEC
, UNIT_SIMPLE_U_EXEC
91 #endif /* FRV_ARCH_H */