This is the mail archive of the
binutils@sourceware.org
mailing list for the binutils project.
Re: [gold patch] Incremental 8/18: Initial support for incremental update
- From: Ian Lance Taylor <iant at google dot com>
- To: Cary Coutant <ccoutant at google dot com>
- Cc: Binutils <binutils at sourceware dot org>
- Date: Mon, 11 Apr 2011 15:12:27 -0700
- Subject: Re: [gold patch] Incremental 8/18: Initial support for incremental update
- References: <BANLkTik8CwBzM1e-7kCLnpAhJzrP3EKbDA@mail.gmail.com> <BANLkTi=qFHPn85qb9q5Vj=Jq8d0A7--VmA@mail.gmail.com> <BANLkTimst4dBqGgTDQu=cx4QgE+_WH3s3g@mail.gmail.com>
Cary Coutant <ccoutant@google.com> writes:
> * archive.cc (Archive::include_member): Adjust call to
> report_object.
> (Add_archive_symbols::run): Track argument serial numbers.
> (Lib_group::include_member): Likewise.
> (Add_lib_group_symbols::run): Adjust call to report_archive_begin.
> * archive.h (Incremental_archive_entry::Archive_member):
> Initialize arg_serial_.
> (Archive_member::arg_serial_): New data member.
> * dynobj.cc (Dynobj::Dynobj): Allow input_file_ to be NULL.
> (Sized_dynobj::do_add_symbols): Track symbols when doing an
> incremental link.
> (Sized_dynobj::do_for_all_local_got_entries): New function.
> * dynobj.h: (Sized_dynobj::do_for_all_local_got_entries): New
> function.
> * fileread.cc (get_mtime): New function.
> * fileread.h (get_mtime): New function.
> * gold.cc (queue_initial_tasks): Check for incremental update.
> (process_incremental_input): New function.
> (queue_middle_tasks): Don't force valid target for incremental
> update.
> * incremental-dump.cc (find_input_containing_global): Adjust
> size of symbol info entry.
> (dump_incremental_inputs): Dump argument serial number and
> in_system_directory flag; bias shndx by 1; print symbol names
> when dumping per-file symbol lists; use new symbol info readers.
> * incremental.cc
> (Output_section_incremental_inputs:update_data_size): New function.
> (Sized_incremental_binary::setup_readers): Setup input readers
> for each input file; build maps for files added from libraries
> and scripts.
> (Sized_incremental_binary::check_input_args): New function.
> (Sized_incremental_binary::do_check_inputs): Build map of argument
> serial numbers to input arguments.
> (Sized_incremental_binary::do_file_has_changed): Rename
> do_file_is_unchanged to this; compare file modification times.
> (Sized_incremental_binary::do_init_layout): New function.
> (Sized_incremental_binary::do_reserve_layout): New function.
> (Sized_incremental_binary::do_get_input_reader): Remove.
> (Sized_incremental_binary::get_symtab_view): New function.
> (Incremental_checker::can_incrementally_link_output_file): Remove.
> (Incremental_inputs::report_command_line): Exclude --debug options.
> (Incremental_inputs::report_archive_begin): Add parameter; track
> argument serial numbers; don't put input file entry for archive
> before archive members.
> (Incremental_inputs::report_archive_end): Put input file entry
> for archive after archive members.
> (Incremental_inputs::report_object): Add parameter; track argument
> serial numbers and in_system_directory flag.
> (Incremental_inputs::report_script): Add parameter; track argument
> serial numbers.
> (Output_section_incremental_inputs::set_final_data_size): Adjust
> size of symbol info entry; check for forwarding symbols.
> (Output_section_incremental_inputs::write_input_files): Write
> in_system_directory flag and argument serial number.
> (Output_section_incremental_inputs::write_info_blocks): Map section
> indices between incremental info and original input file; store
> input section index for each symbol.
> (class Local_got_offset_visitor): Derive from Got_offset_list::Visitor;
> change operator() to visit().
> (class Global_got_offset_visitor): Likewise.
> (class Global_symbol_visitor_got_plt):
> (Output_section_incremental_inputs::write_got_plt): Use new visitor
> classes.
> (Sized_incr_relobj::Sized_incr_relobj): New constructor.
> (Sized_incr_relobj::do_read_symbols): New function.
> (Sized_incr_relobj::do_layout): New function.
> (Sized_incr_relobj::do_layout_deferred_sections): New function.
> (Sized_incr_relobj::do_add_symbols): New function.
> (Sized_incr_relobj::do_should_include_member): New function.
> (Sized_incr_relobj::do_for_all_global_symbols): New function.
> (Sized_incr_relobj::do_for_all_local_got_entries): New function.
> (Sized_incr_relobj::do_section_size): New function.
> (Sized_incr_relobj::do_section_name): New function.
> (Sized_incr_relobj::do_section_contents): New function.
> (Sized_incr_relobj::do_section_flags): New function.
> (Sized_incr_relobj::do_section_entsize): New function.
> (Sized_incr_relobj::do_section_address): New function.
> (Sized_incr_relobj::do_section_type): New function.
> (Sized_incr_relobj::do_section_link): New function.
> (Sized_incr_relobj::do_section_info): New function.
> (Sized_incr_relobj::do_section_addralign): New function.
> (Sized_incr_relobj::do_initialize_xindex): New function.
> (Sized_incr_relobj::do_get_global_symbol_counts): New function.
> (Sized_incr_relobj::do_read_relocs): New function.
> (Sized_incr_relobj::do_gc_process_relocs): New function.
> (Sized_incr_relobj::do_scan_relocs): New function.
> (Sized_incr_relobj::do_count_local_symbols): New function.
> (Sized_incr_relobj::do_finalize_local_symbols): New function.
> (Sized_incr_relobj::do_set_local_dynsym_indexes): New function.
> (Sized_incr_relobj::do_set_local_dynsym_offset): New function.
> (Sized_incr_relobj::do_relocate): New function.
> (Sized_incr_relobj::do_set_section_offset): New function.
> (Sized_incr_dynobj::Sized_incr_dynobj): New function.
> (Sized_incr_dynobj::do_read_symbols): New function.
> (Sized_incr_dynobj::do_layout): New function.
> (Sized_incr_dynobj::do_add_symbols): New function.
> (Sized_incr_dynobj::do_should_include_member): New function.
> (Sized_incr_dynobj::do_for_all_global_symbols): New function.
> (Sized_incr_dynobj::do_for_all_local_got_entries): New function.
> (Sized_incr_dynobj::do_section_size): New function.
> (Sized_incr_dynobj::do_section_name): New function.
> (Sized_incr_dynobj::do_section_contents): New function.
> (Sized_incr_dynobj::do_section_flags): New function.
> (Sized_incr_dynobj::do_section_entsize): New function.
> (Sized_incr_dynobj::do_section_address): New function.
> (Sized_incr_dynobj::do_section_type): New function.
> (Sized_incr_dynobj::do_section_link): New function.
> (Sized_incr_dynobj::do_section_info): New function.
> (Sized_incr_dynobj::do_section_addralign): New function.
> (Sized_incr_dynobj::do_initialize_xindex): New function.
> (Sized_incr_dynobj::do_get_global_symbol_counts): New function.
> (make_sized_incremental_object): New function.
> (Incremental_library::copy_unused_symbols): New function.
> (Incremental_library::do_for_all_unused_symbols): New function.
> * incremental.h (enum Incremental_input_flags): New type.
> (class Incremental_checker): Remove.
> (Incremental_input_entry::Incremental_input_entry): Add argument
> serial number.
> (Incremental_input_entry::arg_serial): New function.
> (Incremental_input_entry::set_is_in_system_directory): New function.
> (Incremental_input_entry::is_in_system_directory): New function.
> (Incremental_input_entry::arg_serial_): New data member.
> (Incremental_input_entry::is_in_system_directory_): New data member.
> (class Script_info): Move here from script.h.
> (Script_info::Script_info): Add filename parameter.
> (Script_info::filename): New function.
> (Script_info::filename_): New data member.
> (Incremental_script_entry::Incremental_script_entry): Add argument
> serial number.
> (Incremental_object_entry::Incremental_object_entry): Likewise.
> (Incremental_object_entry::add_input_section): Build list of input
> sections with map to original shndx.
> (Incremental_object_entry::get_input_section_index): New function.
> (Incremental_object_entry::shndx_): New data member.
> (Incremental_object_entry::name_key_): Rename; adjust all refs.
> (Incremental_object_entry::sh_size_): Rename; adjust all refs.
> (Incremental_archive_entry::Incremental_archive_entry): Add argument
> serial number.
> (Incremental_inputs::report_archive_begin): Likewise.
> (Incremental_inputs::report_object): Likewise.
> (Incremental_inputs::report_script): Likewise.
> (class Incremental_global_symbol_reader): New class.
> (Incremental_input_entry_reader::Incremental_input_entry_reader): Read
> and store flags and input file type.
> (Incremental_input_entry_reader::arg_serial): New function.
> (Incremental_input_entry_reader::type): Extract type from flags.
> (Incremental_input_entry_reader::is_in_system_directory): New function.
> (Incremental_input_entry_reader::get_input_section_count): Call
> accessor function for type.
> (Incremental_input_entry_reader::get_symbol_offset): Call accessor
> function for type; adjust size of global symbol entry.
> (Incremental_input_entry_reader::get_global_symbol_count): Call
> accessor function for type.
> (Incremental_input_entry_reader::get_object_count): Likewise.
> (Incremental_input_entry_reader::get_object_offset): Likewise.
> (Incremental_input_entry_reader::get_member_count): Likewise.
> (Incremental_input_entry_reader::get_unused_symbol_count): Likewise.
> (Incremental_input_entry_reader::get_member_offset): Likewise.
> (Incremental_input_entry_reader::get_unused_symbol): Likewise.
> (Incremental_input_entry_reader::Global_symbol_info): Remove.
> (Incremental_input_entry_reader::get_global_symbol_info): Remove.
> (Incremental_input_entry_reader::get_global_symbol_reader): New
> function.
> (Incremental_input_entry_reader::get_output_symbol_index): New
> function.
> (Incremental_input_entry_reader::type_): Remove.
> (Incremental_input_entry_reader::flags_): New data member.
> (Incremental_inputs_reader::input_file_offset): New function.
> (Incremental_inputs_reader::input_file_index): New function.
> (Incremental_inputs_reader::input_file): Call input_file_offset.
> (Incremental_inputs_reader::input_file_at_offset): New function.
> (Incremental_relocs_reader::get_r_type): Reformat.
> (Incremental_relocs_reader::get_r_shndx): Reformat.
> (Incremental_relocs_reader::get_r_offset): Reformat.
> (Incremental_relocs_reader::data): New function.
> (Incremental_binary::Incremental_binary): Initialize new data members.
> (Incremental_binary::check_inputs): Add cmdline parameter.
> (Incremental_binary::file_is_unchanged): Remove.
> (Input_reader::arg_serial): New function.
> (Input_reader::get_unused_symbol_count): New function.
> (Input_reader::get_unused_symbol): New function.
> (Input_reader::do_arg_serial): New function.
> (Input_reader::do_get_unused_symbol_count): New function.
> (Input_reader::do_get_unused_symbol): New function.
> (Incremental_binary::input_file_count): New function.
> (Incremental_binary::get_input_reader): Change signature to use
> index instead of filename.
> (Incremental_binary::file_has_changed): New function.
> (Incremental_binary::get_input_argument): New function.
> (Incremental_binary::get_library): New function.
> (Incremental_binary::get_script_info): New function.
> (Incremental_binary::init_layout): New function.
> (Incremental_binary::reserve_layout): New function.
> (Incremental_binary::output_file): New function.
> (Incremental_binary::do_check_inputs): New function.
> (Incremental_binary::do_file_is_unchanged): Remove.
> (Incremental_binary::do_file_has_changed): New function.
> (Incremental_binary::do_init_layout): New function.
> (Incremental_binary::do_reserve_layout): New function.
> (Incremental_binary::do_input_file_count): New function.
> (Incremental_binary::do_get_input_reader): Change signature.
> (Incremental_binary::input_args_map_): New data member.
> (Incremental_binary::library_map_): New data member.
> (Incremental_binary::script_map_): New data member.
> (Sized_incremental_binary::Sized_incremental_binary): Initialize
> new data members.
> (Sized_incremental_binary::output_section): New function.
> (Sized_incremental_binary::inputs_reader): Add const.
> (Sized_incremental_binary::symtab_reader): Add const.
> (Sized_incremental_binary::relocs_reader): Add const.
> (Sized_incremental_binary::got_plt_reader): Add const.
> (Sized_incremental_binary::get_symtab_view): New function.
> (Sized_incremental_binary::Inputs_reader): New typedef.
> (Sized_incremental_binary::Input_entry_reader): New typedef.
> (Sized_incremental_binary::do_check_inputs): Add cmdline parameter.
> (Sized_incremental_binary::do_file_is_unchanged): Remove.
> (Sized_incremental_binary::do_file_has_changed): New function.
> (Sized_incremental_binary::do_init_layout): New function.
> (Sized_incremental_binary::do_reserve_layout): New function.
> (Sized_input_reader::Inputs_reader): Remove.
> (Sized_input_reader::Input_entry_reader): Remove.
> (Sized_input_reader::do_arg_serial): New function.
> (Sized_input_reader::do_get_unused_symbol_count): New function.
> (Sized_input_reader::do_get_unused_symbol): New function.
> (Sized_incremental_binary::do_input_file_count): New function.
> (Sized_incremental_binary::do_get_input_reader): Change signature;
> use index instead of filename.
> (Sized_incremental_binary::section_map_): New data member.
> (Sized_incremental_binary::input_entry_readers_): New data member.
> (class Sized_incr_relobj): New class.
> (class Sized_incr_dynobj): New class.
> (make_sized_incremental_object): New function.
> (class Incremental_library): New class.
> * layout.cc (Free_list::num_lists): New static data member.
> (Free_list::num_nodes): New static data member.
> (Free_list::num_removes): New static data member.
> (Free_list::num_remove_visits): New static data member.
> (Free_list::num_allocates): New static data member.
> (Free_list::num_allocate_visits): New static data member.
> (Free_list::init): New function.
> (Free_list::remove): New function.
> (Free_list::allocate): New function.
> (Free_list::dump): New function.
> (Free_list::print_stats): New function.
> (Layout_task_runner::run): Resize output file for incremental updates.
> (Layout::Layout): Initialize new data members.
> (Layout::set_incremental_base): New function.
> (Layout::init_fixed_output_section): New function.
> (Layout::layout_eh_frame): Do not build .eh_frame_hdr section for
> incremental updates.
> (Layout::create_gold_note): Do not create gold note section for
> incremental updates.
> (Layout::set_segment_offsets): Do not recalculate RELRO alignment
> for incremental updates.
> (Layout::set_section_offsets): For incremental updates, allocate space
> from free list.
> (Layout::create_symtab_sections): Layout with offsets relative to
> start of section; for incremental updates, allocate space from free
> list.
> (Layout::create_shdrs): For incremental updates, allocate space from
> free list.
> (Layout::finish_dynamic_section): For incremental updates, do not
> check --as-needed (fixed in subsequent patch).
> * layout.h (class Free_list): New class.
> (Layout::set_incremental_base): New function.
> (Layout::incremental_base): New function.
> (Layout::init_fixed_output_section): New function.
> (Layout::allocate): New function.
> (Layout::incremental_base_): New data member.
> (Layout::free_list_): New data member.
> * main.cc (main): Print Free_list statistics.
> * object.cc (Relobj::finalize_incremental_relocs): Add
> clear_counts parameter; clear counts only when clear_counts is set.
> (Sized_relobj::Sized_relobj): Initialize new base class.
> (Sized_relobj::do_layout): Don't report special sections.
> (Sized_relobj::do_for_all_local_got_entries): New function.
> (Sized_relobj::write_local_symbols): Add symtab_off parameter; add
> symtab_off to all symbol table offsets.
> (Sized_relobj::do_get_global_symbol_counts): Add typename keyword.
> * object.h (class Got_offset_list): Move to top of file.
> (Object::Object): Allow case where input_file == NULL.
> (Object::~Object): Likewise.
> (Object::input_file): Assert that input_file != NULL.
> (Object::lock): Allow case where input_file == NULL.
> (Object::unlock): Likewise.
> (Object::is_locked): Likewise.
> (Object::token): Likewise.
> (Object::release): Likewise.
> (Object::is_incremental): New function.
> (Object::get_mtime): New function.
> (Object::for_all_local_got_entries): New function.
> (Object::clear_view_cache_marks): Allow case where input_file == NULL.
> (Object::set_is_in_system_directory): New function.
> (Object::is_in_system_directory): New function.
> (Object::do_is_incremental): New function.
> (Object::do_get_mtime): New function.
> (Object::do_for_all_local_got_entries): New function.
> (Object::is_in_system_directory_): New data member.
> (Relobj::finalize_incremental_relocs): Add clear_counts parameter.
> (class Sized_relobj_base): New class.
> (class Sized_relobj): Derive from Sized_relobj_base.
> (class Sized_relobj::Symbols): Redeclare from base class.
> (class Sized_relobj::local_got_offset_list): Remove.
> (class Sized_relobj::Output_sections): Redeclare from base class.
> (class Sized_relobj::do_for_all_local_got_entries): New function.
> (class Sized_relobj::write_local_symbols): Add offset parameter.
> (class Sized_relobj::local_symbol_offset_): Update comment.
> (class Sized_relobj::local_dynsym_offset_): Update comment.
> * options.cc (Input_arguments::add_file): Remove const.
> * options.h (Input_file_argument::Input_file_argument):
> Initialize arg_serial_ (all constructors).
> (Input_file_argument::set_arg_serial): New function.
> (Input_file_argument::arg_serial): New function.
> (Input_file_argument::arg_serial_): New data member.
> (Input_arguments::Input_arguments): Initialize file_count_.
> (Input_arguments::add_file): Remove const.
> (Input_arguments::number_of_input_files): New function.
> (Input_arguments::file_count_): New data member.
> (Command_line::number_of_input_files): Call
> Input_arguments::number_of_input_files.
> * output.cc (Output_segment_headers::Output_segment_headers):
> Set current size.
> (Output_section::Input_section::current_data_size): New function.
> (Output_section::Output_section): Initialize new data members.
> (Output_section::add_input_section): Don't do merge sections for
> an incremental link; allocate space from free list for an
> incremental update.
> (Output_section::add_output_section_data): Allocate space from
> free list for an incremental update.
> (Output_section::update_data_size): New function.
> (Output_section::set_fixed_layout): New function.
> (Output_section::reserve): New function.
> (Output_segment::set_section_addresses): Remove const.
> (Output_segment::set_section_list_addresses): Remove const; allocate
> space from free list for an incremental update.
> (Output_segment::set_offset): Adjust size of RELRO segment for an
> incremental update.
> * output.h (Output_data::current_data_size): Move here from
> child classes.
> (Output_data::pre_finalize_data_size): New function.
> (Output_data::update_data_size): New function.
> (Output_section_headers::update_data_size): new function.
> (Output_section_data_build::current_data_size): Move to Output_data.
> (Output_data_strtab::update_data_size): New function.
> (Output_section::current_data_size): Move to Output_data.
> (Output_section::set_fixed_layout): New function.
> (Output_section::has_fixed_layout): New function.
> (Output_section::reserve): New function.
> (Output_section::update_data_size): New function.
> (Output_section::has_fixed_layout_): New data member.
> (Output_section::free_list_): New data member.
> (Output_segment::set_section_addresses): Remove const.
> (Output_segment::set_section_list_addresses): Remove const.
> * plugin.cc (Sized_pluginobj::do_for_all_local_got_entries):
> New function.
> * plugin.h (Sized_pluginobj::do_for_all_local_got_entries):
> New function.
> * readsyms.cc (Read_symbols::do_read_symbols): Add library
> parameter when calling Add_symbols constructor; store argument
> serial number for members of a lib group.
> (Add_symbols::locks): Allow case where token == NULL.
> (Add_symbols::run): Report libraries denoted by --start-lib/--end-lib.
> (Read_member::~Read_member): New function.
> (Read_member::is_runnable): New function.
> (Read_member::locks): New function.
> (Read_member::run): New function.
> (Check_script::~Check_script): New function.
> (Check_script::is_runnable): New function.
> (Check_script::locks): New function.
> (Check_script::run): New function.
> (Check_library::~Check_library): New function.
> (Check_library::is_runnable): New function.
> (Check_library::locks): New function.
> (Check_library::run): New function.
> * readsyms.h (Add_symbols::Add_symbols): Add library parameter.
> (Add_symbols::library_): New data member.
> (class Read_member): New class.
> (class Check_script): New class.
> (class Check_library): New class.
> * reloc.cc (Read_relocs::is_runnable): Allow case where
> token == NULL.
> (Read_relocs::locks): Likewise.
> (Scan_relocs::locks): Likewise.
> (Relocate_task::locks): Likewise.
> (Sized_relobj::do_scan_relocs): Tell finalize_incremental_relocs
> to clear counters.
> (Sized_relobj::incremental_relocs_scan): Fix comment.
> (Sized_relobj::do_relocate): Pass output file offset to
> write_local_symbols.
> (Sized_relobj::incremental_relocs_write_reltype): Use reloc_size
> from class declaration.
> * script.cc (read_input_script): Allocate Script_info; pass
> argument serial number to report_script.
> * script.h (class Script_info): Move to incremental.h.
> * symtab.cc (Symbol_table::add_from_incrobj): New function.
> * symtab.h (Symbol_table::add_from_incrobj): New function.
> (Symbol_table::set_file_offset): New function.
> + if (options.has_plugins())
> + gold_error(_("incremental linking is incompatible with --plugin"));
Will this be possible at some future date?
> + // Incremental update link. Process the list of input files
> + // stored in the base file, and queue a task for each file:
> + // a Read_symbols task for a changed file, and an Add_symbols task
> + // for an unchanged file. We need to mark all the space used by
> + // unchanged files before we can start any tasks running.
> + std::list<Task*> tasks;
Add tasks.reserve(input_file_count);
> +// Process an incremental input file: if it is unchanged from the previous
> +// link, return a task to add its symbols from the base file's incremental
> +// info; if it has changed, return a normal Read_symbols task. We create a
> +// task for every input file, if only to report the file for rebuilding the
> +// incremental info.
> +
> +Task*
> +process_incremental_input(Incremental_binary* ibase,
> + unsigned int input_file_index,
> + Input_objects* input_objects,
> + Symbol_table* symtab,
> + Layout* layout,
> + Dirsearch* search_path,
> + Mapfile* mapfile,
> + Task_token* this_blocker,
> + Task_token* next_blocker)
> +{
This function should be static.
> + gold_debug(DEBUG_INCREMENTAL, "Incremental object: %s, type %d",
> + input_reader->filename(), input_type);
s/ / /
> + if (input_type == INCREMENTAL_INPUT_ARCHIVE)
> + {
> + Incremental_library* lib = ibase->get_library(input_file_index);
> + gold_assert(lib != NULL);
> + if (lib->filename() == "<group>"
> + || !ibase->file_has_changed(input_file_index))
Hmmm. For extreme cleanliness, suppose we change "<group>" to "/group/"
or some other name containing a '/', so that we know for sure that there
is no input file with that name.
> @@ -396,7 +586,8 @@ queue_middle_tasks(const General_options& options,
> // generate an empty file. Existing builds depend on being able to
> // pass an empty archive to the linker and get an empty object file
> // out. In order to do this we need to use a default target.
> - if (input_objects->number_of_input_objects() == 0)
> + if (input_objects->number_of_input_objects() == 0
> + && layout->incremental_base() == NULL)
> parameters_force_valid_target();
Why this change?
> +// Allocate an incremental object of the appropriate size and endianness.
> +Object*
> +make_sized_incremental_object(
> + Incremental_binary* base,
> + unsigned int input_file_index,
> + Incremental_input_type input_type,
> + const Incremental_binary::Input_reader* input_reader);
Add "extern".
> @@ -869,7 +1086,9 @@ Layout::layout_eh_frame(Sized_relobj<size, big_endian>* object,
> this->eh_frame_section_ = os;
> this->eh_frame_data_ = new Eh_frame();
>
> - if (parameters->options().eh_frame_hdr())
> + // For incremental linking, we do not optimize .eh_frame sections
> + // or create a .eh_frame_hdr section.
> + if (parameters->options().eh_frame_hdr() && !parameters->incremental())
> {
> Output_section* hdr_os =
> this->choose_output_section(NULL, ".eh_frame_hdr",
> @@ -901,14 +1120,15 @@ Layout::layout_eh_frame(Sized_relobj<size, big_endian>* object,
>
> gold_assert(this->eh_frame_section_ == os);
>
> - if (this->eh_frame_data_->add_ehframe_input_section(object,
> - symbols,
> - symbols_size,
> - symbol_names,
> - symbol_names_size,
> - shndx,
> - reloc_shndx,
> - reloc_type))
> + if (!parameters->incremental()
> + && this->eh_frame_data_->add_ehframe_input_section(object,
> + symbols,
> + symbols_size,
> + symbol_names,
> + symbol_names_size,
> + shndx,
> + reloc_shndx,
> + reloc_type))
> {
> os->update_flags_for_input_section(shdr.get_sh_flags());
>
Where do these things happen when doing an incremental link?
This is OK with those changes.
Thanks.
Ian