1 /* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro:
2 Original: s390-tevx-linux64.xml */
6 #include "target-descriptions.h"
8 const struct target_desc
*tdesc_s390_tevx_linux64
;
10 initialize_tdesc_s390_tevx_linux64 (void)
12 target_desc_up result
= allocate_target_description ();
13 set_tdesc_architecture (result
.get (), bfd_scan_arch ("s390:31-bit"));
15 struct tdesc_feature
*feature
;
17 feature
= tdesc_create_feature (result
.get (), "org.gnu.gdb.s390.core");
18 tdesc_create_reg (feature
, "pswm", 0, 1, "psw", 32, "uint32");
19 tdesc_create_reg (feature
, "pswa", 1, 1, "psw", 32, "uint32");
20 tdesc_create_reg (feature
, "r0h", 2, 1, "upper", 32, "uint32");
21 tdesc_create_reg (feature
, "r0l", 3, 1, "lower", 32, "uint32");
22 tdesc_create_reg (feature
, "r1h", 4, 1, "upper", 32, "uint32");
23 tdesc_create_reg (feature
, "r1l", 5, 1, "lower", 32, "uint32");
24 tdesc_create_reg (feature
, "r2h", 6, 1, "upper", 32, "uint32");
25 tdesc_create_reg (feature
, "r2l", 7, 1, "lower", 32, "uint32");
26 tdesc_create_reg (feature
, "r3h", 8, 1, "upper", 32, "uint32");
27 tdesc_create_reg (feature
, "r3l", 9, 1, "lower", 32, "uint32");
28 tdesc_create_reg (feature
, "r4h", 10, 1, "upper", 32, "uint32");
29 tdesc_create_reg (feature
, "r4l", 11, 1, "lower", 32, "uint32");
30 tdesc_create_reg (feature
, "r5h", 12, 1, "upper", 32, "uint32");
31 tdesc_create_reg (feature
, "r5l", 13, 1, "lower", 32, "uint32");
32 tdesc_create_reg (feature
, "r6h", 14, 1, "upper", 32, "uint32");
33 tdesc_create_reg (feature
, "r6l", 15, 1, "lower", 32, "uint32");
34 tdesc_create_reg (feature
, "r7h", 16, 1, "upper", 32, "uint32");
35 tdesc_create_reg (feature
, "r7l", 17, 1, "lower", 32, "uint32");
36 tdesc_create_reg (feature
, "r8h", 18, 1, "upper", 32, "uint32");
37 tdesc_create_reg (feature
, "r8l", 19, 1, "lower", 32, "uint32");
38 tdesc_create_reg (feature
, "r9h", 20, 1, "upper", 32, "uint32");
39 tdesc_create_reg (feature
, "r9l", 21, 1, "lower", 32, "uint32");
40 tdesc_create_reg (feature
, "r10h", 22, 1, "upper", 32, "uint32");
41 tdesc_create_reg (feature
, "r10l", 23, 1, "lower", 32, "uint32");
42 tdesc_create_reg (feature
, "r11h", 24, 1, "upper", 32, "uint32");
43 tdesc_create_reg (feature
, "r11l", 25, 1, "lower", 32, "uint32");
44 tdesc_create_reg (feature
, "r12h", 26, 1, "upper", 32, "uint32");
45 tdesc_create_reg (feature
, "r12l", 27, 1, "lower", 32, "uint32");
46 tdesc_create_reg (feature
, "r13h", 28, 1, "upper", 32, "uint32");
47 tdesc_create_reg (feature
, "r13l", 29, 1, "lower", 32, "uint32");
48 tdesc_create_reg (feature
, "r14h", 30, 1, "upper", 32, "uint32");
49 tdesc_create_reg (feature
, "r14l", 31, 1, "lower", 32, "uint32");
50 tdesc_create_reg (feature
, "r15h", 32, 1, "upper", 32, "uint32");
51 tdesc_create_reg (feature
, "r15l", 33, 1, "lower", 32, "uint32");
53 feature
= tdesc_create_feature (result
.get (), "org.gnu.gdb.s390.acr");
54 tdesc_create_reg (feature
, "acr0", 34, 1, "access", 32, "uint32");
55 tdesc_create_reg (feature
, "acr1", 35, 1, "access", 32, "uint32");
56 tdesc_create_reg (feature
, "acr2", 36, 1, "access", 32, "uint32");
57 tdesc_create_reg (feature
, "acr3", 37, 1, "access", 32, "uint32");
58 tdesc_create_reg (feature
, "acr4", 38, 1, "access", 32, "uint32");
59 tdesc_create_reg (feature
, "acr5", 39, 1, "access", 32, "uint32");
60 tdesc_create_reg (feature
, "acr6", 40, 1, "access", 32, "uint32");
61 tdesc_create_reg (feature
, "acr7", 41, 1, "access", 32, "uint32");
62 tdesc_create_reg (feature
, "acr8", 42, 1, "access", 32, "uint32");
63 tdesc_create_reg (feature
, "acr9", 43, 1, "access", 32, "uint32");
64 tdesc_create_reg (feature
, "acr10", 44, 1, "access", 32, "uint32");
65 tdesc_create_reg (feature
, "acr11", 45, 1, "access", 32, "uint32");
66 tdesc_create_reg (feature
, "acr12", 46, 1, "access", 32, "uint32");
67 tdesc_create_reg (feature
, "acr13", 47, 1, "access", 32, "uint32");
68 tdesc_create_reg (feature
, "acr14", 48, 1, "access", 32, "uint32");
69 tdesc_create_reg (feature
, "acr15", 49, 1, "access", 32, "uint32");
71 feature
= tdesc_create_feature (result
.get (), "org.gnu.gdb.s390.fpr");
72 tdesc_create_reg (feature
, "fpc", 50, 1, "float", 32, "uint32");
73 tdesc_create_reg (feature
, "f0", 51, 1, "float", 64, "ieee_double");
74 tdesc_create_reg (feature
, "f1", 52, 1, "float", 64, "ieee_double");
75 tdesc_create_reg (feature
, "f2", 53, 1, "float", 64, "ieee_double");
76 tdesc_create_reg (feature
, "f3", 54, 1, "float", 64, "ieee_double");
77 tdesc_create_reg (feature
, "f4", 55, 1, "float", 64, "ieee_double");
78 tdesc_create_reg (feature
, "f5", 56, 1, "float", 64, "ieee_double");
79 tdesc_create_reg (feature
, "f6", 57, 1, "float", 64, "ieee_double");
80 tdesc_create_reg (feature
, "f7", 58, 1, "float", 64, "ieee_double");
81 tdesc_create_reg (feature
, "f8", 59, 1, "float", 64, "ieee_double");
82 tdesc_create_reg (feature
, "f9", 60, 1, "float", 64, "ieee_double");
83 tdesc_create_reg (feature
, "f10", 61, 1, "float", 64, "ieee_double");
84 tdesc_create_reg (feature
, "f11", 62, 1, "float", 64, "ieee_double");
85 tdesc_create_reg (feature
, "f12", 63, 1, "float", 64, "ieee_double");
86 tdesc_create_reg (feature
, "f13", 64, 1, "float", 64, "ieee_double");
87 tdesc_create_reg (feature
, "f14", 65, 1, "float", 64, "ieee_double");
88 tdesc_create_reg (feature
, "f15", 66, 1, "float", 64, "ieee_double");
90 feature
= tdesc_create_feature (result
.get (), "org.gnu.gdb.s390.linux");
91 tdesc_create_reg (feature
, "orig_r2", 67, 1, "system", 32, "uint32");
92 tdesc_create_reg (feature
, "last_break", 68, 0, "system", 32, "code_ptr");
93 tdesc_create_reg (feature
, "system_call", 69, 1, "system", 32, "uint32");
95 feature
= tdesc_create_feature (result
.get (), "org.gnu.gdb.s390.tdb");
96 tdesc_create_reg (feature
, "tdb0", 70, 1, "tdb", 64, "uint64");
97 tdesc_create_reg (feature
, "tac", 71, 1, "tdb", 64, "uint64");
98 tdesc_create_reg (feature
, "tct", 72, 1, "tdb", 64, "uint64");
99 tdesc_create_reg (feature
, "atia", 73, 1, "tdb", 64, "uint64");
100 tdesc_create_reg (feature
, "tr0", 74, 1, "tdb", 64, "uint64");
101 tdesc_create_reg (feature
, "tr1", 75, 1, "tdb", 64, "uint64");
102 tdesc_create_reg (feature
, "tr2", 76, 1, "tdb", 64, "uint64");
103 tdesc_create_reg (feature
, "tr3", 77, 1, "tdb", 64, "uint64");
104 tdesc_create_reg (feature
, "tr4", 78, 1, "tdb", 64, "uint64");
105 tdesc_create_reg (feature
, "tr5", 79, 1, "tdb", 64, "uint64");
106 tdesc_create_reg (feature
, "tr6", 80, 1, "tdb", 64, "uint64");
107 tdesc_create_reg (feature
, "tr7", 81, 1, "tdb", 64, "uint64");
108 tdesc_create_reg (feature
, "tr8", 82, 1, "tdb", 64, "uint64");
109 tdesc_create_reg (feature
, "tr9", 83, 1, "tdb", 64, "uint64");
110 tdesc_create_reg (feature
, "tr10", 84, 1, "tdb", 64, "uint64");
111 tdesc_create_reg (feature
, "tr11", 85, 1, "tdb", 64, "uint64");
112 tdesc_create_reg (feature
, "tr12", 86, 1, "tdb", 64, "uint64");
113 tdesc_create_reg (feature
, "tr13", 87, 1, "tdb", 64, "uint64");
114 tdesc_create_reg (feature
, "tr14", 88, 1, "tdb", 64, "uint64");
115 tdesc_create_reg (feature
, "tr15", 89, 1, "tdb", 64, "uint64");
117 feature
= tdesc_create_feature (result
.get (), "org.gnu.gdb.s390.vx");
118 tdesc_type
*element_type
;
119 element_type
= tdesc_named_type (feature
, "ieee_single");
120 tdesc_create_vector (feature
, "v4f", element_type
, 4);
122 element_type
= tdesc_named_type (feature
, "ieee_double");
123 tdesc_create_vector (feature
, "v2d", element_type
, 2);
125 element_type
= tdesc_named_type (feature
, "int8");
126 tdesc_create_vector (feature
, "v16i8", element_type
, 16);
128 element_type
= tdesc_named_type (feature
, "int16");
129 tdesc_create_vector (feature
, "v8i16", element_type
, 8);
131 element_type
= tdesc_named_type (feature
, "int32");
132 tdesc_create_vector (feature
, "v4i32", element_type
, 4);
134 element_type
= tdesc_named_type (feature
, "int64");
135 tdesc_create_vector (feature
, "v2i64", element_type
, 2);
137 tdesc_type_with_fields
*type_with_fields
;
138 type_with_fields
= tdesc_create_union (feature
, "vec128");
139 tdesc_type
*field_type
;
140 field_type
= tdesc_named_type (feature
, "v4f");
141 tdesc_add_field (type_with_fields
, "v4_float", field_type
);
142 field_type
= tdesc_named_type (feature
, "v2d");
143 tdesc_add_field (type_with_fields
, "v2_double", field_type
);
144 field_type
= tdesc_named_type (feature
, "v16i8");
145 tdesc_add_field (type_with_fields
, "v16_int8", field_type
);
146 field_type
= tdesc_named_type (feature
, "v8i16");
147 tdesc_add_field (type_with_fields
, "v8_int16", field_type
);
148 field_type
= tdesc_named_type (feature
, "v4i32");
149 tdesc_add_field (type_with_fields
, "v4_int32", field_type
);
150 field_type
= tdesc_named_type (feature
, "v2i64");
151 tdesc_add_field (type_with_fields
, "v2_int64", field_type
);
152 field_type
= tdesc_named_type (feature
, "uint128");
153 tdesc_add_field (type_with_fields
, "uint128", field_type
);
155 tdesc_create_reg (feature
, "v0l", 90, 1, NULL
, 64, "uint64");
156 tdesc_create_reg (feature
, "v1l", 91, 1, NULL
, 64, "uint64");
157 tdesc_create_reg (feature
, "v2l", 92, 1, NULL
, 64, "uint64");
158 tdesc_create_reg (feature
, "v3l", 93, 1, NULL
, 64, "uint64");
159 tdesc_create_reg (feature
, "v4l", 94, 1, NULL
, 64, "uint64");
160 tdesc_create_reg (feature
, "v5l", 95, 1, NULL
, 64, "uint64");
161 tdesc_create_reg (feature
, "v6l", 96, 1, NULL
, 64, "uint64");
162 tdesc_create_reg (feature
, "v7l", 97, 1, NULL
, 64, "uint64");
163 tdesc_create_reg (feature
, "v8l", 98, 1, NULL
, 64, "uint64");
164 tdesc_create_reg (feature
, "v9l", 99, 1, NULL
, 64, "uint64");
165 tdesc_create_reg (feature
, "v10l", 100, 1, NULL
, 64, "uint64");
166 tdesc_create_reg (feature
, "v11l", 101, 1, NULL
, 64, "uint64");
167 tdesc_create_reg (feature
, "v12l", 102, 1, NULL
, 64, "uint64");
168 tdesc_create_reg (feature
, "v13l", 103, 1, NULL
, 64, "uint64");
169 tdesc_create_reg (feature
, "v14l", 104, 1, NULL
, 64, "uint64");
170 tdesc_create_reg (feature
, "v15l", 105, 1, NULL
, 64, "uint64");
171 tdesc_create_reg (feature
, "v16", 106, 1, NULL
, 128, "vec128");
172 tdesc_create_reg (feature
, "v17", 107, 1, NULL
, 128, "vec128");
173 tdesc_create_reg (feature
, "v18", 108, 1, NULL
, 128, "vec128");
174 tdesc_create_reg (feature
, "v19", 109, 1, NULL
, 128, "vec128");
175 tdesc_create_reg (feature
, "v20", 110, 1, NULL
, 128, "vec128");
176 tdesc_create_reg (feature
, "v21", 111, 1, NULL
, 128, "vec128");
177 tdesc_create_reg (feature
, "v22", 112, 1, NULL
, 128, "vec128");
178 tdesc_create_reg (feature
, "v23", 113, 1, NULL
, 128, "vec128");
179 tdesc_create_reg (feature
, "v24", 114, 1, NULL
, 128, "vec128");
180 tdesc_create_reg (feature
, "v25", 115, 1, NULL
, 128, "vec128");
181 tdesc_create_reg (feature
, "v26", 116, 1, NULL
, 128, "vec128");
182 tdesc_create_reg (feature
, "v27", 117, 1, NULL
, 128, "vec128");
183 tdesc_create_reg (feature
, "v28", 118, 1, NULL
, 128, "vec128");
184 tdesc_create_reg (feature
, "v29", 119, 1, NULL
, 128, "vec128");
185 tdesc_create_reg (feature
, "v30", 120, 1, NULL
, 128, "vec128");
186 tdesc_create_reg (feature
, "v31", 121, 1, NULL
, 128, "vec128");
188 tdesc_s390_tevx_linux64
= result
.release ();