]> gcc.gnu.org Git - gcc.git/blob - gcc/tree-streamer-out.c
re PR fortran/90329 (Incompatibility between gfortran and C lapack calls)
[gcc.git] / gcc / tree-streamer-out.c
1 /* Routines for emitting trees to a file stream.
2
3 Copyright (C) 2011-2018 Free Software Foundation, Inc.
4 Contributed by Diego Novillo <dnovillo@google.com>
5
6 This file is part of GCC.
7
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 3, or (at your option) any later
11 version.
12
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING3. If not see
20 <http://www.gnu.org/licenses/>. */
21
22 #include "config.h"
23 #include "system.h"
24 #include "coretypes.h"
25 #include "backend.h"
26 #include "target.h"
27 #include "tree.h"
28 #include "gimple.h"
29 #include "tree-streamer.h"
30 #include "cgraph.h"
31 #include "alias.h"
32 #include "stor-layout.h"
33 #include "gomp-constants.h"
34
35
36 /* Output the STRING constant to the string
37 table in OB. Then put the index onto the INDEX_STREAM. */
38
39 void
40 streamer_write_string_cst (struct output_block *ob,
41 struct lto_output_stream *index_stream,
42 tree string)
43 {
44 streamer_write_string_with_length (ob, index_stream,
45 string ? TREE_STRING_POINTER (string)
46 : NULL,
47 string ? TREE_STRING_LENGTH (string) : 0,
48 true);
49 }
50
51
52 /* Output the identifier ID to the string
53 table in OB. Then put the index onto the INDEX_STREAM. */
54
55 static void
56 write_identifier (struct output_block *ob,
57 struct lto_output_stream *index_stream,
58 tree id)
59 {
60 streamer_write_string_with_length (ob, index_stream,
61 IDENTIFIER_POINTER (id),
62 IDENTIFIER_LENGTH (id),
63 true);
64 }
65
66
67 /* Pack all the non-pointer fields of the TS_BASE structure of
68 expression EXPR into bitpack BP. */
69
70 static inline void
71 pack_ts_base_value_fields (struct bitpack_d *bp, tree expr)
72 {
73 bp_pack_value (bp, TREE_CODE (expr), 16);
74 if (!TYPE_P (expr))
75 {
76 bp_pack_value (bp, TREE_SIDE_EFFECTS (expr), 1);
77 bp_pack_value (bp, TREE_CONSTANT (expr), 1);
78 bp_pack_value (bp, TREE_READONLY (expr), 1);
79
80 /* TREE_PUBLIC is used on types to indicate that the type
81 has a TYPE_CACHED_VALUES vector. This is not streamed out,
82 so we skip it here. */
83 bp_pack_value (bp, TREE_PUBLIC (expr), 1);
84 }
85 else
86 bp_pack_value (bp, 0, 4);
87 bp_pack_value (bp, TREE_ADDRESSABLE (expr), 1);
88 bp_pack_value (bp, TREE_THIS_VOLATILE (expr), 1);
89 if (DECL_P (expr))
90 {
91 bp_pack_value (bp, DECL_UNSIGNED (expr), 1);
92 bp_pack_value (bp, DECL_NAMELESS (expr), 1);
93 }
94 else if (TYPE_P (expr))
95 bp_pack_value (bp, TYPE_UNSIGNED (expr), 1);
96 else
97 bp_pack_value (bp, 0, 1);
98 /* We write debug info two times, do not confuse the second one.
99 The only relevant TREE_ASM_WRITTEN use is on SSA names. */
100 bp_pack_value (bp, (TREE_CODE (expr) != SSA_NAME
101 ? 0 : TREE_ASM_WRITTEN (expr)), 1);
102 if (TYPE_P (expr))
103 bp_pack_value (bp, TYPE_ARTIFICIAL (expr), 1);
104 else
105 bp_pack_value (bp, TREE_NO_WARNING (expr), 1);
106 bp_pack_value (bp, TREE_NOTHROW (expr), 1);
107 bp_pack_value (bp, TREE_STATIC (expr), 1);
108 if (TREE_CODE (expr) != TREE_BINFO)
109 bp_pack_value (bp, TREE_PRIVATE (expr), 1);
110 else
111 bp_pack_value (bp, 0, 1);
112 bp_pack_value (bp, TREE_PROTECTED (expr), 1);
113 bp_pack_value (bp, TREE_DEPRECATED (expr), 1);
114 if (TYPE_P (expr))
115 {
116 if (AGGREGATE_TYPE_P (expr))
117 bp_pack_value (bp, TYPE_REVERSE_STORAGE_ORDER (expr), 1);
118 else
119 bp_pack_value (bp, TYPE_SATURATING (expr), 1);
120 bp_pack_value (bp, TYPE_ADDR_SPACE (expr), 8);
121 }
122 else if (TREE_CODE (expr) == BIT_FIELD_REF || TREE_CODE (expr) == MEM_REF)
123 {
124 bp_pack_value (bp, REF_REVERSE_STORAGE_ORDER (expr), 1);
125 bp_pack_value (bp, 0, 8);
126 }
127 else if (TREE_CODE (expr) == SSA_NAME)
128 {
129 bp_pack_value (bp, SSA_NAME_IS_DEFAULT_DEF (expr), 1);
130 bp_pack_value (bp, 0, 8);
131 }
132 else if (TREE_CODE (expr) == CALL_EXPR)
133 {
134 bp_pack_value (bp, CALL_EXPR_BY_DESCRIPTOR (expr), 1);
135 bp_pack_value (bp, 0, 8);
136 }
137 else
138 bp_pack_value (bp, 0, 9);
139 }
140
141
142 /* Pack all the non-pointer fields of the TS_INTEGER_CST structure of
143 expression EXPR into bitpack BP. */
144
145 static void
146 pack_ts_int_cst_value_fields (struct bitpack_d *bp, tree expr)
147 {
148 int i;
149 /* Note that the number of elements has already been written out in
150 streamer_write_tree_header. */
151 for (i = 0; i < TREE_INT_CST_EXT_NUNITS (expr); i++)
152 bp_pack_var_len_int (bp, TREE_INT_CST_ELT (expr, i));
153 }
154
155
156 /* Pack all the non-pointer fields of the TS_REAL_CST structure of
157 expression EXPR into bitpack BP. */
158
159 static void
160 pack_ts_real_cst_value_fields (struct bitpack_d *bp, tree expr)
161 {
162 unsigned i;
163 REAL_VALUE_TYPE r;
164
165 r = TREE_REAL_CST (expr);
166 bp_pack_value (bp, r.cl, 2);
167 bp_pack_value (bp, r.decimal, 1);
168 bp_pack_value (bp, r.sign, 1);
169 bp_pack_value (bp, r.signalling, 1);
170 bp_pack_value (bp, r.canonical, 1);
171 bp_pack_value (bp, r.uexp, EXP_BITS);
172 for (i = 0; i < SIGSZ; i++)
173 bp_pack_value (bp, r.sig[i], HOST_BITS_PER_LONG);
174 }
175
176
177 /* Pack all the non-pointer fields of the TS_FIXED_CST structure of
178 expression EXPR into bitpack BP. */
179
180 static void
181 pack_ts_fixed_cst_value_fields (struct bitpack_d *bp, tree expr)
182 {
183 struct fixed_value fv = TREE_FIXED_CST (expr);
184 bp_pack_machine_mode (bp, fv.mode);
185 bp_pack_var_len_int (bp, fv.data.low);
186 bp_pack_var_len_int (bp, fv.data.high);
187 }
188
189 /* Pack all the non-pointer fields of the TS_DECL_COMMON structure
190 of expression EXPR into bitpack BP. */
191
192 static void
193 pack_ts_decl_common_value_fields (struct bitpack_d *bp, tree expr)
194 {
195 bp_pack_machine_mode (bp, DECL_MODE (expr));
196 bp_pack_value (bp, DECL_NONLOCAL (expr), 1);
197 bp_pack_value (bp, DECL_VIRTUAL_P (expr), 1);
198 bp_pack_value (bp, DECL_IGNORED_P (expr), 1);
199 bp_pack_value (bp, DECL_ABSTRACT_P (expr), 1);
200 bp_pack_value (bp, DECL_ARTIFICIAL (expr), 1);
201 bp_pack_value (bp, DECL_USER_ALIGN (expr), 1);
202 bp_pack_value (bp, DECL_PRESERVE_P (expr), 1);
203 bp_pack_value (bp, DECL_EXTERNAL (expr), 1);
204 bp_pack_value (bp, DECL_GIMPLE_REG_P (expr), 1);
205 bp_pack_var_len_unsigned (bp, DECL_ALIGN (expr));
206
207 if (TREE_CODE (expr) == LABEL_DECL)
208 {
209 /* Note that we do not write LABEL_DECL_UID. The reader will
210 always assume an initial value of -1 so that the
211 label_to_block_map is recreated by gimple_set_bb. */
212 bp_pack_var_len_unsigned (bp, EH_LANDING_PAD_NR (expr));
213 }
214
215 else if (TREE_CODE (expr) == FIELD_DECL)
216 {
217 bp_pack_value (bp, DECL_PACKED (expr), 1);
218 bp_pack_value (bp, DECL_NONADDRESSABLE_P (expr), 1);
219 bp_pack_value (bp, DECL_PADDING_P (expr), 1);
220 bp_pack_value (bp, expr->decl_common.off_align, 8);
221 }
222
223 else if (VAR_P (expr))
224 {
225 bp_pack_value (bp, DECL_HAS_DEBUG_EXPR_P (expr), 1);
226 bp_pack_value (bp, DECL_NONLOCAL_FRAME (expr), 1);
227 }
228
229 else if (TREE_CODE (expr) == PARM_DECL)
230 bp_pack_value (bp, DECL_HIDDEN_STRING_LENGTH (expr), 1);
231
232 if (TREE_CODE (expr) == RESULT_DECL
233 || TREE_CODE (expr) == PARM_DECL
234 || VAR_P (expr))
235 {
236 bp_pack_value (bp, DECL_BY_REFERENCE (expr), 1);
237 if (VAR_P (expr) || TREE_CODE (expr) == PARM_DECL)
238 bp_pack_value (bp, DECL_HAS_VALUE_EXPR_P (expr), 1);
239 }
240 }
241
242
243 /* Pack all the non-pointer fields of the TS_DECL_WRTL structure
244 of expression EXPR into bitpack BP. */
245
246 static void
247 pack_ts_decl_wrtl_value_fields (struct bitpack_d *bp, tree expr)
248 {
249 bp_pack_value (bp, DECL_REGISTER (expr), 1);
250 }
251
252
253 /* Pack all the non-pointer fields of the TS_DECL_WITH_VIS structure
254 of expression EXPR into bitpack BP. */
255
256 static void
257 pack_ts_decl_with_vis_value_fields (struct bitpack_d *bp, tree expr)
258 {
259 bp_pack_value (bp, DECL_COMMON (expr), 1);
260 bp_pack_value (bp, DECL_DLLIMPORT_P (expr), 1);
261 bp_pack_value (bp, DECL_WEAK (expr), 1);
262 bp_pack_value (bp, DECL_SEEN_IN_BIND_EXPR_P (expr), 1);
263 bp_pack_value (bp, DECL_COMDAT (expr), 1);
264 bp_pack_value (bp, DECL_VISIBILITY (expr), 2);
265 bp_pack_value (bp, DECL_VISIBILITY_SPECIFIED (expr), 1);
266
267 if (VAR_P (expr))
268 {
269 bp_pack_value (bp, DECL_HARD_REGISTER (expr), 1);
270 /* DECL_IN_TEXT_SECTION is set during final asm output only. */
271 bp_pack_value (bp, DECL_IN_CONSTANT_POOL (expr), 1);
272 }
273
274 if (TREE_CODE (expr) == FUNCTION_DECL)
275 {
276 bp_pack_value (bp, DECL_FINAL_P (expr), 1);
277 bp_pack_value (bp, DECL_CXX_CONSTRUCTOR_P (expr), 1);
278 bp_pack_value (bp, DECL_CXX_DESTRUCTOR_P (expr), 1);
279 }
280 }
281
282
283 /* Pack all the non-pointer fields of the TS_FUNCTION_DECL structure
284 of expression EXPR into bitpack BP. */
285
286 static void
287 pack_ts_function_decl_value_fields (struct bitpack_d *bp, tree expr)
288 {
289 bp_pack_enum (bp, built_in_class, BUILT_IN_LAST,
290 DECL_BUILT_IN_CLASS (expr));
291 bp_pack_value (bp, DECL_STATIC_CONSTRUCTOR (expr), 1);
292 bp_pack_value (bp, DECL_STATIC_DESTRUCTOR (expr), 1);
293 bp_pack_value (bp, DECL_UNINLINABLE (expr), 1);
294 bp_pack_value (bp, DECL_POSSIBLY_INLINED (expr), 1);
295 bp_pack_value (bp, DECL_IS_NOVOPS (expr), 1);
296 bp_pack_value (bp, DECL_IS_RETURNS_TWICE (expr), 1);
297 bp_pack_value (bp, DECL_IS_MALLOC (expr), 1);
298 bp_pack_value (bp, DECL_IS_OPERATOR_NEW (expr), 1);
299 bp_pack_value (bp, DECL_DECLARED_INLINE_P (expr), 1);
300 bp_pack_value (bp, DECL_STATIC_CHAIN (expr), 1);
301 bp_pack_value (bp, DECL_NO_INLINE_WARNING_P (expr), 1);
302 bp_pack_value (bp, DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT (expr), 1);
303 bp_pack_value (bp, DECL_NO_LIMIT_STACK (expr), 1);
304 bp_pack_value (bp, DECL_DISREGARD_INLINE_LIMITS (expr), 1);
305 bp_pack_value (bp, DECL_PURE_P (expr), 1);
306 bp_pack_value (bp, DECL_LOOPING_CONST_OR_PURE_P (expr), 1);
307 if (DECL_BUILT_IN_CLASS (expr) != NOT_BUILT_IN)
308 bp_pack_value (bp, DECL_FUNCTION_CODE (expr), 12);
309 }
310
311
312 /* Pack all the non-pointer fields of the TS_TYPE_COMMON structure
313 of expression EXPR into bitpack BP. */
314
315 static void
316 pack_ts_type_common_value_fields (struct bitpack_d *bp, tree expr)
317 {
318 /* for VECTOR_TYPE, TYPE_MODE reevaluates the mode using target_flags
319 not necessary valid in a global context.
320 Use the raw value previously set by layout_type. */
321 bp_pack_machine_mode (bp, TYPE_MODE_RAW (expr));
322 bp_pack_value (bp, TYPE_STRING_FLAG (expr), 1);
323 /* TYPE_NO_FORCE_BLK is private to stor-layout and need
324 no streaming. */
325 bp_pack_value (bp, TYPE_NEEDS_CONSTRUCTING (expr), 1);
326 bp_pack_value (bp, TYPE_PACKED (expr), 1);
327 bp_pack_value (bp, TYPE_RESTRICT (expr), 1);
328 bp_pack_value (bp, TYPE_USER_ALIGN (expr), 1);
329 bp_pack_value (bp, TYPE_READONLY (expr), 1);
330 /* We used to stream TYPE_ALIAS_SET == 0 information to let frontends mark
331 types that are opaque for TBAA. This however did not work as intended,
332 because TYPE_ALIAS_SET == 0 was regularly lost in type merging. */
333 if (RECORD_OR_UNION_TYPE_P (expr))
334 {
335 bp_pack_value (bp, TYPE_TRANSPARENT_AGGR (expr), 1);
336 bp_pack_value (bp, TYPE_FINAL_P (expr), 1);
337 }
338 else if (TREE_CODE (expr) == ARRAY_TYPE)
339 bp_pack_value (bp, TYPE_NONALIASED_COMPONENT (expr), 1);
340 if (AGGREGATE_TYPE_P (expr))
341 bp_pack_value (bp, TYPE_TYPELESS_STORAGE (expr), 1);
342 bp_pack_value (bp, TYPE_EMPTY_P (expr), 1);
343 bp_pack_var_len_unsigned (bp, TYPE_PRECISION (expr));
344 bp_pack_var_len_unsigned (bp, TYPE_ALIGN (expr));
345 }
346
347
348 /* Pack all the non-pointer fields of the TS_BLOCK structure
349 of expression EXPR into bitpack BP. */
350
351 static void
352 pack_ts_block_value_fields (struct output_block *ob,
353 struct bitpack_d *bp, tree expr)
354 {
355 bp_pack_value (bp, BLOCK_ABSTRACT (expr), 1);
356 /* BLOCK_NUMBER is recomputed. */
357 /* Stream BLOCK_SOURCE_LOCATION for the limited cases we can handle - those
358 that represent inlined function scopes.
359 For the rest them on the floor instead of ICEing in dwarf2out.c. */
360 if (inlined_function_outer_scope_p (expr))
361 stream_output_location (ob, bp, BLOCK_SOURCE_LOCATION (expr));
362 else
363 stream_output_location (ob, bp, UNKNOWN_LOCATION);
364 }
365
366 /* Pack all the non-pointer fields of the TS_TRANSLATION_UNIT_DECL structure
367 of expression EXPR into bitpack BP. */
368
369 static void
370 pack_ts_translation_unit_decl_value_fields (struct output_block *ob,
371 struct bitpack_d *bp, tree expr)
372 {
373 bp_pack_string (ob, bp, TRANSLATION_UNIT_LANGUAGE (expr), true);
374 }
375
376
377 /* Pack all the non-pointer fields of the TS_OMP_CLAUSE structure
378 of expression EXPR into bitpack BP. */
379
380 static void
381 pack_ts_omp_clause_value_fields (struct output_block *ob,
382 struct bitpack_d *bp, tree expr)
383 {
384 stream_output_location (ob, bp, OMP_CLAUSE_LOCATION (expr));
385 switch (OMP_CLAUSE_CODE (expr))
386 {
387 case OMP_CLAUSE_DEFAULT:
388 bp_pack_enum (bp, omp_clause_default_kind, OMP_CLAUSE_DEFAULT_LAST,
389 OMP_CLAUSE_DEFAULT_KIND (expr));
390 break;
391 case OMP_CLAUSE_SCHEDULE:
392 bp_pack_enum (bp, omp_clause_schedule_kind, OMP_CLAUSE_SCHEDULE_LAST,
393 OMP_CLAUSE_SCHEDULE_KIND (expr));
394 break;
395 case OMP_CLAUSE_DEPEND:
396 bp_pack_enum (bp, omp_clause_depend_kind, OMP_CLAUSE_DEPEND_LAST,
397 OMP_CLAUSE_DEPEND_KIND (expr));
398 break;
399 case OMP_CLAUSE_MAP:
400 bp_pack_enum (bp, gomp_map_kind, GOMP_MAP_LAST,
401 OMP_CLAUSE_MAP_KIND (expr));
402 break;
403 case OMP_CLAUSE_PROC_BIND:
404 bp_pack_enum (bp, omp_clause_proc_bind_kind, OMP_CLAUSE_PROC_BIND_LAST,
405 OMP_CLAUSE_PROC_BIND_KIND (expr));
406 break;
407 case OMP_CLAUSE_REDUCTION:
408 bp_pack_enum (bp, tree_code, MAX_TREE_CODES,
409 OMP_CLAUSE_REDUCTION_CODE (expr));
410 break;
411 default:
412 break;
413 }
414 }
415
416
417 /* Pack all the bitfields in EXPR into a bit pack. */
418
419 void
420 streamer_write_tree_bitfields (struct output_block *ob, tree expr)
421 {
422 bitpack_d bp = bitpack_create (ob->main_stream);
423 enum tree_code code;
424
425 code = TREE_CODE (expr);
426
427 /* Note that all these functions are highly sensitive to changes in
428 the types and sizes of each of the fields being packed. */
429 pack_ts_base_value_fields (&bp, expr);
430
431 if (CODE_CONTAINS_STRUCT (code, TS_INT_CST))
432 pack_ts_int_cst_value_fields (&bp, expr);
433
434 if (CODE_CONTAINS_STRUCT (code, TS_REAL_CST))
435 pack_ts_real_cst_value_fields (&bp, expr);
436
437 if (CODE_CONTAINS_STRUCT (code, TS_FIXED_CST))
438 pack_ts_fixed_cst_value_fields (&bp, expr);
439
440 if (CODE_CONTAINS_STRUCT (code, TS_DECL_MINIMAL))
441 stream_output_location (ob, &bp, DECL_SOURCE_LOCATION (expr));
442
443 if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
444 pack_ts_decl_common_value_fields (&bp, expr);
445
446 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WRTL))
447 pack_ts_decl_wrtl_value_fields (&bp, expr);
448
449 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WITH_VIS))
450 pack_ts_decl_with_vis_value_fields (&bp, expr);
451
452 if (CODE_CONTAINS_STRUCT (code, TS_FUNCTION_DECL))
453 pack_ts_function_decl_value_fields (&bp, expr);
454
455 if (CODE_CONTAINS_STRUCT (code, TS_TYPE_COMMON))
456 pack_ts_type_common_value_fields (&bp, expr);
457
458 if (CODE_CONTAINS_STRUCT (code, TS_EXP))
459 {
460 stream_output_location (ob, &bp, EXPR_LOCATION (expr));
461 if (code == MEM_REF
462 || code == TARGET_MEM_REF)
463 {
464 bp_pack_value (&bp, MR_DEPENDENCE_CLIQUE (expr), sizeof (short) * 8);
465 if (MR_DEPENDENCE_CLIQUE (expr) != 0)
466 bp_pack_value (&bp, MR_DEPENDENCE_BASE (expr), sizeof (short) * 8);
467 }
468 else if (code == CALL_EXPR)
469 bp_pack_enum (&bp, internal_fn, IFN_LAST, CALL_EXPR_IFN (expr));
470 }
471
472 if (CODE_CONTAINS_STRUCT (code, TS_BLOCK))
473 pack_ts_block_value_fields (ob, &bp, expr);
474
475 if (CODE_CONTAINS_STRUCT (code, TS_TRANSLATION_UNIT_DECL))
476 pack_ts_translation_unit_decl_value_fields (ob, &bp, expr);
477
478 if (CODE_CONTAINS_STRUCT (code, TS_OPTIMIZATION))
479 cl_optimization_stream_out (&bp, TREE_OPTIMIZATION (expr));
480
481 if (CODE_CONTAINS_STRUCT (code, TS_BINFO))
482 bp_pack_var_len_unsigned (&bp, vec_safe_length (BINFO_BASE_ACCESSES (expr)));
483
484 if (CODE_CONTAINS_STRUCT (code, TS_CONSTRUCTOR))
485 bp_pack_var_len_unsigned (&bp, CONSTRUCTOR_NELTS (expr));
486
487 if (CODE_CONTAINS_STRUCT (code, TS_TARGET_OPTION)
488 /* Don't stream these when passing things to a different target. */
489 && !lto_stream_offload_p)
490 cl_target_option_stream_out (ob, &bp, TREE_TARGET_OPTION (expr));
491
492 if (code == OMP_CLAUSE)
493 pack_ts_omp_clause_value_fields (ob, &bp, expr);
494
495 streamer_write_bitpack (&bp);
496 }
497
498
499 /* Emit the chain of tree nodes starting at T. OB is the output block
500 to write to. REF_P is true if chain elements should be emitted
501 as references. */
502
503 void
504 streamer_write_chain (struct output_block *ob, tree t, bool ref_p)
505 {
506 while (t)
507 {
508 /* We avoid outputting external vars or functions by reference
509 to the global decls section as we do not want to have them
510 enter decl merging. This is, of course, only for the call
511 for streaming BLOCK_VARS, but other callers are safe.
512 See also lto-streamer-out.c:DFS_write_tree_body. */
513 if (VAR_OR_FUNCTION_DECL_P (t)
514 && DECL_EXTERNAL (t))
515 stream_write_tree_shallow_non_ref (ob, t, ref_p);
516 else
517 stream_write_tree (ob, t, ref_p);
518
519 t = TREE_CHAIN (t);
520 }
521
522 /* Write a sentinel to terminate the chain. */
523 stream_write_tree (ob, NULL_TREE, ref_p);
524 }
525
526
527 /* Write all pointer fields in the TS_COMMON structure of EXPR to output
528 block OB. If REF_P is true, write a reference to EXPR's pointer
529 fields. */
530
531 static void
532 write_ts_common_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
533 {
534 if (TREE_CODE (expr) != IDENTIFIER_NODE)
535 stream_write_tree (ob, TREE_TYPE (expr), ref_p);
536 }
537
538
539 /* Write all pointer fields in the TS_VECTOR structure of EXPR to output
540 block OB. If REF_P is true, write a reference to EXPR's pointer
541 fields. */
542
543 static void
544 write_ts_vector_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
545 {
546 /* Note that the number of elements for EXPR has already been emitted
547 in EXPR's header (see streamer_write_tree_header). */
548 unsigned int count = vector_cst_encoded_nelts (expr);
549 for (unsigned int i = 0; i < count; ++i)
550 stream_write_tree (ob, VECTOR_CST_ENCODED_ELT (expr, i), ref_p);
551 }
552
553
554 /* Write all pointer fields in the TS_POLY_INT_CST structure of EXPR to
555 output block OB. If REF_P is true, write a reference to EXPR's pointer
556 fields. */
557
558 static void
559 write_ts_poly_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
560 {
561 for (unsigned int i = 0; i < NUM_POLY_INT_COEFFS; ++i)
562 stream_write_tree (ob, POLY_INT_CST_COEFF (expr, i), ref_p);
563 }
564
565
566 /* Write all pointer fields in the TS_COMPLEX structure of EXPR to output
567 block OB. If REF_P is true, write a reference to EXPR's pointer
568 fields. */
569
570 static void
571 write_ts_complex_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
572 {
573 stream_write_tree (ob, TREE_REALPART (expr), ref_p);
574 stream_write_tree (ob, TREE_IMAGPART (expr), ref_p);
575 }
576
577
578 /* Write all pointer fields in the TS_DECL_MINIMAL structure of EXPR
579 to output block OB. If REF_P is true, write a reference to EXPR's
580 pointer fields. */
581
582 static void
583 write_ts_decl_minimal_tree_pointers (struct output_block *ob, tree expr,
584 bool ref_p)
585 {
586 /* Drop names that were created for anonymous entities. */
587 if (DECL_NAME (expr)
588 && TREE_CODE (DECL_NAME (expr)) == IDENTIFIER_NODE
589 && anon_aggrname_p (DECL_NAME (expr)))
590 stream_write_tree (ob, NULL_TREE, ref_p);
591 else
592 stream_write_tree (ob, DECL_NAME (expr), ref_p);
593 if (TREE_CODE (expr) != TRANSLATION_UNIT_DECL
594 && ! DECL_CONTEXT (expr))
595 stream_write_tree (ob, (*all_translation_units)[0], ref_p);
596 else
597 stream_write_tree (ob, DECL_CONTEXT (expr), ref_p);
598 }
599
600
601 /* Write all pointer fields in the TS_DECL_COMMON structure of EXPR to
602 output block OB. If REF_P is true, write a reference to EXPR's
603 pointer fields. */
604
605 static void
606 write_ts_decl_common_tree_pointers (struct output_block *ob, tree expr,
607 bool ref_p)
608 {
609 stream_write_tree (ob, DECL_SIZE (expr), ref_p);
610 stream_write_tree (ob, DECL_SIZE_UNIT (expr), ref_p);
611
612 /* Note, DECL_INITIAL is not handled here. Since DECL_INITIAL needs
613 special handling in LTO, it must be handled by streamer hooks. */
614
615 stream_write_tree (ob, DECL_ATTRIBUTES (expr), ref_p);
616
617 /* On non-early-LTO enabled targets we claim we compiled with -g0
618 but dwarf2out still did its set_decl_origin_self game fooling
619 itself late. Und that here since we won't have access to the
620 early generated abstract DIEs. */
621 tree ao = DECL_ABSTRACT_ORIGIN (expr);
622 if (debug_info_level == DINFO_LEVEL_NONE
623 && ao == expr)
624 ao = NULL_TREE;
625 stream_write_tree (ob, ao, ref_p);
626
627 if ((VAR_P (expr) || TREE_CODE (expr) == PARM_DECL)
628 && DECL_HAS_VALUE_EXPR_P (expr))
629 stream_write_tree (ob, DECL_VALUE_EXPR (expr), ref_p);
630
631 if (VAR_P (expr)
632 && DECL_HAS_DEBUG_EXPR_P (expr))
633 stream_write_tree (ob, DECL_DEBUG_EXPR (expr), ref_p);
634 }
635
636
637 /* Write all pointer fields in the TS_DECL_NON_COMMON structure of
638 EXPR to output block OB. If REF_P is true, write a reference to EXPR's
639 pointer fields. */
640
641 static void
642 write_ts_decl_non_common_tree_pointers (struct output_block *ob, tree expr,
643 bool ref_p)
644 {
645 if (TREE_CODE (expr) == TYPE_DECL)
646 stream_write_tree (ob, DECL_ORIGINAL_TYPE (expr), ref_p);
647 }
648
649
650 /* Write all pointer fields in the TS_DECL_WITH_VIS structure of EXPR
651 to output block OB. If REF_P is true, write a reference to EXPR's
652 pointer fields. */
653
654 static void
655 write_ts_decl_with_vis_tree_pointers (struct output_block *ob, tree expr,
656 bool ref_p)
657 {
658 /* Make sure we don't inadvertently set the assembler name. */
659 if (DECL_ASSEMBLER_NAME_SET_P (expr))
660 stream_write_tree (ob, DECL_ASSEMBLER_NAME (expr), ref_p);
661 else
662 stream_write_tree (ob, NULL_TREE, false);
663 }
664
665
666 /* Write all pointer fields in the TS_FIELD_DECL structure of EXPR to
667 output block OB. If REF_P is true, write a reference to EXPR's
668 pointer fields. */
669
670 static void
671 write_ts_field_decl_tree_pointers (struct output_block *ob, tree expr,
672 bool ref_p)
673 {
674 stream_write_tree (ob, DECL_FIELD_OFFSET (expr), ref_p);
675 stream_write_tree (ob, DECL_BIT_FIELD_TYPE (expr), ref_p);
676 stream_write_tree (ob, DECL_BIT_FIELD_REPRESENTATIVE (expr), ref_p);
677 stream_write_tree (ob, DECL_FIELD_BIT_OFFSET (expr), ref_p);
678 stream_write_tree (ob, DECL_FCONTEXT (expr), ref_p);
679 }
680
681
682 /* Write all pointer fields in the TS_FUNCTION_DECL structure of EXPR
683 to output block OB. If REF_P is true, write a reference to EXPR's
684 pointer fields. */
685
686 static void
687 write_ts_function_decl_tree_pointers (struct output_block *ob, tree expr,
688 bool ref_p)
689 {
690 stream_write_tree (ob, DECL_VINDEX (expr), ref_p);
691 /* DECL_STRUCT_FUNCTION is handled by lto_output_function. */
692 stream_write_tree (ob, DECL_FUNCTION_PERSONALITY (expr), ref_p);
693 /* Don't stream these when passing things to a different target. */
694 if (!lto_stream_offload_p)
695 stream_write_tree (ob, DECL_FUNCTION_SPECIFIC_TARGET (expr), ref_p);
696 stream_write_tree (ob, DECL_FUNCTION_SPECIFIC_OPTIMIZATION (expr), ref_p);
697 }
698
699
700 /* Write all pointer fields in the TS_TYPE_COMMON structure of EXPR to
701 output block OB. If REF_P is true, write a reference to EXPR's
702 pointer fields. */
703
704 static void
705 write_ts_type_common_tree_pointers (struct output_block *ob, tree expr,
706 bool ref_p)
707 {
708 stream_write_tree (ob, TYPE_SIZE (expr), ref_p);
709 stream_write_tree (ob, TYPE_SIZE_UNIT (expr), ref_p);
710 stream_write_tree (ob, TYPE_ATTRIBUTES (expr), ref_p);
711 stream_write_tree (ob, TYPE_NAME (expr), ref_p);
712 /* Do not stream TYPE_POINTER_TO or TYPE_REFERENCE_TO. They will be
713 reconstructed during fixup. */
714 /* Do not stream TYPE_NEXT_VARIANT, we reconstruct the variant lists
715 during fixup. */
716 stream_write_tree (ob, TYPE_MAIN_VARIANT (expr), ref_p);
717 stream_write_tree (ob, TYPE_CONTEXT (expr), ref_p);
718 /* TYPE_CANONICAL is re-computed during type merging, so no need
719 to stream it here. */
720 stream_write_tree (ob, TYPE_STUB_DECL (expr), ref_p);
721 }
722
723 /* Write all pointer fields in the TS_TYPE_NON_COMMON structure of EXPR
724 to output block OB. If REF_P is true, write a reference to EXPR's
725 pointer fields. */
726
727 static void
728 write_ts_type_non_common_tree_pointers (struct output_block *ob, tree expr,
729 bool ref_p)
730 {
731 if (TREE_CODE (expr) == ENUMERAL_TYPE)
732 stream_write_tree (ob, TYPE_VALUES (expr), ref_p);
733 else if (TREE_CODE (expr) == ARRAY_TYPE)
734 stream_write_tree (ob, TYPE_DOMAIN (expr), ref_p);
735 else if (RECORD_OR_UNION_TYPE_P (expr))
736 streamer_write_chain (ob, TYPE_FIELDS (expr), ref_p);
737 else if (TREE_CODE (expr) == FUNCTION_TYPE
738 || TREE_CODE (expr) == METHOD_TYPE)
739 stream_write_tree (ob, TYPE_ARG_TYPES (expr), ref_p);
740
741 if (!POINTER_TYPE_P (expr))
742 stream_write_tree (ob, TYPE_MIN_VALUE_RAW (expr), ref_p);
743 stream_write_tree (ob, TYPE_MAX_VALUE_RAW (expr), ref_p);
744 }
745
746
747 /* Write all pointer fields in the TS_LIST structure of EXPR to output
748 block OB. If REF_P is true, write a reference to EXPR's pointer
749 fields. */
750
751 static void
752 write_ts_list_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
753 {
754 stream_write_tree (ob, TREE_PURPOSE (expr), ref_p);
755 stream_write_tree (ob, TREE_VALUE (expr), ref_p);
756 stream_write_tree (ob, TREE_CHAIN (expr), ref_p);
757 }
758
759
760 /* Write all pointer fields in the TS_VEC structure of EXPR to output
761 block OB. If REF_P is true, write a reference to EXPR's pointer
762 fields. */
763
764 static void
765 write_ts_vec_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
766 {
767 int i;
768
769 /* Note that the number of slots for EXPR has already been emitted
770 in EXPR's header (see streamer_write_tree_header). */
771 for (i = 0; i < TREE_VEC_LENGTH (expr); i++)
772 stream_write_tree (ob, TREE_VEC_ELT (expr, i), ref_p);
773 }
774
775
776 /* Write all pointer fields in the TS_EXP structure of EXPR to output
777 block OB. If REF_P is true, write a reference to EXPR's pointer
778 fields. */
779
780 static void
781 write_ts_exp_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
782 {
783 int i;
784
785 for (i = 0; i < TREE_OPERAND_LENGTH (expr); i++)
786 stream_write_tree (ob, TREE_OPERAND (expr, i), ref_p);
787 stream_write_tree (ob, TREE_BLOCK (expr), ref_p);
788 }
789
790
791 /* Write all pointer fields in the TS_BLOCK structure of EXPR to output
792 block OB. If REF_P is true, write a reference to EXPR's pointer
793 fields. */
794
795 static void
796 write_ts_block_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
797 {
798 streamer_write_chain (ob, BLOCK_VARS (expr), ref_p);
799
800 stream_write_tree (ob, BLOCK_SUPERCONTEXT (expr), ref_p);
801
802 /* Stream BLOCK_ABSTRACT_ORIGIN for the limited cases we can handle - those
803 that represent inlined function scopes.
804 For the rest them on the floor instead of ICEing in dwarf2out.c, but
805 keep the notion of whether the block is an inlined block by refering
806 to itself for the sake of tree_nonartificial_location. */
807 if (inlined_function_outer_scope_p (expr))
808 {
809 tree ultimate_origin = block_ultimate_origin (expr);
810 stream_write_tree (ob, ultimate_origin, ref_p);
811 }
812 else
813 stream_write_tree (ob, (BLOCK_ABSTRACT_ORIGIN (expr)
814 ? expr : NULL_TREE), ref_p);
815 /* Do not stream BLOCK_NONLOCALIZED_VARS. We cannot handle debug information
816 for early inlined BLOCKs so drop it on the floor instead of ICEing in
817 dwarf2out.c. */
818
819 /* BLOCK_FRAGMENT_ORIGIN and BLOCK_FRAGMENT_CHAIN is not live at LTO
820 streaming time. */
821
822 /* Do not output BLOCK_SUBBLOCKS. Instead on streaming-in this
823 list is re-constructed from BLOCK_SUPERCONTEXT. */
824 }
825
826
827 /* Write all pointer fields in the TS_BINFO structure of EXPR to output
828 block OB. If REF_P is true, write a reference to EXPR's pointer
829 fields. */
830
831 static void
832 write_ts_binfo_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
833 {
834 unsigned i;
835 tree t;
836
837 /* Note that the number of BINFO slots has already been emitted in
838 EXPR's header (see streamer_write_tree_header) because this length
839 is needed to build the empty BINFO node on the reader side. */
840 FOR_EACH_VEC_ELT (*BINFO_BASE_BINFOS (expr), i, t)
841 stream_write_tree (ob, t, ref_p);
842 stream_write_tree (ob, NULL_TREE, false);
843
844 stream_write_tree (ob, BINFO_OFFSET (expr), ref_p);
845 stream_write_tree (ob, BINFO_VTABLE (expr), ref_p);
846 stream_write_tree (ob, BINFO_VPTR_FIELD (expr), ref_p);
847
848 /* The number of BINFO_BASE_ACCESSES has already been emitted in
849 EXPR's bitfield section. */
850 FOR_EACH_VEC_SAFE_ELT (BINFO_BASE_ACCESSES (expr), i, t)
851 stream_write_tree (ob, t, ref_p);
852
853 /* Do not walk BINFO_INHERITANCE_CHAIN, BINFO_SUBVTT_INDEX
854 and BINFO_VPTR_INDEX; these are used by C++ FE only. */
855 }
856
857
858 /* Write all pointer fields in the TS_CONSTRUCTOR structure of EXPR to
859 output block OB. If REF_P is true, write a reference to EXPR's
860 pointer fields. */
861
862 static void
863 write_ts_constructor_tree_pointers (struct output_block *ob, tree expr,
864 bool ref_p)
865 {
866 unsigned i;
867 tree index, value;
868
869 FOR_EACH_CONSTRUCTOR_ELT (CONSTRUCTOR_ELTS (expr), i, index, value)
870 {
871 stream_write_tree (ob, index, ref_p);
872 stream_write_tree (ob, value, ref_p);
873 }
874 }
875
876
877 /* Write all pointer fields in the TS_OMP_CLAUSE structure of EXPR
878 to output block OB. If REF_P is true, write a reference to EXPR's
879 pointer fields. */
880
881 static void
882 write_ts_omp_clause_tree_pointers (struct output_block *ob, tree expr,
883 bool ref_p)
884 {
885 int i;
886 for (i = 0; i < omp_clause_num_ops[OMP_CLAUSE_CODE (expr)]; i++)
887 stream_write_tree (ob, OMP_CLAUSE_OPERAND (expr, i), ref_p);
888 if (OMP_CLAUSE_CODE (expr) == OMP_CLAUSE_REDUCTION)
889 {
890 /* We don't stream these right now, handle it if streaming
891 of them is needed. */
892 gcc_assert (OMP_CLAUSE_REDUCTION_GIMPLE_INIT (expr) == NULL);
893 gcc_assert (OMP_CLAUSE_REDUCTION_GIMPLE_MERGE (expr) == NULL);
894 }
895 stream_write_tree (ob, OMP_CLAUSE_CHAIN (expr), ref_p);
896 }
897
898
899 /* Write all pointer fields in EXPR to output block OB. If REF_P is true,
900 the leaves of EXPR are emitted as references. */
901
902 void
903 streamer_write_tree_body (struct output_block *ob, tree expr, bool ref_p)
904 {
905 enum tree_code code;
906
907 lto_stats.num_tree_bodies_output++;
908
909 code = TREE_CODE (expr);
910
911 if (CODE_CONTAINS_STRUCT (code, TS_TYPED))
912 write_ts_common_tree_pointers (ob, expr, ref_p);
913
914 if (CODE_CONTAINS_STRUCT (code, TS_VECTOR))
915 write_ts_vector_tree_pointers (ob, expr, ref_p);
916
917 if (CODE_CONTAINS_STRUCT (code, TS_POLY_INT_CST))
918 write_ts_poly_tree_pointers (ob, expr, ref_p);
919
920 if (CODE_CONTAINS_STRUCT (code, TS_COMPLEX))
921 write_ts_complex_tree_pointers (ob, expr, ref_p);
922
923 if (CODE_CONTAINS_STRUCT (code, TS_DECL_MINIMAL))
924 write_ts_decl_minimal_tree_pointers (ob, expr, ref_p);
925
926 if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
927 write_ts_decl_common_tree_pointers (ob, expr, ref_p);
928
929 if (CODE_CONTAINS_STRUCT (code, TS_DECL_NON_COMMON))
930 write_ts_decl_non_common_tree_pointers (ob, expr, ref_p);
931
932 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WITH_VIS))
933 write_ts_decl_with_vis_tree_pointers (ob, expr, ref_p);
934
935 if (CODE_CONTAINS_STRUCT (code, TS_FIELD_DECL))
936 write_ts_field_decl_tree_pointers (ob, expr, ref_p);
937
938 if (CODE_CONTAINS_STRUCT (code, TS_FUNCTION_DECL))
939 write_ts_function_decl_tree_pointers (ob, expr, ref_p);
940
941 if (CODE_CONTAINS_STRUCT (code, TS_TYPE_COMMON))
942 write_ts_type_common_tree_pointers (ob, expr, ref_p);
943
944 if (CODE_CONTAINS_STRUCT (code, TS_TYPE_NON_COMMON))
945 write_ts_type_non_common_tree_pointers (ob, expr, ref_p);
946
947 if (CODE_CONTAINS_STRUCT (code, TS_LIST))
948 write_ts_list_tree_pointers (ob, expr, ref_p);
949
950 if (CODE_CONTAINS_STRUCT (code, TS_VEC))
951 write_ts_vec_tree_pointers (ob, expr, ref_p);
952
953 if (CODE_CONTAINS_STRUCT (code, TS_EXP))
954 write_ts_exp_tree_pointers (ob, expr, ref_p);
955
956 if (CODE_CONTAINS_STRUCT (code, TS_BLOCK))
957 write_ts_block_tree_pointers (ob, expr, ref_p);
958
959 if (CODE_CONTAINS_STRUCT (code, TS_BINFO))
960 write_ts_binfo_tree_pointers (ob, expr, ref_p);
961
962 if (CODE_CONTAINS_STRUCT (code, TS_CONSTRUCTOR))
963 write_ts_constructor_tree_pointers (ob, expr, ref_p);
964
965 if (code == OMP_CLAUSE)
966 write_ts_omp_clause_tree_pointers (ob, expr, ref_p);
967 }
968
969
970 /* Emit header information for tree EXPR to output block OB. The header
971 contains everything needed to instantiate an empty skeleton for
972 EXPR on the reading side. IX is the index into the streamer cache
973 where EXPR is stored. */
974
975 void
976 streamer_write_tree_header (struct output_block *ob, tree expr)
977 {
978 enum LTO_tags tag;
979 enum tree_code code;
980
981 /* We should not see any tree nodes not handled by the streamer. */
982 code = TREE_CODE (expr);
983
984 /* The header of a tree node consists of its tag, the size of
985 the node, and any other information needed to instantiate
986 EXPR on the reading side (such as the number of slots in
987 variable sized nodes). */
988 tag = lto_tree_code_to_tag (code);
989 streamer_write_record_start (ob, tag);
990
991 /* The text in strings and identifiers are completely emitted in
992 the header. */
993 if (CODE_CONTAINS_STRUCT (code, TS_STRING))
994 streamer_write_string_cst (ob, ob->main_stream, expr);
995 else if (CODE_CONTAINS_STRUCT (code, TS_IDENTIFIER))
996 write_identifier (ob, ob->main_stream, expr);
997 else if (CODE_CONTAINS_STRUCT (code, TS_VECTOR))
998 {
999 bitpack_d bp = bitpack_create (ob->main_stream);
1000 bp_pack_value (&bp, VECTOR_CST_LOG2_NPATTERNS (expr), 8);
1001 bp_pack_value (&bp, VECTOR_CST_NELTS_PER_PATTERN (expr), 8);
1002 streamer_write_bitpack (&bp);
1003 }
1004 else if (CODE_CONTAINS_STRUCT (code, TS_VEC))
1005 streamer_write_hwi (ob, TREE_VEC_LENGTH (expr));
1006 else if (CODE_CONTAINS_STRUCT (code, TS_BINFO))
1007 streamer_write_uhwi (ob, BINFO_N_BASE_BINFOS (expr));
1008 else if (TREE_CODE (expr) == CALL_EXPR)
1009 streamer_write_uhwi (ob, call_expr_nargs (expr));
1010 else if (TREE_CODE (expr) == OMP_CLAUSE)
1011 streamer_write_uhwi (ob, OMP_CLAUSE_CODE (expr));
1012 else if (CODE_CONTAINS_STRUCT (code, TS_INT_CST))
1013 {
1014 gcc_checking_assert (TREE_INT_CST_NUNITS (expr));
1015 streamer_write_uhwi (ob, TREE_INT_CST_NUNITS (expr));
1016 streamer_write_uhwi (ob, TREE_INT_CST_EXT_NUNITS (expr));
1017 }
1018 }
1019
1020
1021 /* Emit the integer constant CST to output block OB. If REF_P is true,
1022 CST's type will be emitted as a reference. */
1023
1024 void
1025 streamer_write_integer_cst (struct output_block *ob, tree cst, bool ref_p)
1026 {
1027 int i;
1028 int len = TREE_INT_CST_NUNITS (cst);
1029 gcc_assert (!TREE_OVERFLOW (cst));
1030 streamer_write_record_start (ob, LTO_integer_cst);
1031 stream_write_tree (ob, TREE_TYPE (cst), ref_p);
1032 /* We're effectively streaming a non-sign-extended wide_int here,
1033 so there's no need to stream TREE_INT_CST_EXT_NUNITS or any
1034 array members beyond LEN. We'll recreate the tree from the
1035 wide_int and the type. */
1036 streamer_write_uhwi (ob, len);
1037 for (i = 0; i < len; i++)
1038 streamer_write_hwi (ob, TREE_INT_CST_ELT (cst, i));
1039 }
This page took 0.0864740000000001 seconds and 5 git commands to generate.