Update changelog entry.
[official-gcc.git] / gcc / tree-streamer-out.c
blob4e7c7429561f139003ca28fc85bc3480d747aa4c
1 /* Routines for emitting trees to a file stream.
3 Copyright (C) 2011-2018 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))
91 bp_pack_value (bp, DECL_UNSIGNED (expr), 1);
92 bp_pack_value (bp, DECL_NAMELESS (expr), 1);
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))
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);
122 else if (TREE_CODE (expr) == BIT_FIELD_REF || TREE_CODE (expr) == MEM_REF)
124 bp_pack_value (bp, REF_REVERSE_STORAGE_ORDER (expr), 1);
125 bp_pack_value (bp, 0, 8);
127 else if (TREE_CODE (expr) == SSA_NAME)
129 bp_pack_value (bp, SSA_NAME_IS_DEFAULT_DEF (expr), 1);
130 bp_pack_value (bp, 0, 8);
132 else if (TREE_CODE (expr) == CALL_EXPR)
134 bp_pack_value (bp, CALL_EXPR_BY_DESCRIPTOR (expr), 1);
135 bp_pack_value (bp, 0, 8);
137 else
138 bp_pack_value (bp, 0, 9);
142 /* Pack all the non-pointer fields of the TS_INTEGER_CST structure of
143 expression EXPR into bitpack BP. */
145 static void
146 pack_ts_int_cst_value_fields (struct bitpack_d *bp, tree expr)
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));
156 /* Pack all the non-pointer fields of the TS_REAL_CST structure of
157 expression EXPR into bitpack BP. */
159 static void
160 pack_ts_real_cst_value_fields (struct bitpack_d *bp, tree expr)
162 unsigned i;
163 REAL_VALUE_TYPE r;
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);
177 /* Pack all the non-pointer fields of the TS_FIXED_CST structure of
178 expression EXPR into bitpack BP. */
180 static void
181 pack_ts_fixed_cst_value_fields (struct bitpack_d *bp, tree expr)
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);
189 /* Pack all the non-pointer fields of the TS_DECL_COMMON structure
190 of expression EXPR into bitpack BP. */
192 static void
193 pack_ts_decl_common_value_fields (struct bitpack_d *bp, tree expr)
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));
207 if (TREE_CODE (expr) == LABEL_DECL)
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));
215 if (TREE_CODE (expr) == FIELD_DECL)
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);
223 if (VAR_P (expr))
225 bp_pack_value (bp, DECL_HAS_DEBUG_EXPR_P (expr), 1);
226 bp_pack_value (bp, DECL_NONLOCAL_FRAME (expr), 1);
229 if (TREE_CODE (expr) == RESULT_DECL
230 || TREE_CODE (expr) == PARM_DECL
231 || VAR_P (expr))
233 bp_pack_value (bp, DECL_BY_REFERENCE (expr), 1);
234 if (VAR_P (expr) || TREE_CODE (expr) == PARM_DECL)
235 bp_pack_value (bp, DECL_HAS_VALUE_EXPR_P (expr), 1);
240 /* Pack all the non-pointer fields of the TS_DECL_WRTL structure
241 of expression EXPR into bitpack BP. */
243 static void
244 pack_ts_decl_wrtl_value_fields (struct bitpack_d *bp, tree expr)
246 bp_pack_value (bp, DECL_REGISTER (expr), 1);
250 /* Pack all the non-pointer fields of the TS_DECL_WITH_VIS structure
251 of expression EXPR into bitpack BP. */
253 static void
254 pack_ts_decl_with_vis_value_fields (struct bitpack_d *bp, tree expr)
256 bp_pack_value (bp, DECL_COMMON (expr), 1);
257 bp_pack_value (bp, DECL_DLLIMPORT_P (expr), 1);
258 bp_pack_value (bp, DECL_WEAK (expr), 1);
259 bp_pack_value (bp, DECL_SEEN_IN_BIND_EXPR_P (expr), 1);
260 bp_pack_value (bp, DECL_COMDAT (expr), 1);
261 bp_pack_value (bp, DECL_VISIBILITY (expr), 2);
262 bp_pack_value (bp, DECL_VISIBILITY_SPECIFIED (expr), 1);
264 if (VAR_P (expr))
266 bp_pack_value (bp, DECL_HARD_REGISTER (expr), 1);
267 /* DECL_IN_TEXT_SECTION is set during final asm output only. */
268 bp_pack_value (bp, DECL_IN_CONSTANT_POOL (expr), 1);
271 if (TREE_CODE (expr) == FUNCTION_DECL)
273 bp_pack_value (bp, DECL_FINAL_P (expr), 1);
274 bp_pack_value (bp, DECL_CXX_CONSTRUCTOR_P (expr), 1);
275 bp_pack_value (bp, DECL_CXX_DESTRUCTOR_P (expr), 1);
280 /* Pack all the non-pointer fields of the TS_FUNCTION_DECL structure
281 of expression EXPR into bitpack BP. */
283 static void
284 pack_ts_function_decl_value_fields (struct bitpack_d *bp, tree expr)
286 bp_pack_enum (bp, built_in_class, BUILT_IN_LAST,
287 DECL_BUILT_IN_CLASS (expr));
288 bp_pack_value (bp, DECL_STATIC_CONSTRUCTOR (expr), 1);
289 bp_pack_value (bp, DECL_STATIC_DESTRUCTOR (expr), 1);
290 bp_pack_value (bp, DECL_UNINLINABLE (expr), 1);
291 bp_pack_value (bp, DECL_POSSIBLY_INLINED (expr), 1);
292 bp_pack_value (bp, DECL_IS_NOVOPS (expr), 1);
293 bp_pack_value (bp, DECL_IS_RETURNS_TWICE (expr), 1);
294 bp_pack_value (bp, DECL_IS_MALLOC (expr), 1);
295 bp_pack_value (bp, DECL_IS_OPERATOR_NEW (expr), 1);
296 bp_pack_value (bp, DECL_DECLARED_INLINE_P (expr), 1);
297 bp_pack_value (bp, DECL_STATIC_CHAIN (expr), 1);
298 bp_pack_value (bp, DECL_NO_INLINE_WARNING_P (expr), 1);
299 bp_pack_value (bp, DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT (expr), 1);
300 bp_pack_value (bp, DECL_NO_LIMIT_STACK (expr), 1);
301 bp_pack_value (bp, DECL_DISREGARD_INLINE_LIMITS (expr), 1);
302 bp_pack_value (bp, DECL_PURE_P (expr), 1);
303 bp_pack_value (bp, DECL_LOOPING_CONST_OR_PURE_P (expr), 1);
304 if (DECL_BUILT_IN_CLASS (expr) != NOT_BUILT_IN)
305 bp_pack_value (bp, DECL_FUNCTION_CODE (expr), 12);
309 /* Pack all the non-pointer fields of the TS_TYPE_COMMON structure
310 of expression EXPR into bitpack BP. */
312 static void
313 pack_ts_type_common_value_fields (struct bitpack_d *bp, tree expr)
315 /* for VECTOR_TYPE, TYPE_MODE reevaluates the mode using target_flags
316 not necessary valid in a global context.
317 Use the raw value previously set by layout_type. */
318 bp_pack_machine_mode (bp, TYPE_MODE_RAW (expr));
319 bp_pack_value (bp, TYPE_STRING_FLAG (expr), 1);
320 /* TYPE_NO_FORCE_BLK is private to stor-layout and need
321 no streaming. */
322 bp_pack_value (bp, TYPE_PACKED (expr), 1);
323 bp_pack_value (bp, TYPE_RESTRICT (expr), 1);
324 bp_pack_value (bp, TYPE_USER_ALIGN (expr), 1);
325 bp_pack_value (bp, TYPE_READONLY (expr), 1);
326 /* We used to stream TYPE_ALIAS_SET == 0 information to let frontends mark
327 types that are opaque for TBAA. This however did not work as intended,
328 because TYPE_ALIAS_SET == 0 was regularly lost in type merging. */
329 if (RECORD_OR_UNION_TYPE_P (expr))
331 bp_pack_value (bp, TYPE_TRANSPARENT_AGGR (expr), 1);
332 bp_pack_value (bp, TYPE_FINAL_P (expr), 1);
334 else if (TREE_CODE (expr) == ARRAY_TYPE)
335 bp_pack_value (bp, TYPE_NONALIASED_COMPONENT (expr), 1);
336 if (AGGREGATE_TYPE_P (expr))
337 bp_pack_value (bp, TYPE_TYPELESS_STORAGE (expr), 1);
338 bp_pack_value (bp, TYPE_EMPTY_P (expr), 1);
339 bp_pack_var_len_unsigned (bp, TYPE_PRECISION (expr));
340 bp_pack_var_len_unsigned (bp, TYPE_ALIGN (expr));
344 /* Pack all the non-pointer fields of the TS_BLOCK structure
345 of expression EXPR into bitpack BP. */
347 static void
348 pack_ts_block_value_fields (struct output_block *ob,
349 struct bitpack_d *bp, tree expr)
351 /* BLOCK_NUMBER is recomputed. */
352 /* Stream BLOCK_SOURCE_LOCATION for the limited cases we can handle - those
353 that represent inlined function scopes.
354 For the rest them on the floor instead of ICEing in dwarf2out.c. */
355 if (inlined_function_outer_scope_p (expr))
356 stream_output_location (ob, bp, BLOCK_SOURCE_LOCATION (expr));
357 else
358 stream_output_location (ob, bp, UNKNOWN_LOCATION);
361 /* Pack all the non-pointer fields of the TS_TRANSLATION_UNIT_DECL structure
362 of expression EXPR into bitpack BP. */
364 static void
365 pack_ts_translation_unit_decl_value_fields (struct output_block *ob,
366 struct bitpack_d *bp, tree expr)
368 bp_pack_string (ob, bp, TRANSLATION_UNIT_LANGUAGE (expr), true);
372 /* Pack all the non-pointer fields of the TS_OMP_CLAUSE structure
373 of expression EXPR into bitpack BP. */
375 static void
376 pack_ts_omp_clause_value_fields (struct output_block *ob,
377 struct bitpack_d *bp, tree expr)
379 stream_output_location (ob, bp, OMP_CLAUSE_LOCATION (expr));
380 switch (OMP_CLAUSE_CODE (expr))
382 case OMP_CLAUSE_DEFAULT:
383 bp_pack_enum (bp, omp_clause_default_kind, OMP_CLAUSE_DEFAULT_LAST,
384 OMP_CLAUSE_DEFAULT_KIND (expr));
385 break;
386 case OMP_CLAUSE_SCHEDULE:
387 bp_pack_enum (bp, omp_clause_schedule_kind, OMP_CLAUSE_SCHEDULE_LAST,
388 OMP_CLAUSE_SCHEDULE_KIND (expr));
389 break;
390 case OMP_CLAUSE_DEPEND:
391 bp_pack_enum (bp, omp_clause_depend_kind, OMP_CLAUSE_DEPEND_LAST,
392 OMP_CLAUSE_DEPEND_KIND (expr));
393 break;
394 case OMP_CLAUSE_MAP:
395 bp_pack_enum (bp, gomp_map_kind, GOMP_MAP_LAST,
396 OMP_CLAUSE_MAP_KIND (expr));
397 break;
398 case OMP_CLAUSE_PROC_BIND:
399 bp_pack_enum (bp, omp_clause_proc_bind_kind, OMP_CLAUSE_PROC_BIND_LAST,
400 OMP_CLAUSE_PROC_BIND_KIND (expr));
401 break;
402 case OMP_CLAUSE_REDUCTION:
403 case OMP_CLAUSE_TASK_REDUCTION:
404 case OMP_CLAUSE_IN_REDUCTION:
405 bp_pack_enum (bp, tree_code, MAX_TREE_CODES,
406 OMP_CLAUSE_REDUCTION_CODE (expr));
407 break;
408 default:
409 break;
414 /* Pack all the bitfields in EXPR into a bit pack. */
416 void
417 streamer_write_tree_bitfields (struct output_block *ob, tree expr)
419 bitpack_d bp = bitpack_create (ob->main_stream);
420 enum tree_code code;
422 code = TREE_CODE (expr);
424 /* Note that all these functions are highly sensitive to changes in
425 the types and sizes of each of the fields being packed. */
426 pack_ts_base_value_fields (&bp, expr);
428 if (CODE_CONTAINS_STRUCT (code, TS_INT_CST))
429 pack_ts_int_cst_value_fields (&bp, expr);
431 if (CODE_CONTAINS_STRUCT (code, TS_REAL_CST))
432 pack_ts_real_cst_value_fields (&bp, expr);
434 if (CODE_CONTAINS_STRUCT (code, TS_FIXED_CST))
435 pack_ts_fixed_cst_value_fields (&bp, expr);
437 if (CODE_CONTAINS_STRUCT (code, TS_DECL_MINIMAL))
438 stream_output_location (ob, &bp, DECL_SOURCE_LOCATION (expr));
440 if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
441 pack_ts_decl_common_value_fields (&bp, expr);
443 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WRTL))
444 pack_ts_decl_wrtl_value_fields (&bp, expr);
446 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WITH_VIS))
447 pack_ts_decl_with_vis_value_fields (&bp, expr);
449 if (CODE_CONTAINS_STRUCT (code, TS_FUNCTION_DECL))
450 pack_ts_function_decl_value_fields (&bp, expr);
452 if (CODE_CONTAINS_STRUCT (code, TS_TYPE_COMMON))
453 pack_ts_type_common_value_fields (&bp, expr);
455 if (CODE_CONTAINS_STRUCT (code, TS_EXP))
457 stream_output_location (ob, &bp, EXPR_LOCATION (expr));
458 if (code == MEM_REF
459 || code == TARGET_MEM_REF)
461 bp_pack_value (&bp, MR_DEPENDENCE_CLIQUE (expr), sizeof (short) * 8);
462 if (MR_DEPENDENCE_CLIQUE (expr) != 0)
463 bp_pack_value (&bp, MR_DEPENDENCE_BASE (expr), sizeof (short) * 8);
465 else if (code == CALL_EXPR)
466 bp_pack_enum (&bp, internal_fn, IFN_LAST, CALL_EXPR_IFN (expr));
469 if (CODE_CONTAINS_STRUCT (code, TS_BLOCK))
470 pack_ts_block_value_fields (ob, &bp, expr);
472 if (CODE_CONTAINS_STRUCT (code, TS_TRANSLATION_UNIT_DECL))
473 pack_ts_translation_unit_decl_value_fields (ob, &bp, expr);
475 if (CODE_CONTAINS_STRUCT (code, TS_OPTIMIZATION))
476 cl_optimization_stream_out (ob, &bp, TREE_OPTIMIZATION (expr));
478 if (CODE_CONTAINS_STRUCT (code, TS_CONSTRUCTOR))
479 bp_pack_var_len_unsigned (&bp, CONSTRUCTOR_NELTS (expr));
481 if (CODE_CONTAINS_STRUCT (code, TS_TARGET_OPTION)
482 /* Don't stream these when passing things to a different target. */
483 && !lto_stream_offload_p)
484 cl_target_option_stream_out (ob, &bp, TREE_TARGET_OPTION (expr));
486 if (code == OMP_CLAUSE)
487 pack_ts_omp_clause_value_fields (ob, &bp, expr);
489 streamer_write_bitpack (&bp);
493 /* Emit the chain of tree nodes starting at T. OB is the output block
494 to write to. REF_P is true if chain elements should be emitted
495 as references. */
497 void
498 streamer_write_chain (struct output_block *ob, tree t, bool ref_p)
500 while (t)
502 /* We avoid outputting external vars or functions by reference
503 to the global decls section as we do not want to have them
504 enter decl merging. We should not need to do this anymore because
505 free_lang_data removes them from block scopes. */
506 gcc_assert (!VAR_OR_FUNCTION_DECL_P (t) || !DECL_EXTERNAL (t));
507 stream_write_tree (ob, t, ref_p);
509 t = TREE_CHAIN (t);
512 /* Write a sentinel to terminate the chain. */
513 stream_write_tree (ob, NULL_TREE, ref_p);
517 /* Write all pointer fields in the TS_COMMON structure of EXPR to output
518 block OB. If REF_P is true, write a reference to EXPR's pointer
519 fields. */
521 static void
522 write_ts_common_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
524 if (TREE_CODE (expr) != IDENTIFIER_NODE)
525 stream_write_tree (ob, TREE_TYPE (expr), ref_p);
529 /* Write all pointer fields in the TS_VECTOR structure of EXPR to output
530 block OB. If REF_P is true, write a reference to EXPR's pointer
531 fields. */
533 static void
534 write_ts_vector_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
536 /* Note that the number of elements for EXPR has already been emitted
537 in EXPR's header (see streamer_write_tree_header). */
538 unsigned int count = vector_cst_encoded_nelts (expr);
539 for (unsigned int i = 0; i < count; ++i)
540 stream_write_tree (ob, VECTOR_CST_ENCODED_ELT (expr, i), ref_p);
544 /* Write all pointer fields in the TS_POLY_INT_CST structure of EXPR to
545 output block OB. If REF_P is true, write a reference to EXPR's pointer
546 fields. */
548 static void
549 write_ts_poly_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
551 for (unsigned int i = 0; i < NUM_POLY_INT_COEFFS; ++i)
552 stream_write_tree (ob, POLY_INT_CST_COEFF (expr, i), ref_p);
556 /* Write all pointer fields in the TS_COMPLEX structure of EXPR to output
557 block OB. If REF_P is true, write a reference to EXPR's pointer
558 fields. */
560 static void
561 write_ts_complex_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
563 stream_write_tree (ob, TREE_REALPART (expr), ref_p);
564 stream_write_tree (ob, TREE_IMAGPART (expr), ref_p);
568 /* Write all pointer fields in the TS_DECL_MINIMAL structure of EXPR
569 to output block OB. If REF_P is true, write a reference to EXPR's
570 pointer fields. */
572 static void
573 write_ts_decl_minimal_tree_pointers (struct output_block *ob, tree expr,
574 bool ref_p)
576 /* Drop names that were created for anonymous entities. */
577 if (DECL_NAME (expr)
578 && TREE_CODE (DECL_NAME (expr)) == IDENTIFIER_NODE
579 && anon_aggrname_p (DECL_NAME (expr)))
580 stream_write_tree (ob, NULL_TREE, ref_p);
581 else
582 stream_write_tree (ob, DECL_NAME (expr), ref_p);
583 if (TREE_CODE (expr) != TRANSLATION_UNIT_DECL
584 && ! DECL_CONTEXT (expr))
585 stream_write_tree (ob, (*all_translation_units)[0], ref_p);
586 else
587 stream_write_tree (ob, DECL_CONTEXT (expr), ref_p);
591 /* Write all pointer fields in the TS_DECL_COMMON structure of EXPR to
592 output block OB. If REF_P is true, write a reference to EXPR's
593 pointer fields. */
595 static void
596 write_ts_decl_common_tree_pointers (struct output_block *ob, tree expr,
597 bool ref_p)
599 stream_write_tree (ob, DECL_SIZE (expr), ref_p);
600 stream_write_tree (ob, DECL_SIZE_UNIT (expr), ref_p);
602 /* Note, DECL_INITIAL is not handled here. Since DECL_INITIAL needs
603 special handling in LTO, it must be handled by streamer hooks. */
605 stream_write_tree (ob, DECL_ATTRIBUTES (expr), ref_p);
606 stream_write_tree (ob, DECL_ABSTRACT_ORIGIN (expr), ref_p);
608 if ((VAR_P (expr) || TREE_CODE (expr) == PARM_DECL)
609 && DECL_HAS_VALUE_EXPR_P (expr))
610 stream_write_tree (ob, DECL_VALUE_EXPR (expr), ref_p);
612 if (VAR_P (expr)
613 && DECL_HAS_DEBUG_EXPR_P (expr))
614 stream_write_tree (ob, DECL_DEBUG_EXPR (expr), ref_p);
618 /* Write all pointer fields in the TS_DECL_NON_COMMON structure of
619 EXPR to output block OB. If REF_P is true, write a reference to EXPR's
620 pointer fields. */
622 static void
623 write_ts_decl_non_common_tree_pointers (struct output_block *, tree, bool)
628 /* Write all pointer fields in the TS_DECL_WITH_VIS structure of EXPR
629 to output block OB. If REF_P is true, write a reference to EXPR's
630 pointer fields. */
632 static void
633 write_ts_decl_with_vis_tree_pointers (struct output_block *ob, tree expr,
634 bool ref_p)
636 /* Make sure we don't inadvertently set the assembler name. */
637 if (DECL_ASSEMBLER_NAME_SET_P (expr))
638 stream_write_tree (ob, DECL_ASSEMBLER_NAME (expr), ref_p);
639 else
640 stream_write_tree (ob, NULL_TREE, false);
644 /* Write all pointer fields in the TS_FIELD_DECL structure of EXPR to
645 output block OB. If REF_P is true, write a reference to EXPR's
646 pointer fields. */
648 static void
649 write_ts_field_decl_tree_pointers (struct output_block *ob, tree expr,
650 bool ref_p)
652 stream_write_tree (ob, DECL_FIELD_OFFSET (expr), ref_p);
653 stream_write_tree (ob, DECL_BIT_FIELD_TYPE (expr), ref_p);
654 stream_write_tree (ob, DECL_BIT_FIELD_REPRESENTATIVE (expr), ref_p);
655 stream_write_tree (ob, DECL_FIELD_BIT_OFFSET (expr), ref_p);
659 /* Write all pointer fields in the TS_FUNCTION_DECL structure of EXPR
660 to output block OB. If REF_P is true, write a reference to EXPR's
661 pointer fields. */
663 static void
664 write_ts_function_decl_tree_pointers (struct output_block *ob, tree expr,
665 bool ref_p)
667 /* DECL_STRUCT_FUNCTION is handled by lto_output_function. */
668 stream_write_tree (ob, DECL_FUNCTION_PERSONALITY (expr), ref_p);
669 /* Don't stream these when passing things to a different target. */
670 if (!lto_stream_offload_p)
671 stream_write_tree (ob, DECL_FUNCTION_SPECIFIC_TARGET (expr), ref_p);
672 stream_write_tree (ob, DECL_FUNCTION_SPECIFIC_OPTIMIZATION (expr), ref_p);
676 /* Write all pointer fields in the TS_TYPE_COMMON structure of EXPR to
677 output block OB. If REF_P is true, write a reference to EXPR's
678 pointer fields. */
680 static void
681 write_ts_type_common_tree_pointers (struct output_block *ob, tree expr,
682 bool ref_p)
684 stream_write_tree (ob, TYPE_SIZE (expr), ref_p);
685 stream_write_tree (ob, TYPE_SIZE_UNIT (expr), ref_p);
686 stream_write_tree (ob, TYPE_ATTRIBUTES (expr), ref_p);
687 stream_write_tree (ob, TYPE_NAME (expr), ref_p);
688 /* Do not stream TYPE_POINTER_TO or TYPE_REFERENCE_TO. They will be
689 reconstructed during fixup. */
690 /* Do not stream TYPE_NEXT_VARIANT, we reconstruct the variant lists
691 during fixup. */
692 stream_write_tree (ob, TYPE_MAIN_VARIANT (expr), ref_p);
693 stream_write_tree (ob, TYPE_CONTEXT (expr), ref_p);
694 /* TYPE_CANONICAL is re-computed during type merging, so no need
695 to stream it here. */
696 /* Do not stream TYPE_STUB_DECL; it is not needed by LTO but currently
697 it can not be freed by free_lang_data without triggering ICEs in
698 langhooks. */
701 /* Write all pointer fields in the TS_TYPE_NON_COMMON structure of EXPR
702 to output block OB. If REF_P is true, write a reference to EXPR's
703 pointer fields. */
705 static void
706 write_ts_type_non_common_tree_pointers (struct output_block *ob, tree expr,
707 bool ref_p)
709 if (TREE_CODE (expr) == ENUMERAL_TYPE)
710 stream_write_tree (ob, TYPE_VALUES (expr), ref_p);
711 else if (TREE_CODE (expr) == ARRAY_TYPE)
712 stream_write_tree (ob, TYPE_DOMAIN (expr), ref_p);
713 else if (RECORD_OR_UNION_TYPE_P (expr))
714 streamer_write_chain (ob, TYPE_FIELDS (expr), ref_p);
715 else if (TREE_CODE (expr) == FUNCTION_TYPE
716 || TREE_CODE (expr) == METHOD_TYPE)
717 stream_write_tree (ob, TYPE_ARG_TYPES (expr), ref_p);
719 if (!POINTER_TYPE_P (expr))
720 stream_write_tree (ob, TYPE_MIN_VALUE_RAW (expr), ref_p);
721 stream_write_tree (ob, TYPE_MAX_VALUE_RAW (expr), ref_p);
725 /* Write all pointer fields in the TS_LIST structure of EXPR to output
726 block OB. If REF_P is true, write a reference to EXPR's pointer
727 fields. */
729 static void
730 write_ts_list_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
732 stream_write_tree (ob, TREE_PURPOSE (expr), ref_p);
733 stream_write_tree (ob, TREE_VALUE (expr), ref_p);
734 stream_write_tree (ob, TREE_CHAIN (expr), ref_p);
738 /* Write all pointer fields in the TS_VEC structure of EXPR to output
739 block OB. If REF_P is true, write a reference to EXPR's pointer
740 fields. */
742 static void
743 write_ts_vec_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
745 int i;
747 /* Note that the number of slots for EXPR has already been emitted
748 in EXPR's header (see streamer_write_tree_header). */
749 for (i = 0; i < TREE_VEC_LENGTH (expr); i++)
750 stream_write_tree (ob, TREE_VEC_ELT (expr, i), ref_p);
754 /* Write all pointer fields in the TS_EXP structure of EXPR to output
755 block OB. If REF_P is true, write a reference to EXPR's pointer
756 fields. */
758 static void
759 write_ts_exp_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
761 int i;
763 for (i = 0; i < TREE_OPERAND_LENGTH (expr); i++)
764 stream_write_tree (ob, TREE_OPERAND (expr, i), ref_p);
765 stream_write_tree (ob, TREE_BLOCK (expr), ref_p);
769 /* Write all pointer fields in the TS_BLOCK structure of EXPR to output
770 block OB. If REF_P is true, write a reference to EXPR's pointer
771 fields. */
773 static void
774 write_ts_block_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
776 streamer_write_chain (ob, BLOCK_VARS (expr), ref_p);
778 stream_write_tree (ob, BLOCK_SUPERCONTEXT (expr), ref_p);
779 stream_write_tree (ob, BLOCK_ABSTRACT_ORIGIN (expr), ref_p);
781 /* Do not stream BLOCK_NONLOCALIZED_VARS. We cannot handle debug information
782 for early inlined BLOCKs so drop it on the floor instead of ICEing in
783 dwarf2out.c. */
785 /* BLOCK_FRAGMENT_ORIGIN and BLOCK_FRAGMENT_CHAIN is not live at LTO
786 streaming time. */
788 /* Do not output BLOCK_SUBBLOCKS. Instead on streaming-in this
789 list is re-constructed from BLOCK_SUPERCONTEXT. */
793 /* Write all pointer fields in the TS_BINFO 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_binfo_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
800 unsigned i;
801 tree t;
803 /* Note that the number of BINFO slots has already been emitted in
804 EXPR's header (see streamer_write_tree_header) because this length
805 is needed to build the empty BINFO node on the reader side. */
806 FOR_EACH_VEC_ELT (*BINFO_BASE_BINFOS (expr), i, t)
807 stream_write_tree (ob, t, ref_p);
808 stream_write_tree (ob, NULL_TREE, false);
810 stream_write_tree (ob, BINFO_OFFSET (expr), ref_p);
811 stream_write_tree (ob, BINFO_VTABLE (expr), ref_p);
813 /* Do not walk BINFO_INHERITANCE_CHAIN, BINFO_SUBVTT_INDEX,
814 BINFO_BASE_ACCESSES and BINFO_VPTR_INDEX; these are used by C++ FE only. */
818 /* Write all pointer fields in the TS_CONSTRUCTOR structure of EXPR to
819 output block OB. If REF_P is true, write a reference to EXPR's
820 pointer fields. */
822 static void
823 write_ts_constructor_tree_pointers (struct output_block *ob, tree expr,
824 bool ref_p)
826 unsigned i;
827 tree index, value;
829 FOR_EACH_CONSTRUCTOR_ELT (CONSTRUCTOR_ELTS (expr), i, index, value)
831 stream_write_tree (ob, index, ref_p);
832 stream_write_tree (ob, value, ref_p);
837 /* Write all pointer fields in the TS_OMP_CLAUSE structure of EXPR
838 to output block OB. If REF_P is true, write a reference to EXPR's
839 pointer fields. */
841 static void
842 write_ts_omp_clause_tree_pointers (struct output_block *ob, tree expr,
843 bool ref_p)
845 int i;
846 for (i = 0; i < omp_clause_num_ops[OMP_CLAUSE_CODE (expr)]; i++)
847 stream_write_tree (ob, OMP_CLAUSE_OPERAND (expr, i), ref_p);
848 switch (OMP_CLAUSE_CODE (expr))
850 case OMP_CLAUSE_REDUCTION:
851 case OMP_CLAUSE_TASK_REDUCTION:
852 case OMP_CLAUSE_IN_REDUCTION:
853 /* We don't stream these right now, handle it if streaming
854 of them is needed. */
855 gcc_assert (OMP_CLAUSE_REDUCTION_GIMPLE_INIT (expr) == NULL);
856 gcc_assert (OMP_CLAUSE_REDUCTION_GIMPLE_MERGE (expr) == NULL);
857 break;
858 default:
859 break;
861 stream_write_tree (ob, OMP_CLAUSE_CHAIN (expr), ref_p);
865 /* Write all pointer fields in EXPR to output block OB. If REF_P is true,
866 the leaves of EXPR are emitted as references. */
868 void
869 streamer_write_tree_body (struct output_block *ob, tree expr, bool ref_p)
871 enum tree_code code;
873 lto_stats.num_tree_bodies_output++;
875 code = TREE_CODE (expr);
877 if (CODE_CONTAINS_STRUCT (code, TS_TYPED))
878 write_ts_common_tree_pointers (ob, expr, ref_p);
880 if (CODE_CONTAINS_STRUCT (code, TS_VECTOR))
881 write_ts_vector_tree_pointers (ob, expr, ref_p);
883 if (CODE_CONTAINS_STRUCT (code, TS_POLY_INT_CST))
884 write_ts_poly_tree_pointers (ob, expr, ref_p);
886 if (CODE_CONTAINS_STRUCT (code, TS_COMPLEX))
887 write_ts_complex_tree_pointers (ob, expr, ref_p);
889 if (CODE_CONTAINS_STRUCT (code, TS_DECL_MINIMAL))
890 write_ts_decl_minimal_tree_pointers (ob, expr, ref_p);
892 if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
893 write_ts_decl_common_tree_pointers (ob, expr, ref_p);
895 if (CODE_CONTAINS_STRUCT (code, TS_DECL_NON_COMMON))
896 write_ts_decl_non_common_tree_pointers (ob, expr, ref_p);
898 if (CODE_CONTAINS_STRUCT (code, TS_DECL_WITH_VIS))
899 write_ts_decl_with_vis_tree_pointers (ob, expr, ref_p);
901 if (CODE_CONTAINS_STRUCT (code, TS_FIELD_DECL))
902 write_ts_field_decl_tree_pointers (ob, expr, ref_p);
904 if (CODE_CONTAINS_STRUCT (code, TS_FUNCTION_DECL))
905 write_ts_function_decl_tree_pointers (ob, expr, ref_p);
907 if (CODE_CONTAINS_STRUCT (code, TS_TYPE_COMMON))
908 write_ts_type_common_tree_pointers (ob, expr, ref_p);
910 if (CODE_CONTAINS_STRUCT (code, TS_TYPE_NON_COMMON))
911 write_ts_type_non_common_tree_pointers (ob, expr, ref_p);
913 if (CODE_CONTAINS_STRUCT (code, TS_LIST))
914 write_ts_list_tree_pointers (ob, expr, ref_p);
916 if (CODE_CONTAINS_STRUCT (code, TS_VEC))
917 write_ts_vec_tree_pointers (ob, expr, ref_p);
919 if (CODE_CONTAINS_STRUCT (code, TS_EXP))
920 write_ts_exp_tree_pointers (ob, expr, ref_p);
922 if (CODE_CONTAINS_STRUCT (code, TS_BLOCK))
923 write_ts_block_tree_pointers (ob, expr, ref_p);
925 if (CODE_CONTAINS_STRUCT (code, TS_BINFO))
926 write_ts_binfo_tree_pointers (ob, expr, ref_p);
928 if (CODE_CONTAINS_STRUCT (code, TS_CONSTRUCTOR))
929 write_ts_constructor_tree_pointers (ob, expr, ref_p);
931 if (code == OMP_CLAUSE)
932 write_ts_omp_clause_tree_pointers (ob, expr, ref_p);
936 /* Emit header information for tree EXPR to output block OB. The header
937 contains everything needed to instantiate an empty skeleton for
938 EXPR on the reading side. IX is the index into the streamer cache
939 where EXPR is stored. */
941 void
942 streamer_write_tree_header (struct output_block *ob, tree expr)
944 enum LTO_tags tag;
945 enum tree_code code;
947 /* We should not see any tree nodes not handled by the streamer. */
948 code = TREE_CODE (expr);
950 /* The header of a tree node consists of its tag, the size of
951 the node, and any other information needed to instantiate
952 EXPR on the reading side (such as the number of slots in
953 variable sized nodes). */
954 tag = lto_tree_code_to_tag (code);
955 streamer_write_record_start (ob, tag);
957 /* The text in strings and identifiers are completely emitted in
958 the header. */
959 if (CODE_CONTAINS_STRUCT (code, TS_STRING))
960 streamer_write_string_cst (ob, ob->main_stream, expr);
961 else if (CODE_CONTAINS_STRUCT (code, TS_IDENTIFIER))
962 write_identifier (ob, ob->main_stream, expr);
963 else if (CODE_CONTAINS_STRUCT (code, TS_VECTOR))
965 bitpack_d bp = bitpack_create (ob->main_stream);
966 bp_pack_value (&bp, VECTOR_CST_LOG2_NPATTERNS (expr), 8);
967 bp_pack_value (&bp, VECTOR_CST_NELTS_PER_PATTERN (expr), 8);
968 streamer_write_bitpack (&bp);
970 else if (CODE_CONTAINS_STRUCT (code, TS_VEC))
971 streamer_write_hwi (ob, TREE_VEC_LENGTH (expr));
972 else if (CODE_CONTAINS_STRUCT (code, TS_BINFO))
973 streamer_write_uhwi (ob, BINFO_N_BASE_BINFOS (expr));
974 else if (TREE_CODE (expr) == CALL_EXPR)
975 streamer_write_uhwi (ob, call_expr_nargs (expr));
976 else if (TREE_CODE (expr) == OMP_CLAUSE)
977 streamer_write_uhwi (ob, OMP_CLAUSE_CODE (expr));
978 else if (CODE_CONTAINS_STRUCT (code, TS_INT_CST))
980 gcc_checking_assert (TREE_INT_CST_NUNITS (expr));
981 streamer_write_uhwi (ob, TREE_INT_CST_NUNITS (expr));
982 streamer_write_uhwi (ob, TREE_INT_CST_EXT_NUNITS (expr));
987 /* Emit the integer constant CST to output block OB. If REF_P is true,
988 CST's type will be emitted as a reference. */
990 void
991 streamer_write_integer_cst (struct output_block *ob, tree cst, bool ref_p)
993 int i;
994 int len = TREE_INT_CST_NUNITS (cst);
995 gcc_assert (!TREE_OVERFLOW (cst));
996 streamer_write_record_start (ob, LTO_integer_cst);
997 stream_write_tree (ob, TREE_TYPE (cst), ref_p);
998 /* We're effectively streaming a non-sign-extended wide_int here,
999 so there's no need to stream TREE_INT_CST_EXT_NUNITS or any
1000 array members beyond LEN. We'll recreate the tree from the
1001 wide_int and the type. */
1002 streamer_write_uhwi (ob, len);
1003 for (i = 0; i < len; i++)
1004 streamer_write_hwi (ob, TREE_INT_CST_ELT (cst, i));