1 /* Routines for emitting trees to a file stream.
2 
3    Copyright (C) 2011-2013 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 "diagnostic.h"
26 #include "tree.h"
27 #include "tree-streamer.h"
28 #include "data-streamer.h"
29 #include "streamer-hooks.h"
30 
31 /* Output the STRING constant to the string
32    table in OB.  Then put the index onto the INDEX_STREAM.  */
33 
34 void
streamer_write_string_cst(struct output_block * ob,struct lto_output_stream * index_stream,tree string)35 streamer_write_string_cst (struct output_block *ob,
36 			   struct lto_output_stream *index_stream,
37 			   tree string)
38 {
39   streamer_write_string_with_length (ob, index_stream,
40 				     string ? TREE_STRING_POINTER (string)
41 					    : NULL,
42 				     string ? TREE_STRING_LENGTH (string) : 0,
43 				     true);
44 }
45 
46 
47 /* Output the identifier ID to the string
48    table in OB.  Then put the index onto the INDEX_STREAM.  */
49 
50 static void
write_identifier(struct output_block * ob,struct lto_output_stream * index_stream,tree id)51 write_identifier (struct output_block *ob,
52 		   struct lto_output_stream *index_stream,
53 		   tree id)
54 {
55   streamer_write_string_with_length (ob, index_stream,
56 				     IDENTIFIER_POINTER (id),
57 				     IDENTIFIER_LENGTH (id),
58 				     true);
59 }
60 
61 
62 /* Pack all the non-pointer fields of the TS_BASE structure of
63    expression EXPR into bitpack BP.  */
64 
65 static void
pack_ts_base_value_fields(struct bitpack_d * bp,tree expr)66 pack_ts_base_value_fields (struct bitpack_d *bp, tree expr)
67 {
68   bp_pack_value (bp, TREE_CODE (expr), 16);
69   if (!TYPE_P (expr))
70     {
71       bp_pack_value (bp, TREE_SIDE_EFFECTS (expr), 1);
72       bp_pack_value (bp, TREE_CONSTANT (expr), 1);
73       bp_pack_value (bp, TREE_READONLY (expr), 1);
74 
75       /* TREE_PUBLIC is used on types to indicate that the type
76 	 has a TYPE_CACHED_VALUES vector.  This is not streamed out,
77 	 so we skip it here.  */
78       bp_pack_value (bp, TREE_PUBLIC (expr), 1);
79     }
80   else
81     bp_pack_value (bp, 0, 4);
82   bp_pack_value (bp, TREE_ADDRESSABLE (expr), 1);
83   bp_pack_value (bp, TREE_THIS_VOLATILE (expr), 1);
84   if (DECL_P (expr))
85     bp_pack_value (bp, DECL_UNSIGNED (expr), 1);
86   else if (TYPE_P (expr))
87     bp_pack_value (bp, TYPE_UNSIGNED (expr), 1);
88   else
89     bp_pack_value (bp, 0, 1);
90   /* We write debug info two times, do not confuse the second one.  */
91   bp_pack_value (bp, ((TYPE_P (expr) || TREE_CODE (expr) == TYPE_DECL)
92 		      ? 0 : TREE_ASM_WRITTEN (expr)), 1);
93   if (TYPE_P (expr))
94     bp_pack_value (bp, TYPE_ARTIFICIAL (expr), 1);
95   else
96     bp_pack_value (bp, TREE_NO_WARNING (expr), 1);
97   bp_pack_value (bp, TREE_USED (expr), 1);
98   bp_pack_value (bp, TREE_NOTHROW (expr), 1);
99   bp_pack_value (bp, TREE_STATIC (expr), 1);
100   bp_pack_value (bp, TREE_PRIVATE (expr), 1);
101   bp_pack_value (bp, TREE_PROTECTED (expr), 1);
102   bp_pack_value (bp, TREE_DEPRECATED (expr), 1);
103   if (TYPE_P (expr))
104     {
105       bp_pack_value (bp, TYPE_SATURATING (expr), 1);
106       bp_pack_value (bp, TYPE_ADDR_SPACE (expr), 8);
107     }
108   else if (TREE_CODE (expr) == SSA_NAME)
109     bp_pack_value (bp, SSA_NAME_IS_DEFAULT_DEF (expr), 1);
110   else
111     bp_pack_value (bp, 0, 1);
112 }
113 
114 
115 /* Pack all the non-pointer fields of the TS_INTEGER_CST structure of
116    expression EXPR into bitpack BP.  */
117 
118 static void
pack_ts_int_cst_value_fields(struct bitpack_d * bp,tree expr)119 pack_ts_int_cst_value_fields (struct bitpack_d *bp, tree expr)
120 {
121   bp_pack_var_len_unsigned (bp, TREE_INT_CST_LOW (expr));
122   bp_pack_var_len_int (bp, TREE_INT_CST_HIGH (expr));
123 }
124 
125 
126 /* Pack all the non-pointer fields of the TS_REAL_CST structure of
127    expression EXPR into bitpack BP.  */
128 
129 static void
pack_ts_real_cst_value_fields(struct bitpack_d * bp,tree expr)130 pack_ts_real_cst_value_fields (struct bitpack_d *bp, tree expr)
131 {
132   unsigned i;
133   REAL_VALUE_TYPE r;
134 
135   r = TREE_REAL_CST (expr);
136   bp_pack_value (bp, r.cl, 2);
137   bp_pack_value (bp, r.decimal, 1);
138   bp_pack_value (bp, r.sign, 1);
139   bp_pack_value (bp, r.signalling, 1);
140   bp_pack_value (bp, r.canonical, 1);
141   bp_pack_value (bp, r.uexp, EXP_BITS);
142   for (i = 0; i < SIGSZ; i++)
143     bp_pack_value (bp, r.sig[i], HOST_BITS_PER_LONG);
144 }
145 
146 
147 /* Pack all the non-pointer fields of the TS_FIXED_CST structure of
148    expression EXPR into bitpack BP.  */
149 
150 static void
pack_ts_fixed_cst_value_fields(struct bitpack_d * bp,tree expr)151 pack_ts_fixed_cst_value_fields (struct bitpack_d *bp, tree expr)
152 {
153   struct fixed_value fv = TREE_FIXED_CST (expr);
154   bp_pack_enum (bp, machine_mode, MAX_MACHINE_MODE, fv.mode);
155   bp_pack_var_len_int (bp, fv.data.low);
156   bp_pack_var_len_int (bp, fv.data.high);
157 }
158 
159 /* Pack all the non-pointer fields of the TS_DECL_COMMON structure
160    of expression EXPR into bitpack BP.  */
161 
162 static void
pack_ts_decl_common_value_fields(struct bitpack_d * bp,tree expr)163 pack_ts_decl_common_value_fields (struct bitpack_d *bp, tree expr)
164 {
165   bp_pack_enum (bp, machine_mode, MAX_MACHINE_MODE, DECL_MODE (expr));
166   bp_pack_value (bp, DECL_NONLOCAL (expr), 1);
167   bp_pack_value (bp, DECL_VIRTUAL_P (expr), 1);
168   bp_pack_value (bp, DECL_IGNORED_P (expr), 1);
169   bp_pack_value (bp, DECL_ABSTRACT (expr), 1);
170   bp_pack_value (bp, DECL_ARTIFICIAL (expr), 1);
171   bp_pack_value (bp, DECL_USER_ALIGN (expr), 1);
172   bp_pack_value (bp, DECL_PRESERVE_P (expr), 1);
173   bp_pack_value (bp, DECL_DEBUG_EXPR_IS_FROM (expr), 1);
174   bp_pack_value (bp, DECL_EXTERNAL (expr), 1);
175   bp_pack_value (bp, DECL_GIMPLE_REG_P (expr), 1);
176   bp_pack_var_len_unsigned (bp, DECL_ALIGN (expr));
177 
178   if (TREE_CODE (expr) == LABEL_DECL)
179     {
180       /* Note that we do not write LABEL_DECL_UID.  The reader will
181 	 always assume an initial value of -1 so that the
182 	 label_to_block_map is recreated by gimple_set_bb.  */
183       bp_pack_value (bp, DECL_ERROR_ISSUED (expr), 1);
184       bp_pack_var_len_unsigned (bp, EH_LANDING_PAD_NR (expr));
185     }
186 
187   if (TREE_CODE (expr) == FIELD_DECL)
188     {
189       bp_pack_value (bp, DECL_PACKED (expr), 1);
190       bp_pack_value (bp, DECL_NONADDRESSABLE_P (expr), 1);
191       bp_pack_value (bp, expr->decl_common.off_align, 8);
192     }
193 
194   if (TREE_CODE (expr) == VAR_DECL)
195     bp_pack_value (bp, DECL_NONLOCAL_FRAME (expr), 1);
196 
197   if (TREE_CODE (expr) == RESULT_DECL
198       || TREE_CODE (expr) == PARM_DECL
199       || TREE_CODE (expr) == VAR_DECL)
200     {
201       bp_pack_value (bp, DECL_BY_REFERENCE (expr), 1);
202       if (TREE_CODE (expr) == VAR_DECL
203 	  || TREE_CODE (expr) == PARM_DECL)
204 	bp_pack_value (bp, DECL_HAS_VALUE_EXPR_P (expr), 1);
205     }
206 }
207 
208 
209 /* Pack all the non-pointer fields of the TS_DECL_WRTL structure
210    of expression EXPR into bitpack BP.  */
211 
212 static void
pack_ts_decl_wrtl_value_fields(struct bitpack_d * bp,tree expr)213 pack_ts_decl_wrtl_value_fields (struct bitpack_d *bp, tree expr)
214 {
215   bp_pack_value (bp, DECL_REGISTER (expr), 1);
216 }
217 
218 
219 /* Pack all the non-pointer fields of the TS_DECL_WITH_VIS structure
220    of expression EXPR into bitpack BP.  */
221 
222 static void
pack_ts_decl_with_vis_value_fields(struct bitpack_d * bp,tree expr)223 pack_ts_decl_with_vis_value_fields (struct bitpack_d *bp, tree expr)
224 {
225   bp_pack_value (bp, DECL_DEFER_OUTPUT (expr), 1);
226   bp_pack_value (bp, DECL_COMMON (expr), 1);
227   bp_pack_value (bp, DECL_DLLIMPORT_P (expr), 1);
228   bp_pack_value (bp, DECL_WEAK (expr), 1);
229   bp_pack_value (bp, DECL_SEEN_IN_BIND_EXPR_P (expr),  1);
230   bp_pack_value (bp, DECL_COMDAT (expr),  1);
231   bp_pack_value (bp, DECL_VISIBILITY (expr),  2);
232   bp_pack_value (bp, DECL_VISIBILITY_SPECIFIED (expr),  1);
233 
234   if (TREE_CODE (expr) == VAR_DECL)
235     {
236       bp_pack_value (bp, DECL_HARD_REGISTER (expr), 1);
237       bp_pack_value (bp, DECL_IN_TEXT_SECTION (expr), 1);
238       bp_pack_value (bp, DECL_IN_CONSTANT_POOL (expr), 1);
239       bp_pack_value (bp, DECL_TLS_MODEL (expr),  3);
240     }
241 
242   if (VAR_OR_FUNCTION_DECL_P (expr))
243     bp_pack_var_len_unsigned (bp, DECL_INIT_PRIORITY (expr));
244 }
245 
246 
247 /* Pack all the non-pointer fields of the TS_FUNCTION_DECL structure
248    of expression EXPR into bitpack BP.  */
249 
250 static void
pack_ts_function_decl_value_fields(struct bitpack_d * bp,tree expr)251 pack_ts_function_decl_value_fields (struct bitpack_d *bp, tree expr)
252 {
253   /* For normal/md builtins we only write the class and code, so they
254      should never be handled here.  */
255   gcc_assert (!streamer_handle_as_builtin_p (expr));
256 
257   bp_pack_enum (bp, built_in_class, BUILT_IN_LAST,
258 		DECL_BUILT_IN_CLASS (expr));
259   bp_pack_value (bp, DECL_STATIC_CONSTRUCTOR (expr), 1);
260   bp_pack_value (bp, DECL_STATIC_DESTRUCTOR (expr), 1);
261   bp_pack_value (bp, DECL_UNINLINABLE (expr), 1);
262   bp_pack_value (bp, DECL_POSSIBLY_INLINED (expr), 1);
263   bp_pack_value (bp, DECL_IS_NOVOPS (expr), 1);
264   bp_pack_value (bp, DECL_IS_RETURNS_TWICE (expr), 1);
265   bp_pack_value (bp, DECL_IS_MALLOC (expr), 1);
266   bp_pack_value (bp, DECL_IS_OPERATOR_NEW (expr), 1);
267   bp_pack_value (bp, DECL_DECLARED_INLINE_P (expr), 1);
268   bp_pack_value (bp, DECL_STATIC_CHAIN (expr), 1);
269   bp_pack_value (bp, DECL_NO_INLINE_WARNING_P (expr), 1);
270   bp_pack_value (bp, DECL_NO_INSTRUMENT_FUNCTION_ENTRY_EXIT (expr), 1);
271   bp_pack_value (bp, DECL_NO_LIMIT_STACK (expr), 1);
272   bp_pack_value (bp, DECL_DISREGARD_INLINE_LIMITS (expr), 1);
273   bp_pack_value (bp, DECL_PURE_P (expr), 1);
274   bp_pack_value (bp, DECL_LOOPING_CONST_OR_PURE_P (expr), 1);
275   if (DECL_BUILT_IN_CLASS (expr) != NOT_BUILT_IN)
276     bp_pack_value (bp, DECL_FUNCTION_CODE (expr), 11);
277   if (DECL_STATIC_DESTRUCTOR (expr))
278     bp_pack_var_len_unsigned (bp, DECL_FINI_PRIORITY (expr));
279 }
280 
281 
282 /* Pack all the non-pointer fields of the TS_TYPE_COMMON structure
283    of expression EXPR into bitpack BP.  */
284 
285 static void
pack_ts_type_common_value_fields(struct bitpack_d * bp,tree expr)286 pack_ts_type_common_value_fields (struct bitpack_d *bp, tree expr)
287 {
288   bp_pack_enum (bp, machine_mode, MAX_MACHINE_MODE, TYPE_MODE (expr));
289   bp_pack_value (bp, TYPE_STRING_FLAG (expr), 1);
290   bp_pack_value (bp, TYPE_NO_FORCE_BLK (expr), 1);
291   bp_pack_value (bp, TYPE_NEEDS_CONSTRUCTING (expr), 1);
292   if (RECORD_OR_UNION_TYPE_P (expr))
293     bp_pack_value (bp, TYPE_TRANSPARENT_AGGR (expr), 1);
294   else if (TREE_CODE (expr) == ARRAY_TYPE)
295     bp_pack_value (bp, TYPE_NONALIASED_COMPONENT (expr), 1);
296   bp_pack_value (bp, TYPE_PACKED (expr), 1);
297   bp_pack_value (bp, TYPE_RESTRICT (expr), 1);
298   bp_pack_value (bp, TYPE_CONTAINS_PLACEHOLDER_INTERNAL (expr), 2);
299   bp_pack_value (bp, TYPE_USER_ALIGN (expr), 1);
300   bp_pack_value (bp, TYPE_READONLY (expr), 1);
301   bp_pack_var_len_unsigned (bp, TYPE_PRECISION (expr));
302   bp_pack_var_len_unsigned (bp, TYPE_ALIGN (expr));
303   bp_pack_var_len_int (bp, TYPE_ALIAS_SET (expr) == 0 ? 0 : -1);
304 }
305 
306 
307 /* Pack all the non-pointer fields of the TS_BLOCK structure
308    of expression EXPR into bitpack BP.  */
309 
310 static void
pack_ts_block_value_fields(struct output_block * ob,struct bitpack_d * bp,tree expr)311 pack_ts_block_value_fields (struct output_block *ob,
312 			    struct bitpack_d *bp, tree expr)
313 {
314   bp_pack_value (bp, BLOCK_ABSTRACT (expr), 1);
315   /* BLOCK_NUMBER is recomputed.  */
316   /* Stream BLOCK_SOURCE_LOCATION for the limited cases we can handle - those
317      that represent inlined function scopes.
318      For the rest them on the floor instead of ICEing in dwarf2out.c.  */
319   if (inlined_function_outer_scope_p (expr))
320     stream_output_location (ob, bp, BLOCK_SOURCE_LOCATION (expr));
321   else
322     stream_output_location (ob, bp, UNKNOWN_LOCATION);
323 }
324 
325 /* Pack all the non-pointer fields of the TS_TRANSLATION_UNIT_DECL structure
326    of expression EXPR into bitpack BP.  */
327 
328 static void
pack_ts_translation_unit_decl_value_fields(struct output_block * ob,struct bitpack_d * bp,tree expr)329 pack_ts_translation_unit_decl_value_fields (struct output_block *ob,
330 					    struct bitpack_d *bp, tree expr)
331 {
332   bp_pack_string (ob, bp, TRANSLATION_UNIT_LANGUAGE (expr), true);
333 }
334 
335 /* Pack a TS_TARGET_OPTION tree in EXPR to BP.  */
336 
337 static void
pack_ts_target_option(struct bitpack_d * bp,tree expr)338 pack_ts_target_option (struct bitpack_d *bp, tree expr)
339 {
340   struct cl_target_option *t = TREE_TARGET_OPTION (expr);
341   unsigned i, len;
342 
343   /* The cl_target_option is target specific and generated by the options
344      awk script, so we just recreate a byte-by-byte copy here. */
345 
346   len = sizeof (struct cl_target_option);
347   for (i = 0; i < len; i++)
348     bp_pack_value (bp, ((unsigned char *)t)[i], 8);
349   /* Catch struct size mismatches between reader and writer. */
350   bp_pack_value (bp, 0x12345678, 32);
351 }
352 
353 /* Pack a TS_OPTIMIZATION tree in EXPR to BP.  */
354 
355 static void
pack_ts_optimization(struct bitpack_d * bp,tree expr)356 pack_ts_optimization (struct bitpack_d *bp, tree expr)
357 {
358   struct cl_optimization *t = TREE_OPTIMIZATION (expr);
359   unsigned i, len;
360 
361   /* The cl_optimization is generated by the options
362      awk script, so we just recreate a byte-by-byte copy here. */
363 
364   len = sizeof (struct cl_optimization);
365   for (i = 0; i < len; i++)
366     bp_pack_value (bp, ((unsigned char *)t)[i], 8);
367   /* Catch struct size mismatches between reader and writer. */
368   bp_pack_value (bp, 0x12345678, 32);
369 }
370 
371 
372 /* Pack all the bitfields in EXPR into a bit pack.  */
373 
374 void
streamer_pack_tree_bitfields(struct output_block * ob,struct bitpack_d * bp,tree expr)375 streamer_pack_tree_bitfields (struct output_block *ob,
376 			      struct bitpack_d *bp, tree expr)
377 {
378   enum tree_code code;
379 
380   code = TREE_CODE (expr);
381 
382   /* Note that all these functions are highly sensitive to changes in
383      the types and sizes of each of the fields being packed.  */
384   pack_ts_base_value_fields (bp, expr);
385 
386   if (CODE_CONTAINS_STRUCT (code, TS_INT_CST))
387     pack_ts_int_cst_value_fields (bp, expr);
388 
389   if (CODE_CONTAINS_STRUCT (code, TS_REAL_CST))
390     pack_ts_real_cst_value_fields (bp, expr);
391 
392   if (CODE_CONTAINS_STRUCT (code, TS_FIXED_CST))
393     pack_ts_fixed_cst_value_fields (bp, expr);
394 
395   if (CODE_CONTAINS_STRUCT (code, TS_DECL_MINIMAL))
396     stream_output_location (ob, bp, DECL_SOURCE_LOCATION (expr));
397 
398   if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
399     pack_ts_decl_common_value_fields (bp, expr);
400 
401   if (CODE_CONTAINS_STRUCT (code, TS_DECL_WRTL))
402     pack_ts_decl_wrtl_value_fields (bp, expr);
403 
404   if (CODE_CONTAINS_STRUCT (code, TS_DECL_WITH_VIS))
405     pack_ts_decl_with_vis_value_fields (bp, expr);
406 
407   if (CODE_CONTAINS_STRUCT (code, TS_FUNCTION_DECL))
408     pack_ts_function_decl_value_fields (bp, expr);
409 
410   if (CODE_CONTAINS_STRUCT (code, TS_TYPE_COMMON))
411     pack_ts_type_common_value_fields (bp, expr);
412 
413   if (CODE_CONTAINS_STRUCT (code, TS_EXP))
414     stream_output_location (ob, bp, EXPR_LOCATION (expr));
415 
416   if (CODE_CONTAINS_STRUCT (code, TS_BLOCK))
417     pack_ts_block_value_fields (ob, bp, expr);
418 
419   if (CODE_CONTAINS_STRUCT (code, TS_TRANSLATION_UNIT_DECL))
420     pack_ts_translation_unit_decl_value_fields (ob, bp, expr);
421 
422   if (CODE_CONTAINS_STRUCT (code, TS_TARGET_OPTION))
423     pack_ts_target_option (bp, expr);
424 
425   if (CODE_CONTAINS_STRUCT (code, TS_OPTIMIZATION))
426     pack_ts_optimization (bp, expr);
427 
428   if (CODE_CONTAINS_STRUCT (code, TS_BINFO))
429     bp_pack_var_len_unsigned (bp, vec_safe_length (BINFO_BASE_ACCESSES (expr)));
430 
431   if (CODE_CONTAINS_STRUCT (code, TS_CONSTRUCTOR))
432     bp_pack_var_len_unsigned (bp, CONSTRUCTOR_NELTS (expr));
433 }
434 
435 
436 /* Write the code and class of builtin EXPR to output block OB.  IX is
437    the index into the streamer cache where EXPR is stored.*/
438 
439 void
streamer_write_builtin(struct output_block * ob,tree expr)440 streamer_write_builtin (struct output_block *ob, tree expr)
441 {
442   gcc_assert (streamer_handle_as_builtin_p (expr));
443 
444   if (DECL_BUILT_IN_CLASS (expr) == BUILT_IN_MD
445       && !targetm.builtin_decl)
446     sorry ("tree bytecode streams do not support machine specific builtin "
447 	   "functions on this target");
448 
449   streamer_write_record_start (ob, LTO_builtin_decl);
450   streamer_write_enum (ob->main_stream, built_in_class, BUILT_IN_LAST,
451 		       DECL_BUILT_IN_CLASS (expr));
452   streamer_write_uhwi (ob, DECL_FUNCTION_CODE (expr));
453 
454   if (DECL_ASSEMBLER_NAME_SET_P (expr))
455     {
456       /* When the assembler name of a builtin gets a user name,
457 	 the new name is always prefixed with '*' by
458 	 set_builtin_user_assembler_name.  So, to prevent the
459 	 reader side from adding a second '*', we omit it here.  */
460       const char *str = IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (expr));
461       if (strlen (str) > 1 && str[0] == '*')
462 	streamer_write_string (ob, ob->main_stream, &str[1], true);
463       else
464 	streamer_write_string (ob, ob->main_stream, NULL, true);
465     }
466   else
467     streamer_write_string (ob, ob->main_stream, NULL, true);
468 }
469 
470 
471 /* Emit the chain of tree nodes starting at T.  OB is the output block
472    to write to.  REF_P is true if chain elements should be emitted
473    as references.  */
474 
475 void
streamer_write_chain(struct output_block * ob,tree t,bool ref_p)476 streamer_write_chain (struct output_block *ob, tree t, bool ref_p)
477 {
478   while (t)
479     {
480       tree saved_chain;
481 
482       /* Clear TREE_CHAIN to avoid blindly recursing into the rest
483 	 of the list.  */
484       saved_chain = TREE_CHAIN (t);
485       TREE_CHAIN (t) = NULL_TREE;
486 
487       /* We avoid outputting external vars or functions by reference
488 	 to the global decls section as we do not want to have them
489 	 enter decl merging.  This is, of course, only for the call
490 	 for streaming BLOCK_VARS, but other callers are safe.  */
491       if (VAR_OR_FUNCTION_DECL_P (t)
492 	  && DECL_EXTERNAL (t))
493 	stream_write_tree_shallow_non_ref (ob, t, ref_p);
494       else
495 	stream_write_tree (ob, t, ref_p);
496 
497       TREE_CHAIN (t) = saved_chain;
498       t = TREE_CHAIN (t);
499     }
500 
501   /* Write a sentinel to terminate the chain.  */
502   stream_write_tree (ob, NULL_TREE, ref_p);
503 }
504 
505 
506 /* Write all pointer fields in the TS_COMMON structure of EXPR to output
507    block OB.  If REF_P is true, write a reference to EXPR's pointer
508    fields.  */
509 
510 static void
write_ts_common_tree_pointers(struct output_block * ob,tree expr,bool ref_p)511 write_ts_common_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
512 {
513   if (TREE_CODE (expr) != IDENTIFIER_NODE)
514     stream_write_tree (ob, TREE_TYPE (expr), ref_p);
515 }
516 
517 
518 /* Write all pointer fields in the TS_VECTOR structure of EXPR to output
519    block OB.  If REF_P is true, write a reference to EXPR's pointer
520    fields.  */
521 
522 static void
write_ts_vector_tree_pointers(struct output_block * ob,tree expr,bool ref_p)523 write_ts_vector_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
524 {
525   unsigned i;
526   /* Note that the number of elements for EXPR has already been emitted
527      in EXPR's header (see streamer_write_tree_header).  */
528   for (i = 0; i < VECTOR_CST_NELTS (expr); ++i)
529     stream_write_tree (ob, VECTOR_CST_ELT (expr, i), ref_p);
530 }
531 
532 
533 /* Write all pointer fields in the TS_COMPLEX structure of EXPR to output
534    block OB.  If REF_P is true, write a reference to EXPR's pointer
535    fields.  */
536 
537 static void
write_ts_complex_tree_pointers(struct output_block * ob,tree expr,bool ref_p)538 write_ts_complex_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
539 {
540   stream_write_tree (ob, TREE_REALPART (expr), ref_p);
541   stream_write_tree (ob, TREE_IMAGPART (expr), ref_p);
542 }
543 
544 
545 /* Write all pointer fields in the TS_DECL_MINIMAL structure of EXPR
546    to output block OB.  If REF_P is true, write a reference to EXPR's
547    pointer fields.  */
548 
549 static void
write_ts_decl_minimal_tree_pointers(struct output_block * ob,tree expr,bool ref_p)550 write_ts_decl_minimal_tree_pointers (struct output_block *ob, tree expr,
551 				     bool ref_p)
552 {
553   stream_write_tree (ob, DECL_NAME (expr), ref_p);
554   stream_write_tree (ob, DECL_CONTEXT (expr), ref_p);
555 }
556 
557 
558 /* Write all pointer fields in the TS_DECL_COMMON structure of EXPR to
559    output block OB.  If REF_P is true, write a reference to EXPR's
560    pointer fields.  */
561 
562 static void
write_ts_decl_common_tree_pointers(struct output_block * ob,tree expr,bool ref_p)563 write_ts_decl_common_tree_pointers (struct output_block *ob, tree expr,
564 				    bool ref_p)
565 {
566   stream_write_tree (ob, DECL_SIZE (expr), ref_p);
567   stream_write_tree (ob, DECL_SIZE_UNIT (expr), ref_p);
568 
569   /* Note, DECL_INITIAL is not handled here.  Since DECL_INITIAL needs
570      special handling in LTO, it must be handled by streamer hooks.  */
571 
572   stream_write_tree (ob, DECL_ATTRIBUTES (expr), ref_p);
573 
574   /* Do not stream DECL_ABSTRACT_ORIGIN.  We cannot handle debug information
575      for early inlining so drop it on the floor instead of ICEing in
576      dwarf2out.c.  */
577 
578   if ((TREE_CODE (expr) == VAR_DECL
579        || TREE_CODE (expr) == PARM_DECL)
580       && DECL_HAS_VALUE_EXPR_P (expr))
581     stream_write_tree (ob, DECL_VALUE_EXPR (expr), ref_p);
582 
583   if (TREE_CODE (expr) == VAR_DECL)
584     stream_write_tree (ob, DECL_DEBUG_EXPR (expr), ref_p);
585 }
586 
587 
588 /* Write all pointer fields in the TS_DECL_NON_COMMON structure of
589    EXPR to output block OB.  If REF_P is true, write a reference to EXPR's
590    pointer fields.  */
591 
592 static void
write_ts_decl_non_common_tree_pointers(struct output_block * ob,tree expr,bool ref_p)593 write_ts_decl_non_common_tree_pointers (struct output_block *ob, tree expr,
594 				        bool ref_p)
595 {
596   if (TREE_CODE (expr) == FUNCTION_DECL)
597     {
598       streamer_write_chain (ob, DECL_ARGUMENTS (expr), ref_p);
599       stream_write_tree (ob, DECL_RESULT (expr), ref_p);
600     }
601   else if (TREE_CODE (expr) == TYPE_DECL)
602     stream_write_tree (ob, DECL_ORIGINAL_TYPE (expr), ref_p);
603   stream_write_tree (ob, DECL_VINDEX (expr), ref_p);
604 }
605 
606 
607 /* Write all pointer fields in the TS_DECL_WITH_VIS structure of EXPR
608    to output block OB.  If REF_P is true, write a reference to EXPR's
609    pointer fields.  */
610 
611 static void
write_ts_decl_with_vis_tree_pointers(struct output_block * ob,tree expr,bool ref_p)612 write_ts_decl_with_vis_tree_pointers (struct output_block *ob, tree expr,
613 			              bool ref_p)
614 {
615   /* Make sure we don't inadvertently set the assembler name.  */
616   if (DECL_ASSEMBLER_NAME_SET_P (expr))
617     stream_write_tree (ob, DECL_ASSEMBLER_NAME (expr), ref_p);
618   else
619     stream_write_tree (ob, NULL_TREE, false);
620 
621   stream_write_tree (ob, DECL_SECTION_NAME (expr), ref_p);
622   stream_write_tree (ob, DECL_COMDAT_GROUP (expr), ref_p);
623 }
624 
625 
626 /* Write all pointer fields in the TS_FIELD_DECL structure of EXPR to
627    output block OB.  If REF_P is true, write a reference to EXPR's
628    pointer fields.  */
629 
630 static void
write_ts_field_decl_tree_pointers(struct output_block * ob,tree expr,bool ref_p)631 write_ts_field_decl_tree_pointers (struct output_block *ob, tree expr,
632 				   bool ref_p)
633 {
634   stream_write_tree (ob, DECL_FIELD_OFFSET (expr), ref_p);
635   stream_write_tree (ob, DECL_BIT_FIELD_TYPE (expr), ref_p);
636   stream_write_tree (ob, DECL_BIT_FIELD_REPRESENTATIVE (expr), ref_p);
637   stream_write_tree (ob, DECL_FIELD_BIT_OFFSET (expr), ref_p);
638   stream_write_tree (ob, DECL_FCONTEXT (expr), ref_p);
639 }
640 
641 
642 /* Write all pointer fields in the TS_FUNCTION_DECL structure of EXPR
643    to output block OB.  If REF_P is true, write a reference to EXPR's
644    pointer fields.  */
645 
646 static void
write_ts_function_decl_tree_pointers(struct output_block * ob,tree expr,bool ref_p)647 write_ts_function_decl_tree_pointers (struct output_block *ob, tree expr,
648 				      bool ref_p)
649 {
650   /* DECL_STRUCT_FUNCTION is handled by lto_output_function.  FIXME lto,
651      maybe it should be handled here?  */
652   stream_write_tree (ob, DECL_FUNCTION_PERSONALITY (expr), ref_p);
653   stream_write_tree (ob, DECL_FUNCTION_SPECIFIC_TARGET (expr), ref_p);
654   stream_write_tree (ob, DECL_FUNCTION_SPECIFIC_OPTIMIZATION (expr), ref_p);
655 }
656 
657 
658 /* Write all pointer fields in the TS_TYPE_COMMON structure of EXPR to
659    output block OB.  If REF_P is true, write a reference to EXPR's
660    pointer fields.  */
661 
662 static void
write_ts_type_common_tree_pointers(struct output_block * ob,tree expr,bool ref_p)663 write_ts_type_common_tree_pointers (struct output_block *ob, tree expr,
664 				    bool ref_p)
665 {
666   stream_write_tree (ob, TYPE_SIZE (expr), ref_p);
667   stream_write_tree (ob, TYPE_SIZE_UNIT (expr), ref_p);
668   stream_write_tree (ob, TYPE_ATTRIBUTES (expr), ref_p);
669   stream_write_tree (ob, TYPE_NAME (expr), ref_p);
670   /* Do not stream TYPE_POINTER_TO or TYPE_REFERENCE_TO.  They will be
671      reconstructed during fixup.  */
672   /* Do not stream TYPE_NEXT_VARIANT, we reconstruct the variant lists
673      during fixup.  */
674   stream_write_tree (ob, TYPE_MAIN_VARIANT (expr), ref_p);
675   stream_write_tree (ob, TYPE_CONTEXT (expr), ref_p);
676   /* TYPE_CANONICAL is re-computed during type merging, so no need
677      to stream it here.  */
678   stream_write_tree (ob, TYPE_STUB_DECL (expr), ref_p);
679 }
680 
681 /* Write all pointer fields in the TS_TYPE_NON_COMMON structure of EXPR
682    to output block OB.  If REF_P is true, write a reference to EXPR's
683    pointer fields.  */
684 
685 static void
write_ts_type_non_common_tree_pointers(struct output_block * ob,tree expr,bool ref_p)686 write_ts_type_non_common_tree_pointers (struct output_block *ob, tree expr,
687 					bool ref_p)
688 {
689   if (TREE_CODE (expr) == ENUMERAL_TYPE)
690     stream_write_tree (ob, TYPE_VALUES (expr), ref_p);
691   else if (TREE_CODE (expr) == ARRAY_TYPE)
692     stream_write_tree (ob, TYPE_DOMAIN (expr), ref_p);
693   else if (RECORD_OR_UNION_TYPE_P (expr))
694     streamer_write_chain (ob, TYPE_FIELDS (expr), ref_p);
695   else if (TREE_CODE (expr) == FUNCTION_TYPE
696 	   || TREE_CODE (expr) == METHOD_TYPE)
697     stream_write_tree (ob, TYPE_ARG_TYPES (expr), ref_p);
698 
699   if (!POINTER_TYPE_P (expr))
700     stream_write_tree (ob, TYPE_MINVAL (expr), ref_p);
701   stream_write_tree (ob, TYPE_MAXVAL (expr), ref_p);
702   if (RECORD_OR_UNION_TYPE_P (expr))
703     stream_write_tree (ob, TYPE_BINFO (expr), ref_p);
704 }
705 
706 
707 /* Write all pointer fields in the TS_LIST structure of EXPR to output
708    block OB.  If REF_P is true, write a reference to EXPR's pointer
709    fields.  */
710 
711 static void
write_ts_list_tree_pointers(struct output_block * ob,tree expr,bool ref_p)712 write_ts_list_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
713 {
714   stream_write_tree (ob, TREE_PURPOSE (expr), ref_p);
715   stream_write_tree (ob, TREE_VALUE (expr), ref_p);
716   streamer_write_chain (ob, TREE_CHAIN (expr), ref_p);
717 }
718 
719 
720 /* Write all pointer fields in the TS_VEC structure of EXPR to output
721    block OB.  If REF_P is true, write a reference to EXPR's pointer
722    fields.  */
723 
724 static void
write_ts_vec_tree_pointers(struct output_block * ob,tree expr,bool ref_p)725 write_ts_vec_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
726 {
727   int i;
728 
729   /* Note that the number of slots for EXPR has already been emitted
730      in EXPR's header (see streamer_write_tree_header).  */
731   for (i = 0; i < TREE_VEC_LENGTH (expr); i++)
732     stream_write_tree (ob, TREE_VEC_ELT (expr, i), ref_p);
733 }
734 
735 
736 /* Write all pointer fields in the TS_EXP structure of EXPR to output
737    block OB.  If REF_P is true, write a reference to EXPR's pointer
738    fields.  */
739 
740 static void
write_ts_exp_tree_pointers(struct output_block * ob,tree expr,bool ref_p)741 write_ts_exp_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
742 {
743   int i;
744 
745   for (i = 0; i < TREE_OPERAND_LENGTH (expr); i++)
746     stream_write_tree (ob, TREE_OPERAND (expr, i), ref_p);
747   stream_write_tree (ob, TREE_BLOCK (expr), ref_p);
748 }
749 
750 
751 /* Write all pointer fields in the TS_BLOCK structure of EXPR to output
752    block OB.  If REF_P is true, write a reference to EXPR's pointer
753    fields.  */
754 
755 static void
write_ts_block_tree_pointers(struct output_block * ob,tree expr,bool ref_p)756 write_ts_block_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
757 {
758   streamer_write_chain (ob, BLOCK_VARS (expr), ref_p);
759 
760   stream_write_tree (ob, BLOCK_SUPERCONTEXT (expr), ref_p);
761 
762   /* Stream BLOCK_ABSTRACT_ORIGIN for the limited cases we can handle - those
763      that represent inlined function scopes.
764      For the rest them on the floor instead of ICEing in dwarf2out.c.  */
765   if (inlined_function_outer_scope_p (expr))
766     {
767       tree ultimate_origin = block_ultimate_origin (expr);
768       stream_write_tree (ob, ultimate_origin, ref_p);
769     }
770   else
771     stream_write_tree (ob, NULL_TREE, ref_p);
772   /* Do not stream BLOCK_NONLOCALIZED_VARS.  We cannot handle debug information
773      for early inlined BLOCKs so drop it on the floor instead of ICEing in
774      dwarf2out.c.  */
775 
776   /* BLOCK_FRAGMENT_ORIGIN and BLOCK_FRAGMENT_CHAIN is not live at LTO
777      streaming time.  */
778 
779   /* Do not output BLOCK_SUBBLOCKS.  Instead on streaming-in this
780      list is re-constructed from BLOCK_SUPERCONTEXT.  */
781 }
782 
783 
784 /* Write all pointer fields in the TS_BINFO structure of EXPR to output
785    block OB.  If REF_P is true, write a reference to EXPR's pointer
786    fields.  */
787 
788 static void
write_ts_binfo_tree_pointers(struct output_block * ob,tree expr,bool ref_p)789 write_ts_binfo_tree_pointers (struct output_block *ob, tree expr, bool ref_p)
790 {
791   unsigned i;
792   tree t;
793 
794   /* Note that the number of BINFO slots has already been emitted in
795      EXPR's header (see streamer_write_tree_header) because this length
796      is needed to build the empty BINFO node on the reader side.  */
797   FOR_EACH_VEC_ELT (*BINFO_BASE_BINFOS (expr), i, t)
798     stream_write_tree (ob, t, ref_p);
799   stream_write_tree (ob, NULL_TREE, false);
800 
801   stream_write_tree (ob, BINFO_OFFSET (expr), ref_p);
802   stream_write_tree (ob, BINFO_VTABLE (expr), ref_p);
803   stream_write_tree (ob, BINFO_VPTR_FIELD (expr), ref_p);
804 
805   /* The number of BINFO_BASE_ACCESSES has already been emitted in
806      EXPR's bitfield section.  */
807   FOR_EACH_VEC_SAFE_ELT (BINFO_BASE_ACCESSES (expr), i, t)
808     stream_write_tree (ob, t, ref_p);
809 
810   stream_write_tree (ob, BINFO_INHERITANCE_CHAIN (expr), ref_p);
811   stream_write_tree (ob, BINFO_SUBVTT_INDEX (expr), ref_p);
812   stream_write_tree (ob, BINFO_VPTR_INDEX (expr), ref_p);
813 }
814 
815 
816 /* Write all pointer fields in the TS_CONSTRUCTOR structure of EXPR to
817    output block OB.  If REF_P is true, write a reference to EXPR's
818    pointer fields.  */
819 
820 static void
write_ts_constructor_tree_pointers(struct output_block * ob,tree expr,bool ref_p)821 write_ts_constructor_tree_pointers (struct output_block *ob, tree expr,
822 				    bool ref_p)
823 {
824   unsigned i;
825   tree index, value;
826 
827   FOR_EACH_CONSTRUCTOR_ELT (CONSTRUCTOR_ELTS (expr), i, index, value)
828     {
829       stream_write_tree (ob, index, ref_p);
830       stream_write_tree (ob, value, ref_p);
831     }
832 }
833 
834 /* Write all pointer fields in EXPR to output block OB.  If REF_P is true,
835    the leaves of EXPR are emitted as references.  */
836 
837 void
streamer_write_tree_body(struct output_block * ob,tree expr,bool ref_p)838 streamer_write_tree_body (struct output_block *ob, tree expr, bool ref_p)
839 {
840   enum tree_code code;
841 
842   code = TREE_CODE (expr);
843 
844   if (CODE_CONTAINS_STRUCT (code, TS_TYPED))
845     write_ts_common_tree_pointers (ob, expr, ref_p);
846 
847   if (CODE_CONTAINS_STRUCT (code, TS_VECTOR))
848     write_ts_vector_tree_pointers (ob, expr, ref_p);
849 
850   if (CODE_CONTAINS_STRUCT (code, TS_COMPLEX))
851     write_ts_complex_tree_pointers (ob, expr, ref_p);
852 
853   if (CODE_CONTAINS_STRUCT (code, TS_DECL_MINIMAL))
854     write_ts_decl_minimal_tree_pointers (ob, expr, ref_p);
855 
856   if (CODE_CONTAINS_STRUCT (code, TS_DECL_COMMON))
857     write_ts_decl_common_tree_pointers (ob, expr, ref_p);
858 
859   if (CODE_CONTAINS_STRUCT (code, TS_DECL_NON_COMMON))
860     write_ts_decl_non_common_tree_pointers (ob, expr, ref_p);
861 
862   if (CODE_CONTAINS_STRUCT (code, TS_DECL_WITH_VIS))
863     write_ts_decl_with_vis_tree_pointers (ob, expr, ref_p);
864 
865   if (CODE_CONTAINS_STRUCT (code, TS_FIELD_DECL))
866     write_ts_field_decl_tree_pointers (ob, expr, ref_p);
867 
868   if (CODE_CONTAINS_STRUCT (code, TS_FUNCTION_DECL))
869     write_ts_function_decl_tree_pointers (ob, expr, ref_p);
870 
871   if (CODE_CONTAINS_STRUCT (code, TS_TYPE_COMMON))
872     write_ts_type_common_tree_pointers (ob, expr, ref_p);
873 
874   if (CODE_CONTAINS_STRUCT (code, TS_TYPE_NON_COMMON))
875     write_ts_type_non_common_tree_pointers (ob, expr, ref_p);
876 
877   if (CODE_CONTAINS_STRUCT (code, TS_LIST))
878     write_ts_list_tree_pointers (ob, expr, ref_p);
879 
880   if (CODE_CONTAINS_STRUCT (code, TS_VEC))
881     write_ts_vec_tree_pointers (ob, expr, ref_p);
882 
883   if (CODE_CONTAINS_STRUCT (code, TS_EXP))
884     write_ts_exp_tree_pointers (ob, expr, ref_p);
885 
886   if (CODE_CONTAINS_STRUCT (code, TS_BLOCK))
887     write_ts_block_tree_pointers (ob, expr, ref_p);
888 
889   if (CODE_CONTAINS_STRUCT (code, TS_BINFO))
890     write_ts_binfo_tree_pointers (ob, expr, ref_p);
891 
892   if (CODE_CONTAINS_STRUCT (code, TS_CONSTRUCTOR))
893     write_ts_constructor_tree_pointers (ob, expr, ref_p);
894 }
895 
896 
897 /* Emit header information for tree EXPR to output block OB.  The header
898    contains everything needed to instantiate an empty skeleton for
899    EXPR on the reading side.  IX is the index into the streamer cache
900    where EXPR is stored.  */
901 
902 void
streamer_write_tree_header(struct output_block * ob,tree expr)903 streamer_write_tree_header (struct output_block *ob, tree expr)
904 {
905   enum LTO_tags tag;
906   enum tree_code code;
907 
908   /* We should not see any tree nodes not handled by the streamer.  */
909   code = TREE_CODE (expr);
910 
911   /* The header of a tree node consists of its tag, the size of
912      the node, and any other information needed to instantiate
913      EXPR on the reading side (such as the number of slots in
914      variable sized nodes).  */
915   tag = lto_tree_code_to_tag (code);
916   streamer_write_record_start (ob, tag);
917 
918   /* The following will cause bootstrap miscomparisons.  Enable with care.  */
919 #ifdef LTO_STREAMER_DEBUG
920   /* This is used mainly for debugging purposes.  When the reader
921      and the writer do not agree on a streamed node, the pointer
922      value for EXPR can be used to track down the differences in
923      the debugger.  */
924   gcc_assert ((HOST_WIDEST_INT) (intptr_t) expr == (intptr_t) expr);
925   streamer_write_hwi (ob, (HOST_WIDEST_INT) (intptr_t) expr);
926 #endif
927 
928   /* The text in strings and identifiers are completely emitted in
929      the header.  */
930   if (CODE_CONTAINS_STRUCT (code, TS_STRING))
931     streamer_write_string_cst (ob, ob->main_stream, expr);
932   else if (CODE_CONTAINS_STRUCT (code, TS_IDENTIFIER))
933     write_identifier (ob, ob->main_stream, expr);
934   else if (CODE_CONTAINS_STRUCT (code, TS_VECTOR))
935     streamer_write_hwi (ob, VECTOR_CST_NELTS (expr));
936   else if (CODE_CONTAINS_STRUCT (code, TS_VEC))
937     streamer_write_hwi (ob, TREE_VEC_LENGTH (expr));
938   else if (CODE_CONTAINS_STRUCT (code, TS_BINFO))
939     streamer_write_uhwi (ob, BINFO_N_BASE_BINFOS (expr));
940   else if (TREE_CODE (expr) == CALL_EXPR)
941     streamer_write_uhwi (ob, call_expr_nargs (expr));
942 }
943 
944 
945 /* Emit the integer constant CST to output block OB.  If REF_P is true,
946    CST's type will be emitted as a reference.  */
947 
948 void
streamer_write_integer_cst(struct output_block * ob,tree cst,bool ref_p)949 streamer_write_integer_cst (struct output_block *ob, tree cst, bool ref_p)
950 {
951   gcc_assert (!TREE_OVERFLOW (cst));
952   streamer_write_record_start (ob, LTO_integer_cst);
953   stream_write_tree (ob, TREE_TYPE (cst), ref_p);
954   streamer_write_uhwi (ob, TREE_INT_CST_LOW (cst));
955   streamer_write_hwi (ob, TREE_INT_CST_HIGH (cst));
956 }
957