Add x86 AVX XML files.
[deliverable/binutils-gdb.git] / gdb / features / i386 / i386-avx.c
CommitLineData
98adf0f3
L
1/* THIS FILE IS GENERATED. Original: i386-avx.xml */
2
3#include "defs.h"
4#include "osabi.h"
5#include "target-descriptions.h"
6
7struct target_desc *tdesc_i386_avx;
8static void
9initialize_tdesc_i386_avx (void)
10{
11 struct target_desc *result = allocate_target_description ();
12 struct tdesc_feature *feature;
13 struct tdesc_type *field_type, *type;
14
15 set_tdesc_architecture (result, bfd_scan_arch ("i386"));
16
17 feature = tdesc_create_feature (result, "org.gnu.gdb.i386.core");
18 field_type = tdesc_create_flags (feature, "i386_eflags", 4);
19 tdesc_add_flag (field_type, 0, "CF");
20 tdesc_add_flag (field_type, 1, "");
21 tdesc_add_flag (field_type, 2, "PF");
22 tdesc_add_flag (field_type, 4, "AF");
23 tdesc_add_flag (field_type, 6, "ZF");
24 tdesc_add_flag (field_type, 7, "SF");
25 tdesc_add_flag (field_type, 8, "TF");
26 tdesc_add_flag (field_type, 9, "IF");
27 tdesc_add_flag (field_type, 10, "DF");
28 tdesc_add_flag (field_type, 11, "OF");
29 tdesc_add_flag (field_type, 14, "NT");
30 tdesc_add_flag (field_type, 16, "RF");
31 tdesc_add_flag (field_type, 17, "VM");
32 tdesc_add_flag (field_type, 18, "AC");
33 tdesc_add_flag (field_type, 19, "VIF");
34 tdesc_add_flag (field_type, 20, "VIP");
35 tdesc_add_flag (field_type, 21, "ID");
36
37 tdesc_create_reg (feature, "eax", 0, 1, NULL, 32, "int32");
38 tdesc_create_reg (feature, "ecx", 1, 1, NULL, 32, "int32");
39 tdesc_create_reg (feature, "edx", 2, 1, NULL, 32, "int32");
40 tdesc_create_reg (feature, "ebx", 3, 1, NULL, 32, "int32");
41 tdesc_create_reg (feature, "esp", 4, 1, NULL, 32, "data_ptr");
42 tdesc_create_reg (feature, "ebp", 5, 1, NULL, 32, "data_ptr");
43 tdesc_create_reg (feature, "esi", 6, 1, NULL, 32, "int32");
44 tdesc_create_reg (feature, "edi", 7, 1, NULL, 32, "int32");
45 tdesc_create_reg (feature, "eip", 8, 1, NULL, 32, "code_ptr");
46 tdesc_create_reg (feature, "eflags", 9, 1, NULL, 32, "i386_eflags");
47 tdesc_create_reg (feature, "cs", 10, 1, NULL, 32, "int32");
48 tdesc_create_reg (feature, "ss", 11, 1, NULL, 32, "int32");
49 tdesc_create_reg (feature, "ds", 12, 1, NULL, 32, "int32");
50 tdesc_create_reg (feature, "es", 13, 1, NULL, 32, "int32");
51 tdesc_create_reg (feature, "fs", 14, 1, NULL, 32, "int32");
52 tdesc_create_reg (feature, "gs", 15, 1, NULL, 32, "int32");
53 tdesc_create_reg (feature, "st0", 16, 1, NULL, 80, "i387_ext");
54 tdesc_create_reg (feature, "st1", 17, 1, NULL, 80, "i387_ext");
55 tdesc_create_reg (feature, "st2", 18, 1, NULL, 80, "i387_ext");
56 tdesc_create_reg (feature, "st3", 19, 1, NULL, 80, "i387_ext");
57 tdesc_create_reg (feature, "st4", 20, 1, NULL, 80, "i387_ext");
58 tdesc_create_reg (feature, "st5", 21, 1, NULL, 80, "i387_ext");
59 tdesc_create_reg (feature, "st6", 22, 1, NULL, 80, "i387_ext");
60 tdesc_create_reg (feature, "st7", 23, 1, NULL, 80, "i387_ext");
61 tdesc_create_reg (feature, "fctrl", 24, 1, "float", 32, "int");
62 tdesc_create_reg (feature, "fstat", 25, 1, "float", 32, "int");
63 tdesc_create_reg (feature, "ftag", 26, 1, "float", 32, "int");
64 tdesc_create_reg (feature, "fiseg", 27, 1, "float", 32, "int");
65 tdesc_create_reg (feature, "fioff", 28, 1, "float", 32, "int");
66 tdesc_create_reg (feature, "foseg", 29, 1, "float", 32, "int");
67 tdesc_create_reg (feature, "fooff", 30, 1, "float", 32, "int");
68 tdesc_create_reg (feature, "fop", 31, 1, "float", 32, "int");
69
70 feature = tdesc_create_feature (result, "org.gnu.gdb.i386.sse");
71 field_type = tdesc_named_type (feature, "ieee_single");
72 tdesc_create_vector (feature, "v4f", field_type, 4);
73
74 field_type = tdesc_named_type (feature, "ieee_double");
75 tdesc_create_vector (feature, "v2d", field_type, 2);
76
77 field_type = tdesc_named_type (feature, "int8");
78 tdesc_create_vector (feature, "v16i8", field_type, 16);
79
80 field_type = tdesc_named_type (feature, "int16");
81 tdesc_create_vector (feature, "v8i16", field_type, 8);
82
83 field_type = tdesc_named_type (feature, "int32");
84 tdesc_create_vector (feature, "v4i32", field_type, 4);
85
86 field_type = tdesc_named_type (feature, "int64");
87 tdesc_create_vector (feature, "v2i64", field_type, 2);
88
89 type = tdesc_create_union (feature, "vec128");
90 field_type = tdesc_named_type (feature, "v4f");
91 tdesc_add_field (type, "v4_float", field_type);
92 field_type = tdesc_named_type (feature, "v2d");
93 tdesc_add_field (type, "v2_double", field_type);
94 field_type = tdesc_named_type (feature, "v16i8");
95 tdesc_add_field (type, "v16_int8", field_type);
96 field_type = tdesc_named_type (feature, "v8i16");
97 tdesc_add_field (type, "v8_int16", field_type);
98 field_type = tdesc_named_type (feature, "v4i32");
99 tdesc_add_field (type, "v4_int32", field_type);
100 field_type = tdesc_named_type (feature, "v2i64");
101 tdesc_add_field (type, "v2_int64", field_type);
102 field_type = tdesc_named_type (feature, "uint128");
103 tdesc_add_field (type, "uint128", field_type);
104
105 field_type = tdesc_create_flags (feature, "i386_mxcsr", 4);
106 tdesc_add_flag (field_type, 0, "IE");
107 tdesc_add_flag (field_type, 1, "DE");
108 tdesc_add_flag (field_type, 2, "ZE");
109 tdesc_add_flag (field_type, 3, "OE");
110 tdesc_add_flag (field_type, 4, "UE");
111 tdesc_add_flag (field_type, 5, "PE");
112 tdesc_add_flag (field_type, 6, "DAZ");
113 tdesc_add_flag (field_type, 7, "IM");
114 tdesc_add_flag (field_type, 8, "DM");
115 tdesc_add_flag (field_type, 9, "ZM");
116 tdesc_add_flag (field_type, 10, "OM");
117 tdesc_add_flag (field_type, 11, "UM");
118 tdesc_add_flag (field_type, 12, "PM");
119 tdesc_add_flag (field_type, 15, "FZ");
120
121 tdesc_create_reg (feature, "xmm0", 32, 1, NULL, 128, "vec128");
122 tdesc_create_reg (feature, "xmm1", 33, 1, NULL, 128, "vec128");
123 tdesc_create_reg (feature, "xmm2", 34, 1, NULL, 128, "vec128");
124 tdesc_create_reg (feature, "xmm3", 35, 1, NULL, 128, "vec128");
125 tdesc_create_reg (feature, "xmm4", 36, 1, NULL, 128, "vec128");
126 tdesc_create_reg (feature, "xmm5", 37, 1, NULL, 128, "vec128");
127 tdesc_create_reg (feature, "xmm6", 38, 1, NULL, 128, "vec128");
128 tdesc_create_reg (feature, "xmm7", 39, 1, NULL, 128, "vec128");
129 tdesc_create_reg (feature, "mxcsr", 40, 1, "vector", 32, "i386_mxcsr");
130
131 feature = tdesc_create_feature (result, "org.gnu.gdb.i386.avx");
132 tdesc_create_reg (feature, "ymm0h", 41, 1, NULL, 128, "uint128");
133 tdesc_create_reg (feature, "ymm1h", 42, 1, NULL, 128, "uint128");
134 tdesc_create_reg (feature, "ymm2h", 43, 1, NULL, 128, "uint128");
135 tdesc_create_reg (feature, "ymm3h", 44, 1, NULL, 128, "uint128");
136 tdesc_create_reg (feature, "ymm4h", 45, 1, NULL, 128, "uint128");
137 tdesc_create_reg (feature, "ymm5h", 46, 1, NULL, 128, "uint128");
138 tdesc_create_reg (feature, "ymm6h", 47, 1, NULL, 128, "uint128");
139 tdesc_create_reg (feature, "ymm7h", 48, 1, NULL, 128, "uint128");
140
141 tdesc_i386_avx = result;
142}
This page took 0.041427 seconds and 4 git commands to generate.