re PR fortran/68318 (ICE on duplicate entry declarations)
[official-gcc.git] / gcc / tree-streamer-out.c
blobd0b7f6db171c4cebfe9e85cafa0fb3e42030c3df
1 /* Routines for emitting trees to a file stream.
3 Copyright (C) 2011-2015 Free Software Foundation, Inc.
4 Contributed by Diego Novillo <dnovillo@google.com>
6 This file is part of GCC.
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.
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.
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/>. */
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"
36 /* Output the STRING constant to the string
37 table in OB. Then put the index onto the INDEX_STREAM. */
39 void
40 streamer_write_string_cst (struct output_block *ob,
41 struct lto_output_stream *index_stream,
42 tree string)
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);
52 /* Output the identifier ID to the string
53 table in OB. Then put the index onto the INDEX_STREAM. */
55 static void
56 write_identifier (struct output_block *ob,
57 struct lto_output_stream *index_stream,
58 tree id)
60 streamer_write_string_with_length (ob, index_stream,
61 IDENTIFIER_POINTER (id),
62 IDENTIFIER_LENGTH (id),
63 true);
67 /* Pack all the non-pointer fields of the TS_BASE structure of
68 expression EXPR into bitpack BP. */
70 static inline void
71 pack_ts_base_value_fields (struct bitpack_d *bp, tree expr)
73 bp_pack_value (bp, TREE_CODE (expr), 16);
74 if (!TYPE_P (expr))
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);
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);
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 bp_pack_value (bp, DECL_UNSIGNED (expr), 1);
91 else if (TYPE_P (expr))
92 bp_pack_value (bp, TYPE_UNSIGNED (expr), 1);
93 else
94 bp_pack_value (bp, 0, 1);
95 /* We write debug info two times, do not confuse the second one.
96 The only relevant TREE_ASM_WRITTEN use is on SSA names. */
97 bp_pack_value (bp, (TREE_CODE (expr) != SSA_NAME
98 ? 0 : TREE_ASM_WRITTEN (expr)), 1);
99 if (TYPE_P (expr))
100 bp_pack_value (bp, TYPE_ARTIFICIAL (expr), 1);
101 else
102 bp_pack_value (bp, TREE_NO_WARNING (expr), 1);
103 bp_pack_value (bp, TREE_NOTHROW (expr), 1);
104 bp_pack_value (bp, TREE_STATIC (expr), 1);
105 if (TREE_CODE (expr) != TREE_BINFO)
106 bp_pack_value (bp, TREE_PRIVATE (expr), 1);
107 else
108 bp_pack_value (bp, 0, 1);
109 bp_pack_value (bp, TREE_PROTECTED (expr), 1);
110 bp_pack_value (bp, TREE_DEPRECATED (expr), 1);
111 if (TYPE_P (expr))
113 if (AGGREGATE_TYPE_P (expr))
114 bp_pack_value (bp, TYPE_REVERSE_STORAGE_ORDER (expr), 1);
115 else
116 bp_pack_value (bp, TYPE_SATURATING (expr), 1);
117 bp_pack_value (bp, TYPE_ADDR_SPACE (expr), 8);
119 else if (TREE_CODE (expr) == BIT_FIELD_REF || TREE_CODE (expr) == MEM_REF)
121 bp_pack_value (bp, REF_REVERSE_STORAGE_ORDER (expr), 1);
122 bp_pack_value (bp, 0, 8);
124 else if (TREE_CODE (expr) == SSA_NAME)
126 bp_pack_value (bp, SSA_NAME_IS_DEFAULT_DEF (expr), 1);
127 bp_pack_value (bp, 0, 8);
129 else
130 bp_pack_value (bp, 0, 9);
134 /* Pack all the non-pointer fields of the TS_INTEGER_CST structure of
135 expression EXPR into bitpack BP. */
137 static void
138 pack_ts_int_cst_value_fields (struct bitpack_d *bp, tree expr)
140 int i;
141 /* Note that the number of elements has already been written out in
142 streamer_write_tree_header. */
143 for (i = 0; i < TREE_INT_CST_EXT_NUNITS (expr); i++)
144 bp_pack_var_len_int (bp, TREE_INT_CST_ELT (expr, i));
148 /* Pack all the non-pointer fields of the TS_REAL_CST structure of
149 expression EXPR into bitpack BP. */
151 static void
152 pack_ts_real_cst_value_fields (struct bitpack_d *bp, tree expr)
154 unsigned i;
155 REAL_VALUE_TYPE r;
157 r = TREE_REAL_CST (expr);
158 bp_pack_value (bp, r.cl, 2);
159 bp_pack_value (bp, r.decimal, 1);
160 bp_pack_value (bp, r.sign, 1);
161 bp_pack_value (bp, r.signalling, 1);
162 bp_pack_value (bp, r.canonical, 1);
163 bp_pack_value (bp, r.uexp, EXP_BITS);
164 for (i = 0; i < SIGSZ; i++)
165 bp_pack_value (bp, r.sig[i], HOST_BITS_PER_LONG);
169 /* Pack all the non-pointer fields of the TS_FIXED_CST structure of
170 expression EXPR into bitpack BP. */
172 static void
173 pack_ts_fixed_cst_value_fields (struct bitpack_d *bp, tree expr)
175 struct fixed_value fv = TREE_FIXED_CST (expr);
176 bp_pack_machine_mode (bp, fv.mode);
177 bp_pack_var_len_int (bp, fv.data.low);
178 bp_pack_var_len_int (bp, fv.data.high);
181 /* Pack all the non-pointer fields of the TS_DECL_COMMON structure
182 of expression EXPR into bitpack BP. */
184 static void
185 pack_ts_decl_common_value_fields (struct bitpack_d *bp, tree expr)
187 bp_pack_machine_mode (bp, DECL_MODE (expr));
188 bp_pack_value (bp, DECL_NONLOCAL (expr), 1);
189 bp_pack_value (bp, DECL_VIRTUAL_P (expr), 1);
190 bp_pack_value (bp, DECL_IGNORED_P (expr), 1);
191 bp_pack_value (bp, DECL_ABSTRACT_P (expr), 1);
192 bp_pack_value (bp, DECL_ARTIFICIAL (expr), 1);
193 bp_pack_value (bp, DECL_USER_ALIGN (expr), 1);
194 bp_pack_value (bp, DECL_PRESERVE_P (expr), 1);
195 bp_pack_value (bp, DECL_EXTERNAL (expr), 1);
196 bp_pack_value (bp, DECL_GIMPLE_REG_P (expr), 1);
197 bp_pack_var_len_unsigned (bp, DECL_ALIGN (expr));
199 if (TREE_CODE (expr) == LABEL_DECL)
201 /* Note that we do not write LABEL_DECL_UID. The reader will
202 always assume an initial value of -1 so that the
203 label_to_block_map is recreated by gimple_set_bb. */
204 bp_pack_var_len_unsigned (bp, EH_LANDING_PAD_NR (expr));
207 if (TREE_CODE (expr) == FIELD_DECL)
209 bp_pack_value (bp, DECL_PACKED (expr), 1);
210 bp_pack_value (bp, DECL_NONADDRESSABLE_P (expr), 1);
211 bp_pack_value (bp, expr->decl_common.off_align, 8);
214 if (TREE_CODE (expr) == VAR_DECL)
216 bp_pack_value (bp, DECL_HAS_DEBUG_EXPR_P (expr), 1);
217 bp_pack_value (bp, DECL_NONLOCAL_FRAME (expr), 1);
220 if (TREE_CODE (expr) == RESULT_DECL
221 || TREE_CODE (expr) == PARM_DECL
222 || TREE_CODE (expr) == VAR_DECL)
224 bp_pack_value (bp, DECL_BY_REFERENCE (expr), 1);
225 if (TREE_CODE (expr) == VAR_DECL
226 || TREE_CODE (expr) == PARM_DECL)
227 bp_pack_value (bp, DECL_HAS_VALUE_EXPR_P (expr), 1);
232 /* Pack all the non-pointer fields of the TS_DECL_WRTL structure
233 of expression EXPR into bitpack BP. */
235 static void
236 pack_ts_decl_wrtl_value_fields (struct bitpack_d *bp, tree expr)
238 bp_pack_value (bp, DECL_REGISTER (expr), 1);
242 /* Pack all the non-pointer fields of the TS_DECL_WITH_VIS structure
243 of expression EXPR into bitpack BP. */
245 static void
246 pack_ts_decl_with_vis_value_fields (struct bitpack_d *bp, tree expr)
248 bp_pack_value (bp, DECL_COMMON (expr), 1);
249 bp_pack_value (bp, DECL_DLLIMPORT_P (expr), 1);
250 bp_pack_value (bp, DECL_WEAK (expr), 1);
251 bp_pack_value (bp, DECL_SEEN_IN_BIND_EXPR_P (expr), 1);
252 bp_pack_value (bp, DECL_COMDAT (expr), 1);
253 bp_pack_value (bp, DECL_VISIBILITY (expr), 2);
254 bp_pack_value (bp, DECL_VISIBILITY_SPECIFIED (expr), 1);
256 if (TREE_CODE (expr) == VAR_DECL)
258 bp_pack_value (bp, DECL_HARD_REGISTER (expr), 1);
259 /* DECL_IN_TEXT_SECTION is set during final asm output only. */
260 bp_pack_value (bp, DECL_IN_CONSTANT_POOL (expr), 1);
263 if (TREE_CODE (expr) == FUNCTION_DECL)
265 bp_pack_value (bp, DECL_FINAL_P (expr), 1);
266 bp_pack_value (bp, DECL_CXX_CONSTRUCTOR_P (expr), 1);
267 bp_pack_value (bp, DECL_CXX_DESTRUCTOR_P (expr), 1);
272 /* Pack all the non-pointer fields of the TS_FUNCTION_DECL structure
273 of expression EXPR into bitpack BP. */
275 static void
276 pack_ts_function_decl_value_fields (struct bitpack_d *bp, tree expr)
278 /* For normal/md builtins we only write the class and code, so they
279 should never be handled here. */
280 gcc_assert (!streamer_handle_as_builtin_p (expr));
282 bp_pack_enum (bp, built_in_class, BUILT_IN_LAST,
283 DECL_BUILT_IN_CLASS (expr));
284 bp_pack_value (bp, DECL_STATIC_CONSTRUCTOR (expr), 1);
285 bp_pack_value (bp, DECL_STATIC_DESTRUCTOR (expr), 1);
286 bp_pack_value (bp, DECL_UNINLINABLE (expr), 1);
287 bp_pack_value (bp, DECL_POSSIBLY_INLINED (expr), 1);
288 bp_pack_value (bp, DECL_IS_NOVOPS (expr), 1);
289 bp_pack_value (bp, DECL_IS_RETURNS_TWICE (expr), 1);
290 bp_pack_value (bp, DECL_IS_MALLOC (expr), 1);
291 bp_pack_value (bp, DECL_IS_OPERATOR_NEW (expr), 1);
292 bp_pack_value (bp, DECL_DECLARED_INLINE_P (expr), 1);
293 bp_pack_value (bp, DECL_STATIC_CHAIN (expr), 1);
294 bp_pack_value (bp, DECL_NO_INLINE_WARNING_P (expr), 1);
295 bp_pack_value (bp, DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT (expr), 1);
296 bp_pack_value (bp, DECL_NO_LIMIT_STACK (expr), 1);
297 bp_pack_value (bp, DECL_DISREGARD_INLINE_LIMITS (expr), 1);
298 bp_pack_value (bp, DECL_PURE_P (expr), 1);
299 bp_pack_value (bp, DECL_LOOPING_CONST_OR_PURE_P (expr), 1);
300 if (DECL_BUILT_IN_CLASS (expr) != NOT_BUILT_IN)
301 bp_pack_value (bp, DECL_FUNCTION_CODE (expr), 12);
305 /* Pack all the non-pointer fields of the TS_TYPE_COMMON structure
306 of expression EXPR into bitpack BP. */
308 static void
309 pack_ts_type_common_value_fields (struct bitpack_d *bp, tree expr)
311 bp_pack_machine_mode (bp, TYPE_MODE (expr));
312 bp_pack_value (bp, TYPE_STRING_FLAG (expr), 1);
313 /* TYPE_NO_FORCE_BLK is private to stor-layout and need
314 no streaming. */
315 bp_pack_value (bp, TYPE_NEEDS_CONSTRUCTING (expr), 1);
316 if (RECORD_OR_UNION_TYPE_P (expr))
318 bp_pack_value (bp, TYPE_TRANSPARENT_AGGR (expr), 1);
319 bp_pack_value (bp, TYPE_FINAL_P (expr), 1);
321 else if (TREE_CODE (expr) == ARRAY_TYPE)
322 bp_pack_value (bp, TYPE_NONALIASED_COMPONENT (expr), 1);
323 bp_pack_value (bp, TYPE_PACKED (expr), 1);
324 bp_pack_value (bp, TYPE_RESTRICT (expr), 1);
325 bp_pack_value (bp, TYPE_USER_ALIGN (expr), 1);
326 bp_pack_value (bp, TYPE_READONLY (expr), 1);
327 bp_pack_var_len_unsigned (bp, TYPE_PRECISION (expr));
328 bp_pack_var_len_unsigned (bp, TYPE_ALIGN (expr));
329 /* Make sure to preserve the fact whether the frontend would assign
330 alias-set zero to this type. */
331 bp_pack_var_len_int (bp, (TYPE_ALIAS_SET (expr) == 0
332 || (!in_lto_p
333 && get_alias_set (expr) == 0)) ? 0 : -1);
337 /* Pack all the non-pointer fields of the TS_BLOCK structure
338 of expression EXPR into bitpack BP. */
340 static void
341 pack_ts_block_value_fields (struct output_block *ob,
342 struct bitpack_d *bp, tree expr)
344 bp_pack_value (bp, BLOCK_ABSTRACT (expr), 1);
345 /* BLOCK_NUMBER is recomputed. */
346 /* Stream BLOCK_SOURCE_LOCATION for the limited cases we can handle - those
347 that represent inlined function scopes.
348 For the rest them on the floor instead of ICEing in dwarf2out.c. */
349 if (inlined_function_outer_scope_p (expr))
350 stream_output_location (ob, bp, BLOCK_SOURCE_LOCATION (expr));
351 else
352 stream_output_location (ob, bp, UNKNOWN_LOCATION);
355 /* Pack all the non-pointer fields of the TS_TRANSLATION_UNIT_DECL structure
356 of expression EXPR into bitpack BP. */
358 static void
359 pack_ts_translation_unit_decl_value_fields (struct output_block *ob,
360 struct bitpack_d *bp, tree expr)
362 bp_pack_string (ob, bp, TRANSLATION_UNIT_LANGUAGE (expr), true);
366 /* Pack all the non-pointer fields of the TS_OMP_CLAUSE structure
367 of expression EXPR into bitpack BP. */
369 static void
370 pack_ts_omp_clause_value_fields (struct output_block *ob,
371 struct bitpack_d *bp, tree expr)
373 stream_output_location (ob, bp, OMP_CLAUSE_LOCATION (expr));
374 switch (OMP_CLAUSE_CODE (expr))
376 case OMP_CLAUSE_DEFAULT:
377 bp_pack_enum (bp, omp_clause_default_kind, OMP_CLAUSE_DEFAULT_LAST,
378 OMP_CLAUSE_DEFAULT_KIND (expr));
379 break;
380 case OMP_CLAUSE_SCHEDULE:
381 bp_pack_enum (bp, omp_clause_schedule_kind, OMP_CLAUSE_SCHEDULE_LAST,
382 OMP_CLAUSE_SCHEDULE_KIND (expr));
383 break;
384 case OMP_CLAUSE_DEPEND:
385 bp_pack_enum (bp, omp_clause_depend_kind, OMP_CLAUSE_DEPEND_LAST,
386 OMP_CLAUSE_DEPEND_KIND (expr));
387 break;
388 case OMP_CLAUSE_MAP:
389 bp_pack_enum (bp, gomp_map_kind, GOMP_MAP_LAST,
390 OMP_CLAUSE_MAP_KIND (expr));
391 break;
392 case OMP_CLAUSE_PROC_BIND:
393 bp_pack_enum (bp, omp_clause_proc_bind_kind, OMP_CLAUSE_PROC_BIND_LAST,
394 OMP_CLAUSE_PROC_BIND_KIND (expr));
395 break;
396 case OMP_CLAUSE_REDUCTION:
397 bp_pack_enum (bp, tree_code, MAX_TREE_CODES,
398 OMP_CLAUSE_REDUCTION_CODE (expr));
399 break;
400 default:
401 break;
406 /* Pack all the bitfields in EXPR into a bit pack. */
408 void
409 streamer_write_tree_bitfields (struct output_block *ob, tree expr)
411 bitpack_d bp = bitpack_create (ob->main_stream);
412 enum tree_code code;
414 code = TREE_CODE (expr);
416 /* Note that all these functions are highly sensitive to changes in
417 the types and sizes of each of the fields being packed. */
418 pack_ts_base_value_fields (&bp, expr);
420 if (CODE_CONTAINS_STRUCT (code, TS_INT_CST))
421 pack_ts_int_cst_value_fields (&bp, expr);
423 if (CODE_CONTAINS_STRUCT (code, TS_REAL_CST))
424 pack_ts_real_cst_value_fields (&bp, expr);
426 if (CODE_CONTAINS_STRUCT (code, TS_FIXED_CST))
427 pack_ts_fixed_cst_value_fields (&bp, expr);
429 if (CODE_CONTAINS_STRUCT (code, TS_DECL_MINIMAL))
430 stream_output_location (ob, &bp, DECL_SOURCE_LOCATION (expr));
432 if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
433 pack_ts_decl_common_value_fields (&bp, expr);
435 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WRTL))
436 pack_ts_decl_wrtl_value_fields (&bp, expr);
438 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WITH_VIS))
439 pack_ts_decl_with_vis_value_fields (&bp, expr);
441 if (CODE_CONTAINS_STRUCT (code, TS_FUNCTION_DECL))
442 pack_ts_function_decl_value_fields (&bp, expr);
444 if (CODE_CONTAINS_STRUCT (code, TS_TYPE_COMMON))
445 pack_ts_type_common_value_fields (&bp, expr);
447 if (CODE_CONTAINS_STRUCT (code, TS_EXP))
449 stream_output_location (ob, &bp, EXPR_LOCATION (expr));
450 if (code == MEM_REF
451 || code == TARGET_MEM_REF)
453 bp_pack_value (&bp, MR_DEPENDENCE_CLIQUE (expr), sizeof (short) * 8);
454 if (MR_DEPENDENCE_CLIQUE (expr) != 0)
455 bp_pack_value (&bp, MR_DEPENDENCE_BASE (expr), sizeof (short) * 8);
459 if (CODE_CONTAINS_STRUCT (code, TS_BLOCK))
460 pack_ts_block_value_fields (ob, &bp, expr);
462 if (CODE_CONTAINS_STRUCT (code, TS_TRANSLATION_UNIT_DECL))
463 pack_ts_translation_unit_decl_value_fields (ob, &bp, expr);
465 if (CODE_CONTAINS_STRUCT (code, TS_OPTIMIZATION))
466 cl_optimization_stream_out (&bp, TREE_OPTIMIZATION (expr));
468 if (CODE_CONTAINS_STRUCT (code, TS_BINFO))
469 bp_pack_var_len_unsigned (&bp, vec_safe_length (BINFO_BASE_ACCESSES (expr)));
471 if (CODE_CONTAINS_STRUCT (code, TS_CONSTRUCTOR))
472 bp_pack_var_len_unsigned (&bp, CONSTRUCTOR_NELTS (expr));
474 if (CODE_CONTAINS_STRUCT (code, TS_TARGET_OPTION)
475 /* Don't stream these when passing things to a different target. */
476 && !lto_stream_offload_p)
477 cl_target_option_stream_out (ob, &bp, TREE_TARGET_OPTION (expr));
479 if (code == OMP_CLAUSE)
480 pack_ts_omp_clause_value_fields (ob, &bp, expr);
482 streamer_write_bitpack (&bp);
486 /* Write the code and class of builtin EXPR to output block OB. IX is
487 the index into the streamer cache where EXPR is stored.*/
489 void
490 streamer_write_builtin (struct output_block *ob, tree expr)
492 gcc_assert (streamer_handle_as_builtin_p (expr));
494 if (DECL_BUILT_IN_CLASS (expr) == BUILT_IN_MD
495 && !targetm.builtin_decl)
496 sorry ("tree bytecode streams do not support machine specific builtin "
497 "functions on this target");
499 streamer_write_record_start (ob, LTO_builtin_decl);
500 streamer_write_enum (ob->main_stream, built_in_class, BUILT_IN_LAST,
501 DECL_BUILT_IN_CLASS (expr));
502 streamer_write_uhwi (ob, DECL_FUNCTION_CODE (expr));
504 if (DECL_ASSEMBLER_NAME_SET_P (expr))
506 /* When the assembler name of a builtin gets a user name,
507 the new name is always prefixed with '*' by
508 set_builtin_user_assembler_name. So, to prevent the
509 reader side from adding a second '*', we omit it here. */
510 const char *str = IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (expr));
511 if (strlen (str) > 1 && str[0] == '*')
512 streamer_write_string (ob, ob->main_stream, &str[1], true);
513 else
514 streamer_write_string (ob, ob->main_stream, NULL, true);
516 else
517 streamer_write_string (ob, ob->main_stream, NULL, true);
521 /* Emit the chain of tree nodes starting at T. OB is the output block
522 to write to. REF_P is true if chain elements should be emitted
523 as references. */
525 void
526 streamer_write_chain (struct output_block *ob, tree t, bool ref_p)
528 while (t)
530 /* We avoid outputting external vars or functions by reference
531 to the global decls section as we do not want to have them
532 enter decl merging. This is, of course, only for the call
533 for streaming BLOCK_VARS, but other callers are safe.
534 See also lto-streamer-out.c:DFS_write_tree_body. */
535 if (VAR_OR_FUNCTION_DECL_P (t)
536 && DECL_EXTERNAL (t))
537 stream_write_tree_shallow_non_ref (ob, t, ref_p);
538 else
539 stream_write_tree (ob, t, ref_p);
541 t = TREE_CHAIN (t);
544 /* Write a sentinel to terminate the chain. */
545 stream_write_tree (ob, NULL_TREE, ref_p);
549 /* Write all pointer fields in the TS_COMMON structure of EXPR to output
550 block OB. If REF_P is true, write a reference to EXPR's pointer
551 fields. */
553 static void
554 write_ts_common_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
556 if (TREE_CODE (expr) != IDENTIFIER_NODE)
557 stream_write_tree (ob, TREE_TYPE (expr), ref_p);
561 /* Write all pointer fields in the TS_VECTOR structure of EXPR to output
562 block OB. If REF_P is true, write a reference to EXPR's pointer
563 fields. */
565 static void
566 write_ts_vector_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
568 unsigned i;
569 /* Note that the number of elements for EXPR has already been emitted
570 in EXPR's header (see streamer_write_tree_header). */
571 for (i = 0; i < VECTOR_CST_NELTS (expr); ++i)
572 stream_write_tree (ob, VECTOR_CST_ELT (expr, i), ref_p);
576 /* Write all pointer fields in the TS_COMPLEX structure of EXPR to output
577 block OB. If REF_P is true, write a reference to EXPR's pointer
578 fields. */
580 static void
581 write_ts_complex_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
583 stream_write_tree (ob, TREE_REALPART (expr), ref_p);
584 stream_write_tree (ob, TREE_IMAGPART (expr), ref_p);
588 /* Write all pointer fields in the TS_DECL_MINIMAL structure of EXPR
589 to output block OB. If REF_P is true, write a reference to EXPR's
590 pointer fields. */
592 static void
593 write_ts_decl_minimal_tree_pointers (struct output_block *ob, tree expr,
594 bool ref_p)
596 /* Drop names that were created for anonymous entities. */
597 if (DECL_NAME (expr)
598 && TREE_CODE (DECL_NAME (expr)) == IDENTIFIER_NODE
599 && anon_aggrname_p (DECL_NAME (expr)))
600 stream_write_tree (ob, NULL_TREE, ref_p);
601 else
602 stream_write_tree (ob, DECL_NAME (expr), ref_p);
603 stream_write_tree (ob, DECL_CONTEXT (expr), ref_p);
607 /* Write all pointer fields in the TS_DECL_COMMON structure of EXPR to
608 output block OB. If REF_P is true, write a reference to EXPR's
609 pointer fields. */
611 static void
612 write_ts_decl_common_tree_pointers (struct output_block *ob, tree expr,
613 bool ref_p)
615 stream_write_tree (ob, DECL_SIZE (expr), ref_p);
616 stream_write_tree (ob, DECL_SIZE_UNIT (expr), ref_p);
618 /* Note, DECL_INITIAL is not handled here. Since DECL_INITIAL needs
619 special handling in LTO, it must be handled by streamer hooks. */
621 stream_write_tree (ob, DECL_ATTRIBUTES (expr), ref_p);
623 /* Do not stream DECL_ABSTRACT_ORIGIN. We cannot handle debug information
624 for early inlining so drop it on the floor instead of ICEing in
625 dwarf2out.c. */
627 if ((TREE_CODE (expr) == VAR_DECL
628 || TREE_CODE (expr) == PARM_DECL)
629 && DECL_HAS_VALUE_EXPR_P (expr))
630 stream_write_tree (ob, DECL_VALUE_EXPR (expr), ref_p);
632 if (TREE_CODE (expr) == VAR_DECL)
633 stream_write_tree (ob, DECL_DEBUG_EXPR (expr), ref_p);
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. */
641 static void
642 write_ts_decl_non_common_tree_pointers (struct output_block *ob, tree expr,
643 bool ref_p)
645 if (TREE_CODE (expr) == TYPE_DECL)
646 stream_write_tree (ob, DECL_ORIGINAL_TYPE (expr), ref_p);
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. */
654 static void
655 write_ts_decl_with_vis_tree_pointers (struct output_block *ob, tree expr,
656 bool ref_p)
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);
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. */
670 static void
671 write_ts_field_decl_tree_pointers (struct output_block *ob, tree expr,
672 bool ref_p)
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);
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. */
686 static void
687 write_ts_function_decl_tree_pointers (struct output_block *ob, tree expr,
688 bool ref_p)
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);
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. */
704 static void
705 write_ts_type_common_tree_pointers (struct output_block *ob, tree expr,
706 bool ref_p)
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);
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. */
727 static void
728 write_ts_type_non_common_tree_pointers (struct output_block *ob, tree expr,
729 bool ref_p)
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);
741 if (!POINTER_TYPE_P (expr))
742 stream_write_tree (ob, TYPE_MINVAL (expr), ref_p);
743 stream_write_tree (ob, TYPE_MAXVAL (expr), ref_p);
744 if (RECORD_OR_UNION_TYPE_P (expr))
745 stream_write_tree (ob, TYPE_BINFO (expr), ref_p);
749 /* Write all pointer fields in the TS_LIST structure of EXPR to output
750 block OB. If REF_P is true, write a reference to EXPR's pointer
751 fields. */
753 static void
754 write_ts_list_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
756 stream_write_tree (ob, TREE_PURPOSE (expr), ref_p);
757 stream_write_tree (ob, TREE_VALUE (expr), ref_p);
758 stream_write_tree (ob, TREE_CHAIN (expr), ref_p);
762 /* Write all pointer fields in the TS_VEC structure of EXPR to output
763 block OB. If REF_P is true, write a reference to EXPR's pointer
764 fields. */
766 static void
767 write_ts_vec_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
769 int i;
771 /* Note that the number of slots for EXPR has already been emitted
772 in EXPR's header (see streamer_write_tree_header). */
773 for (i = 0; i < TREE_VEC_LENGTH (expr); i++)
774 stream_write_tree (ob, TREE_VEC_ELT (expr, i), ref_p);
778 /* Write all pointer fields in the TS_EXP structure of EXPR to output
779 block OB. If REF_P is true, write a reference to EXPR's pointer
780 fields. */
782 static void
783 write_ts_exp_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
785 int i;
787 for (i = 0; i < TREE_OPERAND_LENGTH (expr); i++)
788 stream_write_tree (ob, TREE_OPERAND (expr, i), ref_p);
789 stream_write_tree (ob, TREE_BLOCK (expr), ref_p);
793 /* Write all pointer fields in the TS_BLOCK structure of EXPR to output
794 block OB. If REF_P is true, write a reference to EXPR's pointer
795 fields. */
797 static void
798 write_ts_block_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
800 streamer_write_chain (ob, BLOCK_VARS (expr), ref_p);
802 stream_write_tree (ob, BLOCK_SUPERCONTEXT (expr), ref_p);
804 /* Stream BLOCK_ABSTRACT_ORIGIN for the limited cases we can handle - those
805 that represent inlined function scopes.
806 For the rest them on the floor instead of ICEing in dwarf2out.c. */
807 if (inlined_function_outer_scope_p (expr))
809 tree ultimate_origin = block_ultimate_origin (expr);
810 stream_write_tree (ob, ultimate_origin, ref_p);
812 else
813 stream_write_tree (ob, NULL_TREE, ref_p);
814 /* Do not stream BLOCK_NONLOCALIZED_VARS. We cannot handle debug information
815 for early inlined BLOCKs so drop it on the floor instead of ICEing in
816 dwarf2out.c. */
818 /* BLOCK_FRAGMENT_ORIGIN and BLOCK_FRAGMENT_CHAIN is not live at LTO
819 streaming time. */
821 /* Do not output BLOCK_SUBBLOCKS. Instead on streaming-in this
822 list is re-constructed from BLOCK_SUPERCONTEXT. */
826 /* Write all pointer fields in the TS_BINFO structure of EXPR to output
827 block OB. If REF_P is true, write a reference to EXPR's pointer
828 fields. */
830 static void
831 write_ts_binfo_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
833 unsigned i;
834 tree t;
836 /* Note that the number of BINFO slots has already been emitted in
837 EXPR's header (see streamer_write_tree_header) because this length
838 is needed to build the empty BINFO node on the reader side. */
839 FOR_EACH_VEC_ELT (*BINFO_BASE_BINFOS (expr), i, t)
840 stream_write_tree (ob, t, ref_p);
841 stream_write_tree (ob, NULL_TREE, false);
843 stream_write_tree (ob, BINFO_OFFSET (expr), ref_p);
844 stream_write_tree (ob, BINFO_VTABLE (expr), ref_p);
845 stream_write_tree (ob, BINFO_VPTR_FIELD (expr), ref_p);
847 /* The number of BINFO_BASE_ACCESSES has already been emitted in
848 EXPR's bitfield section. */
849 FOR_EACH_VEC_SAFE_ELT (BINFO_BASE_ACCESSES (expr), i, t)
850 stream_write_tree (ob, t, ref_p);
852 /* Do not walk BINFO_INHERITANCE_CHAIN, BINFO_SUBVTT_INDEX
853 and BINFO_VPTR_INDEX; these are used by C++ FE only. */
857 /* Write all pointer fields in the TS_CONSTRUCTOR structure of EXPR to
858 output block OB. If REF_P is true, write a reference to EXPR's
859 pointer fields. */
861 static void
862 write_ts_constructor_tree_pointers (struct output_block *ob, tree expr,
863 bool ref_p)
865 unsigned i;
866 tree index, value;
868 FOR_EACH_CONSTRUCTOR_ELT (CONSTRUCTOR_ELTS (expr), i, index, value)
870 stream_write_tree (ob, index, ref_p);
871 stream_write_tree (ob, value, ref_p);
876 /* Write all pointer fields in the TS_OMP_CLAUSE structure of EXPR
877 to output block OB. If REF_P is true, write a reference to EXPR's
878 pointer fields. */
880 static void
881 write_ts_omp_clause_tree_pointers (struct output_block *ob, tree expr,
882 bool ref_p)
884 int i;
885 for (i = 0; i < omp_clause_num_ops[OMP_CLAUSE_CODE (expr)]; i++)
886 stream_write_tree (ob, OMP_CLAUSE_OPERAND (expr, i), ref_p);
887 if (OMP_CLAUSE_CODE (expr) == OMP_CLAUSE_REDUCTION)
889 /* We don't stream these right now, handle it if streaming
890 of them is needed. */
891 gcc_assert (OMP_CLAUSE_REDUCTION_GIMPLE_INIT (expr) == NULL);
892 gcc_assert (OMP_CLAUSE_REDUCTION_GIMPLE_MERGE (expr) == NULL);
894 stream_write_tree (ob, OMP_CLAUSE_CHAIN (expr), ref_p);
898 /* Write all pointer fields in EXPR to output block OB. If REF_P is true,
899 the leaves of EXPR are emitted as references. */
901 void
902 streamer_write_tree_body (struct output_block *ob, tree expr, bool ref_p)
904 enum tree_code code;
906 lto_stats.num_tree_bodies_output++;
908 code = TREE_CODE (expr);
910 if (CODE_CONTAINS_STRUCT (code, TS_TYPED))
911 write_ts_common_tree_pointers (ob, expr, ref_p);
913 if (CODE_CONTAINS_STRUCT (code, TS_VECTOR))
914 write_ts_vector_tree_pointers (ob, expr, ref_p);
916 if (CODE_CONTAINS_STRUCT (code, TS_COMPLEX))
917 write_ts_complex_tree_pointers (ob, expr, ref_p);
919 if (CODE_CONTAINS_STRUCT (code, TS_DECL_MINIMAL))
920 write_ts_decl_minimal_tree_pointers (ob, expr, ref_p);
922 if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
923 write_ts_decl_common_tree_pointers (ob, expr, ref_p);
925 if (CODE_CONTAINS_STRUCT (code, TS_DECL_NON_COMMON))
926 write_ts_decl_non_common_tree_pointers (ob, expr, ref_p);
928 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WITH_VIS))
929 write_ts_decl_with_vis_tree_pointers (ob, expr, ref_p);
931 if (CODE_CONTAINS_STRUCT (code, TS_FIELD_DECL))
932 write_ts_field_decl_tree_pointers (ob, expr, ref_p);
934 if (CODE_CONTAINS_STRUCT (code, TS_FUNCTION_DECL))
935 write_ts_function_decl_tree_pointers (ob, expr, ref_p);
937 if (CODE_CONTAINS_STRUCT (code, TS_TYPE_COMMON))
938 write_ts_type_common_tree_pointers (ob, expr, ref_p);
940 if (CODE_CONTAINS_STRUCT (code, TS_TYPE_NON_COMMON))
941 write_ts_type_non_common_tree_pointers (ob, expr, ref_p);
943 if (CODE_CONTAINS_STRUCT (code, TS_LIST))
944 write_ts_list_tree_pointers (ob, expr, ref_p);
946 if (CODE_CONTAINS_STRUCT (code, TS_VEC))
947 write_ts_vec_tree_pointers (ob, expr, ref_p);
949 if (CODE_CONTAINS_STRUCT (code, TS_EXP))
950 write_ts_exp_tree_pointers (ob, expr, ref_p);
952 if (CODE_CONTAINS_STRUCT (code, TS_BLOCK))
953 write_ts_block_tree_pointers (ob, expr, ref_p);
955 if (CODE_CONTAINS_STRUCT (code, TS_BINFO))
956 write_ts_binfo_tree_pointers (ob, expr, ref_p);
958 if (CODE_CONTAINS_STRUCT (code, TS_CONSTRUCTOR))
959 write_ts_constructor_tree_pointers (ob, expr, ref_p);
961 if (code == OMP_CLAUSE)
962 write_ts_omp_clause_tree_pointers (ob, expr, ref_p);
966 /* Emit header information for tree EXPR to output block OB. The header
967 contains everything needed to instantiate an empty skeleton for
968 EXPR on the reading side. IX is the index into the streamer cache
969 where EXPR is stored. */
971 void
972 streamer_write_tree_header (struct output_block *ob, tree expr)
974 enum LTO_tags tag;
975 enum tree_code code;
977 /* We should not see any tree nodes not handled by the streamer. */
978 code = TREE_CODE (expr);
980 /* The header of a tree node consists of its tag, the size of
981 the node, and any other information needed to instantiate
982 EXPR on the reading side (such as the number of slots in
983 variable sized nodes). */
984 tag = lto_tree_code_to_tag (code);
985 streamer_write_record_start (ob, tag);
987 /* The following will cause bootstrap miscomparisons. Enable with care. */
988 #ifdef LTO_STREAMER_DEBUG
989 /* This is used mainly for debugging purposes. When the reader
990 and the writer do not agree on a streamed node, the pointer
991 value for EXPR can be used to track down the differences in
992 the debugger. */
993 gcc_assert ((HOST_WIDE_INT) (intptr_t) expr == (intptr_t) expr);
994 streamer_write_hwi (ob, (HOST_WIDE_INT) (intptr_t) expr);
995 #endif
997 /* The text in strings and identifiers are completely emitted in
998 the header. */
999 if (CODE_CONTAINS_STRUCT (code, TS_STRING))
1000 streamer_write_string_cst (ob, ob->main_stream, expr);
1001 else if (CODE_CONTAINS_STRUCT (code, TS_IDENTIFIER))
1002 write_identifier (ob, ob->main_stream, expr);
1003 else if (CODE_CONTAINS_STRUCT (code, TS_VECTOR))
1004 streamer_write_hwi (ob, VECTOR_CST_NELTS (expr));
1005 else if (CODE_CONTAINS_STRUCT (code, TS_VEC))
1006 streamer_write_hwi (ob, TREE_VEC_LENGTH (expr));
1007 else if (CODE_CONTAINS_STRUCT (code, TS_BINFO))
1008 streamer_write_uhwi (ob, BINFO_N_BASE_BINFOS (expr));
1009 else if (TREE_CODE (expr) == CALL_EXPR)
1010 streamer_write_uhwi (ob, call_expr_nargs (expr));
1011 else if (TREE_CODE (expr) == OMP_CLAUSE)
1012 streamer_write_uhwi (ob, OMP_CLAUSE_CODE (expr));
1013 else if (CODE_CONTAINS_STRUCT (code, TS_INT_CST))
1015 gcc_checking_assert (TREE_INT_CST_NUNITS (expr));
1016 streamer_write_uhwi (ob, TREE_INT_CST_NUNITS (expr));
1017 streamer_write_uhwi (ob, TREE_INT_CST_EXT_NUNITS (expr));
1022 /* Emit the integer constant CST to output block OB. If REF_P is true,
1023 CST's type will be emitted as a reference. */
1025 void
1026 streamer_write_integer_cst (struct output_block *ob, tree cst, bool ref_p)
1028 int i;
1029 int len = TREE_INT_CST_NUNITS (cst);
1030 gcc_assert (!TREE_OVERFLOW (cst));
1031 streamer_write_record_start (ob, LTO_integer_cst);
1032 stream_write_tree (ob, TREE_TYPE (cst), ref_p);
1033 /* We're effectively streaming a non-sign-extended wide_int here,
1034 so there's no need to stream TREE_INT_CST_EXT_NUNITS or any
1035 array members beyond LEN. We'll recreate the tree from the
1036 wide_int and the type. */
1037 streamer_write_uhwi (ob, len);
1038 for (i = 0; i < len; i++)
1039 streamer_write_hwi (ob, TREE_INT_CST_ELT (cst, i));