15 struct tdesc_feature *feature;
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");
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");
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");
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");
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");
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");