]> git.ipfire.org Git - thirdparty/gcc.git/blob - gcc/lto-streamer-out.c
This patch implements generic type query and conversion functions,
[thirdparty/gcc.git] / gcc / lto-streamer-out.c
1 /* Write the GIMPLE representation to a file stream.
2
3 Copyright 2009, 2010 Free Software Foundation, Inc.
4 Contributed by Kenneth Zadeck <zadeck@naturalbridge.com>
5 Re-implemented by Diego Novillo <dnovillo@google.com>
6
7 This file is part of GCC.
8
9 GCC is free software; you can redistribute it and/or modify it under
10 the terms of the GNU General Public License as published by the Free
11 Software Foundation; either version 3, or (at your option) any later
12 version.
13
14 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
15 WARRANTY; without even the implied warranty of MERCHANTABILITY or
16 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
17 for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with GCC; see the file COPYING3. If not see
21 <http://www.gnu.org/licenses/>. */
22
23 #include "config.h"
24 #include "system.h"
25 #include "coretypes.h"
26 #include "tm.h"
27 #include "tree.h"
28 #include "expr.h"
29 #include "flags.h"
30 #include "params.h"
31 #include "input.h"
32 #include "hashtab.h"
33 #include "basic-block.h"
34 #include "tree-flow.h"
35 #include "tree-pass.h"
36 #include "cgraph.h"
37 #include "function.h"
38 #include "ggc.h"
39 #include "diagnostic-core.h"
40 #include "except.h"
41 #include "vec.h"
42 #include "lto-symtab.h"
43 #include "lto-streamer.h"
44 #include "data-streamer.h"
45 #include "gimple-streamer.h"
46 #include "tree-streamer.h"
47 #include "streamer-hooks.h"
48
49
50 /* Clear the line info stored in DATA_IN. */
51
52 static void
53 clear_line_info (struct output_block *ob)
54 {
55 ob->current_file = NULL;
56 ob->current_line = 0;
57 ob->current_col = 0;
58 }
59
60
61 /* Create the output block and return it. SECTION_TYPE is
62 LTO_section_function_body or LTO_static_initializer. */
63
64 struct output_block *
65 create_output_block (enum lto_section_type section_type)
66 {
67 struct output_block *ob = XCNEW (struct output_block);
68
69 ob->section_type = section_type;
70 ob->decl_state = lto_get_out_decl_state ();
71 ob->main_stream = XCNEW (struct lto_output_stream);
72 ob->string_stream = XCNEW (struct lto_output_stream);
73 ob->writer_cache = streamer_tree_cache_create ();
74
75 if (section_type == LTO_section_function_body)
76 ob->cfg_stream = XCNEW (struct lto_output_stream);
77
78 clear_line_info (ob);
79
80 ob->string_hash_table = htab_create (37, hash_string_slot_node,
81 eq_string_slot_node, NULL);
82 gcc_obstack_init (&ob->obstack);
83
84 return ob;
85 }
86
87
88 /* Destroy the output block OB. */
89
90 void
91 destroy_output_block (struct output_block *ob)
92 {
93 enum lto_section_type section_type = ob->section_type;
94
95 htab_delete (ob->string_hash_table);
96
97 free (ob->main_stream);
98 free (ob->string_stream);
99 if (section_type == LTO_section_function_body)
100 free (ob->cfg_stream);
101
102 streamer_tree_cache_delete (ob->writer_cache);
103 obstack_free (&ob->obstack, NULL);
104
105 free (ob);
106 }
107
108
109 /* Look up NODE in the type table and write the index for it to OB. */
110
111 static void
112 output_type_ref (struct output_block *ob, tree node)
113 {
114 streamer_write_record_start (ob, LTO_type_ref);
115 lto_output_type_ref_index (ob->decl_state, ob->main_stream, node);
116 }
117
118
119 /* Return true if tree node T is written to various tables. For these
120 nodes, we sometimes want to write their phyiscal representation
121 (via lto_output_tree), and sometimes we need to emit an index
122 reference into a table (via lto_output_tree_ref). */
123
124 static bool
125 tree_is_indexable (tree t)
126 {
127 if (TREE_CODE (t) == PARM_DECL)
128 return true;
129 else if (TREE_CODE (t) == VAR_DECL && decl_function_context (t)
130 && !TREE_STATIC (t))
131 return false;
132 /* Variably modified types need to be streamed alongside function
133 bodies because they can refer to local entities. Together with
134 them we have to localize their members as well.
135 ??? In theory that includes non-FIELD_DECLs as well. */
136 else if (TYPE_P (t)
137 && variably_modified_type_p (t, NULL_TREE))
138 return false;
139 else if (TREE_CODE (t) == FIELD_DECL
140 && variably_modified_type_p (DECL_CONTEXT (t), NULL_TREE))
141 return false;
142 else
143 return (TYPE_P (t) || DECL_P (t) || TREE_CODE (t) == SSA_NAME);
144 }
145
146
147 /* Output info about new location into bitpack BP.
148 After outputting bitpack, lto_output_location_data has
149 to be done to output actual data. */
150
151 void
152 lto_output_location (struct output_block *ob, struct bitpack_d *bp,
153 location_t loc)
154 {
155 expanded_location xloc;
156
157 loc = LOCATION_LOCUS (loc);
158 bp_pack_value (bp, loc == UNKNOWN_LOCATION, 1);
159 if (loc == UNKNOWN_LOCATION)
160 return;
161
162 xloc = expand_location (loc);
163
164 bp_pack_value (bp, ob->current_file != xloc.file, 1);
165 if (ob->current_file != xloc.file)
166 bp_pack_var_len_unsigned (bp,
167 streamer_string_index (ob, xloc.file,
168 strlen (xloc.file) + 1,
169 true));
170 ob->current_file = xloc.file;
171
172 bp_pack_value (bp, ob->current_line != xloc.line, 1);
173 if (ob->current_line != xloc.line)
174 bp_pack_var_len_unsigned (bp, xloc.line);
175 ob->current_line = xloc.line;
176
177 bp_pack_value (bp, ob->current_col != xloc.column, 1);
178 if (ob->current_col != xloc.column)
179 bp_pack_var_len_unsigned (bp, xloc.column);
180 ob->current_col = xloc.column;
181 }
182
183
184 /* If EXPR is an indexable tree node, output a reference to it to
185 output block OB. Otherwise, output the physical representation of
186 EXPR to OB. */
187
188 static void
189 lto_output_tree_ref (struct output_block *ob, tree expr)
190 {
191 enum tree_code code;
192
193 if (TYPE_P (expr))
194 {
195 output_type_ref (ob, expr);
196 return;
197 }
198
199 code = TREE_CODE (expr);
200 switch (code)
201 {
202 case SSA_NAME:
203 streamer_write_record_start (ob, LTO_ssa_name_ref);
204 streamer_write_uhwi (ob, SSA_NAME_VERSION (expr));
205 break;
206
207 case FIELD_DECL:
208 streamer_write_record_start (ob, LTO_field_decl_ref);
209 lto_output_field_decl_index (ob->decl_state, ob->main_stream, expr);
210 break;
211
212 case FUNCTION_DECL:
213 streamer_write_record_start (ob, LTO_function_decl_ref);
214 lto_output_fn_decl_index (ob->decl_state, ob->main_stream, expr);
215 break;
216
217 case VAR_DECL:
218 case DEBUG_EXPR_DECL:
219 gcc_assert (decl_function_context (expr) == NULL || TREE_STATIC (expr));
220 case PARM_DECL:
221 streamer_write_record_start (ob, LTO_global_decl_ref);
222 lto_output_var_decl_index (ob->decl_state, ob->main_stream, expr);
223 break;
224
225 case CONST_DECL:
226 streamer_write_record_start (ob, LTO_const_decl_ref);
227 lto_output_var_decl_index (ob->decl_state, ob->main_stream, expr);
228 break;
229
230 case IMPORTED_DECL:
231 gcc_assert (decl_function_context (expr) == NULL);
232 streamer_write_record_start (ob, LTO_imported_decl_ref);
233 lto_output_var_decl_index (ob->decl_state, ob->main_stream, expr);
234 break;
235
236 case TYPE_DECL:
237 streamer_write_record_start (ob, LTO_type_decl_ref);
238 lto_output_type_decl_index (ob->decl_state, ob->main_stream, expr);
239 break;
240
241 case NAMESPACE_DECL:
242 streamer_write_record_start (ob, LTO_namespace_decl_ref);
243 lto_output_namespace_decl_index (ob->decl_state, ob->main_stream, expr);
244 break;
245
246 case LABEL_DECL:
247 streamer_write_record_start (ob, LTO_label_decl_ref);
248 lto_output_var_decl_index (ob->decl_state, ob->main_stream, expr);
249 break;
250
251 case RESULT_DECL:
252 streamer_write_record_start (ob, LTO_result_decl_ref);
253 lto_output_var_decl_index (ob->decl_state, ob->main_stream, expr);
254 break;
255
256 case TRANSLATION_UNIT_DECL:
257 streamer_write_record_start (ob, LTO_translation_unit_decl_ref);
258 lto_output_var_decl_index (ob->decl_state, ob->main_stream, expr);
259 break;
260
261 default:
262 /* No other node is indexable, so it should have been handled by
263 lto_output_tree. */
264 gcc_unreachable ();
265 }
266 }
267
268
269 /* Return true if EXPR is a tree node that can be written to disk. */
270
271 static inline bool
272 lto_is_streamable (tree expr)
273 {
274 enum tree_code code = TREE_CODE (expr);
275
276 /* Notice that we reject SSA_NAMEs as well. We only emit the SSA
277 name version in lto_output_tree_ref (see output_ssa_names). */
278 return !is_lang_specific (expr)
279 && code != SSA_NAME
280 && code != CALL_EXPR
281 && code != LANG_TYPE
282 && code != MODIFY_EXPR
283 && code != INIT_EXPR
284 && code != TARGET_EXPR
285 && code != BIND_EXPR
286 && code != WITH_CLEANUP_EXPR
287 && code != STATEMENT_LIST
288 && code != OMP_CLAUSE
289 && (code == CASE_LABEL_EXPR
290 || code == DECL_EXPR
291 || TREE_CODE_CLASS (code) != tcc_statement);
292 }
293
294
295 /* Write a physical representation of tree node EXPR to output block
296 OB. If REF_P is true, the leaves of EXPR are emitted as references
297 via lto_output_tree_ref. IX is the index into the streamer cache
298 where EXPR is stored. */
299
300 static void
301 lto_write_tree (struct output_block *ob, tree expr, bool ref_p)
302 {
303 struct bitpack_d bp;
304
305 if (!lto_is_streamable (expr))
306 internal_error ("tree code %qs is not supported in LTO streams",
307 tree_code_name[TREE_CODE (expr)]);
308
309 /* Write the header, containing everything needed to materialize
310 EXPR on the reading side. */
311 streamer_write_tree_header (ob, expr);
312
313 /* Pack all the non-pointer fields in EXPR into a bitpack and write
314 the resulting bitpack. */
315 bp = bitpack_create (ob->main_stream);
316 streamer_pack_tree_bitfields (ob, &bp, expr);
317 streamer_write_bitpack (&bp);
318
319 /* Write all the pointer fields in EXPR. */
320 streamer_write_tree_body (ob, expr, ref_p);
321
322 /* Write any LTO-specific data to OB. */
323 if (DECL_P (expr)
324 && TREE_CODE (expr) != FUNCTION_DECL
325 && TREE_CODE (expr) != TRANSLATION_UNIT_DECL)
326 {
327 /* Handle DECL_INITIAL for symbols. */
328 tree initial = DECL_INITIAL (expr);
329 if (TREE_CODE (expr) == VAR_DECL
330 && (TREE_STATIC (expr) || DECL_EXTERNAL (expr))
331 && initial)
332 {
333 lto_symtab_encoder_t encoder;
334 struct varpool_node *vnode;
335
336 encoder = ob->decl_state->symtab_node_encoder;
337 vnode = varpool_get_node (expr);
338 if (!vnode
339 || !lto_symtab_encoder_encode_initializer_p (encoder,
340 vnode))
341 initial = error_mark_node;
342 }
343
344 stream_write_tree (ob, initial, ref_p);
345 }
346
347 /* Mark the end of EXPR. */
348 streamer_write_zero (ob);
349 }
350
351
352 /* Emit the physical representation of tree node EXPR to output block
353 OB. If THIS_REF_P is true, the leaves of EXPR are emitted as references
354 via lto_output_tree_ref. REF_P is used for streaming siblings of EXPR. */
355
356 void
357 lto_output_tree (struct output_block *ob, tree expr,
358 bool ref_p, bool this_ref_p)
359 {
360 unsigned ix;
361 bool existed_p;
362
363 if (expr == NULL_TREE)
364 {
365 streamer_write_record_start (ob, LTO_null);
366 return;
367 }
368
369 if (this_ref_p && tree_is_indexable (expr))
370 {
371 lto_output_tree_ref (ob, expr);
372 return;
373 }
374
375 /* Shared INTEGER_CST nodes are special because they need their original type
376 to be materialized by the reader (to implement TYPE_CACHED_VALUES). */
377 if (TREE_CODE (expr) == INTEGER_CST
378 && !TREE_OVERFLOW (expr))
379 {
380 streamer_write_integer_cst (ob, expr, ref_p);
381 return;
382 }
383
384 existed_p = streamer_tree_cache_insert (ob->writer_cache, expr, &ix);
385 if (existed_p)
386 {
387 /* If a node has already been streamed out, make sure that
388 we don't write it more than once. Otherwise, the reader
389 will instantiate two different nodes for the same object. */
390 streamer_write_record_start (ob, LTO_tree_pickle_reference);
391 streamer_write_uhwi (ob, ix);
392 streamer_write_enum (ob->main_stream, LTO_tags, LTO_NUM_TAGS,
393 lto_tree_code_to_tag (TREE_CODE (expr)));
394 }
395 else if (streamer_handle_as_builtin_p (expr))
396 {
397 /* MD and NORMAL builtins do not need to be written out
398 completely as they are always instantiated by the
399 compiler on startup. The only builtins that need to
400 be written out are BUILT_IN_FRONTEND. For all other
401 builtins, we simply write the class and code. */
402 streamer_write_builtin (ob, expr);
403 }
404 else
405 {
406 /* This is the first time we see EXPR, write its fields
407 to OB. */
408 lto_write_tree (ob, expr, ref_p);
409 }
410 }
411
412
413 /* Output to OB a list of try/catch handlers starting with FIRST. */
414
415 static void
416 output_eh_try_list (struct output_block *ob, eh_catch first)
417 {
418 eh_catch n;
419
420 for (n = first; n; n = n->next_catch)
421 {
422 streamer_write_record_start (ob, LTO_eh_catch);
423 stream_write_tree (ob, n->type_list, true);
424 stream_write_tree (ob, n->filter_list, true);
425 stream_write_tree (ob, n->label, true);
426 }
427
428 streamer_write_record_start (ob, LTO_null);
429 }
430
431
432 /* Output EH region R in function FN to OB. CURR_RN is the slot index
433 that is being emitted in FN->EH->REGION_ARRAY. This is used to
434 detect EH region sharing. */
435
436 static void
437 output_eh_region (struct output_block *ob, eh_region r)
438 {
439 enum LTO_tags tag;
440
441 if (r == NULL)
442 {
443 streamer_write_record_start (ob, LTO_null);
444 return;
445 }
446
447 if (r->type == ERT_CLEANUP)
448 tag = LTO_ert_cleanup;
449 else if (r->type == ERT_TRY)
450 tag = LTO_ert_try;
451 else if (r->type == ERT_ALLOWED_EXCEPTIONS)
452 tag = LTO_ert_allowed_exceptions;
453 else if (r->type == ERT_MUST_NOT_THROW)
454 tag = LTO_ert_must_not_throw;
455 else
456 gcc_unreachable ();
457
458 streamer_write_record_start (ob, tag);
459 streamer_write_hwi (ob, r->index);
460
461 if (r->outer)
462 streamer_write_hwi (ob, r->outer->index);
463 else
464 streamer_write_zero (ob);
465
466 if (r->inner)
467 streamer_write_hwi (ob, r->inner->index);
468 else
469 streamer_write_zero (ob);
470
471 if (r->next_peer)
472 streamer_write_hwi (ob, r->next_peer->index);
473 else
474 streamer_write_zero (ob);
475
476 if (r->type == ERT_TRY)
477 {
478 output_eh_try_list (ob, r->u.eh_try.first_catch);
479 }
480 else if (r->type == ERT_ALLOWED_EXCEPTIONS)
481 {
482 stream_write_tree (ob, r->u.allowed.type_list, true);
483 stream_write_tree (ob, r->u.allowed.label, true);
484 streamer_write_uhwi (ob, r->u.allowed.filter);
485 }
486 else if (r->type == ERT_MUST_NOT_THROW)
487 {
488 stream_write_tree (ob, r->u.must_not_throw.failure_decl, true);
489 bitpack_d bp = bitpack_create (ob->main_stream);
490 stream_output_location (ob, &bp, r->u.must_not_throw.failure_loc);
491 streamer_write_bitpack (&bp);
492 }
493
494 if (r->landing_pads)
495 streamer_write_hwi (ob, r->landing_pads->index);
496 else
497 streamer_write_zero (ob);
498 }
499
500
501 /* Output landing pad LP to OB. */
502
503 static void
504 output_eh_lp (struct output_block *ob, eh_landing_pad lp)
505 {
506 if (lp == NULL)
507 {
508 streamer_write_record_start (ob, LTO_null);
509 return;
510 }
511
512 streamer_write_record_start (ob, LTO_eh_landing_pad);
513 streamer_write_hwi (ob, lp->index);
514 if (lp->next_lp)
515 streamer_write_hwi (ob, lp->next_lp->index);
516 else
517 streamer_write_zero (ob);
518
519 if (lp->region)
520 streamer_write_hwi (ob, lp->region->index);
521 else
522 streamer_write_zero (ob);
523
524 stream_write_tree (ob, lp->post_landing_pad, true);
525 }
526
527
528 /* Output the existing eh_table to OB. */
529
530 static void
531 output_eh_regions (struct output_block *ob, struct function *fn)
532 {
533 if (fn->eh && fn->eh->region_tree)
534 {
535 unsigned i;
536 eh_region eh;
537 eh_landing_pad lp;
538 tree ttype;
539
540 streamer_write_record_start (ob, LTO_eh_table);
541
542 /* Emit the index of the root of the EH region tree. */
543 streamer_write_hwi (ob, fn->eh->region_tree->index);
544
545 /* Emit all the EH regions in the region array. */
546 streamer_write_hwi (ob, VEC_length (eh_region, fn->eh->region_array));
547 FOR_EACH_VEC_ELT (eh_region, fn->eh->region_array, i, eh)
548 output_eh_region (ob, eh);
549
550 /* Emit all landing pads. */
551 streamer_write_hwi (ob, VEC_length (eh_landing_pad, fn->eh->lp_array));
552 FOR_EACH_VEC_ELT (eh_landing_pad, fn->eh->lp_array, i, lp)
553 output_eh_lp (ob, lp);
554
555 /* Emit all the runtime type data. */
556 streamer_write_hwi (ob, VEC_length (tree, fn->eh->ttype_data));
557 FOR_EACH_VEC_ELT (tree, fn->eh->ttype_data, i, ttype)
558 stream_write_tree (ob, ttype, true);
559
560 /* Emit the table of action chains. */
561 if (targetm.arm_eabi_unwinder)
562 {
563 tree t;
564 streamer_write_hwi (ob, VEC_length (tree,
565 fn->eh->ehspec_data.arm_eabi));
566 FOR_EACH_VEC_ELT (tree, fn->eh->ehspec_data.arm_eabi, i, t)
567 stream_write_tree (ob, t, true);
568 }
569 else
570 {
571 uchar c;
572 streamer_write_hwi (ob, VEC_length (uchar,
573 fn->eh->ehspec_data.other));
574 FOR_EACH_VEC_ELT (uchar, fn->eh->ehspec_data.other, i, c)
575 streamer_write_char_stream (ob->main_stream, c);
576 }
577 }
578
579 /* The LTO_null either terminates the record or indicates that there
580 are no eh_records at all. */
581 streamer_write_record_start (ob, LTO_null);
582 }
583
584
585 /* Output all of the active ssa names to the ssa_names stream. */
586
587 static void
588 output_ssa_names (struct output_block *ob, struct function *fn)
589 {
590 unsigned int i, len;
591
592 len = VEC_length (tree, SSANAMES (fn));
593 streamer_write_uhwi (ob, len);
594
595 for (i = 1; i < len; i++)
596 {
597 tree ptr = VEC_index (tree, SSANAMES (fn), i);
598
599 if (ptr == NULL_TREE
600 || SSA_NAME_IN_FREE_LIST (ptr)
601 || virtual_operand_p (ptr))
602 continue;
603
604 streamer_write_uhwi (ob, i);
605 streamer_write_char_stream (ob->main_stream,
606 SSA_NAME_IS_DEFAULT_DEF (ptr));
607 if (SSA_NAME_VAR (ptr))
608 stream_write_tree (ob, SSA_NAME_VAR (ptr), true);
609 else
610 /* ??? This drops SSA_NAME_IDENTIFIER on the floor. */
611 stream_write_tree (ob, TREE_TYPE (ptr), true);
612 }
613
614 streamer_write_zero (ob);
615 }
616
617
618 /* Output the cfg. */
619
620 static void
621 output_cfg (struct output_block *ob, struct function *fn)
622 {
623 struct lto_output_stream *tmp_stream = ob->main_stream;
624 basic_block bb;
625
626 ob->main_stream = ob->cfg_stream;
627
628 streamer_write_enum (ob->main_stream, profile_status_d, PROFILE_LAST,
629 profile_status_for_function (fn));
630
631 /* Output the number of the highest basic block. */
632 streamer_write_uhwi (ob, last_basic_block_for_function (fn));
633
634 FOR_ALL_BB_FN (bb, fn)
635 {
636 edge_iterator ei;
637 edge e;
638
639 streamer_write_hwi (ob, bb->index);
640
641 /* Output the successors and the edge flags. */
642 streamer_write_uhwi (ob, EDGE_COUNT (bb->succs));
643 FOR_EACH_EDGE (e, ei, bb->succs)
644 {
645 streamer_write_uhwi (ob, e->dest->index);
646 streamer_write_hwi (ob, e->probability);
647 streamer_write_hwi (ob, e->count);
648 streamer_write_uhwi (ob, e->flags);
649 }
650 }
651
652 streamer_write_hwi (ob, -1);
653
654 bb = ENTRY_BLOCK_PTR;
655 while (bb->next_bb)
656 {
657 streamer_write_hwi (ob, bb->next_bb->index);
658 bb = bb->next_bb;
659 }
660
661 streamer_write_hwi (ob, -1);
662
663 ob->main_stream = tmp_stream;
664 }
665
666
667 /* Create the header in the file using OB. If the section type is for
668 a function, set FN to the decl for that function. */
669
670 void
671 produce_asm (struct output_block *ob, tree fn)
672 {
673 enum lto_section_type section_type = ob->section_type;
674 struct lto_function_header header;
675 char *section_name;
676 struct lto_output_stream *header_stream;
677
678 if (section_type == LTO_section_function_body)
679 {
680 const char *name = IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (fn));
681 section_name = lto_get_section_name (section_type, name, NULL);
682 }
683 else
684 section_name = lto_get_section_name (section_type, NULL, NULL);
685
686 lto_begin_section (section_name, !flag_wpa);
687 free (section_name);
688
689 /* The entire header is stream computed here. */
690 memset (&header, 0, sizeof (struct lto_function_header));
691
692 /* Write the header. */
693 header.lto_header.major_version = LTO_major_version;
694 header.lto_header.minor_version = LTO_minor_version;
695
696 header.compressed_size = 0;
697
698 if (section_type == LTO_section_function_body)
699 header.cfg_size = ob->cfg_stream->total_size;
700 header.main_size = ob->main_stream->total_size;
701 header.string_size = ob->string_stream->total_size;
702
703 header_stream = XCNEW (struct lto_output_stream);
704 lto_output_data_stream (header_stream, &header, sizeof header);
705 lto_write_stream (header_stream);
706 free (header_stream);
707
708 /* Put all of the gimple and the string table out the asm file as a
709 block of text. */
710 if (section_type == LTO_section_function_body)
711 lto_write_stream (ob->cfg_stream);
712 lto_write_stream (ob->main_stream);
713 lto_write_stream (ob->string_stream);
714
715 lto_end_section ();
716 }
717
718
719 /* Output the base body of struct function FN using output block OB. */
720
721 static void
722 output_struct_function_base (struct output_block *ob, struct function *fn)
723 {
724 struct bitpack_d bp;
725 unsigned i;
726 tree t;
727
728 /* Output the static chain and non-local goto save area. */
729 stream_write_tree (ob, fn->static_chain_decl, true);
730 stream_write_tree (ob, fn->nonlocal_goto_save_area, true);
731
732 /* Output all the local variables in the function. */
733 streamer_write_hwi (ob, VEC_length (tree, fn->local_decls));
734 FOR_EACH_VEC_ELT (tree, fn->local_decls, i, t)
735 stream_write_tree (ob, t, true);
736
737 /* Output current IL state of the function. */
738 streamer_write_uhwi (ob, fn->curr_properties);
739
740 /* Write all the attributes for FN. */
741 bp = bitpack_create (ob->main_stream);
742 bp_pack_value (&bp, fn->is_thunk, 1);
743 bp_pack_value (&bp, fn->has_local_explicit_reg_vars, 1);
744 bp_pack_value (&bp, fn->returns_pcc_struct, 1);
745 bp_pack_value (&bp, fn->returns_struct, 1);
746 bp_pack_value (&bp, fn->can_throw_non_call_exceptions, 1);
747 bp_pack_value (&bp, fn->can_delete_dead_exceptions, 1);
748 bp_pack_value (&bp, fn->always_inline_functions_inlined, 1);
749 bp_pack_value (&bp, fn->after_inlining, 1);
750 bp_pack_value (&bp, fn->stdarg, 1);
751 bp_pack_value (&bp, fn->has_nonlocal_label, 1);
752 bp_pack_value (&bp, fn->calls_alloca, 1);
753 bp_pack_value (&bp, fn->calls_setjmp, 1);
754 bp_pack_value (&bp, fn->va_list_fpr_size, 8);
755 bp_pack_value (&bp, fn->va_list_gpr_size, 8);
756
757 /* Output the function start and end loci. */
758 stream_output_location (ob, &bp, fn->function_start_locus);
759 stream_output_location (ob, &bp, fn->function_end_locus);
760
761 streamer_write_bitpack (&bp);
762 }
763
764
765 /* Output the body of function NODE->DECL. */
766
767 static void
768 output_function (struct cgraph_node *node)
769 {
770 tree function;
771 struct function *fn;
772 basic_block bb;
773 struct output_block *ob;
774
775 function = node->symbol.decl;
776 fn = DECL_STRUCT_FUNCTION (function);
777 ob = create_output_block (LTO_section_function_body);
778
779 clear_line_info (ob);
780 ob->cgraph_node = node;
781
782 gcc_assert (current_function_decl == NULL_TREE && cfun == NULL);
783
784 /* Set current_function_decl and cfun. */
785 push_cfun (fn);
786
787 /* Make string 0 be a NULL string. */
788 streamer_write_char_stream (ob->string_stream, 0);
789
790 streamer_write_record_start (ob, LTO_function);
791
792 output_struct_function_base (ob, fn);
793
794 /* Output all the SSA names used in the function. */
795 output_ssa_names (ob, fn);
796
797 /* Output any exception handling regions. */
798 output_eh_regions (ob, fn);
799
800 /* Output DECL_INITIAL for the function, which contains the tree of
801 lexical scopes. */
802 stream_write_tree (ob, DECL_INITIAL (function), true);
803
804 /* We will renumber the statements. The code that does this uses
805 the same ordering that we use for serializing them so we can use
806 the same code on the other end and not have to write out the
807 statement numbers. We do not assign UIDs to PHIs here because
808 virtual PHIs get re-computed on-the-fly which would make numbers
809 inconsistent. */
810 set_gimple_stmt_max_uid (cfun, 0);
811 FOR_ALL_BB (bb)
812 {
813 gimple_stmt_iterator gsi;
814 for (gsi = gsi_start_bb (bb); !gsi_end_p (gsi); gsi_next (&gsi))
815 {
816 gimple stmt = gsi_stmt (gsi);
817 gimple_set_uid (stmt, inc_gimple_stmt_max_uid (cfun));
818 }
819 }
820
821 /* Output the code for the function. */
822 FOR_ALL_BB_FN (bb, fn)
823 output_bb (ob, bb, fn);
824
825 /* The terminator for this function. */
826 streamer_write_record_start (ob, LTO_null);
827
828 output_cfg (ob, fn);
829
830 /* Create a section to hold the pickled output of this function. */
831 produce_asm (ob, function);
832
833 destroy_output_block (ob);
834
835 pop_cfun ();
836 }
837
838
839 /* Emit toplevel asms. */
840
841 void
842 lto_output_toplevel_asms (void)
843 {
844 struct output_block *ob;
845 struct asm_node *can;
846 char *section_name;
847 struct lto_output_stream *header_stream;
848 struct lto_asm_header header;
849
850 if (! asm_nodes)
851 return;
852
853 ob = create_output_block (LTO_section_asm);
854
855 /* Make string 0 be a NULL string. */
856 streamer_write_char_stream (ob->string_stream, 0);
857
858 for (can = asm_nodes; can; can = can->next)
859 {
860 streamer_write_string_cst (ob, ob->main_stream, can->asm_str);
861 streamer_write_hwi (ob, can->order);
862 }
863
864 streamer_write_string_cst (ob, ob->main_stream, NULL_TREE);
865
866 section_name = lto_get_section_name (LTO_section_asm, NULL, NULL);
867 lto_begin_section (section_name, !flag_wpa);
868 free (section_name);
869
870 /* The entire header stream is computed here. */
871 memset (&header, 0, sizeof (header));
872
873 /* Write the header. */
874 header.lto_header.major_version = LTO_major_version;
875 header.lto_header.minor_version = LTO_minor_version;
876
877 header.main_size = ob->main_stream->total_size;
878 header.string_size = ob->string_stream->total_size;
879
880 header_stream = XCNEW (struct lto_output_stream);
881 lto_output_data_stream (header_stream, &header, sizeof (header));
882 lto_write_stream (header_stream);
883 free (header_stream);
884
885 /* Put all of the gimple and the string table out the asm file as a
886 block of text. */
887 lto_write_stream (ob->main_stream);
888 lto_write_stream (ob->string_stream);
889
890 lto_end_section ();
891
892 destroy_output_block (ob);
893 }
894
895
896 /* Copy the function body of NODE without deserializing. */
897
898 static void
899 copy_function (struct cgraph_node *node)
900 {
901 tree function = node->symbol.decl;
902 struct lto_file_decl_data *file_data = node->symbol.lto_file_data;
903 struct lto_output_stream *output_stream = XCNEW (struct lto_output_stream);
904 const char *data;
905 size_t len;
906 const char *name = IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (function));
907 char *section_name =
908 lto_get_section_name (LTO_section_function_body, name, NULL);
909 size_t i, j;
910 struct lto_in_decl_state *in_state;
911 struct lto_out_decl_state *out_state = lto_get_out_decl_state ();
912
913 lto_begin_section (section_name, !flag_wpa);
914 free (section_name);
915
916 /* We may have renamed the declaration, e.g., a static function. */
917 name = lto_get_decl_name_mapping (file_data, name);
918
919 data = lto_get_section_data (file_data, LTO_section_function_body,
920 name, &len);
921 gcc_assert (data);
922
923 /* Do a bit copy of the function body. */
924 lto_output_data_stream (output_stream, data, len);
925 lto_write_stream (output_stream);
926
927 /* Copy decls. */
928 in_state =
929 lto_get_function_in_decl_state (node->symbol.lto_file_data, function);
930 gcc_assert (in_state);
931
932 for (i = 0; i < LTO_N_DECL_STREAMS; i++)
933 {
934 size_t n = in_state->streams[i].size;
935 tree *trees = in_state->streams[i].trees;
936 struct lto_tree_ref_encoder *encoder = &(out_state->streams[i]);
937
938 /* The out state must have the same indices and the in state.
939 So just copy the vector. All the encoders in the in state
940 must be empty where we reach here. */
941 gcc_assert (lto_tree_ref_encoder_size (encoder) == 0);
942 for (j = 0; j < n; j++)
943 VEC_safe_push (tree, heap, encoder->trees, trees[j]);
944 encoder->next_index = n;
945 }
946
947 lto_free_section_data (file_data, LTO_section_function_body, name,
948 data, len);
949 free (output_stream);
950 lto_end_section ();
951 }
952
953
954 /* Main entry point from the pass manager. */
955
956 static void
957 lto_output (void)
958 {
959 struct lto_out_decl_state *decl_state;
960 #ifdef ENABLE_CHECKING
961 bitmap output = lto_bitmap_alloc ();
962 #endif
963 int i, n_nodes;
964 lto_symtab_encoder_t encoder = lto_get_out_decl_state ()->symtab_node_encoder;
965
966 /* Initialize the streamer. */
967 lto_streamer_init ();
968
969 n_nodes = lto_symtab_encoder_size (encoder);
970 /* Process only the functions with bodies. */
971 for (i = 0; i < n_nodes; i++)
972 {
973 symtab_node snode = lto_symtab_encoder_deref (encoder, i);
974 cgraph_node *node = dyn_cast <cgraph_node> (snode);
975 if (node
976 && lto_symtab_encoder_encode_body_p (encoder, node)
977 && !node->alias
978 && !node->thunk.thunk_p)
979 {
980 #ifdef ENABLE_CHECKING
981 gcc_assert (!bitmap_bit_p (output, DECL_UID (node->symbol.decl)));
982 bitmap_set_bit (output, DECL_UID (node->symbol.decl));
983 #endif
984 decl_state = lto_new_out_decl_state ();
985 lto_push_out_decl_state (decl_state);
986 if (gimple_has_body_p (node->symbol.decl))
987 output_function (node);
988 else
989 copy_function (node);
990 gcc_assert (lto_get_out_decl_state () == decl_state);
991 lto_pop_out_decl_state ();
992 lto_record_function_out_decl_state (node->symbol.decl, decl_state);
993 }
994 }
995
996 /* Emit the callgraph after emitting function bodies. This needs to
997 be done now to make sure that all the statements in every function
998 have been renumbered so that edges can be associated with call
999 statements using the statement UIDs. */
1000 output_symtab ();
1001
1002 #ifdef ENABLE_CHECKING
1003 lto_bitmap_free (output);
1004 #endif
1005 }
1006
1007 struct ipa_opt_pass_d pass_ipa_lto_gimple_out =
1008 {
1009 {
1010 IPA_PASS,
1011 "lto_gimple_out", /* name */
1012 gate_lto_out, /* gate */
1013 NULL, /* execute */
1014 NULL, /* sub */
1015 NULL, /* next */
1016 0, /* static_pass_number */
1017 TV_IPA_LTO_GIMPLE_OUT, /* tv_id */
1018 0, /* properties_required */
1019 0, /* properties_provided */
1020 0, /* properties_destroyed */
1021 0, /* todo_flags_start */
1022 0 /* todo_flags_finish */
1023 },
1024 NULL, /* generate_summary */
1025 lto_output, /* write_summary */
1026 NULL, /* read_summary */
1027 lto_output, /* write_optimization_summary */
1028 NULL, /* read_optimization_summary */
1029 NULL, /* stmt_fixup */
1030 0, /* TODOs */
1031 NULL, /* function_transform */
1032 NULL /* variable_transform */
1033 };
1034
1035
1036 /* Write each node in encoded by ENCODER to OB, as well as those reachable
1037 from it and required for correct representation of its semantics.
1038 Each node in ENCODER must be a global declaration or a type. A node
1039 is written only once, even if it appears multiple times in the
1040 vector. Certain transitively-reachable nodes, such as those
1041 representing expressions, may be duplicated, but such nodes
1042 must not appear in ENCODER itself. */
1043
1044 static void
1045 write_global_stream (struct output_block *ob,
1046 struct lto_tree_ref_encoder *encoder)
1047 {
1048 tree t;
1049 size_t index;
1050 const size_t size = lto_tree_ref_encoder_size (encoder);
1051
1052 for (index = 0; index < size; index++)
1053 {
1054 t = lto_tree_ref_encoder_get_tree (encoder, index);
1055 if (!streamer_tree_cache_lookup (ob->writer_cache, t, NULL))
1056 stream_write_tree (ob, t, false);
1057 }
1058 }
1059
1060
1061 /* Write a sequence of indices into the globals vector corresponding
1062 to the trees in ENCODER. These are used by the reader to map the
1063 indices used to refer to global entities within function bodies to
1064 their referents. */
1065
1066 static void
1067 write_global_references (struct output_block *ob,
1068 struct lto_output_stream *ref_stream,
1069 struct lto_tree_ref_encoder *encoder)
1070 {
1071 tree t;
1072 uint32_t index;
1073 const uint32_t size = lto_tree_ref_encoder_size (encoder);
1074
1075 /* Write size as 32-bit unsigned. */
1076 lto_output_data_stream (ref_stream, &size, sizeof (int32_t));
1077
1078 for (index = 0; index < size; index++)
1079 {
1080 uint32_t slot_num;
1081
1082 t = lto_tree_ref_encoder_get_tree (encoder, index);
1083 streamer_tree_cache_lookup (ob->writer_cache, t, &slot_num);
1084 gcc_assert (slot_num != (unsigned)-1);
1085 lto_output_data_stream (ref_stream, &slot_num, sizeof slot_num);
1086 }
1087 }
1088
1089
1090 /* Write all the streams in an lto_out_decl_state STATE using
1091 output block OB and output stream OUT_STREAM. */
1092
1093 void
1094 lto_output_decl_state_streams (struct output_block *ob,
1095 struct lto_out_decl_state *state)
1096 {
1097 int i;
1098
1099 for (i = 0; i < LTO_N_DECL_STREAMS; i++)
1100 write_global_stream (ob, &state->streams[i]);
1101 }
1102
1103
1104 /* Write all the references in an lto_out_decl_state STATE using
1105 output block OB and output stream OUT_STREAM. */
1106
1107 void
1108 lto_output_decl_state_refs (struct output_block *ob,
1109 struct lto_output_stream *out_stream,
1110 struct lto_out_decl_state *state)
1111 {
1112 unsigned i;
1113 uint32_t ref;
1114 tree decl;
1115
1116 /* Write reference to FUNCTION_DECL. If there is not function,
1117 write reference to void_type_node. */
1118 decl = (state->fn_decl) ? state->fn_decl : void_type_node;
1119 streamer_tree_cache_lookup (ob->writer_cache, decl, &ref);
1120 gcc_assert (ref != (unsigned)-1);
1121 lto_output_data_stream (out_stream, &ref, sizeof (uint32_t));
1122
1123 for (i = 0; i < LTO_N_DECL_STREAMS; i++)
1124 write_global_references (ob, out_stream, &state->streams[i]);
1125 }
1126
1127
1128 /* Return the written size of STATE. */
1129
1130 static size_t
1131 lto_out_decl_state_written_size (struct lto_out_decl_state *state)
1132 {
1133 int i;
1134 size_t size;
1135
1136 size = sizeof (int32_t); /* fn_ref. */
1137 for (i = 0; i < LTO_N_DECL_STREAMS; i++)
1138 {
1139 size += sizeof (int32_t); /* vector size. */
1140 size += (lto_tree_ref_encoder_size (&state->streams[i])
1141 * sizeof (int32_t));
1142 }
1143 return size;
1144 }
1145
1146
1147 /* Write symbol T into STREAM in CACHE. SEEN specifies symbols we wrote
1148 so far. */
1149
1150 static void
1151 write_symbol (struct streamer_tree_cache_d *cache,
1152 struct lto_output_stream *stream,
1153 tree t, struct pointer_set_t *seen, bool alias)
1154 {
1155 const char *name;
1156 enum gcc_plugin_symbol_kind kind;
1157 enum gcc_plugin_symbol_visibility visibility;
1158 unsigned slot_num;
1159 unsigned HOST_WIDEST_INT size;
1160 const char *comdat;
1161 unsigned char c;
1162
1163 /* None of the following kinds of symbols are needed in the
1164 symbol table. */
1165 if (!TREE_PUBLIC (t)
1166 || is_builtin_fn (t)
1167 || DECL_ABSTRACT (t)
1168 || TREE_CODE (t) == RESULT_DECL)
1169 return;
1170
1171 gcc_assert (TREE_CODE (t) == VAR_DECL
1172 || TREE_CODE (t) == FUNCTION_DECL);
1173
1174 name = IDENTIFIER_POINTER (DECL_ASSEMBLER_NAME (t));
1175
1176 /* This behaves like assemble_name_raw in varasm.c, performing the
1177 same name manipulations that ASM_OUTPUT_LABELREF does. */
1178 name = IDENTIFIER_POINTER ((*targetm.asm_out.mangle_assembler_name) (name));
1179
1180 if (pointer_set_contains (seen, name))
1181 return;
1182 pointer_set_insert (seen, name);
1183
1184 streamer_tree_cache_lookup (cache, t, &slot_num);
1185 gcc_assert (slot_num != (unsigned)-1);
1186
1187 if (DECL_EXTERNAL (t))
1188 {
1189 if (DECL_WEAK (t))
1190 kind = GCCPK_WEAKUNDEF;
1191 else
1192 kind = GCCPK_UNDEF;
1193 }
1194 else
1195 {
1196 if (DECL_WEAK (t))
1197 kind = GCCPK_WEAKDEF;
1198 else if (DECL_COMMON (t))
1199 kind = GCCPK_COMMON;
1200 else
1201 kind = GCCPK_DEF;
1202
1203 /* When something is defined, it should have node attached. */
1204 gcc_assert (alias || TREE_CODE (t) != VAR_DECL
1205 || varpool_get_node (t)->finalized);
1206 gcc_assert (alias || TREE_CODE (t) != FUNCTION_DECL
1207 || (cgraph_get_node (t)
1208 && cgraph_get_node (t)->analyzed));
1209 }
1210
1211 /* Imitate what default_elf_asm_output_external do.
1212 When symbol is external, we need to output it with DEFAULT visibility
1213 when compiling with -fvisibility=default, while with HIDDEN visibility
1214 when symbol has attribute (visibility("hidden")) specified.
1215 targetm.binds_local_p check DECL_VISIBILITY_SPECIFIED and gets this
1216 right. */
1217
1218 if (DECL_EXTERNAL (t)
1219 && !targetm.binds_local_p (t))
1220 visibility = GCCPV_DEFAULT;
1221 else
1222 switch (DECL_VISIBILITY(t))
1223 {
1224 case VISIBILITY_DEFAULT:
1225 visibility = GCCPV_DEFAULT;
1226 break;
1227 case VISIBILITY_PROTECTED:
1228 visibility = GCCPV_PROTECTED;
1229 break;
1230 case VISIBILITY_HIDDEN:
1231 visibility = GCCPV_HIDDEN;
1232 break;
1233 case VISIBILITY_INTERNAL:
1234 visibility = GCCPV_INTERNAL;
1235 break;
1236 }
1237
1238 if (kind == GCCPK_COMMON
1239 && DECL_SIZE_UNIT (t)
1240 && TREE_CODE (DECL_SIZE_UNIT (t)) == INTEGER_CST)
1241 size = TREE_INT_CST_LOW (DECL_SIZE_UNIT (t));
1242 else
1243 size = 0;
1244
1245 if (DECL_ONE_ONLY (t))
1246 comdat = IDENTIFIER_POINTER (DECL_COMDAT_GROUP (t));
1247 else
1248 comdat = "";
1249
1250 lto_output_data_stream (stream, name, strlen (name) + 1);
1251 lto_output_data_stream (stream, comdat, strlen (comdat) + 1);
1252 c = (unsigned char) kind;
1253 lto_output_data_stream (stream, &c, 1);
1254 c = (unsigned char) visibility;
1255 lto_output_data_stream (stream, &c, 1);
1256 lto_output_data_stream (stream, &size, 8);
1257 lto_output_data_stream (stream, &slot_num, 4);
1258 }
1259
1260
1261 /* Write an IL symbol table to OB.
1262 SET and VSET are cgraph/varpool node sets we are outputting. */
1263
1264 static void
1265 produce_symtab (struct output_block *ob)
1266 {
1267 struct streamer_tree_cache_d *cache = ob->writer_cache;
1268 char *section_name = lto_get_section_name (LTO_section_symtab, NULL, NULL);
1269 struct pointer_set_t *seen;
1270 struct lto_output_stream stream;
1271 lto_symtab_encoder_t encoder = ob->decl_state->symtab_node_encoder;
1272 lto_symtab_encoder_iterator lsei;
1273
1274 lto_begin_section (section_name, false);
1275 free (section_name);
1276
1277 seen = pointer_set_create ();
1278 memset (&stream, 0, sizeof (stream));
1279
1280 /* Write the symbol table.
1281 First write everything defined and then all declarations.
1282 This is neccesary to handle cases where we have duplicated symbols. */
1283 for (lsei = lsei_start (encoder);
1284 !lsei_end_p (lsei); lsei_next (&lsei))
1285 {
1286 symtab_node node = lsei_node (lsei);
1287
1288 if (!symtab_real_symbol_p (node) || DECL_EXTERNAL (node->symbol.decl))
1289 continue;
1290 write_symbol (cache, &stream, node->symbol.decl, seen, false);
1291 }
1292 for (lsei = lsei_start (encoder);
1293 !lsei_end_p (lsei); lsei_next (&lsei))
1294 {
1295 symtab_node node = lsei_node (lsei);
1296
1297 if (!symtab_real_symbol_p (node) || !DECL_EXTERNAL (node->symbol.decl))
1298 continue;
1299 write_symbol (cache, &stream, node->symbol.decl, seen, false);
1300 }
1301
1302 lto_write_stream (&stream);
1303 pointer_set_destroy (seen);
1304
1305 lto_end_section ();
1306 }
1307
1308
1309 /* This pass is run after all of the functions are serialized and all
1310 of the IPA passes have written their serialized forms. This pass
1311 causes the vector of all of the global decls and types used from
1312 this file to be written in to a section that can then be read in to
1313 recover these on other side. */
1314
1315 static void
1316 produce_asm_for_decls (void)
1317 {
1318 struct lto_out_decl_state *out_state;
1319 struct lto_out_decl_state *fn_out_state;
1320 struct lto_decl_header header;
1321 char *section_name;
1322 struct output_block *ob;
1323 struct lto_output_stream *header_stream, *decl_state_stream;
1324 unsigned idx, num_fns;
1325 size_t decl_state_size;
1326 int32_t num_decl_states;
1327
1328 ob = create_output_block (LTO_section_decls);
1329 ob->global = true;
1330
1331 memset (&header, 0, sizeof (struct lto_decl_header));
1332
1333 section_name = lto_get_section_name (LTO_section_decls, NULL, NULL);
1334 lto_begin_section (section_name, !flag_wpa);
1335 free (section_name);
1336
1337 /* Make string 0 be a NULL string. */
1338 streamer_write_char_stream (ob->string_stream, 0);
1339
1340 gcc_assert (!alias_pairs);
1341
1342 /* Write the global symbols. */
1343 out_state = lto_get_out_decl_state ();
1344 num_fns = VEC_length (lto_out_decl_state_ptr, lto_function_decl_states);
1345 lto_output_decl_state_streams (ob, out_state);
1346 for (idx = 0; idx < num_fns; idx++)
1347 {
1348 fn_out_state =
1349 VEC_index (lto_out_decl_state_ptr, lto_function_decl_states, idx);
1350 lto_output_decl_state_streams (ob, fn_out_state);
1351 }
1352
1353 header.lto_header.major_version = LTO_major_version;
1354 header.lto_header.minor_version = LTO_minor_version;
1355
1356 /* Currently not used. This field would allow us to preallocate
1357 the globals vector, so that it need not be resized as it is extended. */
1358 header.num_nodes = -1;
1359
1360 /* Compute the total size of all decl out states. */
1361 decl_state_size = sizeof (int32_t);
1362 decl_state_size += lto_out_decl_state_written_size (out_state);
1363 for (idx = 0; idx < num_fns; idx++)
1364 {
1365 fn_out_state =
1366 VEC_index (lto_out_decl_state_ptr, lto_function_decl_states, idx);
1367 decl_state_size += lto_out_decl_state_written_size (fn_out_state);
1368 }
1369 header.decl_state_size = decl_state_size;
1370
1371 header.main_size = ob->main_stream->total_size;
1372 header.string_size = ob->string_stream->total_size;
1373
1374 header_stream = XCNEW (struct lto_output_stream);
1375 lto_output_data_stream (header_stream, &header, sizeof header);
1376 lto_write_stream (header_stream);
1377 free (header_stream);
1378
1379 /* Write the main out-decl state, followed by out-decl states of
1380 functions. */
1381 decl_state_stream = XCNEW (struct lto_output_stream);
1382 num_decl_states = num_fns + 1;
1383 lto_output_data_stream (decl_state_stream, &num_decl_states,
1384 sizeof (num_decl_states));
1385 lto_output_decl_state_refs (ob, decl_state_stream, out_state);
1386 for (idx = 0; idx < num_fns; idx++)
1387 {
1388 fn_out_state =
1389 VEC_index (lto_out_decl_state_ptr, lto_function_decl_states, idx);
1390 lto_output_decl_state_refs (ob, decl_state_stream, fn_out_state);
1391 }
1392 lto_write_stream (decl_state_stream);
1393 free(decl_state_stream);
1394
1395 lto_write_stream (ob->main_stream);
1396 lto_write_stream (ob->string_stream);
1397
1398 lto_end_section ();
1399
1400 /* Write the symbol table. It is used by linker to determine dependencies
1401 and thus we can skip it for WPA. */
1402 if (!flag_wpa)
1403 produce_symtab (ob);
1404
1405 /* Write command line opts. */
1406 lto_write_options ();
1407
1408 /* Deallocate memory and clean up. */
1409 for (idx = 0; idx < num_fns; idx++)
1410 {
1411 fn_out_state =
1412 VEC_index (lto_out_decl_state_ptr, lto_function_decl_states, idx);
1413 lto_delete_out_decl_state (fn_out_state);
1414 }
1415 lto_symtab_encoder_delete (ob->decl_state->symtab_node_encoder);
1416 VEC_free (lto_out_decl_state_ptr, heap, lto_function_decl_states);
1417 lto_function_decl_states = NULL;
1418 destroy_output_block (ob);
1419 }
1420
1421
1422 struct ipa_opt_pass_d pass_ipa_lto_finish_out =
1423 {
1424 {
1425 IPA_PASS,
1426 "lto_decls_out", /* name */
1427 gate_lto_out, /* gate */
1428 NULL, /* execute */
1429 NULL, /* sub */
1430 NULL, /* next */
1431 0, /* static_pass_number */
1432 TV_IPA_LTO_DECL_OUT, /* tv_id */
1433 0, /* properties_required */
1434 0, /* properties_provided */
1435 0, /* properties_destroyed */
1436 0, /* todo_flags_start */
1437 0 /* todo_flags_finish */
1438 },
1439 NULL, /* generate_summary */
1440 produce_asm_for_decls, /* write_summary */
1441 NULL, /* read_summary */
1442 produce_asm_for_decls, /* write_optimization_summary */
1443 NULL, /* read_optimization_summary */
1444 NULL, /* stmt_fixup */
1445 0, /* TODOs */
1446 NULL, /* function_transform */
1447 NULL /* variable_transform */
1448 };