Split rank_one_type_parm_complex from rank_one_type
[deliverable/binutils-gdb.git] / gdb / features / aarch64-sve.c
CommitLineData
42a4f53d 1/* Copyright (C) 2018-2019 Free Software Foundation, Inc.
95228a0d
AH
2
3 This file is part of GDB.
4
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 3 of the License, or
8 (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with this program. If not, see <http://www.gnu.org/licenses/>. */
17
18#include "common/tdesc.h"
19
20/* This function is NOT auto generated from xml. Create the aarch64 with SVE
21 feature into RESULT, where SCALE is the number of 128 bit chunks in a Z
22 register. */
23
24static int
25create_feature_aarch64_sve (struct target_desc *result, long regnum,
39bfb937 26 uint64_t scale)
95228a0d
AH
27{
28 struct tdesc_feature *feature;
29 tdesc_type *element_type, *field_type;
30 tdesc_type_with_fields *type_with_fields;
31
32 feature = tdesc_create_feature (result, "org.gnu.gdb.aarch64.sve");
33
34 element_type = tdesc_named_type (feature, "ieee_double");
35 tdesc_create_vector (feature, "svevdf", element_type, 2 * scale);
36
37 element_type = tdesc_named_type (feature, "uint64");
38 tdesc_create_vector (feature, "svevdu", element_type, 2 * scale);
39
40 element_type = tdesc_named_type (feature, "int64");
41 tdesc_create_vector (feature, "svevds", element_type, 2 * scale);
42
43 element_type = tdesc_named_type (feature, "ieee_single");
44 tdesc_create_vector (feature, "svevsf", element_type, 4 * scale);
45
46 element_type = tdesc_named_type (feature, "uint32");
47 tdesc_create_vector (feature, "svevsu", element_type, 4 * scale);
48
49 element_type = tdesc_named_type (feature, "int32");
50 tdesc_create_vector (feature, "svevss", element_type, 4 * scale);
51
52 element_type = tdesc_named_type (feature, "uint16");
53 tdesc_create_vector (feature, "svevhu", element_type, 8 * scale);
54
55 element_type = tdesc_named_type (feature, "int16");
56 tdesc_create_vector (feature, "svevhs", element_type, 8 * scale);
57
58 element_type = tdesc_named_type (feature, "uint8");
59 tdesc_create_vector (feature, "svevbu", element_type, 16 * scale);
60
61 element_type = tdesc_named_type (feature, "int8");
62 tdesc_create_vector (feature, "svevbs", element_type, 16 * scale);
63
64 type_with_fields = tdesc_create_union (feature, "svevnd");
65 field_type = tdesc_named_type (feature, "svevdf");
66 tdesc_add_field (type_with_fields, "f", field_type);
67 field_type = tdesc_named_type (feature, "svevdu");
68 tdesc_add_field (type_with_fields, "u", field_type);
69 field_type = tdesc_named_type (feature, "svevds");
70 tdesc_add_field (type_with_fields, "s", field_type);
71
72 type_with_fields = tdesc_create_union (feature, "svevns");
73 field_type = tdesc_named_type (feature, "svevsf");
74 tdesc_add_field (type_with_fields, "f", field_type);
75 field_type = tdesc_named_type (feature, "svevsu");
76 tdesc_add_field (type_with_fields, "u", field_type);
77 field_type = tdesc_named_type (feature, "svevss");
78 tdesc_add_field (type_with_fields, "s", field_type);
79
80 type_with_fields = tdesc_create_union (feature, "svevnh");
81 field_type = tdesc_named_type (feature, "svevhu");
82 tdesc_add_field (type_with_fields, "u", field_type);
83 field_type = tdesc_named_type (feature, "svevhs");
84 tdesc_add_field (type_with_fields, "s", field_type);
85
86 type_with_fields = tdesc_create_union (feature, "svevnb");
87 field_type = tdesc_named_type (feature, "svevbu");
88 tdesc_add_field (type_with_fields, "u", field_type);
89 field_type = tdesc_named_type (feature, "svevbs");
90 tdesc_add_field (type_with_fields, "s", field_type);
91
92 type_with_fields = tdesc_create_union (feature, "svev");
93 field_type = tdesc_named_type (feature, "svevnd");
94 tdesc_add_field (type_with_fields, "d", field_type);
95 field_type = tdesc_named_type (feature, "svevns");
96 tdesc_add_field (type_with_fields, "s", field_type);
97 field_type = tdesc_named_type (feature, "svevnh");
98 tdesc_add_field (type_with_fields, "h", field_type);
99 field_type = tdesc_named_type (feature, "svevnb");
100 tdesc_add_field (type_with_fields, "b", field_type);
101
102 field_type = tdesc_named_type (feature, "uint8");
103 tdesc_create_vector (feature, "svep", field_type, 2 * scale);
104
105 tdesc_create_reg (feature, "z0", regnum++, 1, NULL, 128 * scale, "svev");
106 tdesc_create_reg (feature, "z1", regnum++, 1, NULL, 128 * scale, "svev");
107 tdesc_create_reg (feature, "z2", regnum++, 1, NULL, 128 * scale, "svev");
108 tdesc_create_reg (feature, "z3", regnum++, 1, NULL, 128 * scale, "svev");
109 tdesc_create_reg (feature, "z4", regnum++, 1, NULL, 128 * scale, "svev");
110 tdesc_create_reg (feature, "z5", regnum++, 1, NULL, 128 * scale, "svev");
111 tdesc_create_reg (feature, "z6", regnum++, 1, NULL, 128 * scale, "svev");
112 tdesc_create_reg (feature, "z7", regnum++, 1, NULL, 128 * scale, "svev");
113 tdesc_create_reg (feature, "z8", regnum++, 1, NULL, 128 * scale, "svev");
114 tdesc_create_reg (feature, "z9", regnum++, 1, NULL, 128 * scale, "svev");
115 tdesc_create_reg (feature, "z10", regnum++, 1, NULL, 128 * scale, "svev");
116 tdesc_create_reg (feature, "z11", regnum++, 1, NULL, 128 * scale, "svev");
117 tdesc_create_reg (feature, "z12", regnum++, 1, NULL, 128 * scale, "svev");
118 tdesc_create_reg (feature, "z13", regnum++, 1, NULL, 128 * scale, "svev");
119 tdesc_create_reg (feature, "z14", regnum++, 1, NULL, 128 * scale, "svev");
120 tdesc_create_reg (feature, "z15", regnum++, 1, NULL, 128 * scale, "svev");
121 tdesc_create_reg (feature, "z16", regnum++, 1, NULL, 128 * scale, "svev");
122 tdesc_create_reg (feature, "z17", regnum++, 1, NULL, 128 * scale, "svev");
123 tdesc_create_reg (feature, "z18", regnum++, 1, NULL, 128 * scale, "svev");
124 tdesc_create_reg (feature, "z19", regnum++, 1, NULL, 128 * scale, "svev");
125 tdesc_create_reg (feature, "z20", regnum++, 1, NULL, 128 * scale, "svev");
126 tdesc_create_reg (feature, "z21", regnum++, 1, NULL, 128 * scale, "svev");
127 tdesc_create_reg (feature, "z22", regnum++, 1, NULL, 128 * scale, "svev");
128 tdesc_create_reg (feature, "z23", regnum++, 1, NULL, 128 * scale, "svev");
129 tdesc_create_reg (feature, "z24", regnum++, 1, NULL, 128 * scale, "svev");
130 tdesc_create_reg (feature, "z25", regnum++, 1, NULL, 128 * scale, "svev");
131 tdesc_create_reg (feature, "z26", regnum++, 1, NULL, 128 * scale, "svev");
132 tdesc_create_reg (feature, "z27", regnum++, 1, NULL, 128 * scale, "svev");
133 tdesc_create_reg (feature, "z28", regnum++, 1, NULL, 128 * scale, "svev");
134 tdesc_create_reg (feature, "z29", regnum++, 1, NULL, 128 * scale, "svev");
135 tdesc_create_reg (feature, "z30", regnum++, 1, NULL, 128 * scale, "svev");
136 tdesc_create_reg (feature, "z31", regnum++, 1, NULL, 128 * scale, "svev");
137 tdesc_create_reg (feature, "fpsr", regnum++, 1, NULL, 32, "int");
138 tdesc_create_reg (feature, "fpcr", regnum++, 1, NULL, 32, "int");
139 tdesc_create_reg (feature, "p0", regnum++, 1, NULL, 16 * scale, "svep");
140 tdesc_create_reg (feature, "p1", regnum++, 1, NULL, 16 * scale, "svep");
141 tdesc_create_reg (feature, "p2", regnum++, 1, NULL, 16 * scale, "svep");
142 tdesc_create_reg (feature, "p3", regnum++, 1, NULL, 16 * scale, "svep");
143 tdesc_create_reg (feature, "p4", regnum++, 1, NULL, 16 * scale, "svep");
144 tdesc_create_reg (feature, "p5", regnum++, 1, NULL, 16 * scale, "svep");
145 tdesc_create_reg (feature, "p6", regnum++, 1, NULL, 16 * scale, "svep");
146 tdesc_create_reg (feature, "p7", regnum++, 1, NULL, 16 * scale, "svep");
147 tdesc_create_reg (feature, "p8", regnum++, 1, NULL, 16 * scale, "svep");
148 tdesc_create_reg (feature, "p9", regnum++, 1, NULL, 16 * scale, "svep");
149 tdesc_create_reg (feature, "p10", regnum++, 1, NULL, 16 * scale, "svep");
150 tdesc_create_reg (feature, "p11", regnum++, 1, NULL, 16 * scale, "svep");
151 tdesc_create_reg (feature, "p12", regnum++, 1, NULL, 16 * scale, "svep");
152 tdesc_create_reg (feature, "p13", regnum++, 1, NULL, 16 * scale, "svep");
153 tdesc_create_reg (feature, "p14", regnum++, 1, NULL, 16 * scale, "svep");
154 tdesc_create_reg (feature, "p15", regnum++, 1, NULL, 16 * scale, "svep");
155 tdesc_create_reg (feature, "ffr", regnum++, 1, NULL, 16 * scale, "svep");
156 tdesc_create_reg (feature, "vg", regnum++, 1, NULL, 64, "int");
157 return regnum;
158}
This page took 0.084836 seconds and 4 git commands to generate.