Even when stripping all symbols, we need to write out the dynamic

symbol table.
This commit is contained in:
Ian Lance Taylor 2008-02-07 04:35:41 +00:00
parent 88dd47ac00
commit 5fe2a0f55b
2 changed files with 13 additions and 12 deletions

View file

@ -307,16 +307,13 @@ queue_final_tasks(const General_options& options,
Task_token* final_blocker = new Task_token(true);
// Queue a task to write out the symbol table.
if (!options.strip_all())
{
final_blocker->add_blocker();
workqueue->queue(new Write_symbols_task(symtab,
input_objects,
layout->sympool(),
layout->dynpool(),
of,
final_blocker));
}
final_blocker->add_blocker();
workqueue->queue(new Write_symbols_task(symtab,
input_objects,
layout->sympool(),
layout->dynpool(),
of,
final_blocker));
// Queue a task to write out the output sections.
output_sections_blocker->add_blocker();

View file

@ -1827,14 +1827,18 @@ Symbol_table::sized_write_globals(const Input_objects* input_objects,
const unsigned int output_count = this->output_count_;
const section_size_type oview_size = output_count * sym_size;
const unsigned int first_global_index = this->first_global_index_;
unsigned char* const psyms = of->get_output_view(this->offset_, oview_size);
unsigned char* psyms;
if (this->offset_ == 0 || output_count == 0)
psyms = NULL;
else
psyms = of->get_output_view(this->offset_, oview_size);
const unsigned int dynamic_count = this->dynamic_count_;
const section_size_type dynamic_size = dynamic_count * sym_size;
const unsigned int first_dynamic_global_index =
this->first_dynamic_global_index_;
unsigned char* dynamic_view;
if (this->dynamic_offset_ == 0)
if (this->dynamic_offset_ == 0 || dynamic_count == 0)
dynamic_view = NULL;
else
dynamic_view = of->get_output_view(this->dynamic_offset_, dynamic_size);