annotate gcc/tree-core.h @ 136:4627f235cf2a

fix c-next example
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Thu, 08 Nov 2018 14:11:56 +0900
parents 84e7813d76e9
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Core data structures for the 'tree' type.
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
2 Copyright (C) 1989-2018 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 This file is part of GCC.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 GCC is free software; you can redistribute it and/or modify it under
kono
parents:
diff changeset
7 the terms of the GNU General Public License as published by the Free
kono
parents:
diff changeset
8 Software Foundation; either version 3, or (at your option) any later
kono
parents:
diff changeset
9 version.
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
kono
parents:
diff changeset
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
kono
parents:
diff changeset
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
kono
parents:
diff changeset
14 for more details.
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
17 along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
18 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 #ifndef GCC_TREE_CORE_H
kono
parents:
diff changeset
21 #define GCC_TREE_CORE_H
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 #include "symtab.h"
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 /* This file contains all the data structures that define the 'tree' type.
kono
parents:
diff changeset
26 There are no accessor macros nor functions in this file. Only the
kono
parents:
diff changeset
27 basic data structures, extern declarations and type definitions. */
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 /*---------------------------------------------------------------------------
kono
parents:
diff changeset
30 Forward type declarations. Mostly to avoid including unnecessary headers
kono
parents:
diff changeset
31 ---------------------------------------------------------------------------*/
kono
parents:
diff changeset
32 struct function;
kono
parents:
diff changeset
33 struct real_value;
kono
parents:
diff changeset
34 struct fixed_value;
kono
parents:
diff changeset
35 struct ptr_info_def;
kono
parents:
diff changeset
36 struct range_info_def;
kono
parents:
diff changeset
37 struct die_struct;
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 /*---------------------------------------------------------------------------
kono
parents:
diff changeset
41 #defined constants
kono
parents:
diff changeset
42 ---------------------------------------------------------------------------*/
kono
parents:
diff changeset
43 /* Nonzero if this is a call to a function whose return value depends
kono
parents:
diff changeset
44 solely on its arguments, has no side effects, and does not read
kono
parents:
diff changeset
45 global memory. This corresponds to TREE_READONLY for function
kono
parents:
diff changeset
46 decls. */
kono
parents:
diff changeset
47 #define ECF_CONST (1 << 0)
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 /* Nonzero if this is a call to "pure" function (like const function,
kono
parents:
diff changeset
50 but may read memory. This corresponds to DECL_PURE_P for function
kono
parents:
diff changeset
51 decls. */
kono
parents:
diff changeset
52 #define ECF_PURE (1 << 1)
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 /* Nonzero if this is ECF_CONST or ECF_PURE but cannot be proven to no
kono
parents:
diff changeset
55 infinite loop. This corresponds to DECL_LOOPING_CONST_OR_PURE_P
kono
parents:
diff changeset
56 for function decls.*/
kono
parents:
diff changeset
57 #define ECF_LOOPING_CONST_OR_PURE (1 << 2)
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 /* Nonzero if this call will never return. */
kono
parents:
diff changeset
60 #define ECF_NORETURN (1 << 3)
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 /* Nonzero if this is a call to malloc or a related function. */
kono
parents:
diff changeset
63 #define ECF_MALLOC (1 << 4)
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 /* Nonzero if it is plausible that this is a call to alloca. */
kono
parents:
diff changeset
66 #define ECF_MAY_BE_ALLOCA (1 << 5)
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 /* Nonzero if this is a call to a function that won't throw an exception. */
kono
parents:
diff changeset
69 #define ECF_NOTHROW (1 << 6)
kono
parents:
diff changeset
70
kono
parents:
diff changeset
71 /* Nonzero if this is a call to setjmp or a related function. */
kono
parents:
diff changeset
72 #define ECF_RETURNS_TWICE (1 << 7)
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 /* Nonzero if this call replaces the current stack frame. */
kono
parents:
diff changeset
75 #define ECF_SIBCALL (1 << 8)
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 /* Function does not read or write memory (but may have side effects, so
kono
parents:
diff changeset
78 it does not necessarily fit ECF_CONST). */
kono
parents:
diff changeset
79 #define ECF_NOVOPS (1 << 9)
kono
parents:
diff changeset
80
kono
parents:
diff changeset
81 /* The function does not lead to calls within current function unit. */
kono
parents:
diff changeset
82 #define ECF_LEAF (1 << 10)
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 /* Nonzero if this call returns its first argument. */
kono
parents:
diff changeset
85 #define ECF_RET1 (1 << 11)
kono
parents:
diff changeset
86
kono
parents:
diff changeset
87 /* Nonzero if this call does not affect transactions. */
kono
parents:
diff changeset
88 #define ECF_TM_PURE (1 << 12)
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 /* Nonzero if this call is into the transaction runtime library. */
kono
parents:
diff changeset
91 #define ECF_TM_BUILTIN (1 << 13)
kono
parents:
diff changeset
92
kono
parents:
diff changeset
93 /* Nonzero if this is an indirect call by descriptor. */
kono
parents:
diff changeset
94 #define ECF_BY_DESCRIPTOR (1 << 14)
kono
parents:
diff changeset
95
kono
parents:
diff changeset
96 /* Nonzero if this is a cold function. */
kono
parents:
diff changeset
97 #define ECF_COLD (1 << 15)
kono
parents:
diff changeset
98
kono
parents:
diff changeset
99 /* Call argument flags. */
kono
parents:
diff changeset
100 /* Nonzero if the argument is not dereferenced recursively, thus only
kono
parents:
diff changeset
101 directly reachable memory is read or written. */
kono
parents:
diff changeset
102 #define EAF_DIRECT (1 << 0)
kono
parents:
diff changeset
103
kono
parents:
diff changeset
104 /* Nonzero if memory reached by the argument is not clobbered. */
kono
parents:
diff changeset
105 #define EAF_NOCLOBBER (1 << 1)
kono
parents:
diff changeset
106
kono
parents:
diff changeset
107 /* Nonzero if the argument does not escape. */
kono
parents:
diff changeset
108 #define EAF_NOESCAPE (1 << 2)
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 /* Nonzero if the argument is not used by the function. */
kono
parents:
diff changeset
111 #define EAF_UNUSED (1 << 3)
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 /* Call return flags. */
kono
parents:
diff changeset
114 /* Mask for the argument number that is returned. Lower two bits of
kono
parents:
diff changeset
115 the return flags, encodes argument slots zero to three. */
kono
parents:
diff changeset
116 #define ERF_RETURN_ARG_MASK (3)
kono
parents:
diff changeset
117
kono
parents:
diff changeset
118 /* Nonzero if the return value is equal to the argument number
kono
parents:
diff changeset
119 flags & ERF_RETURN_ARG_MASK. */
kono
parents:
diff changeset
120 #define ERF_RETURNS_ARG (1 << 2)
kono
parents:
diff changeset
121
kono
parents:
diff changeset
122 /* Nonzero if the return value does not alias with anything. Functions
kono
parents:
diff changeset
123 with the malloc attribute have this set on their return value. */
kono
parents:
diff changeset
124 #define ERF_NOALIAS (1 << 3)
kono
parents:
diff changeset
125
kono
parents:
diff changeset
126
kono
parents:
diff changeset
127 /*---------------------------------------------------------------------------
kono
parents:
diff changeset
128 Enumerations
kono
parents:
diff changeset
129 ---------------------------------------------------------------------------*/
kono
parents:
diff changeset
130 /* Codes of tree nodes. */
kono
parents:
diff changeset
131 #define DEFTREECODE(SYM, STRING, TYPE, NARGS) SYM,
kono
parents:
diff changeset
132 #define END_OF_BASE_TREE_CODES LAST_AND_UNUSED_TREE_CODE,
kono
parents:
diff changeset
133
kono
parents:
diff changeset
134 enum tree_code {
kono
parents:
diff changeset
135 #include "all-tree.def"
kono
parents:
diff changeset
136 MAX_TREE_CODES
kono
parents:
diff changeset
137 };
kono
parents:
diff changeset
138
kono
parents:
diff changeset
139 #undef DEFTREECODE
kono
parents:
diff changeset
140 #undef END_OF_BASE_TREE_CODES
kono
parents:
diff changeset
141
kono
parents:
diff changeset
142 /* Number of language-independent tree codes. */
kono
parents:
diff changeset
143 #define NUM_TREE_CODES \
kono
parents:
diff changeset
144 ((int) LAST_AND_UNUSED_TREE_CODE)
kono
parents:
diff changeset
145
kono
parents:
diff changeset
146 #define CODE_CONTAINS_STRUCT(CODE, STRUCT) \
kono
parents:
diff changeset
147 (tree_contains_struct[(CODE)][(STRUCT)])
kono
parents:
diff changeset
148
kono
parents:
diff changeset
149
kono
parents:
diff changeset
150 /* Classify which part of the compiler has defined a given builtin function.
kono
parents:
diff changeset
151 Note that we assume below that this is no more than two bits. */
kono
parents:
diff changeset
152 enum built_in_class {
kono
parents:
diff changeset
153 NOT_BUILT_IN = 0,
kono
parents:
diff changeset
154 BUILT_IN_FRONTEND,
kono
parents:
diff changeset
155 BUILT_IN_MD,
kono
parents:
diff changeset
156 BUILT_IN_NORMAL
kono
parents:
diff changeset
157 };
kono
parents:
diff changeset
158
kono
parents:
diff changeset
159 /* Last marker used for LTO stremaing of built_in_class. We can not add it
kono
parents:
diff changeset
160 to the enum since we need the enumb to fit in 2 bits. */
kono
parents:
diff changeset
161 #define BUILT_IN_LAST (BUILT_IN_NORMAL + 1)
kono
parents:
diff changeset
162
kono
parents:
diff changeset
163 /* Codes that identify the various built in functions
kono
parents:
diff changeset
164 so that expand_call can identify them quickly. */
kono
parents:
diff changeset
165 #define DEF_BUILTIN(ENUM, N, C, T, LT, B, F, NA, AT, IM, COND) ENUM,
kono
parents:
diff changeset
166 enum built_in_function {
kono
parents:
diff changeset
167 #include "builtins.def"
kono
parents:
diff changeset
168 /* Complex division routines in libgcc. These are done via builtins
kono
parents:
diff changeset
169 because emit_library_call_value can't handle complex values. */
kono
parents:
diff changeset
170 BUILT_IN_COMPLEX_MUL_MIN,
kono
parents:
diff changeset
171 BUILT_IN_COMPLEX_MUL_MAX
kono
parents:
diff changeset
172 = BUILT_IN_COMPLEX_MUL_MIN
kono
parents:
diff changeset
173 + MAX_MODE_COMPLEX_FLOAT
kono
parents:
diff changeset
174 - MIN_MODE_COMPLEX_FLOAT,
kono
parents:
diff changeset
175
kono
parents:
diff changeset
176 BUILT_IN_COMPLEX_DIV_MIN,
kono
parents:
diff changeset
177 BUILT_IN_COMPLEX_DIV_MAX
kono
parents:
diff changeset
178 = BUILT_IN_COMPLEX_DIV_MIN
kono
parents:
diff changeset
179 + MAX_MODE_COMPLEX_FLOAT
kono
parents:
diff changeset
180 - MIN_MODE_COMPLEX_FLOAT,
kono
parents:
diff changeset
181
kono
parents:
diff changeset
182 /* Upper bound on non-language-specific builtins. */
kono
parents:
diff changeset
183 END_BUILTINS
kono
parents:
diff changeset
184 };
kono
parents:
diff changeset
185
kono
parents:
diff changeset
186 /* Internal functions. */
kono
parents:
diff changeset
187 enum internal_fn {
kono
parents:
diff changeset
188 #define DEF_INTERNAL_FN(CODE, FLAGS, FNSPEC) IFN_##CODE,
kono
parents:
diff changeset
189 #include "internal-fn.def"
kono
parents:
diff changeset
190 IFN_LAST
kono
parents:
diff changeset
191 };
kono
parents:
diff changeset
192
kono
parents:
diff changeset
193 /* An enum that combines target-independent built-in functions with
kono
parents:
diff changeset
194 internal functions, so that they can be treated in a similar way.
kono
parents:
diff changeset
195 The numbers for built-in functions are the same as for the
kono
parents:
diff changeset
196 built_in_function enum. The numbers for internal functions
kono
parents:
diff changeset
197 start at END_BUITLINS. */
kono
parents:
diff changeset
198 enum combined_fn {
kono
parents:
diff changeset
199 #define DEF_BUILTIN(ENUM, N, C, T, LT, B, F, NA, AT, IM, COND) \
kono
parents:
diff changeset
200 CFN_##ENUM = int (ENUM),
kono
parents:
diff changeset
201 #include "builtins.def"
kono
parents:
diff changeset
202
kono
parents:
diff changeset
203
kono
parents:
diff changeset
204 #define DEF_INTERNAL_FN(CODE, FLAGS, FNSPEC) \
kono
parents:
diff changeset
205 CFN_##CODE = int (END_BUILTINS) + int (IFN_##CODE),
kono
parents:
diff changeset
206 #include "internal-fn.def"
kono
parents:
diff changeset
207
kono
parents:
diff changeset
208 CFN_LAST
kono
parents:
diff changeset
209 };
kono
parents:
diff changeset
210
kono
parents:
diff changeset
211 /* Tree code classes. Each tree_code has an associated code class
kono
parents:
diff changeset
212 represented by a TREE_CODE_CLASS. */
kono
parents:
diff changeset
213 enum tree_code_class {
kono
parents:
diff changeset
214 tcc_exceptional, /* An exceptional code (fits no category). */
kono
parents:
diff changeset
215 tcc_constant, /* A constant. */
kono
parents:
diff changeset
216 /* Order of tcc_type and tcc_declaration is important. */
kono
parents:
diff changeset
217 tcc_type, /* A type object code. */
kono
parents:
diff changeset
218 tcc_declaration, /* A declaration (also serving as variable refs). */
kono
parents:
diff changeset
219 tcc_reference, /* A reference to storage. */
kono
parents:
diff changeset
220 tcc_comparison, /* A comparison expression. */
kono
parents:
diff changeset
221 tcc_unary, /* A unary arithmetic expression. */
kono
parents:
diff changeset
222 tcc_binary, /* A binary arithmetic expression. */
kono
parents:
diff changeset
223 tcc_statement, /* A statement expression, which have side effects
kono
parents:
diff changeset
224 but usually no interesting value. */
kono
parents:
diff changeset
225 tcc_vl_exp, /* A function call or other expression with a
kono
parents:
diff changeset
226 variable-length operand vector. */
kono
parents:
diff changeset
227 tcc_expression /* Any other expression. */
kono
parents:
diff changeset
228 };
kono
parents:
diff changeset
229
kono
parents:
diff changeset
230 /* OMP_CLAUSE codes. Do not reorder, as this is used to index into
kono
parents:
diff changeset
231 the tables omp_clause_num_ops and omp_clause_code_name. */
kono
parents:
diff changeset
232 enum omp_clause_code {
kono
parents:
diff changeset
233 /* Clause zero is special-cased inside the parser
kono
parents:
diff changeset
234 (c_parser_omp_variable_list). */
kono
parents:
diff changeset
235 OMP_CLAUSE_ERROR = 0,
kono
parents:
diff changeset
236
kono
parents:
diff changeset
237 /* OpenACC/OpenMP clause: private (variable_list). */
kono
parents:
diff changeset
238 OMP_CLAUSE_PRIVATE,
kono
parents:
diff changeset
239
kono
parents:
diff changeset
240 /* OpenMP clause: shared (variable_list). */
kono
parents:
diff changeset
241 OMP_CLAUSE_SHARED,
kono
parents:
diff changeset
242
kono
parents:
diff changeset
243 /* OpenACC/OpenMP clause: firstprivate (variable_list). */
kono
parents:
diff changeset
244 OMP_CLAUSE_FIRSTPRIVATE,
kono
parents:
diff changeset
245
kono
parents:
diff changeset
246 /* OpenMP clause: lastprivate (variable_list). */
kono
parents:
diff changeset
247 OMP_CLAUSE_LASTPRIVATE,
kono
parents:
diff changeset
248
kono
parents:
diff changeset
249 /* OpenACC/OpenMP clause: reduction (operator:variable_list).
kono
parents:
diff changeset
250 OMP_CLAUSE_REDUCTION_CODE: The tree_code of the operator.
kono
parents:
diff changeset
251 Operand 1: OMP_CLAUSE_REDUCTION_INIT: Stmt-list to initialize the var.
kono
parents:
diff changeset
252 Operand 2: OMP_CLAUSE_REDUCTION_MERGE: Stmt-list to merge private var
kono
parents:
diff changeset
253 into the shared one.
kono
parents:
diff changeset
254 Operand 3: OMP_CLAUSE_REDUCTION_PLACEHOLDER: A dummy VAR_DECL
kono
parents:
diff changeset
255 placeholder used in OMP_CLAUSE_REDUCTION_{INIT,MERGE}.
kono
parents:
diff changeset
256 Operand 4: OMP_CLAUSE_REDUCTION_DECL_PLACEHOLDER: Another dummy
kono
parents:
diff changeset
257 VAR_DECL placeholder, used like the above for C/C++ array
kono
parents:
diff changeset
258 reductions. */
kono
parents:
diff changeset
259 OMP_CLAUSE_REDUCTION,
kono
parents:
diff changeset
260
kono
parents:
diff changeset
261 /* OpenMP clause: copyin (variable_list). */
kono
parents:
diff changeset
262 OMP_CLAUSE_COPYIN,
kono
parents:
diff changeset
263
kono
parents:
diff changeset
264 /* OpenMP clause: copyprivate (variable_list). */
kono
parents:
diff changeset
265 OMP_CLAUSE_COPYPRIVATE,
kono
parents:
diff changeset
266
kono
parents:
diff changeset
267 /* OpenMP clause: linear (variable-list[:linear-step]). */
kono
parents:
diff changeset
268 OMP_CLAUSE_LINEAR,
kono
parents:
diff changeset
269
kono
parents:
diff changeset
270 /* OpenMP clause: aligned (variable-list[:alignment]). */
kono
parents:
diff changeset
271 OMP_CLAUSE_ALIGNED,
kono
parents:
diff changeset
272
kono
parents:
diff changeset
273 /* OpenMP clause: depend ({in,out,inout}:variable-list). */
kono
parents:
diff changeset
274 OMP_CLAUSE_DEPEND,
kono
parents:
diff changeset
275
kono
parents:
diff changeset
276 /* OpenMP clause: uniform (argument-list). */
kono
parents:
diff changeset
277 OMP_CLAUSE_UNIFORM,
kono
parents:
diff changeset
278
kono
parents:
diff changeset
279 /* OpenMP clause: to (extended-list).
kono
parents:
diff changeset
280 Only when it appears in declare target. */
kono
parents:
diff changeset
281 OMP_CLAUSE_TO_DECLARE,
kono
parents:
diff changeset
282
kono
parents:
diff changeset
283 /* OpenMP clause: link (variable-list). */
kono
parents:
diff changeset
284 OMP_CLAUSE_LINK,
kono
parents:
diff changeset
285
kono
parents:
diff changeset
286 /* OpenMP clause: from (variable-list). */
kono
parents:
diff changeset
287 OMP_CLAUSE_FROM,
kono
parents:
diff changeset
288
kono
parents:
diff changeset
289 /* OpenMP clause: to (variable-list). */
kono
parents:
diff changeset
290 OMP_CLAUSE_TO,
kono
parents:
diff changeset
291
kono
parents:
diff changeset
292 /* OpenACC clauses: {copy, copyin, copyout, create, delete, deviceptr,
kono
parents:
diff changeset
293 device, host (self), present, present_or_copy (pcopy), present_or_copyin
kono
parents:
diff changeset
294 (pcopyin), present_or_copyout (pcopyout), present_or_create (pcreate)}
kono
parents:
diff changeset
295 (variable-list).
kono
parents:
diff changeset
296
kono
parents:
diff changeset
297 OpenMP clause: map ({alloc:,to:,from:,tofrom:,}variable-list). */
kono
parents:
diff changeset
298 OMP_CLAUSE_MAP,
kono
parents:
diff changeset
299
kono
parents:
diff changeset
300 /* OpenACC clause: use_device (variable_list).
kono
parents:
diff changeset
301 OpenMP clause: use_device_ptr (variable-list). */
kono
parents:
diff changeset
302 OMP_CLAUSE_USE_DEVICE_PTR,
kono
parents:
diff changeset
303
kono
parents:
diff changeset
304 /* OpenMP clause: is_device_ptr (variable-list). */
kono
parents:
diff changeset
305 OMP_CLAUSE_IS_DEVICE_PTR,
kono
parents:
diff changeset
306
kono
parents:
diff changeset
307 /* Internal structure to hold OpenACC cache directive's variable-list.
kono
parents:
diff changeset
308 #pragma acc cache (variable-list). */
kono
parents:
diff changeset
309 OMP_CLAUSE__CACHE_,
kono
parents:
diff changeset
310
kono
parents:
diff changeset
311 /* OpenACC clause: gang [(gang-argument-list)].
kono
parents:
diff changeset
312 Where
kono
parents:
diff changeset
313 gang-argument-list: [gang-argument-list, ] gang-argument
kono
parents:
diff changeset
314 gang-argument: [num:] integer-expression
kono
parents:
diff changeset
315 | static: size-expression
kono
parents:
diff changeset
316 size-expression: * | integer-expression. */
kono
parents:
diff changeset
317 OMP_CLAUSE_GANG,
kono
parents:
diff changeset
318
kono
parents:
diff changeset
319 /* OpenACC clause: async [(integer-expression)]. */
kono
parents:
diff changeset
320 OMP_CLAUSE_ASYNC,
kono
parents:
diff changeset
321
kono
parents:
diff changeset
322 /* OpenACC clause: wait [(integer-expression-list)]. */
kono
parents:
diff changeset
323 OMP_CLAUSE_WAIT,
kono
parents:
diff changeset
324
kono
parents:
diff changeset
325 /* OpenACC clause: auto. */
kono
parents:
diff changeset
326 OMP_CLAUSE_AUTO,
kono
parents:
diff changeset
327
kono
parents:
diff changeset
328 /* OpenACC clause: seq. */
kono
parents:
diff changeset
329 OMP_CLAUSE_SEQ,
kono
parents:
diff changeset
330
kono
parents:
diff changeset
331 /* Internal clause: temporary for combined loops expansion. */
kono
parents:
diff changeset
332 OMP_CLAUSE__LOOPTEMP_,
kono
parents:
diff changeset
333
kono
parents:
diff changeset
334 /* OpenACC/OpenMP clause: if (scalar-expression). */
kono
parents:
diff changeset
335 OMP_CLAUSE_IF,
kono
parents:
diff changeset
336
kono
parents:
diff changeset
337 /* OpenMP clause: num_threads (integer-expression). */
kono
parents:
diff changeset
338 OMP_CLAUSE_NUM_THREADS,
kono
parents:
diff changeset
339
kono
parents:
diff changeset
340 /* OpenMP clause: schedule. */
kono
parents:
diff changeset
341 OMP_CLAUSE_SCHEDULE,
kono
parents:
diff changeset
342
kono
parents:
diff changeset
343 /* OpenMP clause: nowait. */
kono
parents:
diff changeset
344 OMP_CLAUSE_NOWAIT,
kono
parents:
diff changeset
345
kono
parents:
diff changeset
346 /* OpenMP clause: ordered [(constant-integer-expression)]. */
kono
parents:
diff changeset
347 OMP_CLAUSE_ORDERED,
kono
parents:
diff changeset
348
kono
parents:
diff changeset
349 /* OpenACC/OpenMP clause: default. */
kono
parents:
diff changeset
350 OMP_CLAUSE_DEFAULT,
kono
parents:
diff changeset
351
kono
parents:
diff changeset
352 /* OpenACC/OpenMP clause: collapse (constant-integer-expression). */
kono
parents:
diff changeset
353 OMP_CLAUSE_COLLAPSE,
kono
parents:
diff changeset
354
kono
parents:
diff changeset
355 /* OpenMP clause: untied. */
kono
parents:
diff changeset
356 OMP_CLAUSE_UNTIED,
kono
parents:
diff changeset
357
kono
parents:
diff changeset
358 /* OpenMP clause: final (scalar-expression). */
kono
parents:
diff changeset
359 OMP_CLAUSE_FINAL,
kono
parents:
diff changeset
360
kono
parents:
diff changeset
361 /* OpenMP clause: mergeable. */
kono
parents:
diff changeset
362 OMP_CLAUSE_MERGEABLE,
kono
parents:
diff changeset
363
kono
parents:
diff changeset
364 /* OpenMP clause: device (integer-expression). */
kono
parents:
diff changeset
365 OMP_CLAUSE_DEVICE,
kono
parents:
diff changeset
366
kono
parents:
diff changeset
367 /* OpenMP clause: dist_schedule (static[:chunk-size]). */
kono
parents:
diff changeset
368 OMP_CLAUSE_DIST_SCHEDULE,
kono
parents:
diff changeset
369
kono
parents:
diff changeset
370 /* OpenMP clause: inbranch. */
kono
parents:
diff changeset
371 OMP_CLAUSE_INBRANCH,
kono
parents:
diff changeset
372
kono
parents:
diff changeset
373 /* OpenMP clause: notinbranch. */
kono
parents:
diff changeset
374 OMP_CLAUSE_NOTINBRANCH,
kono
parents:
diff changeset
375
kono
parents:
diff changeset
376 /* OpenMP clause: num_teams(integer-expression). */
kono
parents:
diff changeset
377 OMP_CLAUSE_NUM_TEAMS,
kono
parents:
diff changeset
378
kono
parents:
diff changeset
379 /* OpenMP clause: thread_limit(integer-expression). */
kono
parents:
diff changeset
380 OMP_CLAUSE_THREAD_LIMIT,
kono
parents:
diff changeset
381
kono
parents:
diff changeset
382 /* OpenMP clause: proc_bind ({master,close,spread}). */
kono
parents:
diff changeset
383 OMP_CLAUSE_PROC_BIND,
kono
parents:
diff changeset
384
kono
parents:
diff changeset
385 /* OpenMP clause: safelen (constant-integer-expression). */
kono
parents:
diff changeset
386 OMP_CLAUSE_SAFELEN,
kono
parents:
diff changeset
387
kono
parents:
diff changeset
388 /* OpenMP clause: simdlen (constant-integer-expression). */
kono
parents:
diff changeset
389 OMP_CLAUSE_SIMDLEN,
kono
parents:
diff changeset
390
kono
parents:
diff changeset
391 /* OpenMP clause: for. */
kono
parents:
diff changeset
392 OMP_CLAUSE_FOR,
kono
parents:
diff changeset
393
kono
parents:
diff changeset
394 /* OpenMP clause: parallel. */
kono
parents:
diff changeset
395 OMP_CLAUSE_PARALLEL,
kono
parents:
diff changeset
396
kono
parents:
diff changeset
397 /* OpenMP clause: sections. */
kono
parents:
diff changeset
398 OMP_CLAUSE_SECTIONS,
kono
parents:
diff changeset
399
kono
parents:
diff changeset
400 /* OpenMP clause: taskgroup. */
kono
parents:
diff changeset
401 OMP_CLAUSE_TASKGROUP,
kono
parents:
diff changeset
402
kono
parents:
diff changeset
403 /* OpenMP clause: priority (integer-expression). */
kono
parents:
diff changeset
404 OMP_CLAUSE_PRIORITY,
kono
parents:
diff changeset
405
kono
parents:
diff changeset
406 /* OpenMP clause: grainsize (integer-expression). */
kono
parents:
diff changeset
407 OMP_CLAUSE_GRAINSIZE,
kono
parents:
diff changeset
408
kono
parents:
diff changeset
409 /* OpenMP clause: num_tasks (integer-expression). */
kono
parents:
diff changeset
410 OMP_CLAUSE_NUM_TASKS,
kono
parents:
diff changeset
411
kono
parents:
diff changeset
412 /* OpenMP clause: nogroup. */
kono
parents:
diff changeset
413 OMP_CLAUSE_NOGROUP,
kono
parents:
diff changeset
414
kono
parents:
diff changeset
415 /* OpenMP clause: threads. */
kono
parents:
diff changeset
416 OMP_CLAUSE_THREADS,
kono
parents:
diff changeset
417
kono
parents:
diff changeset
418 /* OpenMP clause: simd. */
kono
parents:
diff changeset
419 OMP_CLAUSE_SIMD,
kono
parents:
diff changeset
420
kono
parents:
diff changeset
421 /* OpenMP clause: hint (integer-expression). */
kono
parents:
diff changeset
422 OMP_CLAUSE_HINT,
kono
parents:
diff changeset
423
kono
parents:
diff changeset
424 /* OpenMP clause: defaultmap (tofrom: scalar). */
kono
parents:
diff changeset
425 OMP_CLAUSE_DEFAULTMAP,
kono
parents:
diff changeset
426
kono
parents:
diff changeset
427 /* Internally used only clause, holding SIMD uid. */
kono
parents:
diff changeset
428 OMP_CLAUSE__SIMDUID_,
kono
parents:
diff changeset
429
kono
parents:
diff changeset
430 /* Internally used only clause, flag whether this is SIMT simd
kono
parents:
diff changeset
431 loop or not. */
kono
parents:
diff changeset
432 OMP_CLAUSE__SIMT_,
kono
parents:
diff changeset
433
kono
parents:
diff changeset
434 /* OpenACC clause: independent. */
kono
parents:
diff changeset
435 OMP_CLAUSE_INDEPENDENT,
kono
parents:
diff changeset
436
kono
parents:
diff changeset
437 /* OpenACC clause: worker [( [num:] integer-expression)]. */
kono
parents:
diff changeset
438 OMP_CLAUSE_WORKER,
kono
parents:
diff changeset
439
kono
parents:
diff changeset
440 /* OpenACC clause: vector [( [length:] integer-expression)]. */
kono
parents:
diff changeset
441 OMP_CLAUSE_VECTOR,
kono
parents:
diff changeset
442
kono
parents:
diff changeset
443 /* OpenACC clause: num_gangs (integer-expression). */
kono
parents:
diff changeset
444 OMP_CLAUSE_NUM_GANGS,
kono
parents:
diff changeset
445
kono
parents:
diff changeset
446 /* OpenACC clause: num_workers (integer-expression). */
kono
parents:
diff changeset
447 OMP_CLAUSE_NUM_WORKERS,
kono
parents:
diff changeset
448
kono
parents:
diff changeset
449 /* OpenACC clause: vector_length (integer-expression). */
kono
parents:
diff changeset
450 OMP_CLAUSE_VECTOR_LENGTH,
kono
parents:
diff changeset
451
kono
parents:
diff changeset
452 /* OpenACC clause: tile ( size-expr-list ). */
kono
parents:
diff changeset
453 OMP_CLAUSE_TILE,
kono
parents:
diff changeset
454
kono
parents:
diff changeset
455 /* OpenMP internal-only clause to specify grid dimensions of a gridified
kono
parents:
diff changeset
456 kernel. */
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
457 OMP_CLAUSE__GRIDDIM_,
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
458
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
459 /* OpenACC clause: if_present. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
460 OMP_CLAUSE_IF_PRESENT,
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
461
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
462 /* OpenACC clause: finalize. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
463 OMP_CLAUSE_FINALIZE
111
kono
parents:
diff changeset
464 };
kono
parents:
diff changeset
465
kono
parents:
diff changeset
466 #undef DEFTREESTRUCT
kono
parents:
diff changeset
467 #define DEFTREESTRUCT(ENUM, NAME) ENUM,
kono
parents:
diff changeset
468 enum tree_node_structure_enum {
kono
parents:
diff changeset
469 #include "treestruct.def"
kono
parents:
diff changeset
470 LAST_TS_ENUM
kono
parents:
diff changeset
471 };
kono
parents:
diff changeset
472 #undef DEFTREESTRUCT
kono
parents:
diff changeset
473
kono
parents:
diff changeset
474 enum omp_clause_schedule_kind {
kono
parents:
diff changeset
475 OMP_CLAUSE_SCHEDULE_STATIC,
kono
parents:
diff changeset
476 OMP_CLAUSE_SCHEDULE_DYNAMIC,
kono
parents:
diff changeset
477 OMP_CLAUSE_SCHEDULE_GUIDED,
kono
parents:
diff changeset
478 OMP_CLAUSE_SCHEDULE_AUTO,
kono
parents:
diff changeset
479 OMP_CLAUSE_SCHEDULE_RUNTIME,
kono
parents:
diff changeset
480 OMP_CLAUSE_SCHEDULE_MASK = (1 << 3) - 1,
kono
parents:
diff changeset
481 OMP_CLAUSE_SCHEDULE_MONOTONIC = (1 << 3),
kono
parents:
diff changeset
482 OMP_CLAUSE_SCHEDULE_NONMONOTONIC = (1 << 4),
kono
parents:
diff changeset
483 OMP_CLAUSE_SCHEDULE_LAST = 2 * OMP_CLAUSE_SCHEDULE_NONMONOTONIC - 1
kono
parents:
diff changeset
484 };
kono
parents:
diff changeset
485
kono
parents:
diff changeset
486 enum omp_clause_default_kind {
kono
parents:
diff changeset
487 OMP_CLAUSE_DEFAULT_UNSPECIFIED,
kono
parents:
diff changeset
488 OMP_CLAUSE_DEFAULT_SHARED,
kono
parents:
diff changeset
489 OMP_CLAUSE_DEFAULT_NONE,
kono
parents:
diff changeset
490 OMP_CLAUSE_DEFAULT_PRIVATE,
kono
parents:
diff changeset
491 OMP_CLAUSE_DEFAULT_FIRSTPRIVATE,
kono
parents:
diff changeset
492 OMP_CLAUSE_DEFAULT_PRESENT,
kono
parents:
diff changeset
493 OMP_CLAUSE_DEFAULT_LAST
kono
parents:
diff changeset
494 };
kono
parents:
diff changeset
495
kono
parents:
diff changeset
496 /* There is a TYPE_QUAL value for each type qualifier. They can be
kono
parents:
diff changeset
497 combined by bitwise-or to form the complete set of qualifiers for a
kono
parents:
diff changeset
498 type. */
kono
parents:
diff changeset
499 enum cv_qualifier {
kono
parents:
diff changeset
500 TYPE_UNQUALIFIED = 0x0,
kono
parents:
diff changeset
501 TYPE_QUAL_CONST = 0x1,
kono
parents:
diff changeset
502 TYPE_QUAL_VOLATILE = 0x2,
kono
parents:
diff changeset
503 TYPE_QUAL_RESTRICT = 0x4,
kono
parents:
diff changeset
504 TYPE_QUAL_ATOMIC = 0x8
kono
parents:
diff changeset
505 };
kono
parents:
diff changeset
506
kono
parents:
diff changeset
507 /* Standard named or nameless data types of the C compiler. */
kono
parents:
diff changeset
508 enum tree_index {
kono
parents:
diff changeset
509 TI_ERROR_MARK,
kono
parents:
diff changeset
510 TI_INTQI_TYPE,
kono
parents:
diff changeset
511 TI_INTHI_TYPE,
kono
parents:
diff changeset
512 TI_INTSI_TYPE,
kono
parents:
diff changeset
513 TI_INTDI_TYPE,
kono
parents:
diff changeset
514 TI_INTTI_TYPE,
kono
parents:
diff changeset
515
kono
parents:
diff changeset
516 TI_UINTQI_TYPE,
kono
parents:
diff changeset
517 TI_UINTHI_TYPE,
kono
parents:
diff changeset
518 TI_UINTSI_TYPE,
kono
parents:
diff changeset
519 TI_UINTDI_TYPE,
kono
parents:
diff changeset
520 TI_UINTTI_TYPE,
kono
parents:
diff changeset
521
kono
parents:
diff changeset
522 TI_ATOMICQI_TYPE,
kono
parents:
diff changeset
523 TI_ATOMICHI_TYPE,
kono
parents:
diff changeset
524 TI_ATOMICSI_TYPE,
kono
parents:
diff changeset
525 TI_ATOMICDI_TYPE,
kono
parents:
diff changeset
526 TI_ATOMICTI_TYPE,
kono
parents:
diff changeset
527
kono
parents:
diff changeset
528 TI_UINT16_TYPE,
kono
parents:
diff changeset
529 TI_UINT32_TYPE,
kono
parents:
diff changeset
530 TI_UINT64_TYPE,
kono
parents:
diff changeset
531
kono
parents:
diff changeset
532 TI_VOID,
kono
parents:
diff changeset
533
kono
parents:
diff changeset
534 TI_INTEGER_ZERO,
kono
parents:
diff changeset
535 TI_INTEGER_ONE,
kono
parents:
diff changeset
536 TI_INTEGER_THREE,
kono
parents:
diff changeset
537 TI_INTEGER_MINUS_ONE,
kono
parents:
diff changeset
538 TI_NULL_POINTER,
kono
parents:
diff changeset
539
kono
parents:
diff changeset
540 TI_SIZE_ZERO,
kono
parents:
diff changeset
541 TI_SIZE_ONE,
kono
parents:
diff changeset
542
kono
parents:
diff changeset
543 TI_BITSIZE_ZERO,
kono
parents:
diff changeset
544 TI_BITSIZE_ONE,
kono
parents:
diff changeset
545 TI_BITSIZE_UNIT,
kono
parents:
diff changeset
546
kono
parents:
diff changeset
547 TI_PUBLIC,
kono
parents:
diff changeset
548 TI_PROTECTED,
kono
parents:
diff changeset
549 TI_PRIVATE,
kono
parents:
diff changeset
550
kono
parents:
diff changeset
551 TI_BOOLEAN_FALSE,
kono
parents:
diff changeset
552 TI_BOOLEAN_TRUE,
kono
parents:
diff changeset
553
kono
parents:
diff changeset
554 TI_FLOAT_TYPE,
kono
parents:
diff changeset
555 TI_DOUBLE_TYPE,
kono
parents:
diff changeset
556 TI_LONG_DOUBLE_TYPE,
kono
parents:
diff changeset
557
kono
parents:
diff changeset
558 /* The _FloatN and _FloatNx types must be consecutive, and in the
kono
parents:
diff changeset
559 same sequence as the corresponding complex types, which must also
kono
parents:
diff changeset
560 be consecutive; _FloatN must come before _FloatNx; the order must
kono
parents:
diff changeset
561 also be the same as in the floatn_nx_types array and the RID_*
kono
parents:
diff changeset
562 values in c-common.h. This is so that iterations over these
kono
parents:
diff changeset
563 types work as intended. */
kono
parents:
diff changeset
564 TI_FLOAT16_TYPE,
kono
parents:
diff changeset
565 TI_FLOATN_TYPE_FIRST = TI_FLOAT16_TYPE,
kono
parents:
diff changeset
566 TI_FLOATN_NX_TYPE_FIRST = TI_FLOAT16_TYPE,
kono
parents:
diff changeset
567 TI_FLOAT32_TYPE,
kono
parents:
diff changeset
568 TI_FLOAT64_TYPE,
kono
parents:
diff changeset
569 TI_FLOAT128_TYPE,
kono
parents:
diff changeset
570 TI_FLOATN_TYPE_LAST = TI_FLOAT128_TYPE,
kono
parents:
diff changeset
571 #define NUM_FLOATN_TYPES (TI_FLOATN_TYPE_LAST - TI_FLOATN_TYPE_FIRST + 1)
kono
parents:
diff changeset
572 TI_FLOAT32X_TYPE,
kono
parents:
diff changeset
573 TI_FLOATNX_TYPE_FIRST = TI_FLOAT32X_TYPE,
kono
parents:
diff changeset
574 TI_FLOAT64X_TYPE,
kono
parents:
diff changeset
575 TI_FLOAT128X_TYPE,
kono
parents:
diff changeset
576 TI_FLOATNX_TYPE_LAST = TI_FLOAT128X_TYPE,
kono
parents:
diff changeset
577 TI_FLOATN_NX_TYPE_LAST = TI_FLOAT128X_TYPE,
kono
parents:
diff changeset
578 #define NUM_FLOATNX_TYPES (TI_FLOATNX_TYPE_LAST - TI_FLOATNX_TYPE_FIRST + 1)
kono
parents:
diff changeset
579 #define NUM_FLOATN_NX_TYPES (TI_FLOATN_NX_TYPE_LAST \
kono
parents:
diff changeset
580 - TI_FLOATN_NX_TYPE_FIRST \
kono
parents:
diff changeset
581 + 1)
kono
parents:
diff changeset
582
kono
parents:
diff changeset
583 /* Put the complex types after their component types, so that in (sequential)
kono
parents:
diff changeset
584 tree streaming we can assert that their component types have already been
kono
parents:
diff changeset
585 handled (see tree-streamer.c:record_common_node). */
kono
parents:
diff changeset
586 TI_COMPLEX_INTEGER_TYPE,
kono
parents:
diff changeset
587 TI_COMPLEX_FLOAT_TYPE,
kono
parents:
diff changeset
588 TI_COMPLEX_DOUBLE_TYPE,
kono
parents:
diff changeset
589 TI_COMPLEX_LONG_DOUBLE_TYPE,
kono
parents:
diff changeset
590
kono
parents:
diff changeset
591 TI_COMPLEX_FLOAT16_TYPE,
kono
parents:
diff changeset
592 TI_COMPLEX_FLOATN_NX_TYPE_FIRST = TI_COMPLEX_FLOAT16_TYPE,
kono
parents:
diff changeset
593 TI_COMPLEX_FLOAT32_TYPE,
kono
parents:
diff changeset
594 TI_COMPLEX_FLOAT64_TYPE,
kono
parents:
diff changeset
595 TI_COMPLEX_FLOAT128_TYPE,
kono
parents:
diff changeset
596 TI_COMPLEX_FLOAT32X_TYPE,
kono
parents:
diff changeset
597 TI_COMPLEX_FLOAT64X_TYPE,
kono
parents:
diff changeset
598 TI_COMPLEX_FLOAT128X_TYPE,
kono
parents:
diff changeset
599
kono
parents:
diff changeset
600 TI_FLOAT_PTR_TYPE,
kono
parents:
diff changeset
601 TI_DOUBLE_PTR_TYPE,
kono
parents:
diff changeset
602 TI_LONG_DOUBLE_PTR_TYPE,
kono
parents:
diff changeset
603 TI_INTEGER_PTR_TYPE,
kono
parents:
diff changeset
604
kono
parents:
diff changeset
605 TI_VOID_TYPE,
kono
parents:
diff changeset
606 TI_PTR_TYPE,
kono
parents:
diff changeset
607 TI_CONST_PTR_TYPE,
kono
parents:
diff changeset
608 TI_SIZE_TYPE,
kono
parents:
diff changeset
609 TI_PID_TYPE,
kono
parents:
diff changeset
610 TI_PTRDIFF_TYPE,
kono
parents:
diff changeset
611 TI_VA_LIST_TYPE,
kono
parents:
diff changeset
612 TI_VA_LIST_GPR_COUNTER_FIELD,
kono
parents:
diff changeset
613 TI_VA_LIST_FPR_COUNTER_FIELD,
kono
parents:
diff changeset
614 TI_BOOLEAN_TYPE,
kono
parents:
diff changeset
615 TI_FILEPTR_TYPE,
kono
parents:
diff changeset
616 TI_CONST_TM_PTR_TYPE,
kono
parents:
diff changeset
617 TI_FENV_T_PTR_TYPE,
kono
parents:
diff changeset
618 TI_CONST_FENV_T_PTR_TYPE,
kono
parents:
diff changeset
619 TI_FEXCEPT_T_PTR_TYPE,
kono
parents:
diff changeset
620 TI_CONST_FEXCEPT_T_PTR_TYPE,
kono
parents:
diff changeset
621 TI_POINTER_SIZED_TYPE,
kono
parents:
diff changeset
622
kono
parents:
diff changeset
623 TI_DFLOAT32_TYPE,
kono
parents:
diff changeset
624 TI_DFLOAT64_TYPE,
kono
parents:
diff changeset
625 TI_DFLOAT128_TYPE,
kono
parents:
diff changeset
626 TI_DFLOAT32_PTR_TYPE,
kono
parents:
diff changeset
627 TI_DFLOAT64_PTR_TYPE,
kono
parents:
diff changeset
628 TI_DFLOAT128_PTR_TYPE,
kono
parents:
diff changeset
629
kono
parents:
diff changeset
630 TI_VOID_LIST_NODE,
kono
parents:
diff changeset
631
kono
parents:
diff changeset
632 TI_MAIN_IDENTIFIER,
kono
parents:
diff changeset
633
kono
parents:
diff changeset
634 TI_SAT_SFRACT_TYPE,
kono
parents:
diff changeset
635 TI_SAT_FRACT_TYPE,
kono
parents:
diff changeset
636 TI_SAT_LFRACT_TYPE,
kono
parents:
diff changeset
637 TI_SAT_LLFRACT_TYPE,
kono
parents:
diff changeset
638 TI_SAT_USFRACT_TYPE,
kono
parents:
diff changeset
639 TI_SAT_UFRACT_TYPE,
kono
parents:
diff changeset
640 TI_SAT_ULFRACT_TYPE,
kono
parents:
diff changeset
641 TI_SAT_ULLFRACT_TYPE,
kono
parents:
diff changeset
642 TI_SFRACT_TYPE,
kono
parents:
diff changeset
643 TI_FRACT_TYPE,
kono
parents:
diff changeset
644 TI_LFRACT_TYPE,
kono
parents:
diff changeset
645 TI_LLFRACT_TYPE,
kono
parents:
diff changeset
646 TI_USFRACT_TYPE,
kono
parents:
diff changeset
647 TI_UFRACT_TYPE,
kono
parents:
diff changeset
648 TI_ULFRACT_TYPE,
kono
parents:
diff changeset
649 TI_ULLFRACT_TYPE,
kono
parents:
diff changeset
650 TI_SAT_SACCUM_TYPE,
kono
parents:
diff changeset
651 TI_SAT_ACCUM_TYPE,
kono
parents:
diff changeset
652 TI_SAT_LACCUM_TYPE,
kono
parents:
diff changeset
653 TI_SAT_LLACCUM_TYPE,
kono
parents:
diff changeset
654 TI_SAT_USACCUM_TYPE,
kono
parents:
diff changeset
655 TI_SAT_UACCUM_TYPE,
kono
parents:
diff changeset
656 TI_SAT_ULACCUM_TYPE,
kono
parents:
diff changeset
657 TI_SAT_ULLACCUM_TYPE,
kono
parents:
diff changeset
658 TI_SACCUM_TYPE,
kono
parents:
diff changeset
659 TI_ACCUM_TYPE,
kono
parents:
diff changeset
660 TI_LACCUM_TYPE,
kono
parents:
diff changeset
661 TI_LLACCUM_TYPE,
kono
parents:
diff changeset
662 TI_USACCUM_TYPE,
kono
parents:
diff changeset
663 TI_UACCUM_TYPE,
kono
parents:
diff changeset
664 TI_ULACCUM_TYPE,
kono
parents:
diff changeset
665 TI_ULLACCUM_TYPE,
kono
parents:
diff changeset
666 TI_QQ_TYPE,
kono
parents:
diff changeset
667 TI_HQ_TYPE,
kono
parents:
diff changeset
668 TI_SQ_TYPE,
kono
parents:
diff changeset
669 TI_DQ_TYPE,
kono
parents:
diff changeset
670 TI_TQ_TYPE,
kono
parents:
diff changeset
671 TI_UQQ_TYPE,
kono
parents:
diff changeset
672 TI_UHQ_TYPE,
kono
parents:
diff changeset
673 TI_USQ_TYPE,
kono
parents:
diff changeset
674 TI_UDQ_TYPE,
kono
parents:
diff changeset
675 TI_UTQ_TYPE,
kono
parents:
diff changeset
676 TI_SAT_QQ_TYPE,
kono
parents:
diff changeset
677 TI_SAT_HQ_TYPE,
kono
parents:
diff changeset
678 TI_SAT_SQ_TYPE,
kono
parents:
diff changeset
679 TI_SAT_DQ_TYPE,
kono
parents:
diff changeset
680 TI_SAT_TQ_TYPE,
kono
parents:
diff changeset
681 TI_SAT_UQQ_TYPE,
kono
parents:
diff changeset
682 TI_SAT_UHQ_TYPE,
kono
parents:
diff changeset
683 TI_SAT_USQ_TYPE,
kono
parents:
diff changeset
684 TI_SAT_UDQ_TYPE,
kono
parents:
diff changeset
685 TI_SAT_UTQ_TYPE,
kono
parents:
diff changeset
686 TI_HA_TYPE,
kono
parents:
diff changeset
687 TI_SA_TYPE,
kono
parents:
diff changeset
688 TI_DA_TYPE,
kono
parents:
diff changeset
689 TI_TA_TYPE,
kono
parents:
diff changeset
690 TI_UHA_TYPE,
kono
parents:
diff changeset
691 TI_USA_TYPE,
kono
parents:
diff changeset
692 TI_UDA_TYPE,
kono
parents:
diff changeset
693 TI_UTA_TYPE,
kono
parents:
diff changeset
694 TI_SAT_HA_TYPE,
kono
parents:
diff changeset
695 TI_SAT_SA_TYPE,
kono
parents:
diff changeset
696 TI_SAT_DA_TYPE,
kono
parents:
diff changeset
697 TI_SAT_TA_TYPE,
kono
parents:
diff changeset
698 TI_SAT_UHA_TYPE,
kono
parents:
diff changeset
699 TI_SAT_USA_TYPE,
kono
parents:
diff changeset
700 TI_SAT_UDA_TYPE,
kono
parents:
diff changeset
701 TI_SAT_UTA_TYPE,
kono
parents:
diff changeset
702
kono
parents:
diff changeset
703 TI_OPTIMIZATION_DEFAULT,
kono
parents:
diff changeset
704 TI_OPTIMIZATION_CURRENT,
kono
parents:
diff changeset
705 TI_TARGET_OPTION_DEFAULT,
kono
parents:
diff changeset
706 TI_TARGET_OPTION_CURRENT,
kono
parents:
diff changeset
707 TI_CURRENT_TARGET_PRAGMA,
kono
parents:
diff changeset
708 TI_CURRENT_OPTIMIZE_PRAGMA,
kono
parents:
diff changeset
709
kono
parents:
diff changeset
710 TI_MAX
kono
parents:
diff changeset
711 };
kono
parents:
diff changeset
712
kono
parents:
diff changeset
713 /* An enumeration of the standard C integer types. These must be
kono
parents:
diff changeset
714 ordered so that shorter types appear before longer ones, and so
kono
parents:
diff changeset
715 that signed types appear before unsigned ones, for the correct
kono
parents:
diff changeset
716 functioning of interpret_integer() in c-lex.c. */
kono
parents:
diff changeset
717 enum integer_type_kind {
kono
parents:
diff changeset
718 itk_char,
kono
parents:
diff changeset
719 itk_signed_char,
kono
parents:
diff changeset
720 itk_unsigned_char,
kono
parents:
diff changeset
721 itk_short,
kono
parents:
diff changeset
722 itk_unsigned_short,
kono
parents:
diff changeset
723 itk_int,
kono
parents:
diff changeset
724 itk_unsigned_int,
kono
parents:
diff changeset
725 itk_long,
kono
parents:
diff changeset
726 itk_unsigned_long,
kono
parents:
diff changeset
727 itk_long_long,
kono
parents:
diff changeset
728 itk_unsigned_long_long,
kono
parents:
diff changeset
729
kono
parents:
diff changeset
730 itk_intN_0,
kono
parents:
diff changeset
731 itk_unsigned_intN_0,
kono
parents:
diff changeset
732 itk_intN_1,
kono
parents:
diff changeset
733 itk_unsigned_intN_1,
kono
parents:
diff changeset
734 itk_intN_2,
kono
parents:
diff changeset
735 itk_unsigned_intN_2,
kono
parents:
diff changeset
736 itk_intN_3,
kono
parents:
diff changeset
737 itk_unsigned_intN_3,
kono
parents:
diff changeset
738
kono
parents:
diff changeset
739 itk_none
kono
parents:
diff changeset
740 };
kono
parents:
diff changeset
741
kono
parents:
diff changeset
742 /* A pointer-to-function member type looks like:
kono
parents:
diff changeset
743
kono
parents:
diff changeset
744 struct {
kono
parents:
diff changeset
745 __P __pfn;
kono
parents:
diff changeset
746 ptrdiff_t __delta;
kono
parents:
diff changeset
747 };
kono
parents:
diff changeset
748
kono
parents:
diff changeset
749 If __pfn is NULL, it is a NULL pointer-to-member-function.
kono
parents:
diff changeset
750
kono
parents:
diff changeset
751 (Because the vtable is always the first thing in the object, we
kono
parents:
diff changeset
752 don't need its offset.) If the function is virtual, then PFN is
kono
parents:
diff changeset
753 one plus twice the index into the vtable; otherwise, it is just a
kono
parents:
diff changeset
754 pointer to the function.
kono
parents:
diff changeset
755
kono
parents:
diff changeset
756 Unfortunately, using the lowest bit of PFN doesn't work in
kono
parents:
diff changeset
757 architectures that don't impose alignment requirements on function
kono
parents:
diff changeset
758 addresses, or that use the lowest bit to tell one ISA from another,
kono
parents:
diff changeset
759 for example. For such architectures, we use the lowest bit of
kono
parents:
diff changeset
760 DELTA instead of the lowest bit of the PFN, and DELTA will be
kono
parents:
diff changeset
761 multiplied by 2. */
kono
parents:
diff changeset
762 enum ptrmemfunc_vbit_where_t {
kono
parents:
diff changeset
763 ptrmemfunc_vbit_in_pfn,
kono
parents:
diff changeset
764 ptrmemfunc_vbit_in_delta
kono
parents:
diff changeset
765 };
kono
parents:
diff changeset
766
kono
parents:
diff changeset
767 /* Flags that may be passed in the third argument of decl_attributes, and
kono
parents:
diff changeset
768 to handler functions for attributes. */
kono
parents:
diff changeset
769 enum attribute_flags {
kono
parents:
diff changeset
770 /* The type passed in is the type of a DECL, and any attributes that
kono
parents:
diff changeset
771 should be passed in again to be applied to the DECL rather than the
kono
parents:
diff changeset
772 type should be returned. */
kono
parents:
diff changeset
773 ATTR_FLAG_DECL_NEXT = 1,
kono
parents:
diff changeset
774 /* The type passed in is a function return type, and any attributes that
kono
parents:
diff changeset
775 should be passed in again to be applied to the function type rather
kono
parents:
diff changeset
776 than the return type should be returned. */
kono
parents:
diff changeset
777 ATTR_FLAG_FUNCTION_NEXT = 2,
kono
parents:
diff changeset
778 /* The type passed in is an array element type, and any attributes that
kono
parents:
diff changeset
779 should be passed in again to be applied to the array type rather
kono
parents:
diff changeset
780 than the element type should be returned. */
kono
parents:
diff changeset
781 ATTR_FLAG_ARRAY_NEXT = 4,
kono
parents:
diff changeset
782 /* The type passed in is a structure, union or enumeration type being
kono
parents:
diff changeset
783 created, and should be modified in place. */
kono
parents:
diff changeset
784 ATTR_FLAG_TYPE_IN_PLACE = 8,
kono
parents:
diff changeset
785 /* The attributes are being applied by default to a library function whose
kono
parents:
diff changeset
786 name indicates known behavior, and should be silently ignored if they
kono
parents:
diff changeset
787 are not in fact compatible with the function type. */
kono
parents:
diff changeset
788 ATTR_FLAG_BUILT_IN = 16,
kono
parents:
diff changeset
789 /* A given attribute has been parsed as a C++-11 attribute. */
kono
parents:
diff changeset
790 ATTR_FLAG_CXX11 = 32
kono
parents:
diff changeset
791 };
kono
parents:
diff changeset
792
kono
parents:
diff changeset
793 /* Types used to represent sizes. */
kono
parents:
diff changeset
794 enum size_type_kind {
kono
parents:
diff changeset
795 stk_sizetype, /* Normal representation of sizes in bytes. */
kono
parents:
diff changeset
796 stk_ssizetype, /* Signed representation of sizes in bytes. */
kono
parents:
diff changeset
797 stk_bitsizetype, /* Normal representation of sizes in bits. */
kono
parents:
diff changeset
798 stk_sbitsizetype, /* Signed representation of sizes in bits. */
kono
parents:
diff changeset
799 stk_type_kind_last
kono
parents:
diff changeset
800 };
kono
parents:
diff changeset
801
kono
parents:
diff changeset
802 enum operand_equal_flag {
kono
parents:
diff changeset
803 OEP_ONLY_CONST = 1,
kono
parents:
diff changeset
804 OEP_PURE_SAME = 2,
kono
parents:
diff changeset
805 OEP_MATCH_SIDE_EFFECTS = 4,
kono
parents:
diff changeset
806 OEP_ADDRESS_OF = 8,
kono
parents:
diff changeset
807 /* Internal within operand_equal_p: */
kono
parents:
diff changeset
808 OEP_NO_HASH_CHECK = 16,
kono
parents:
diff changeset
809 /* Internal within inchash::add_expr: */
kono
parents:
diff changeset
810 OEP_HASH_CHECK = 32,
kono
parents:
diff changeset
811 /* Makes operand_equal_p handle more expressions: */
kono
parents:
diff changeset
812 OEP_LEXICOGRAPHIC = 64
kono
parents:
diff changeset
813 };
kono
parents:
diff changeset
814
kono
parents:
diff changeset
815 /* Enum and arrays used for tree allocation stats.
kono
parents:
diff changeset
816 Keep in sync with tree.c:tree_node_kind_names. */
kono
parents:
diff changeset
817 enum tree_node_kind {
kono
parents:
diff changeset
818 d_kind,
kono
parents:
diff changeset
819 t_kind,
kono
parents:
diff changeset
820 b_kind,
kono
parents:
diff changeset
821 s_kind,
kono
parents:
diff changeset
822 r_kind,
kono
parents:
diff changeset
823 e_kind,
kono
parents:
diff changeset
824 c_kind,
kono
parents:
diff changeset
825 id_kind,
kono
parents:
diff changeset
826 vec_kind,
kono
parents:
diff changeset
827 binfo_kind,
kono
parents:
diff changeset
828 ssa_name_kind,
kono
parents:
diff changeset
829 constr_kind,
kono
parents:
diff changeset
830 x_kind,
kono
parents:
diff changeset
831 lang_decl,
kono
parents:
diff changeset
832 lang_type,
kono
parents:
diff changeset
833 omp_clause_kind,
kono
parents:
diff changeset
834 all_kinds
kono
parents:
diff changeset
835 };
kono
parents:
diff changeset
836
kono
parents:
diff changeset
837 enum annot_expr_kind {
kono
parents:
diff changeset
838 annot_expr_ivdep_kind,
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
839 annot_expr_unroll_kind,
111
kono
parents:
diff changeset
840 annot_expr_no_vector_kind,
kono
parents:
diff changeset
841 annot_expr_vector_kind,
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
842 annot_expr_parallel_kind,
111
kono
parents:
diff changeset
843 annot_expr_kind_last
kono
parents:
diff changeset
844 };
kono
parents:
diff changeset
845
kono
parents:
diff changeset
846 /*---------------------------------------------------------------------------
kono
parents:
diff changeset
847 Type definitions
kono
parents:
diff changeset
848 ---------------------------------------------------------------------------*/
kono
parents:
diff changeset
849 /* When processing aliases at the symbol table level, we need the
kono
parents:
diff changeset
850 declaration of target. For this reason we need to queue aliases and
kono
parents:
diff changeset
851 process them after all declarations has been produced. */
kono
parents:
diff changeset
852 struct GTY(()) alias_pair {
kono
parents:
diff changeset
853 tree decl;
kono
parents:
diff changeset
854 tree target;
kono
parents:
diff changeset
855 };
kono
parents:
diff changeset
856
kono
parents:
diff changeset
857 /* An initialization priority. */
kono
parents:
diff changeset
858 typedef unsigned short priority_type;
kono
parents:
diff changeset
859
kono
parents:
diff changeset
860 /* The type of a callback function for walking over tree structure. */
kono
parents:
diff changeset
861 typedef tree (*walk_tree_fn) (tree *, int *, void *);
kono
parents:
diff changeset
862
kono
parents:
diff changeset
863 /* The type of a callback function that represents a custom walk_tree. */
kono
parents:
diff changeset
864 typedef tree (*walk_tree_lh) (tree *, int *, tree (*) (tree *, int *, void *),
kono
parents:
diff changeset
865 void *, hash_set<tree> *);
kono
parents:
diff changeset
866
kono
parents:
diff changeset
867
kono
parents:
diff changeset
868 /*---------------------------------------------------------------------------
kono
parents:
diff changeset
869 Main data structures
kono
parents:
diff changeset
870 ---------------------------------------------------------------------------*/
kono
parents:
diff changeset
871 /* A tree node can represent a data type, a variable, an expression
kono
parents:
diff changeset
872 or a statement. Each node has a TREE_CODE which says what kind of
kono
parents:
diff changeset
873 thing it represents. Some common codes are:
kono
parents:
diff changeset
874 INTEGER_TYPE -- represents a type of integers.
kono
parents:
diff changeset
875 ARRAY_TYPE -- represents a type of pointer.
kono
parents:
diff changeset
876 VAR_DECL -- represents a declared variable.
kono
parents:
diff changeset
877 INTEGER_CST -- represents a constant integer value.
kono
parents:
diff changeset
878 PLUS_EXPR -- represents a sum (an expression).
kono
parents:
diff changeset
879
kono
parents:
diff changeset
880 As for the contents of a tree node: there are some fields
kono
parents:
diff changeset
881 that all nodes share. Each TREE_CODE has various special-purpose
kono
parents:
diff changeset
882 fields as well. The fields of a node are never accessed directly,
kono
parents:
diff changeset
883 always through accessor macros. */
kono
parents:
diff changeset
884
kono
parents:
diff changeset
885 /* Every kind of tree node starts with this structure,
kono
parents:
diff changeset
886 so all nodes have these fields.
kono
parents:
diff changeset
887
kono
parents:
diff changeset
888 See the accessor macros, defined below, for documentation of the
kono
parents:
diff changeset
889 fields, and the table below which connects the fields and the
kono
parents:
diff changeset
890 accessor macros. */
kono
parents:
diff changeset
891
kono
parents:
diff changeset
892 struct GTY(()) tree_base {
kono
parents:
diff changeset
893 ENUM_BITFIELD(tree_code) code : 16;
kono
parents:
diff changeset
894
kono
parents:
diff changeset
895 unsigned side_effects_flag : 1;
kono
parents:
diff changeset
896 unsigned constant_flag : 1;
kono
parents:
diff changeset
897 unsigned addressable_flag : 1;
kono
parents:
diff changeset
898 unsigned volatile_flag : 1;
kono
parents:
diff changeset
899 unsigned readonly_flag : 1;
kono
parents:
diff changeset
900 unsigned asm_written_flag: 1;
kono
parents:
diff changeset
901 unsigned nowarning_flag : 1;
kono
parents:
diff changeset
902 unsigned visited : 1;
kono
parents:
diff changeset
903
kono
parents:
diff changeset
904 unsigned used_flag : 1;
kono
parents:
diff changeset
905 unsigned nothrow_flag : 1;
kono
parents:
diff changeset
906 unsigned static_flag : 1;
kono
parents:
diff changeset
907 unsigned public_flag : 1;
kono
parents:
diff changeset
908 unsigned private_flag : 1;
kono
parents:
diff changeset
909 unsigned protected_flag : 1;
kono
parents:
diff changeset
910 unsigned deprecated_flag : 1;
kono
parents:
diff changeset
911 unsigned default_def_flag : 1;
kono
parents:
diff changeset
912
kono
parents:
diff changeset
913 union {
kono
parents:
diff changeset
914 /* The bits in the following structure should only be used with
kono
parents:
diff changeset
915 accessor macros that constrain inputs with tree checking. */
kono
parents:
diff changeset
916 struct {
kono
parents:
diff changeset
917 unsigned lang_flag_0 : 1;
kono
parents:
diff changeset
918 unsigned lang_flag_1 : 1;
kono
parents:
diff changeset
919 unsigned lang_flag_2 : 1;
kono
parents:
diff changeset
920 unsigned lang_flag_3 : 1;
kono
parents:
diff changeset
921 unsigned lang_flag_4 : 1;
kono
parents:
diff changeset
922 unsigned lang_flag_5 : 1;
kono
parents:
diff changeset
923 unsigned lang_flag_6 : 1;
kono
parents:
diff changeset
924 unsigned saturating_flag : 1;
kono
parents:
diff changeset
925
kono
parents:
diff changeset
926 unsigned unsigned_flag : 1;
kono
parents:
diff changeset
927 unsigned packed_flag : 1;
kono
parents:
diff changeset
928 unsigned user_align : 1;
kono
parents:
diff changeset
929 unsigned nameless_flag : 1;
kono
parents:
diff changeset
930 unsigned atomic_flag : 1;
kono
parents:
diff changeset
931 unsigned spare0 : 3;
kono
parents:
diff changeset
932
kono
parents:
diff changeset
933 unsigned spare1 : 8;
kono
parents:
diff changeset
934
kono
parents:
diff changeset
935 /* This field is only used with TREE_TYPE nodes; the only reason it is
kono
parents:
diff changeset
936 present in tree_base instead of tree_type is to save space. The size
kono
parents:
diff changeset
937 of the field must be large enough to hold addr_space_t values. */
kono
parents:
diff changeset
938 unsigned address_space : 8;
kono
parents:
diff changeset
939 } bits;
kono
parents:
diff changeset
940
kono
parents:
diff changeset
941 /* The following fields are present in tree_base to save space. The
kono
parents:
diff changeset
942 nodes using them do not require any of the flags above and so can
kono
parents:
diff changeset
943 make better use of the 4-byte sized word. */
kono
parents:
diff changeset
944
kono
parents:
diff changeset
945 /* The number of HOST_WIDE_INTs in an INTEGER_CST. */
kono
parents:
diff changeset
946 struct {
kono
parents:
diff changeset
947 /* The number of HOST_WIDE_INTs if the INTEGER_CST is accessed in
kono
parents:
diff changeset
948 its native precision. */
kono
parents:
diff changeset
949 unsigned char unextended;
kono
parents:
diff changeset
950
kono
parents:
diff changeset
951 /* The number of HOST_WIDE_INTs if the INTEGER_CST is extended to
kono
parents:
diff changeset
952 wider precisions based on its TYPE_SIGN. */
kono
parents:
diff changeset
953 unsigned char extended;
kono
parents:
diff changeset
954
kono
parents:
diff changeset
955 /* The number of HOST_WIDE_INTs if the INTEGER_CST is accessed in
kono
parents:
diff changeset
956 offset_int precision, with smaller integers being extended
kono
parents:
diff changeset
957 according to their TYPE_SIGN. This is equal to one of the two
kono
parents:
diff changeset
958 fields above but is cached for speed. */
kono
parents:
diff changeset
959 unsigned char offset;
kono
parents:
diff changeset
960 } int_length;
kono
parents:
diff changeset
961
kono
parents:
diff changeset
962 /* VEC length. This field is only used with TREE_VEC. */
kono
parents:
diff changeset
963 int length;
kono
parents:
diff changeset
964
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
965 /* This field is only used with VECTOR_CST. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
966 struct {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
967 /* The value of VECTOR_CST_LOG2_NPATTERNS. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
968 unsigned int log2_npatterns : 8;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
969
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
970 /* The value of VECTOR_CST_NELTS_PER_PATTERN. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
971 unsigned int nelts_per_pattern : 8;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
972
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
973 /* For future expansion. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
974 unsigned int unused : 16;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
975 } vector_cst;
111
kono
parents:
diff changeset
976
kono
parents:
diff changeset
977 /* SSA version number. This field is only used with SSA_NAME. */
kono
parents:
diff changeset
978 unsigned int version;
kono
parents:
diff changeset
979
kono
parents:
diff changeset
980 /* CHREC_VARIABLE. This field is only used with POLYNOMIAL_CHREC. */
kono
parents:
diff changeset
981 unsigned int chrec_var;
kono
parents:
diff changeset
982
kono
parents:
diff changeset
983 /* Internal function code. */
kono
parents:
diff changeset
984 enum internal_fn ifn;
kono
parents:
diff changeset
985
kono
parents:
diff changeset
986 /* The following two fields are used for MEM_REF and TARGET_MEM_REF
kono
parents:
diff changeset
987 expression trees and specify known data non-dependences. For
kono
parents:
diff changeset
988 two memory references in a function they are known to not
kono
parents:
diff changeset
989 alias if dependence_info.clique are equal and dependence_info.base
kono
parents:
diff changeset
990 are distinct. */
kono
parents:
diff changeset
991 struct {
kono
parents:
diff changeset
992 unsigned short clique;
kono
parents:
diff changeset
993 unsigned short base;
kono
parents:
diff changeset
994 } dependence_info;
kono
parents:
diff changeset
995 } GTY((skip(""))) u;
kono
parents:
diff changeset
996 };
kono
parents:
diff changeset
997
kono
parents:
diff changeset
998 /* The following table lists the uses of each of the above flags and
kono
parents:
diff changeset
999 for which types of nodes they are defined.
kono
parents:
diff changeset
1000
kono
parents:
diff changeset
1001 addressable_flag:
kono
parents:
diff changeset
1002
kono
parents:
diff changeset
1003 TREE_ADDRESSABLE in
kono
parents:
diff changeset
1004 VAR_DECL, PARM_DECL, RESULT_DECL, FUNCTION_DECL, LABEL_DECL
kono
parents:
diff changeset
1005 SSA_NAME
kono
parents:
diff changeset
1006 all types
kono
parents:
diff changeset
1007 CONSTRUCTOR, IDENTIFIER_NODE
kono
parents:
diff changeset
1008 STMT_EXPR
kono
parents:
diff changeset
1009
kono
parents:
diff changeset
1010 CALL_EXPR_TAILCALL in
kono
parents:
diff changeset
1011 CALL_EXPR
kono
parents:
diff changeset
1012
kono
parents:
diff changeset
1013 CASE_LOW_SEEN in
kono
parents:
diff changeset
1014 CASE_LABEL_EXPR
kono
parents:
diff changeset
1015
kono
parents:
diff changeset
1016 PREDICT_EXPR_OUTCOME in
kono
parents:
diff changeset
1017 PREDICT_EXPR
kono
parents:
diff changeset
1018
kono
parents:
diff changeset
1019 static_flag:
kono
parents:
diff changeset
1020
kono
parents:
diff changeset
1021 TREE_STATIC in
kono
parents:
diff changeset
1022 VAR_DECL, FUNCTION_DECL
kono
parents:
diff changeset
1023 CONSTRUCTOR
kono
parents:
diff changeset
1024
kono
parents:
diff changeset
1025 TREE_NO_TRAMPOLINE in
kono
parents:
diff changeset
1026 ADDR_EXPR
kono
parents:
diff changeset
1027
kono
parents:
diff changeset
1028 BINFO_VIRTUAL_P in
kono
parents:
diff changeset
1029 TREE_BINFO
kono
parents:
diff changeset
1030
kono
parents:
diff changeset
1031 TREE_SYMBOL_REFERENCED in
kono
parents:
diff changeset
1032 IDENTIFIER_NODE
kono
parents:
diff changeset
1033
kono
parents:
diff changeset
1034 CLEANUP_EH_ONLY in
kono
parents:
diff changeset
1035 TARGET_EXPR, WITH_CLEANUP_EXPR
kono
parents:
diff changeset
1036
kono
parents:
diff changeset
1037 TRY_CATCH_IS_CLEANUP in
kono
parents:
diff changeset
1038 TRY_CATCH_EXPR
kono
parents:
diff changeset
1039
kono
parents:
diff changeset
1040 ASM_INPUT_P in
kono
parents:
diff changeset
1041 ASM_EXPR
kono
parents:
diff changeset
1042
kono
parents:
diff changeset
1043 TYPE_REF_CAN_ALIAS_ALL in
kono
parents:
diff changeset
1044 POINTER_TYPE, REFERENCE_TYPE
kono
parents:
diff changeset
1045
kono
parents:
diff changeset
1046 CASE_HIGH_SEEN in
kono
parents:
diff changeset
1047 CASE_LABEL_EXPR
kono
parents:
diff changeset
1048
kono
parents:
diff changeset
1049 ENUM_IS_SCOPED in
kono
parents:
diff changeset
1050 ENUMERAL_TYPE
kono
parents:
diff changeset
1051
kono
parents:
diff changeset
1052 TRANSACTION_EXPR_OUTER in
kono
parents:
diff changeset
1053 TRANSACTION_EXPR
kono
parents:
diff changeset
1054
kono
parents:
diff changeset
1055 SSA_NAME_ANTI_RANGE_P in
kono
parents:
diff changeset
1056 SSA_NAME
kono
parents:
diff changeset
1057
kono
parents:
diff changeset
1058 MUST_TAIL_CALL in
kono
parents:
diff changeset
1059 CALL_EXPR
kono
parents:
diff changeset
1060
kono
parents:
diff changeset
1061 public_flag:
kono
parents:
diff changeset
1062
kono
parents:
diff changeset
1063 TREE_OVERFLOW in
kono
parents:
diff changeset
1064 INTEGER_CST, REAL_CST, COMPLEX_CST, VECTOR_CST
kono
parents:
diff changeset
1065
kono
parents:
diff changeset
1066 TREE_PUBLIC in
kono
parents:
diff changeset
1067 VAR_DECL, FUNCTION_DECL
kono
parents:
diff changeset
1068 IDENTIFIER_NODE
kono
parents:
diff changeset
1069
kono
parents:
diff changeset
1070 CONSTRUCTOR_NO_CLEARING in
kono
parents:
diff changeset
1071 CONSTRUCTOR
kono
parents:
diff changeset
1072
kono
parents:
diff changeset
1073 ASM_VOLATILE_P in
kono
parents:
diff changeset
1074 ASM_EXPR
kono
parents:
diff changeset
1075
kono
parents:
diff changeset
1076 CALL_EXPR_VA_ARG_PACK in
kono
parents:
diff changeset
1077 CALL_EXPR
kono
parents:
diff changeset
1078
kono
parents:
diff changeset
1079 TYPE_CACHED_VALUES_P in
kono
parents:
diff changeset
1080 all types
kono
parents:
diff changeset
1081
kono
parents:
diff changeset
1082 SAVE_EXPR_RESOLVED_P in
kono
parents:
diff changeset
1083 SAVE_EXPR
kono
parents:
diff changeset
1084
kono
parents:
diff changeset
1085 OMP_CLAUSE_LASTPRIVATE_FIRSTPRIVATE in
kono
parents:
diff changeset
1086 OMP_CLAUSE_LASTPRIVATE
kono
parents:
diff changeset
1087
kono
parents:
diff changeset
1088 OMP_CLAUSE_PRIVATE_DEBUG in
kono
parents:
diff changeset
1089 OMP_CLAUSE_PRIVATE
kono
parents:
diff changeset
1090
kono
parents:
diff changeset
1091 OMP_CLAUSE_LINEAR_NO_COPYIN in
kono
parents:
diff changeset
1092 OMP_CLAUSE_LINEAR
kono
parents:
diff changeset
1093
kono
parents:
diff changeset
1094 OMP_CLAUSE_MAP_ZERO_BIAS_ARRAY_SECTION in
kono
parents:
diff changeset
1095 OMP_CLAUSE_MAP
kono
parents:
diff changeset
1096
kono
parents:
diff changeset
1097 OMP_CLAUSE_REDUCTION_OMP_ORIG_REF in
kono
parents:
diff changeset
1098 OMP_CLAUSE_REDUCTION
kono
parents:
diff changeset
1099
kono
parents:
diff changeset
1100 TRANSACTION_EXPR_RELAXED in
kono
parents:
diff changeset
1101 TRANSACTION_EXPR
kono
parents:
diff changeset
1102
kono
parents:
diff changeset
1103 FALLTHROUGH_LABEL_P in
kono
parents:
diff changeset
1104 LABEL_DECL
kono
parents:
diff changeset
1105
kono
parents:
diff changeset
1106 SSA_NAME_IS_VIRTUAL_OPERAND in
kono
parents:
diff changeset
1107 SSA_NAME
kono
parents:
diff changeset
1108
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1109 EXPR_LOCATION_WRAPPER_P in
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1110 NON_LVALUE_EXPR, VIEW_CONVERT_EXPR
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1111
111
kono
parents:
diff changeset
1112 private_flag:
kono
parents:
diff changeset
1113
kono
parents:
diff changeset
1114 TREE_PRIVATE in
kono
parents:
diff changeset
1115 all decls
kono
parents:
diff changeset
1116
kono
parents:
diff changeset
1117 CALL_EXPR_RETURN_SLOT_OPT in
kono
parents:
diff changeset
1118 CALL_EXPR
kono
parents:
diff changeset
1119
kono
parents:
diff changeset
1120 OMP_SECTION_LAST in
kono
parents:
diff changeset
1121 OMP_SECTION
kono
parents:
diff changeset
1122
kono
parents:
diff changeset
1123 OMP_PARALLEL_COMBINED in
kono
parents:
diff changeset
1124 OMP_PARALLEL
kono
parents:
diff changeset
1125
kono
parents:
diff changeset
1126 OMP_ATOMIC_SEQ_CST in
kono
parents:
diff changeset
1127 OMP_ATOMIC*
kono
parents:
diff changeset
1128
kono
parents:
diff changeset
1129 OMP_CLAUSE_PRIVATE_OUTER_REF in
kono
parents:
diff changeset
1130 OMP_CLAUSE_PRIVATE
kono
parents:
diff changeset
1131
kono
parents:
diff changeset
1132 OMP_CLAUSE_LINEAR_NO_COPYOUT in
kono
parents:
diff changeset
1133 OMP_CLAUSE_LINEAR
kono
parents:
diff changeset
1134
kono
parents:
diff changeset
1135 TYPE_REF_IS_RVALUE in
kono
parents:
diff changeset
1136 REFERENCE_TYPE
kono
parents:
diff changeset
1137
kono
parents:
diff changeset
1138 ENUM_IS_OPAQUE in
kono
parents:
diff changeset
1139 ENUMERAL_TYPE
kono
parents:
diff changeset
1140
kono
parents:
diff changeset
1141 protected_flag:
kono
parents:
diff changeset
1142
kono
parents:
diff changeset
1143 TREE_PROTECTED in
kono
parents:
diff changeset
1144 BLOCK
kono
parents:
diff changeset
1145 all decls
kono
parents:
diff changeset
1146
kono
parents:
diff changeset
1147 CALL_FROM_THUNK_P and
kono
parents:
diff changeset
1148 CALL_ALLOCA_FOR_VAR_P in
kono
parents:
diff changeset
1149 CALL_EXPR
kono
parents:
diff changeset
1150
kono
parents:
diff changeset
1151 OMP_CLAUSE_LINEAR_VARIABLE_STRIDE in
kono
parents:
diff changeset
1152 OMP_CLAUSE_LINEAR
kono
parents:
diff changeset
1153
kono
parents:
diff changeset
1154 side_effects_flag:
kono
parents:
diff changeset
1155
kono
parents:
diff changeset
1156 TREE_SIDE_EFFECTS in
kono
parents:
diff changeset
1157 all expressions
kono
parents:
diff changeset
1158 all decls
kono
parents:
diff changeset
1159 all constants
kono
parents:
diff changeset
1160
kono
parents:
diff changeset
1161 FORCED_LABEL in
kono
parents:
diff changeset
1162 LABEL_DECL
kono
parents:
diff changeset
1163
kono
parents:
diff changeset
1164 volatile_flag:
kono
parents:
diff changeset
1165
kono
parents:
diff changeset
1166 TREE_THIS_VOLATILE in
kono
parents:
diff changeset
1167 all expressions
kono
parents:
diff changeset
1168 all decls
kono
parents:
diff changeset
1169
kono
parents:
diff changeset
1170 TYPE_VOLATILE in
kono
parents:
diff changeset
1171 all types
kono
parents:
diff changeset
1172
kono
parents:
diff changeset
1173 readonly_flag:
kono
parents:
diff changeset
1174
kono
parents:
diff changeset
1175 TREE_READONLY in
kono
parents:
diff changeset
1176 all expressions
kono
parents:
diff changeset
1177 all decls
kono
parents:
diff changeset
1178
kono
parents:
diff changeset
1179 TYPE_READONLY in
kono
parents:
diff changeset
1180 all types
kono
parents:
diff changeset
1181
kono
parents:
diff changeset
1182 constant_flag:
kono
parents:
diff changeset
1183
kono
parents:
diff changeset
1184 TREE_CONSTANT in
kono
parents:
diff changeset
1185 all expressions
kono
parents:
diff changeset
1186 all decls
kono
parents:
diff changeset
1187 all constants
kono
parents:
diff changeset
1188
kono
parents:
diff changeset
1189 TYPE_SIZES_GIMPLIFIED in
kono
parents:
diff changeset
1190 all types
kono
parents:
diff changeset
1191
kono
parents:
diff changeset
1192 unsigned_flag:
kono
parents:
diff changeset
1193
kono
parents:
diff changeset
1194 TYPE_UNSIGNED in
kono
parents:
diff changeset
1195 all types
kono
parents:
diff changeset
1196
kono
parents:
diff changeset
1197 DECL_UNSIGNED in
kono
parents:
diff changeset
1198 all decls
kono
parents:
diff changeset
1199
kono
parents:
diff changeset
1200 asm_written_flag:
kono
parents:
diff changeset
1201
kono
parents:
diff changeset
1202 TREE_ASM_WRITTEN in
kono
parents:
diff changeset
1203 VAR_DECL, FUNCTION_DECL, TYPE_DECL
kono
parents:
diff changeset
1204 RECORD_TYPE, UNION_TYPE, QUAL_UNION_TYPE
kono
parents:
diff changeset
1205 BLOCK, STRING_CST
kono
parents:
diff changeset
1206
kono
parents:
diff changeset
1207 SSA_NAME_OCCURS_IN_ABNORMAL_PHI in
kono
parents:
diff changeset
1208 SSA_NAME
kono
parents:
diff changeset
1209
kono
parents:
diff changeset
1210 used_flag:
kono
parents:
diff changeset
1211
kono
parents:
diff changeset
1212 TREE_USED in
kono
parents:
diff changeset
1213 all expressions
kono
parents:
diff changeset
1214 all decls
kono
parents:
diff changeset
1215 IDENTIFIER_NODE
kono
parents:
diff changeset
1216
kono
parents:
diff changeset
1217 nothrow_flag:
kono
parents:
diff changeset
1218
kono
parents:
diff changeset
1219 TREE_NOTHROW in
kono
parents:
diff changeset
1220 CALL_EXPR
kono
parents:
diff changeset
1221 FUNCTION_DECL
kono
parents:
diff changeset
1222
kono
parents:
diff changeset
1223 TREE_THIS_NOTRAP in
kono
parents:
diff changeset
1224 INDIRECT_REF, MEM_REF, TARGET_MEM_REF, ARRAY_REF, ARRAY_RANGE_REF
kono
parents:
diff changeset
1225
kono
parents:
diff changeset
1226 SSA_NAME_IN_FREE_LIST in
kono
parents:
diff changeset
1227 SSA_NAME
kono
parents:
diff changeset
1228
kono
parents:
diff changeset
1229 DECL_NONALIASED in
kono
parents:
diff changeset
1230 VAR_DECL
kono
parents:
diff changeset
1231
kono
parents:
diff changeset
1232 deprecated_flag:
kono
parents:
diff changeset
1233
kono
parents:
diff changeset
1234 TREE_DEPRECATED in
kono
parents:
diff changeset
1235 all decls
kono
parents:
diff changeset
1236 all types
kono
parents:
diff changeset
1237
kono
parents:
diff changeset
1238 IDENTIFIER_TRANSPARENT_ALIAS in
kono
parents:
diff changeset
1239 IDENTIFIER_NODE
kono
parents:
diff changeset
1240
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1241 SSA_NAME_POINTS_TO_READONLY_MEMORY in
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1242 SSA_NAME
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1243
111
kono
parents:
diff changeset
1244 visited:
kono
parents:
diff changeset
1245
kono
parents:
diff changeset
1246 TREE_VISITED in
kono
parents:
diff changeset
1247 all trees (used liberally by many passes)
kono
parents:
diff changeset
1248
kono
parents:
diff changeset
1249 saturating_flag:
kono
parents:
diff changeset
1250
kono
parents:
diff changeset
1251 TYPE_REVERSE_STORAGE_ORDER in
kono
parents:
diff changeset
1252 RECORD_TYPE, UNION_TYPE, QUAL_UNION_TYPE, ARRAY_TYPE
kono
parents:
diff changeset
1253
kono
parents:
diff changeset
1254 TYPE_SATURATING in
kono
parents:
diff changeset
1255 other types
kono
parents:
diff changeset
1256
kono
parents:
diff changeset
1257 VAR_DECL_IS_VIRTUAL_OPERAND in
kono
parents:
diff changeset
1258 VAR_DECL
kono
parents:
diff changeset
1259
kono
parents:
diff changeset
1260 nowarning_flag:
kono
parents:
diff changeset
1261
kono
parents:
diff changeset
1262 TREE_NO_WARNING in
kono
parents:
diff changeset
1263 all expressions
kono
parents:
diff changeset
1264 all decls
kono
parents:
diff changeset
1265
kono
parents:
diff changeset
1266 TYPE_ARTIFICIAL in
kono
parents:
diff changeset
1267 all types
kono
parents:
diff changeset
1268
kono
parents:
diff changeset
1269 default_def_flag:
kono
parents:
diff changeset
1270
kono
parents:
diff changeset
1271 TYPE_FINAL_P in
kono
parents:
diff changeset
1272 RECORD_TYPE, UNION_TYPE and QUAL_UNION_TYPE
kono
parents:
diff changeset
1273
kono
parents:
diff changeset
1274 TYPE_VECTOR_OPAQUE in
kono
parents:
diff changeset
1275 VECTOR_TYPE
kono
parents:
diff changeset
1276
kono
parents:
diff changeset
1277 SSA_NAME_IS_DEFAULT_DEF in
kono
parents:
diff changeset
1278 SSA_NAME
kono
parents:
diff changeset
1279
kono
parents:
diff changeset
1280 DECL_NONLOCAL_FRAME in
kono
parents:
diff changeset
1281 VAR_DECL
kono
parents:
diff changeset
1282
kono
parents:
diff changeset
1283 REF_REVERSE_STORAGE_ORDER in
kono
parents:
diff changeset
1284 BIT_FIELD_REF, MEM_REF
kono
parents:
diff changeset
1285
kono
parents:
diff changeset
1286 FUNC_ADDR_BY_DESCRIPTOR in
kono
parents:
diff changeset
1287 ADDR_EXPR
kono
parents:
diff changeset
1288
kono
parents:
diff changeset
1289 CALL_EXPR_BY_DESCRIPTOR in
kono
parents:
diff changeset
1290 CALL_EXPR
kono
parents:
diff changeset
1291 */
kono
parents:
diff changeset
1292
kono
parents:
diff changeset
1293 struct GTY(()) tree_typed {
kono
parents:
diff changeset
1294 struct tree_base base;
kono
parents:
diff changeset
1295 tree type;
kono
parents:
diff changeset
1296 };
kono
parents:
diff changeset
1297
kono
parents:
diff changeset
1298 struct GTY(()) tree_common {
kono
parents:
diff changeset
1299 struct tree_typed typed;
kono
parents:
diff changeset
1300 tree chain;
kono
parents:
diff changeset
1301 };
kono
parents:
diff changeset
1302
kono
parents:
diff changeset
1303 struct GTY(()) tree_int_cst {
kono
parents:
diff changeset
1304 struct tree_typed typed;
kono
parents:
diff changeset
1305 HOST_WIDE_INT val[1];
kono
parents:
diff changeset
1306 };
kono
parents:
diff changeset
1307
kono
parents:
diff changeset
1308
kono
parents:
diff changeset
1309 struct GTY(()) tree_real_cst {
kono
parents:
diff changeset
1310 struct tree_typed typed;
kono
parents:
diff changeset
1311 struct real_value * real_cst_ptr;
kono
parents:
diff changeset
1312 };
kono
parents:
diff changeset
1313
kono
parents:
diff changeset
1314 struct GTY(()) tree_fixed_cst {
kono
parents:
diff changeset
1315 struct tree_typed typed;
kono
parents:
diff changeset
1316 struct fixed_value * fixed_cst_ptr;
kono
parents:
diff changeset
1317 };
kono
parents:
diff changeset
1318
kono
parents:
diff changeset
1319 struct GTY(()) tree_string {
kono
parents:
diff changeset
1320 struct tree_typed typed;
kono
parents:
diff changeset
1321 int length;
kono
parents:
diff changeset
1322 char str[1];
kono
parents:
diff changeset
1323 };
kono
parents:
diff changeset
1324
kono
parents:
diff changeset
1325 struct GTY(()) tree_complex {
kono
parents:
diff changeset
1326 struct tree_typed typed;
kono
parents:
diff changeset
1327 tree real;
kono
parents:
diff changeset
1328 tree imag;
kono
parents:
diff changeset
1329 };
kono
parents:
diff changeset
1330
kono
parents:
diff changeset
1331 struct GTY(()) tree_vector {
kono
parents:
diff changeset
1332 struct tree_typed typed;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1333 tree GTY ((length ("vector_cst_encoded_nelts ((tree) &%h)"))) elts[1];
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1334 };
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1335
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1336 struct GTY(()) tree_poly_int_cst {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1337 struct tree_typed typed;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1338 tree coeffs[NUM_POLY_INT_COEFFS];
111
kono
parents:
diff changeset
1339 };
kono
parents:
diff changeset
1340
kono
parents:
diff changeset
1341 struct GTY(()) tree_identifier {
kono
parents:
diff changeset
1342 struct tree_common common;
kono
parents:
diff changeset
1343 struct ht_identifier id;
kono
parents:
diff changeset
1344 };
kono
parents:
diff changeset
1345
kono
parents:
diff changeset
1346 struct GTY(()) tree_list {
kono
parents:
diff changeset
1347 struct tree_common common;
kono
parents:
diff changeset
1348 tree purpose;
kono
parents:
diff changeset
1349 tree value;
kono
parents:
diff changeset
1350 };
kono
parents:
diff changeset
1351
kono
parents:
diff changeset
1352 struct GTY(()) tree_vec {
kono
parents:
diff changeset
1353 struct tree_common common;
kono
parents:
diff changeset
1354 tree GTY ((length ("TREE_VEC_LENGTH ((tree)&%h)"))) a[1];
kono
parents:
diff changeset
1355 };
kono
parents:
diff changeset
1356
kono
parents:
diff changeset
1357 /* A single element of a CONSTRUCTOR. VALUE holds the actual value of the
kono
parents:
diff changeset
1358 element. INDEX can optionally design the position of VALUE: in arrays,
kono
parents:
diff changeset
1359 it is the index where VALUE has to be placed; in structures, it is the
kono
parents:
diff changeset
1360 FIELD_DECL of the member. */
kono
parents:
diff changeset
1361 struct GTY(()) constructor_elt {
kono
parents:
diff changeset
1362 tree index;
kono
parents:
diff changeset
1363 tree value;
kono
parents:
diff changeset
1364 };
kono
parents:
diff changeset
1365
kono
parents:
diff changeset
1366 struct GTY(()) tree_constructor {
kono
parents:
diff changeset
1367 struct tree_typed typed;
kono
parents:
diff changeset
1368 vec<constructor_elt, va_gc> *elts;
kono
parents:
diff changeset
1369 };
kono
parents:
diff changeset
1370
kono
parents:
diff changeset
1371 enum omp_clause_depend_kind
kono
parents:
diff changeset
1372 {
kono
parents:
diff changeset
1373 OMP_CLAUSE_DEPEND_IN,
kono
parents:
diff changeset
1374 OMP_CLAUSE_DEPEND_OUT,
kono
parents:
diff changeset
1375 OMP_CLAUSE_DEPEND_INOUT,
kono
parents:
diff changeset
1376 OMP_CLAUSE_DEPEND_SOURCE,
kono
parents:
diff changeset
1377 OMP_CLAUSE_DEPEND_SINK,
kono
parents:
diff changeset
1378 OMP_CLAUSE_DEPEND_LAST
kono
parents:
diff changeset
1379 };
kono
parents:
diff changeset
1380
kono
parents:
diff changeset
1381 enum omp_clause_proc_bind_kind
kono
parents:
diff changeset
1382 {
kono
parents:
diff changeset
1383 /* Numbers should match omp_proc_bind_t enum in omp.h. */
kono
parents:
diff changeset
1384 OMP_CLAUSE_PROC_BIND_FALSE = 0,
kono
parents:
diff changeset
1385 OMP_CLAUSE_PROC_BIND_TRUE = 1,
kono
parents:
diff changeset
1386 OMP_CLAUSE_PROC_BIND_MASTER = 2,
kono
parents:
diff changeset
1387 OMP_CLAUSE_PROC_BIND_CLOSE = 3,
kono
parents:
diff changeset
1388 OMP_CLAUSE_PROC_BIND_SPREAD = 4,
kono
parents:
diff changeset
1389 OMP_CLAUSE_PROC_BIND_LAST
kono
parents:
diff changeset
1390 };
kono
parents:
diff changeset
1391
kono
parents:
diff changeset
1392 enum omp_clause_linear_kind
kono
parents:
diff changeset
1393 {
kono
parents:
diff changeset
1394 OMP_CLAUSE_LINEAR_DEFAULT,
kono
parents:
diff changeset
1395 OMP_CLAUSE_LINEAR_REF,
kono
parents:
diff changeset
1396 OMP_CLAUSE_LINEAR_VAL,
kono
parents:
diff changeset
1397 OMP_CLAUSE_LINEAR_UVAL
kono
parents:
diff changeset
1398 };
kono
parents:
diff changeset
1399
kono
parents:
diff changeset
1400 struct GTY(()) tree_exp {
kono
parents:
diff changeset
1401 struct tree_typed typed;
kono
parents:
diff changeset
1402 location_t locus;
kono
parents:
diff changeset
1403 tree GTY ((special ("tree_exp"),
kono
parents:
diff changeset
1404 desc ("TREE_CODE ((tree) &%0)")))
kono
parents:
diff changeset
1405 operands[1];
kono
parents:
diff changeset
1406 };
kono
parents:
diff changeset
1407
kono
parents:
diff changeset
1408 /* Immediate use linking structure. This structure is used for maintaining
kono
parents:
diff changeset
1409 a doubly linked list of uses of an SSA_NAME. */
kono
parents:
diff changeset
1410 struct GTY(()) ssa_use_operand_t {
kono
parents:
diff changeset
1411 struct ssa_use_operand_t* GTY((skip(""))) prev;
kono
parents:
diff changeset
1412 struct ssa_use_operand_t* GTY((skip(""))) next;
kono
parents:
diff changeset
1413 /* Immediate uses for a given SSA name are maintained as a cyclic
kono
parents:
diff changeset
1414 list. To recognize the root of this list, the location field
kono
parents:
diff changeset
1415 needs to point to the original SSA name. Since statements and
kono
parents:
diff changeset
1416 SSA names are of different data types, we need this union. See
kono
parents:
diff changeset
1417 the explanation in struct imm_use_iterator. */
kono
parents:
diff changeset
1418 union { gimple *stmt; tree ssa_name; } GTY((skip(""))) loc;
kono
parents:
diff changeset
1419 tree *GTY((skip(""))) use;
kono
parents:
diff changeset
1420 };
kono
parents:
diff changeset
1421
kono
parents:
diff changeset
1422 struct GTY(()) tree_ssa_name {
kono
parents:
diff changeset
1423 struct tree_typed typed;
kono
parents:
diff changeset
1424
kono
parents:
diff changeset
1425 /* _DECL wrapped by this SSA name. */
kono
parents:
diff changeset
1426 tree var;
kono
parents:
diff changeset
1427
kono
parents:
diff changeset
1428 /* Statement that defines this SSA name. */
kono
parents:
diff changeset
1429 gimple *def_stmt;
kono
parents:
diff changeset
1430
kono
parents:
diff changeset
1431 /* Value range information. */
kono
parents:
diff changeset
1432 union ssa_name_info_type {
kono
parents:
diff changeset
1433 /* Pointer attributes used for alias analysis. */
kono
parents:
diff changeset
1434 struct GTY ((tag ("0"))) ptr_info_def *ptr_info;
kono
parents:
diff changeset
1435 /* Value range attributes used for zero/sign extension elimination. */
kono
parents:
diff changeset
1436 struct GTY ((tag ("1"))) range_info_def *range_info;
kono
parents:
diff changeset
1437 } GTY ((desc ("%1.typed.type ?" \
kono
parents:
diff changeset
1438 "!POINTER_TYPE_P (TREE_TYPE ((tree)&%1)) : 2"))) info;
kono
parents:
diff changeset
1439
kono
parents:
diff changeset
1440 /* Immediate uses list for this SSA_NAME. */
kono
parents:
diff changeset
1441 struct ssa_use_operand_t imm_uses;
kono
parents:
diff changeset
1442 };
kono
parents:
diff changeset
1443
kono
parents:
diff changeset
1444 struct GTY(()) phi_arg_d {
kono
parents:
diff changeset
1445 /* imm_use MUST be the first element in struct because we do some
kono
parents:
diff changeset
1446 pointer arithmetic with it. See phi_arg_index_from_use. */
kono
parents:
diff changeset
1447 struct ssa_use_operand_t imm_use;
kono
parents:
diff changeset
1448 tree def;
kono
parents:
diff changeset
1449 location_t locus;
kono
parents:
diff changeset
1450 };
kono
parents:
diff changeset
1451
kono
parents:
diff changeset
1452 struct GTY(()) tree_omp_clause {
kono
parents:
diff changeset
1453 struct tree_common common;
kono
parents:
diff changeset
1454 location_t locus;
kono
parents:
diff changeset
1455 enum omp_clause_code code;
kono
parents:
diff changeset
1456 union omp_clause_subcode {
kono
parents:
diff changeset
1457 enum omp_clause_default_kind default_kind;
kono
parents:
diff changeset
1458 enum omp_clause_schedule_kind schedule_kind;
kono
parents:
diff changeset
1459 enum omp_clause_depend_kind depend_kind;
kono
parents:
diff changeset
1460 /* See include/gomp-constants.h for enum gomp_map_kind's values. */
kono
parents:
diff changeset
1461 unsigned int map_kind;
kono
parents:
diff changeset
1462 enum omp_clause_proc_bind_kind proc_bind_kind;
kono
parents:
diff changeset
1463 enum tree_code reduction_code;
kono
parents:
diff changeset
1464 enum omp_clause_linear_kind linear_kind;
kono
parents:
diff changeset
1465 enum tree_code if_modifier;
kono
parents:
diff changeset
1466 /* The dimension a OMP_CLAUSE__GRIDDIM_ clause of a gridified target
kono
parents:
diff changeset
1467 construct describes. */
kono
parents:
diff changeset
1468 unsigned int dimension;
kono
parents:
diff changeset
1469 } GTY ((skip)) subcode;
kono
parents:
diff changeset
1470
kono
parents:
diff changeset
1471 /* The gimplification of OMP_CLAUSE_REDUCTION_{INIT,MERGE} for omp-low's
kono
parents:
diff changeset
1472 usage. */
kono
parents:
diff changeset
1473 gimple_seq gimple_reduction_init;
kono
parents:
diff changeset
1474 gimple_seq gimple_reduction_merge;
kono
parents:
diff changeset
1475
kono
parents:
diff changeset
1476 tree GTY ((length ("omp_clause_num_ops[OMP_CLAUSE_CODE ((tree)&%h)]")))
kono
parents:
diff changeset
1477 ops[1];
kono
parents:
diff changeset
1478 };
kono
parents:
diff changeset
1479
kono
parents:
diff changeset
1480 struct GTY(()) tree_block {
kono
parents:
diff changeset
1481 struct tree_base base;
kono
parents:
diff changeset
1482 tree chain;
kono
parents:
diff changeset
1483
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1484 unsigned block_num;
111
kono
parents:
diff changeset
1485
kono
parents:
diff changeset
1486 location_t locus;
kono
parents:
diff changeset
1487 location_t end_locus;
kono
parents:
diff changeset
1488
kono
parents:
diff changeset
1489 tree vars;
kono
parents:
diff changeset
1490 vec<tree, va_gc> *nonlocalized_vars;
kono
parents:
diff changeset
1491
kono
parents:
diff changeset
1492 tree subblocks;
kono
parents:
diff changeset
1493 tree supercontext;
kono
parents:
diff changeset
1494 tree abstract_origin;
kono
parents:
diff changeset
1495 tree fragment_origin;
kono
parents:
diff changeset
1496 tree fragment_chain;
kono
parents:
diff changeset
1497
kono
parents:
diff changeset
1498 /* Pointer to the DWARF lexical block. */
kono
parents:
diff changeset
1499 struct die_struct *die;
kono
parents:
diff changeset
1500 };
kono
parents:
diff changeset
1501
kono
parents:
diff changeset
1502 struct GTY(()) tree_type_common {
kono
parents:
diff changeset
1503 struct tree_common common;
kono
parents:
diff changeset
1504 tree size;
kono
parents:
diff changeset
1505 tree size_unit;
kono
parents:
diff changeset
1506 tree attributes;
kono
parents:
diff changeset
1507 unsigned int uid;
kono
parents:
diff changeset
1508
kono
parents:
diff changeset
1509 unsigned int precision : 10;
kono
parents:
diff changeset
1510 unsigned no_force_blk_flag : 1;
kono
parents:
diff changeset
1511 unsigned needs_constructing_flag : 1;
kono
parents:
diff changeset
1512 unsigned transparent_aggr_flag : 1;
kono
parents:
diff changeset
1513 unsigned restrict_flag : 1;
kono
parents:
diff changeset
1514 unsigned contains_placeholder_bits : 2;
kono
parents:
diff changeset
1515
kono
parents:
diff changeset
1516 ENUM_BITFIELD(machine_mode) mode : 8;
kono
parents:
diff changeset
1517
kono
parents:
diff changeset
1518 unsigned string_flag : 1;
kono
parents:
diff changeset
1519 unsigned lang_flag_0 : 1;
kono
parents:
diff changeset
1520 unsigned lang_flag_1 : 1;
kono
parents:
diff changeset
1521 unsigned lang_flag_2 : 1;
kono
parents:
diff changeset
1522 unsigned lang_flag_3 : 1;
kono
parents:
diff changeset
1523 unsigned lang_flag_4 : 1;
kono
parents:
diff changeset
1524 unsigned lang_flag_5 : 1;
kono
parents:
diff changeset
1525 unsigned lang_flag_6 : 1;
kono
parents:
diff changeset
1526 unsigned lang_flag_7 : 1;
kono
parents:
diff changeset
1527
kono
parents:
diff changeset
1528 /* TYPE_ALIGN in log2; this has to be large enough to hold values
kono
parents:
diff changeset
1529 of the maximum of BIGGEST_ALIGNMENT and MAX_OFILE_ALIGNMENT,
kono
parents:
diff changeset
1530 the latter being usually the larger. For ELF it is 8<<28,
kono
parents:
diff changeset
1531 so we need to store the value 32 (not 31, as we need the zero
kono
parents:
diff changeset
1532 as well), hence six bits. */
kono
parents:
diff changeset
1533 unsigned align : 6;
kono
parents:
diff changeset
1534 unsigned warn_if_not_align : 6;
kono
parents:
diff changeset
1535 unsigned typeless_storage : 1;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1536 unsigned empty_flag : 1;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1537 unsigned spare : 17;
111
kono
parents:
diff changeset
1538
kono
parents:
diff changeset
1539 alias_set_type alias_set;
kono
parents:
diff changeset
1540 tree pointer_to;
kono
parents:
diff changeset
1541 tree reference_to;
kono
parents:
diff changeset
1542 union tree_type_symtab {
kono
parents:
diff changeset
1543 int GTY ((tag ("TYPE_SYMTAB_IS_ADDRESS"))) address;
kono
parents:
diff changeset
1544 struct die_struct * GTY ((tag ("TYPE_SYMTAB_IS_DIE"))) die;
kono
parents:
diff changeset
1545 } GTY ((desc ("debug_hooks->tree_type_symtab_field"))) symtab;
kono
parents:
diff changeset
1546 tree canonical;
kono
parents:
diff changeset
1547 tree next_variant;
kono
parents:
diff changeset
1548 tree main_variant;
kono
parents:
diff changeset
1549 tree context;
kono
parents:
diff changeset
1550 tree name;
kono
parents:
diff changeset
1551 };
kono
parents:
diff changeset
1552
kono
parents:
diff changeset
1553 struct GTY(()) tree_type_with_lang_specific {
kono
parents:
diff changeset
1554 struct tree_type_common common;
kono
parents:
diff changeset
1555 /* Points to a structure whose details depend on the language in use. */
kono
parents:
diff changeset
1556 struct lang_type *lang_specific;
kono
parents:
diff changeset
1557 };
kono
parents:
diff changeset
1558
kono
parents:
diff changeset
1559 struct GTY(()) tree_type_non_common {
kono
parents:
diff changeset
1560 struct tree_type_with_lang_specific with_lang_specific;
kono
parents:
diff changeset
1561 tree values;
kono
parents:
diff changeset
1562 tree minval;
kono
parents:
diff changeset
1563 tree maxval;
kono
parents:
diff changeset
1564 tree lang_1;
kono
parents:
diff changeset
1565 };
kono
parents:
diff changeset
1566
kono
parents:
diff changeset
1567 struct GTY (()) tree_binfo {
kono
parents:
diff changeset
1568 struct tree_common common;
kono
parents:
diff changeset
1569
kono
parents:
diff changeset
1570 tree offset;
kono
parents:
diff changeset
1571 tree vtable;
kono
parents:
diff changeset
1572 tree virtuals;
kono
parents:
diff changeset
1573 tree vptr_field;
kono
parents:
diff changeset
1574 vec<tree, va_gc> *base_accesses;
kono
parents:
diff changeset
1575 tree inheritance;
kono
parents:
diff changeset
1576
kono
parents:
diff changeset
1577 tree vtt_subvtt;
kono
parents:
diff changeset
1578 tree vtt_vptr;
kono
parents:
diff changeset
1579
kono
parents:
diff changeset
1580 vec<tree, va_gc> base_binfos;
kono
parents:
diff changeset
1581 };
kono
parents:
diff changeset
1582
kono
parents:
diff changeset
1583 struct GTY(()) tree_decl_minimal {
kono
parents:
diff changeset
1584 struct tree_common common;
kono
parents:
diff changeset
1585 location_t locus;
kono
parents:
diff changeset
1586 unsigned int uid;
kono
parents:
diff changeset
1587 tree name;
kono
parents:
diff changeset
1588 tree context;
kono
parents:
diff changeset
1589 };
kono
parents:
diff changeset
1590
kono
parents:
diff changeset
1591 struct GTY(()) tree_decl_common {
kono
parents:
diff changeset
1592 struct tree_decl_minimal common;
kono
parents:
diff changeset
1593 tree size;
kono
parents:
diff changeset
1594
kono
parents:
diff changeset
1595 ENUM_BITFIELD(machine_mode) mode : 8;
kono
parents:
diff changeset
1596
kono
parents:
diff changeset
1597 unsigned nonlocal_flag : 1;
kono
parents:
diff changeset
1598 unsigned virtual_flag : 1;
kono
parents:
diff changeset
1599 unsigned ignored_flag : 1;
kono
parents:
diff changeset
1600 unsigned abstract_flag : 1;
kono
parents:
diff changeset
1601 unsigned artificial_flag : 1;
kono
parents:
diff changeset
1602 unsigned preserve_flag: 1;
kono
parents:
diff changeset
1603 unsigned debug_expr_is_from : 1;
kono
parents:
diff changeset
1604
kono
parents:
diff changeset
1605 unsigned lang_flag_0 : 1;
kono
parents:
diff changeset
1606 unsigned lang_flag_1 : 1;
kono
parents:
diff changeset
1607 unsigned lang_flag_2 : 1;
kono
parents:
diff changeset
1608 unsigned lang_flag_3 : 1;
kono
parents:
diff changeset
1609 unsigned lang_flag_4 : 1;
kono
parents:
diff changeset
1610 unsigned lang_flag_5 : 1;
kono
parents:
diff changeset
1611 unsigned lang_flag_6 : 1;
kono
parents:
diff changeset
1612 unsigned lang_flag_7 : 1;
kono
parents:
diff changeset
1613 unsigned lang_flag_8 : 1;
kono
parents:
diff changeset
1614
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1615 /* In VAR_DECL and PARM_DECL, this is DECL_REGISTER
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1616 IN TRANSLATION_UNIT_DECL, this is TRANSLATION_UNIT_WARN_EMPTY_P. */
111
kono
parents:
diff changeset
1617 unsigned decl_flag_0 : 1;
kono
parents:
diff changeset
1618 /* In FIELD_DECL, this is DECL_BIT_FIELD
kono
parents:
diff changeset
1619 In VAR_DECL and FUNCTION_DECL, this is DECL_EXTERNAL.
kono
parents:
diff changeset
1620 In TYPE_DECL, this is TYPE_DECL_SUPPRESS_DEBUG. */
kono
parents:
diff changeset
1621 unsigned decl_flag_1 : 1;
kono
parents:
diff changeset
1622 /* In FIELD_DECL, this is DECL_NONADDRESSABLE_P
kono
parents:
diff changeset
1623 In VAR_DECL, PARM_DECL and RESULT_DECL, this is
kono
parents:
diff changeset
1624 DECL_HAS_VALUE_EXPR_P. */
kono
parents:
diff changeset
1625 unsigned decl_flag_2 : 1;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1626 /* In FIELD_DECL, this is DECL_PADDING_P. */
111
kono
parents:
diff changeset
1627 unsigned decl_flag_3 : 1;
kono
parents:
diff changeset
1628 /* Logically, these two would go in a theoretical base shared by var and
kono
parents:
diff changeset
1629 parm decl. */
kono
parents:
diff changeset
1630 unsigned gimple_reg_flag : 1;
kono
parents:
diff changeset
1631 /* In VAR_DECL, PARM_DECL and RESULT_DECL, this is DECL_BY_REFERENCE. */
kono
parents:
diff changeset
1632 unsigned decl_by_reference_flag : 1;
kono
parents:
diff changeset
1633 /* In a VAR_DECL and PARM_DECL, this is DECL_READ_P. */
kono
parents:
diff changeset
1634 unsigned decl_read_flag : 1;
kono
parents:
diff changeset
1635 /* In a VAR_DECL or RESULT_DECL, this is DECL_NONSHAREABLE. */
kono
parents:
diff changeset
1636 unsigned decl_nonshareable_flag : 1;
kono
parents:
diff changeset
1637
kono
parents:
diff changeset
1638 /* DECL_OFFSET_ALIGN, used only for FIELD_DECLs. */
kono
parents:
diff changeset
1639 unsigned int off_align : 6;
kono
parents:
diff changeset
1640
kono
parents:
diff changeset
1641 /* DECL_ALIGN. It should have the same size as TYPE_ALIGN. */
kono
parents:
diff changeset
1642 unsigned int align : 6;
kono
parents:
diff changeset
1643
kono
parents:
diff changeset
1644 /* DECL_WARN_IF_NOT_ALIGN. It should have the same size as
kono
parents:
diff changeset
1645 TYPE_WARN_IF_NOT_ALIGN. */
kono
parents:
diff changeset
1646 unsigned int warn_if_not_align : 6;
kono
parents:
diff changeset
1647
kono
parents:
diff changeset
1648 /* 14 bits unused. */
kono
parents:
diff changeset
1649
kono
parents:
diff changeset
1650 /* UID for points-to sets, stable over copying from inlining. */
kono
parents:
diff changeset
1651 unsigned int pt_uid;
kono
parents:
diff changeset
1652
kono
parents:
diff changeset
1653 tree size_unit;
kono
parents:
diff changeset
1654 tree initial;
kono
parents:
diff changeset
1655 tree attributes;
kono
parents:
diff changeset
1656 tree abstract_origin;
kono
parents:
diff changeset
1657
kono
parents:
diff changeset
1658 /* Points to a structure whose details depend on the language in use. */
kono
parents:
diff changeset
1659 struct lang_decl *lang_specific;
kono
parents:
diff changeset
1660 };
kono
parents:
diff changeset
1661
kono
parents:
diff changeset
1662 struct GTY(()) tree_decl_with_rtl {
kono
parents:
diff changeset
1663 struct tree_decl_common common;
kono
parents:
diff changeset
1664 rtx rtl;
kono
parents:
diff changeset
1665 };
kono
parents:
diff changeset
1666
kono
parents:
diff changeset
1667 struct GTY(()) tree_field_decl {
kono
parents:
diff changeset
1668 struct tree_decl_common common;
kono
parents:
diff changeset
1669
kono
parents:
diff changeset
1670 tree offset;
kono
parents:
diff changeset
1671 tree bit_field_type;
kono
parents:
diff changeset
1672 tree qualifier;
kono
parents:
diff changeset
1673 tree bit_offset;
kono
parents:
diff changeset
1674 tree fcontext;
kono
parents:
diff changeset
1675 };
kono
parents:
diff changeset
1676
kono
parents:
diff changeset
1677 struct GTY(()) tree_label_decl {
kono
parents:
diff changeset
1678 struct tree_decl_with_rtl common;
kono
parents:
diff changeset
1679 int label_decl_uid;
kono
parents:
diff changeset
1680 int eh_landing_pad_nr;
kono
parents:
diff changeset
1681 };
kono
parents:
diff changeset
1682
kono
parents:
diff changeset
1683 struct GTY(()) tree_result_decl {
kono
parents:
diff changeset
1684 struct tree_decl_with_rtl common;
kono
parents:
diff changeset
1685 };
kono
parents:
diff changeset
1686
kono
parents:
diff changeset
1687 struct GTY(()) tree_const_decl {
kono
parents:
diff changeset
1688 struct tree_decl_common common;
kono
parents:
diff changeset
1689 };
kono
parents:
diff changeset
1690
kono
parents:
diff changeset
1691 struct GTY(()) tree_parm_decl {
kono
parents:
diff changeset
1692 struct tree_decl_with_rtl common;
kono
parents:
diff changeset
1693 rtx incoming_rtl;
kono
parents:
diff changeset
1694 };
kono
parents:
diff changeset
1695
kono
parents:
diff changeset
1696 struct GTY(()) tree_decl_with_vis {
kono
parents:
diff changeset
1697 struct tree_decl_with_rtl common;
kono
parents:
diff changeset
1698 tree assembler_name;
kono
parents:
diff changeset
1699 struct symtab_node *symtab_node;
kono
parents:
diff changeset
1700
kono
parents:
diff changeset
1701 /* Belong to VAR_DECL exclusively. */
kono
parents:
diff changeset
1702 unsigned defer_output : 1;
kono
parents:
diff changeset
1703 unsigned hard_register : 1;
kono
parents:
diff changeset
1704 unsigned common_flag : 1;
kono
parents:
diff changeset
1705 unsigned in_text_section : 1;
kono
parents:
diff changeset
1706 unsigned in_constant_pool : 1;
kono
parents:
diff changeset
1707 unsigned dllimport_flag : 1;
kono
parents:
diff changeset
1708 /* Don't belong to VAR_DECL exclusively. */
kono
parents:
diff changeset
1709 unsigned weak_flag : 1;
kono
parents:
diff changeset
1710
kono
parents:
diff changeset
1711 unsigned seen_in_bind_expr : 1;
kono
parents:
diff changeset
1712 unsigned comdat_flag : 1;
kono
parents:
diff changeset
1713 /* Used for FUNCTION_DECL, VAR_DECL and in C++ for TYPE_DECL. */
kono
parents:
diff changeset
1714 ENUM_BITFIELD(symbol_visibility) visibility : 2;
kono
parents:
diff changeset
1715 unsigned visibility_specified : 1;
kono
parents:
diff changeset
1716
kono
parents:
diff changeset
1717 /* Belong to FUNCTION_DECL exclusively. */
kono
parents:
diff changeset
1718 unsigned init_priority_p : 1;
kono
parents:
diff changeset
1719 /* Used by C++ only. Might become a generic decl flag. */
kono
parents:
diff changeset
1720 unsigned shadowed_for_var_p : 1;
kono
parents:
diff changeset
1721 /* Belong to FUNCTION_DECL exclusively. */
kono
parents:
diff changeset
1722 unsigned cxx_constructor : 1;
kono
parents:
diff changeset
1723 /* Belong to FUNCTION_DECL exclusively. */
kono
parents:
diff changeset
1724 unsigned cxx_destructor : 1;
kono
parents:
diff changeset
1725 /* Belong to FUNCTION_DECL exclusively. */
kono
parents:
diff changeset
1726 unsigned final : 1;
kono
parents:
diff changeset
1727 /* Belong to FUNCTION_DECL exclusively. */
kono
parents:
diff changeset
1728 unsigned regdecl_flag : 1;
kono
parents:
diff changeset
1729 /* 14 unused bits. */
kono
parents:
diff changeset
1730 };
kono
parents:
diff changeset
1731
kono
parents:
diff changeset
1732 struct GTY(()) tree_var_decl {
kono
parents:
diff changeset
1733 struct tree_decl_with_vis common;
kono
parents:
diff changeset
1734 };
kono
parents:
diff changeset
1735
kono
parents:
diff changeset
1736 struct GTY(()) tree_decl_non_common {
kono
parents:
diff changeset
1737 struct tree_decl_with_vis common;
kono
parents:
diff changeset
1738 /* Almost all FE's use this. */
kono
parents:
diff changeset
1739 tree result;
kono
parents:
diff changeset
1740 };
kono
parents:
diff changeset
1741
kono
parents:
diff changeset
1742 /* FUNCTION_DECL inherits from DECL_NON_COMMON because of the use of the
kono
parents:
diff changeset
1743 arguments/result/saved_tree fields by front ends. It was either inherit
kono
parents:
diff changeset
1744 FUNCTION_DECL from non_common, or inherit non_common from FUNCTION_DECL,
kono
parents:
diff changeset
1745 which seemed a bit strange. */
kono
parents:
diff changeset
1746
kono
parents:
diff changeset
1747 struct GTY(()) tree_function_decl {
kono
parents:
diff changeset
1748 struct tree_decl_non_common common;
kono
parents:
diff changeset
1749
kono
parents:
diff changeset
1750 struct function *f;
kono
parents:
diff changeset
1751
kono
parents:
diff changeset
1752 /* Arguments of the function. */
kono
parents:
diff changeset
1753 tree arguments;
kono
parents:
diff changeset
1754 /* The personality function. Used for stack unwinding. */
kono
parents:
diff changeset
1755 tree personality;
kono
parents:
diff changeset
1756
kono
parents:
diff changeset
1757 /* Function specific options that are used by this function. */
kono
parents:
diff changeset
1758 tree function_specific_target; /* target options */
kono
parents:
diff changeset
1759 tree function_specific_optimization; /* optimization options */
kono
parents:
diff changeset
1760
kono
parents:
diff changeset
1761 /* Generic function body. */
kono
parents:
diff changeset
1762 tree saved_tree;
kono
parents:
diff changeset
1763 /* Index within a virtual table. */
kono
parents:
diff changeset
1764 tree vindex;
kono
parents:
diff changeset
1765
kono
parents:
diff changeset
1766 /* In a FUNCTION_DECL for which DECL_BUILT_IN holds, this is
kono
parents:
diff changeset
1767 DECL_FUNCTION_CODE. Otherwise unused.
kono
parents:
diff changeset
1768 ??? The bitfield needs to be able to hold all target function
kono
parents:
diff changeset
1769 codes as well. */
kono
parents:
diff changeset
1770 ENUM_BITFIELD(built_in_function) function_code : 12;
kono
parents:
diff changeset
1771 ENUM_BITFIELD(built_in_class) built_in_class : 2;
kono
parents:
diff changeset
1772
kono
parents:
diff changeset
1773 unsigned static_ctor_flag : 1;
kono
parents:
diff changeset
1774 unsigned static_dtor_flag : 1;
kono
parents:
diff changeset
1775
kono
parents:
diff changeset
1776 unsigned uninlinable : 1;
kono
parents:
diff changeset
1777 unsigned possibly_inlined : 1;
kono
parents:
diff changeset
1778 unsigned novops_flag : 1;
kono
parents:
diff changeset
1779 unsigned returns_twice_flag : 1;
kono
parents:
diff changeset
1780 unsigned malloc_flag : 1;
kono
parents:
diff changeset
1781 unsigned operator_new_flag : 1;
kono
parents:
diff changeset
1782 unsigned declared_inline_flag : 1;
kono
parents:
diff changeset
1783 unsigned no_inline_warning_flag : 1;
kono
parents:
diff changeset
1784
kono
parents:
diff changeset
1785 unsigned no_instrument_function_entry_exit : 1;
kono
parents:
diff changeset
1786 unsigned no_limit_stack : 1;
kono
parents:
diff changeset
1787 unsigned disregard_inline_limits : 1;
kono
parents:
diff changeset
1788 unsigned pure_flag : 1;
kono
parents:
diff changeset
1789 unsigned looping_const_or_pure_flag : 1;
kono
parents:
diff changeset
1790 unsigned has_debug_args_flag : 1;
kono
parents:
diff changeset
1791 unsigned versioned_function : 1;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1792 unsigned lambda_function: 1;
111
kono
parents:
diff changeset
1793 /* No bits left. */
kono
parents:
diff changeset
1794 };
kono
parents:
diff changeset
1795
kono
parents:
diff changeset
1796 struct GTY(()) tree_translation_unit_decl {
kono
parents:
diff changeset
1797 struct tree_decl_common common;
kono
parents:
diff changeset
1798 /* Source language of this translation unit. Used for DWARF output. */
kono
parents:
diff changeset
1799 const char * GTY((skip(""))) language;
kono
parents:
diff changeset
1800 /* TODO: Non-optimization used to build this translation unit. */
kono
parents:
diff changeset
1801 /* TODO: Root of a partial DWARF tree for global types and decls. */
kono
parents:
diff changeset
1802 };
kono
parents:
diff changeset
1803
kono
parents:
diff changeset
1804 struct GTY(()) tree_type_decl {
kono
parents:
diff changeset
1805 struct tree_decl_non_common common;
kono
parents:
diff changeset
1806
kono
parents:
diff changeset
1807 };
kono
parents:
diff changeset
1808
kono
parents:
diff changeset
1809 struct GTY ((chain_next ("%h.next"), chain_prev ("%h.prev"))) tree_statement_list_node
kono
parents:
diff changeset
1810 {
kono
parents:
diff changeset
1811 struct tree_statement_list_node *prev;
kono
parents:
diff changeset
1812 struct tree_statement_list_node *next;
kono
parents:
diff changeset
1813 tree stmt;
kono
parents:
diff changeset
1814 };
kono
parents:
diff changeset
1815
kono
parents:
diff changeset
1816 struct GTY(()) tree_statement_list
kono
parents:
diff changeset
1817 {
kono
parents:
diff changeset
1818 struct tree_typed typed;
kono
parents:
diff changeset
1819 struct tree_statement_list_node *head;
kono
parents:
diff changeset
1820 struct tree_statement_list_node *tail;
kono
parents:
diff changeset
1821 };
kono
parents:
diff changeset
1822
kono
parents:
diff changeset
1823
kono
parents:
diff changeset
1824 /* Optimization options used by a function. */
kono
parents:
diff changeset
1825
kono
parents:
diff changeset
1826 struct GTY(()) tree_optimization_option {
kono
parents:
diff changeset
1827 struct tree_base base;
kono
parents:
diff changeset
1828
kono
parents:
diff changeset
1829 /* The optimization options used by the user. */
kono
parents:
diff changeset
1830 struct cl_optimization *opts;
kono
parents:
diff changeset
1831
kono
parents:
diff changeset
1832 /* Target optabs for this set of optimization options. This is of
kono
parents:
diff changeset
1833 type `struct target_optabs *'. */
kono
parents:
diff changeset
1834 void *GTY ((atomic)) optabs;
kono
parents:
diff changeset
1835
kono
parents:
diff changeset
1836 /* The value of this_target_optabs against which the optabs above were
kono
parents:
diff changeset
1837 generated. */
kono
parents:
diff changeset
1838 struct target_optabs *GTY ((skip)) base_optabs;
kono
parents:
diff changeset
1839 };
kono
parents:
diff changeset
1840
kono
parents:
diff changeset
1841 /* Forward declaration, defined in target-globals.h. */
kono
parents:
diff changeset
1842
kono
parents:
diff changeset
1843 struct GTY(()) target_globals;
kono
parents:
diff changeset
1844
kono
parents:
diff changeset
1845 /* Target options used by a function. */
kono
parents:
diff changeset
1846
kono
parents:
diff changeset
1847 struct GTY(()) tree_target_option {
kono
parents:
diff changeset
1848 struct tree_base base;
kono
parents:
diff changeset
1849
kono
parents:
diff changeset
1850 /* Target globals for the corresponding target option. */
kono
parents:
diff changeset
1851 struct target_globals *globals;
kono
parents:
diff changeset
1852
kono
parents:
diff changeset
1853 /* The optimization options used by the user. */
kono
parents:
diff changeset
1854 struct cl_target_option *opts;
kono
parents:
diff changeset
1855 };
kono
parents:
diff changeset
1856
kono
parents:
diff changeset
1857 /* Define the overall contents of a tree node.
kono
parents:
diff changeset
1858 It may be any of the structures declared above
kono
parents:
diff changeset
1859 for various types of node. */
kono
parents:
diff changeset
1860 union GTY ((ptr_alias (union lang_tree_node),
kono
parents:
diff changeset
1861 desc ("tree_node_structure (&%h)"), variable_size)) tree_node {
kono
parents:
diff changeset
1862 struct tree_base GTY ((tag ("TS_BASE"))) base;
kono
parents:
diff changeset
1863 struct tree_typed GTY ((tag ("TS_TYPED"))) typed;
kono
parents:
diff changeset
1864 struct tree_common GTY ((tag ("TS_COMMON"))) common;
kono
parents:
diff changeset
1865 struct tree_int_cst GTY ((tag ("TS_INT_CST"))) int_cst;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1866 struct tree_poly_int_cst GTY ((tag ("TS_POLY_INT_CST"))) poly_int_cst;
111
kono
parents:
diff changeset
1867 struct tree_real_cst GTY ((tag ("TS_REAL_CST"))) real_cst;
kono
parents:
diff changeset
1868 struct tree_fixed_cst GTY ((tag ("TS_FIXED_CST"))) fixed_cst;
kono
parents:
diff changeset
1869 struct tree_vector GTY ((tag ("TS_VECTOR"))) vector;
kono
parents:
diff changeset
1870 struct tree_string GTY ((tag ("TS_STRING"))) string;
kono
parents:
diff changeset
1871 struct tree_complex GTY ((tag ("TS_COMPLEX"))) complex;
kono
parents:
diff changeset
1872 struct tree_identifier GTY ((tag ("TS_IDENTIFIER"))) identifier;
kono
parents:
diff changeset
1873 struct tree_decl_minimal GTY((tag ("TS_DECL_MINIMAL"))) decl_minimal;
kono
parents:
diff changeset
1874 struct tree_decl_common GTY ((tag ("TS_DECL_COMMON"))) decl_common;
kono
parents:
diff changeset
1875 struct tree_decl_with_rtl GTY ((tag ("TS_DECL_WRTL"))) decl_with_rtl;
kono
parents:
diff changeset
1876 struct tree_decl_non_common GTY ((tag ("TS_DECL_NON_COMMON")))
kono
parents:
diff changeset
1877 decl_non_common;
kono
parents:
diff changeset
1878 struct tree_parm_decl GTY ((tag ("TS_PARM_DECL"))) parm_decl;
kono
parents:
diff changeset
1879 struct tree_decl_with_vis GTY ((tag ("TS_DECL_WITH_VIS"))) decl_with_vis;
kono
parents:
diff changeset
1880 struct tree_var_decl GTY ((tag ("TS_VAR_DECL"))) var_decl;
kono
parents:
diff changeset
1881 struct tree_field_decl GTY ((tag ("TS_FIELD_DECL"))) field_decl;
kono
parents:
diff changeset
1882 struct tree_label_decl GTY ((tag ("TS_LABEL_DECL"))) label_decl;
kono
parents:
diff changeset
1883 struct tree_result_decl GTY ((tag ("TS_RESULT_DECL"))) result_decl;
kono
parents:
diff changeset
1884 struct tree_const_decl GTY ((tag ("TS_CONST_DECL"))) const_decl;
kono
parents:
diff changeset
1885 struct tree_type_decl GTY ((tag ("TS_TYPE_DECL"))) type_decl;
kono
parents:
diff changeset
1886 struct tree_function_decl GTY ((tag ("TS_FUNCTION_DECL"))) function_decl;
kono
parents:
diff changeset
1887 struct tree_translation_unit_decl GTY ((tag ("TS_TRANSLATION_UNIT_DECL")))
kono
parents:
diff changeset
1888 translation_unit_decl;
kono
parents:
diff changeset
1889 struct tree_type_common GTY ((tag ("TS_TYPE_COMMON"))) type_common;
kono
parents:
diff changeset
1890 struct tree_type_with_lang_specific GTY ((tag ("TS_TYPE_WITH_LANG_SPECIFIC")))
kono
parents:
diff changeset
1891 type_with_lang_specific;
kono
parents:
diff changeset
1892 struct tree_type_non_common GTY ((tag ("TS_TYPE_NON_COMMON")))
kono
parents:
diff changeset
1893 type_non_common;
kono
parents:
diff changeset
1894 struct tree_list GTY ((tag ("TS_LIST"))) list;
kono
parents:
diff changeset
1895 struct tree_vec GTY ((tag ("TS_VEC"))) vec;
kono
parents:
diff changeset
1896 struct tree_exp GTY ((tag ("TS_EXP"))) exp;
kono
parents:
diff changeset
1897 struct tree_ssa_name GTY ((tag ("TS_SSA_NAME"))) ssa_name;
kono
parents:
diff changeset
1898 struct tree_block GTY ((tag ("TS_BLOCK"))) block;
kono
parents:
diff changeset
1899 struct tree_binfo GTY ((tag ("TS_BINFO"))) binfo;
kono
parents:
diff changeset
1900 struct tree_statement_list GTY ((tag ("TS_STATEMENT_LIST"))) stmt_list;
kono
parents:
diff changeset
1901 struct tree_constructor GTY ((tag ("TS_CONSTRUCTOR"))) constructor;
kono
parents:
diff changeset
1902 struct tree_omp_clause GTY ((tag ("TS_OMP_CLAUSE"))) omp_clause;
kono
parents:
diff changeset
1903 struct tree_optimization_option GTY ((tag ("TS_OPTIMIZATION"))) optimization;
kono
parents:
diff changeset
1904 struct tree_target_option GTY ((tag ("TS_TARGET_OPTION"))) target_option;
kono
parents:
diff changeset
1905 };
kono
parents:
diff changeset
1906
kono
parents:
diff changeset
1907 /* Structure describing an attribute and a function to handle it. */
kono
parents:
diff changeset
1908 struct attribute_spec {
kono
parents:
diff changeset
1909 /* The name of the attribute (without any leading or trailing __),
kono
parents:
diff changeset
1910 or NULL to mark the end of a table of attributes. */
kono
parents:
diff changeset
1911 const char *name;
kono
parents:
diff changeset
1912 /* The minimum length of the list of arguments of the attribute. */
kono
parents:
diff changeset
1913 int min_length;
kono
parents:
diff changeset
1914 /* The maximum length of the list of arguments of the attribute
kono
parents:
diff changeset
1915 (-1 for no maximum). */
kono
parents:
diff changeset
1916 int max_length;
kono
parents:
diff changeset
1917 /* Whether this attribute requires a DECL. If it does, it will be passed
kono
parents:
diff changeset
1918 from types of DECLs, function return types and array element types to
kono
parents:
diff changeset
1919 the DECLs, function types and array types respectively; but when
kono
parents:
diff changeset
1920 applied to a type in any other circumstances, it will be ignored with
kono
parents:
diff changeset
1921 a warning. (If greater control is desired for a given attribute,
kono
parents:
diff changeset
1922 this should be false, and the flags argument to the handler may be
kono
parents:
diff changeset
1923 used to gain greater control in that case.) */
kono
parents:
diff changeset
1924 bool decl_required;
kono
parents:
diff changeset
1925 /* Whether this attribute requires a type. If it does, it will be passed
kono
parents:
diff changeset
1926 from a DECL to the type of that DECL. */
kono
parents:
diff changeset
1927 bool type_required;
kono
parents:
diff changeset
1928 /* Whether this attribute requires a function (or method) type. If it does,
kono
parents:
diff changeset
1929 it will be passed from a function pointer type to the target type,
kono
parents:
diff changeset
1930 and from a function return type (which is not itself a function
kono
parents:
diff changeset
1931 pointer type) to the function type. */
kono
parents:
diff changeset
1932 bool function_type_required;
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1933 /* Specifies if attribute affects type's identity. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1934 bool affects_type_identity;
111
kono
parents:
diff changeset
1935 /* Function to handle this attribute. NODE points to the node to which
kono
parents:
diff changeset
1936 the attribute is to be applied. If a DECL, it should be modified in
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1937 place; if a TYPE, a copy should be created. NAME is the canonicalized
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1938 name of the attribute i.e. without any leading or trailing underscores.
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1939 ARGS is the TREE_LIST of the arguments (which may be NULL). FLAGS gives
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1940 further information about the context of the attribute. Afterwards, the
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1941 attributes will be added to the DECL_ATTRIBUTES or TYPE_ATTRIBUTES, as
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1942 appropriate, unless *NO_ADD_ATTRS is set to true (which should be done on
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1943 error, as well as in any other cases when the attributes should not be
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1944 added to the DECL or TYPE). Depending on FLAGS, any attributes to be
111
kono
parents:
diff changeset
1945 applied to another type or DECL later may be returned;
kono
parents:
diff changeset
1946 otherwise the return value should be NULL_TREE. This pointer may be
kono
parents:
diff changeset
1947 NULL if no special handling is required beyond the checks implied
kono
parents:
diff changeset
1948 by the rest of this structure. */
kono
parents:
diff changeset
1949 tree (*handler) (tree *node, tree name, tree args,
kono
parents:
diff changeset
1950 int flags, bool *no_add_attrs);
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1951
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1952 /* Specifies the name of an attribute that's mutually exclusive with
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1953 this one, and whether the relationship applies to the function,
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1954 variable, or type form of the attribute. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1955 struct exclusions {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1956 const char *name;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1957 bool function;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1958 bool variable;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1959 bool type;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1960 };
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1961
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1962 /* An array of attribute exclusions describing names of other attributes
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1963 that this attribute is mutually exclusive with. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
1964 const exclusions *exclude;
111
kono
parents:
diff changeset
1965 };
kono
parents:
diff changeset
1966
kono
parents:
diff changeset
1967 /* These functions allow a front-end to perform a manual layout of a
kono
parents:
diff changeset
1968 RECORD_TYPE. (For instance, if the placement of subsequent fields
kono
parents:
diff changeset
1969 depends on the placement of fields so far.) Begin by calling
kono
parents:
diff changeset
1970 start_record_layout. Then, call place_field for each of the
kono
parents:
diff changeset
1971 fields. Then, call finish_record_layout. See layout_type for the
kono
parents:
diff changeset
1972 default way in which these functions are used. */
kono
parents:
diff changeset
1973 typedef struct record_layout_info_s {
kono
parents:
diff changeset
1974 /* The RECORD_TYPE that we are laying out. */
kono
parents:
diff changeset
1975 tree t;
kono
parents:
diff changeset
1976 /* The offset into the record so far, in bytes, not including bits in
kono
parents:
diff changeset
1977 BITPOS. */
kono
parents:
diff changeset
1978 tree offset;
kono
parents:
diff changeset
1979 /* The last known alignment of SIZE. */
kono
parents:
diff changeset
1980 unsigned int offset_align;
kono
parents:
diff changeset
1981 /* The bit position within the last OFFSET_ALIGN bits, in bits. */
kono
parents:
diff changeset
1982 tree bitpos;
kono
parents:
diff changeset
1983 /* The alignment of the record so far, in bits. */
kono
parents:
diff changeset
1984 unsigned int record_align;
kono
parents:
diff changeset
1985 /* The alignment of the record so far, ignoring #pragma pack and
kono
parents:
diff changeset
1986 __attribute__ ((packed)), in bits. */
kono
parents:
diff changeset
1987 unsigned int unpacked_align;
kono
parents:
diff changeset
1988 /* The previous field laid out. */
kono
parents:
diff changeset
1989 tree prev_field;
kono
parents:
diff changeset
1990 /* The static variables (i.e., class variables, as opposed to
kono
parents:
diff changeset
1991 instance variables) encountered in T. */
kono
parents:
diff changeset
1992 vec<tree, va_gc> *pending_statics;
kono
parents:
diff changeset
1993 /* Bits remaining in the current alignment group */
kono
parents:
diff changeset
1994 int remaining_in_alignment;
kono
parents:
diff changeset
1995 /* True if we've seen a packed field that didn't have normal
kono
parents:
diff changeset
1996 alignment anyway. */
kono
parents:
diff changeset
1997 int packed_maybe_necessary;
kono
parents:
diff changeset
1998 } *record_layout_info;
kono
parents:
diff changeset
1999
kono
parents:
diff changeset
2000 /* Iterator for going through the function arguments. */
kono
parents:
diff changeset
2001 struct function_args_iterator {
kono
parents:
diff changeset
2002 tree next; /* TREE_LIST pointing to the next argument */
kono
parents:
diff changeset
2003 };
kono
parents:
diff changeset
2004
kono
parents:
diff changeset
2005 /* Structures to map from a tree to another tree. */
kono
parents:
diff changeset
2006 struct GTY(()) tree_map_base {
kono
parents:
diff changeset
2007 tree from;
kono
parents:
diff changeset
2008 };
kono
parents:
diff changeset
2009
kono
parents:
diff changeset
2010 /* Map from a tree to another tree. */
kono
parents:
diff changeset
2011
kono
parents:
diff changeset
2012 struct GTY((for_user)) tree_map {
kono
parents:
diff changeset
2013 struct tree_map_base base;
kono
parents:
diff changeset
2014 unsigned int hash;
kono
parents:
diff changeset
2015 tree to;
kono
parents:
diff changeset
2016 };
kono
parents:
diff changeset
2017
kono
parents:
diff changeset
2018 /* Map from a decl tree to another tree. */
kono
parents:
diff changeset
2019 struct GTY((for_user)) tree_decl_map {
kono
parents:
diff changeset
2020 struct tree_map_base base;
kono
parents:
diff changeset
2021 tree to;
kono
parents:
diff changeset
2022 };
kono
parents:
diff changeset
2023
kono
parents:
diff changeset
2024 /* Map from a tree to an int. */
kono
parents:
diff changeset
2025 struct GTY((for_user)) tree_int_map {
kono
parents:
diff changeset
2026 struct tree_map_base base;
kono
parents:
diff changeset
2027 unsigned int to;
kono
parents:
diff changeset
2028 };
kono
parents:
diff changeset
2029
kono
parents:
diff changeset
2030 /* Map from a decl tree to a tree vector. */
kono
parents:
diff changeset
2031 struct GTY((for_user)) tree_vec_map {
kono
parents:
diff changeset
2032 struct tree_map_base base;
kono
parents:
diff changeset
2033 vec<tree, va_gc> *to;
kono
parents:
diff changeset
2034 };
kono
parents:
diff changeset
2035
kono
parents:
diff changeset
2036 /* Abstract iterators for CALL_EXPRs. These static inline definitions
kono
parents:
diff changeset
2037 have to go towards the end of tree.h so that union tree_node is fully
kono
parents:
diff changeset
2038 defined by this point. */
kono
parents:
diff changeset
2039
kono
parents:
diff changeset
2040 /* Structure containing iterator state. */
kono
parents:
diff changeset
2041 struct call_expr_arg_iterator {
kono
parents:
diff changeset
2042 tree t; /* the call_expr */
kono
parents:
diff changeset
2043 int n; /* argument count */
kono
parents:
diff changeset
2044 int i; /* next argument index */
kono
parents:
diff changeset
2045 };
kono
parents:
diff changeset
2046
kono
parents:
diff changeset
2047 struct const_call_expr_arg_iterator {
kono
parents:
diff changeset
2048 const_tree t; /* the call_expr */
kono
parents:
diff changeset
2049 int n; /* argument count */
kono
parents:
diff changeset
2050 int i; /* next argument index */
kono
parents:
diff changeset
2051 };
kono
parents:
diff changeset
2052
kono
parents:
diff changeset
2053 /* The builtin_info structure holds the FUNCTION_DECL of the standard builtin
kono
parents:
diff changeset
2054 function, and flags. */
kono
parents:
diff changeset
2055 struct GTY(()) builtin_info_type {
kono
parents:
diff changeset
2056 tree decl;
kono
parents:
diff changeset
2057 /* Whether the user can use <xxx> instead of explicitly using calls
kono
parents:
diff changeset
2058 to __builtin_<xxx>. */
kono
parents:
diff changeset
2059 unsigned implicit_p : 1;
kono
parents:
diff changeset
2060 /* Whether the user has provided a declaration of <xxx>. */
kono
parents:
diff changeset
2061 unsigned declared_p : 1;
kono
parents:
diff changeset
2062 };
kono
parents:
diff changeset
2063
kono
parents:
diff changeset
2064 /* Information about a _FloatN or _FloatNx type that may be
kono
parents:
diff changeset
2065 supported. */
kono
parents:
diff changeset
2066 struct floatn_type_info {
kono
parents:
diff changeset
2067 /* The number N in the type name. */
kono
parents:
diff changeset
2068 int n;
kono
parents:
diff changeset
2069 /* Whether it is an extended type _FloatNx (true) or an interchange
kono
parents:
diff changeset
2070 type (false). */
kono
parents:
diff changeset
2071 bool extended;
kono
parents:
diff changeset
2072 };
kono
parents:
diff changeset
2073
kono
parents:
diff changeset
2074
kono
parents:
diff changeset
2075 /*---------------------------------------------------------------------------
kono
parents:
diff changeset
2076 Global variables
kono
parents:
diff changeset
2077 ---------------------------------------------------------------------------*/
kono
parents:
diff changeset
2078 /* Matrix describing the structures contained in a given tree code. */
kono
parents:
diff changeset
2079 extern bool tree_contains_struct[MAX_TREE_CODES][64];
kono
parents:
diff changeset
2080
kono
parents:
diff changeset
2081 /* Class of tree given its code. */
kono
parents:
diff changeset
2082 extern const enum tree_code_class tree_code_type[];
kono
parents:
diff changeset
2083
kono
parents:
diff changeset
2084 /* Each tree code class has an associated string representation.
kono
parents:
diff changeset
2085 These must correspond to the tree_code_class entries. */
kono
parents:
diff changeset
2086 extern const char *const tree_code_class_strings[];
kono
parents:
diff changeset
2087
kono
parents:
diff changeset
2088 /* Number of argument-words in each kind of tree-node. */
kono
parents:
diff changeset
2089 extern const unsigned char tree_code_length[];
kono
parents:
diff changeset
2090
kono
parents:
diff changeset
2091 /* Vector of all alias pairs for global symbols. */
kono
parents:
diff changeset
2092 extern GTY(()) vec<alias_pair, va_gc> *alias_pairs;
kono
parents:
diff changeset
2093
kono
parents:
diff changeset
2094 /* Names of all the built_in classes. */
kono
parents:
diff changeset
2095 extern const char *const built_in_class_names[BUILT_IN_LAST];
kono
parents:
diff changeset
2096
kono
parents:
diff changeset
2097 /* Names of all the built_in functions. */
kono
parents:
diff changeset
2098 extern const char * built_in_names[(int) END_BUILTINS];
kono
parents:
diff changeset
2099
kono
parents:
diff changeset
2100 /* Number of operands and names for each OMP_CLAUSE node. */
kono
parents:
diff changeset
2101 extern unsigned const char omp_clause_num_ops[];
kono
parents:
diff changeset
2102 extern const char * const omp_clause_code_name[];
kono
parents:
diff changeset
2103
kono
parents:
diff changeset
2104 /* A vector of all translation-units. */
kono
parents:
diff changeset
2105 extern GTY (()) vec<tree, va_gc> *all_translation_units;
kono
parents:
diff changeset
2106
kono
parents:
diff changeset
2107 /* Vector of standard trees used by the C compiler. */
kono
parents:
diff changeset
2108 extern GTY(()) tree global_trees[TI_MAX];
kono
parents:
diff changeset
2109
kono
parents:
diff changeset
2110 /* The standard C integer types. Use integer_type_kind to index into
kono
parents:
diff changeset
2111 this array. */
kono
parents:
diff changeset
2112 extern GTY(()) tree integer_types[itk_none];
kono
parents:
diff changeset
2113
kono
parents:
diff changeset
2114 /* Types used to represent sizes. */
kono
parents:
diff changeset
2115 extern GTY(()) tree sizetype_tab[(int) stk_type_kind_last];
kono
parents:
diff changeset
2116
kono
parents:
diff changeset
2117 /* Arrays for keeping track of tree node statistics. */
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
2118 extern uint64_t tree_node_counts[];
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
2119 extern uint64_t tree_node_sizes[];
111
kono
parents:
diff changeset
2120
kono
parents:
diff changeset
2121 /* True if we are in gimple form and the actions of the folders need to
kono
parents:
diff changeset
2122 be restricted. False if we are not in gimple form and folding is not
kono
parents:
diff changeset
2123 restricted to creating gimple expressions. */
kono
parents:
diff changeset
2124 extern bool in_gimple_form;
kono
parents:
diff changeset
2125
kono
parents:
diff changeset
2126 /* Functional interface to the builtin functions. */
kono
parents:
diff changeset
2127 extern GTY(()) builtin_info_type builtin_info[(int)END_BUILTINS];
kono
parents:
diff changeset
2128
kono
parents:
diff changeset
2129 /* If nonzero, an upper limit on alignment of structure fields, in bits, */
kono
parents:
diff changeset
2130 extern unsigned int maximum_field_alignment;
kono
parents:
diff changeset
2131
kono
parents:
diff changeset
2132 /* Points to the FUNCTION_DECL of the function whose body we are reading. */
kono
parents:
diff changeset
2133 extern GTY(()) tree current_function_decl;
kono
parents:
diff changeset
2134
kono
parents:
diff changeset
2135 /* Nonzero means a FUNC_BEGIN label was emitted. */
kono
parents:
diff changeset
2136 extern GTY(()) const char * current_function_func_begin_label;
kono
parents:
diff changeset
2137
kono
parents:
diff changeset
2138 /* Information about the _FloatN and _FloatNx types. */
kono
parents:
diff changeset
2139 extern const floatn_type_info floatn_nx_types[NUM_FLOATN_NX_TYPES];
kono
parents:
diff changeset
2140
kono
parents:
diff changeset
2141 #endif // GCC_TREE_CORE_H