GCC Middle and Back End API Reference
lto-streamer.cc File Reference
#include "config.h"
#include "system.h"
#include "coretypes.h"
#include "backend.h"
#include "tree.h"
#include "gimple.h"
#include "tree-streamer.h"
#include "cgraph.h"
#include "lto-streamer.h"
#include "toplev.h"
#include "lto-section-names.h"
Include dependency graph for lto-streamer.cc:

Functions

const char * lto_tag_name (enum LTO_tags tag)
 
char * lto_get_section_name (int section_type, const char *name, int node_order, struct lto_file_decl_data *f)
 
void print_lto_report (const char *s)
 
void lto_streamer_init (void)
 
bool gate_lto_out (void)
 
void lto_check_version (int major, int minor, const char *file_name)
 
void lto_streamer_hooks_init (void)
 

Variables

struct lto_stats_d lto_stats
 
const char * section_name_prefix = LTO_SECTION_NAME_PREFIX
 
bool lto_stream_offload_p
 
FILE * streamer_dump_file
 

Function Documentation

◆ gate_lto_out()

bool gate_lto_out ( void )
Gate function for all LTO streaming passes.   

References seen_error().

◆ lto_check_version()

void lto_check_version ( int major,
int minor,
const char * file_name )
Check that the version MAJOR.MINOR is the correct version number.   

References fatal_error(), input_location, LTO_major_version, and LTO_minor_version.

◆ lto_get_section_name()

char * lto_get_section_name ( int section_type,
const char * name,
int node_order,
struct lto_file_decl_data * f )
Get a section name for a particular type or name.  The NAME field
is only used if SECTION_TYPE is LTO_section_function_body. For all
others it is ignored.  The callee of this function is responsible
to free the returned name.   

References free(), gcc_assert, get_random_seed(), HOST_WIDE_INT_PRINT_HEX_PURE, lto_file_decl_data::id, internal_error(), LTO_N_SECTION_TYPES, LTO_section_function_body, lto_section_name, LTO_section_opts, NULL, and section_name_prefix.

Referenced by copy_function_or_variable(), lto_destroy_simple_output_block(), lto_output_toplevel_asms(), lto_write_mode_table(), lto_write_options(), produce_asm(), produce_asm_for_decls(), produce_lto_section(), produce_symtab(), and produce_symtab_extension().

◆ lto_streamer_hooks_init()

◆ lto_streamer_init()

void lto_streamer_init ( void )
Initialization common to the LTO reader and writer.   

References streamer_check_handled_ts_structures().

Referenced by lto_output(), and lto_reader_init().

◆ lto_tag_name()

◆ print_lto_report()

Variable Documentation

◆ lto_stats

struct lto_stats_d lto_stats
Miscellaneous utilities for GIMPLE streaming.  Things that are used
   in both input and output are here.

   Copyright (C) 2009-2024 Free Software Foundation, Inc.
   Contributed by Doug Kwan <dougkwan@google.com>

This file is part of GCC.

GCC is free software; you can redistribute it and/or modify it under
the terms of the GNU General Public License as published by the Free
Software Foundation; either version 3, or (at your option) any later
version.

GCC is distributed in the hope that it will be useful, but WITHOUT ANY
WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
for more details.

You should have received a copy of the GNU General Public License
along with GCC; see the file COPYING3.  If not see
<http://www.gnu.org/licenses/>.   
Statistics gathered during LTO, WPA and LTRANS.   

Referenced by varpool_node::get_constructor(), cgraph_node::get_untransformed_body(), lto_compress_block(), lto_compression_zlib(), lto_get_section_data(), lto_output_tree(), lto_uncompress_block(), lto_uncompression_zlib(), print_lto_report(), and streamer_write_tree_body().

◆ lto_stream_offload_p

◆ section_name_prefix

const char* section_name_prefix = LTO_SECTION_NAME_PREFIX
Can be either OFFLOAD_SECTION_NAME_PREFIX when we stream IR for offload
compiler, or LTO_SECTION_NAME_PREFIX for LTO case.   

Referenced by ipa_passes(), and lto_get_section_name().

◆ streamer_dump_file