2010-04-14 Doug Kwan <dougkwan@google.com>
* arm.cc (Arm_output_section::fix_exidx_coverage): Mark object for local symbol recounting if we remove a section due to ICF. * gold.cc (queue_middle_gc_tasks): Create a dummy blocker if there are no regular objects in input.
This commit is contained in:
parent
7a8f71bfab
commit
04ceb17cc3
3 changed files with 20 additions and 1 deletions
|
@ -1,3 +1,10 @@
|
||||||
|
2010-04-14 Doug Kwan <dougkwan@google.com>
|
||||||
|
|
||||||
|
* arm.cc (Arm_output_section::fix_exidx_coverage): Mark object
|
||||||
|
for local symbol recounting if we remove a section due to ICF.
|
||||||
|
* gold.cc (queue_middle_gc_tasks): Create a dummy blocker if
|
||||||
|
there are no regular objects in input.
|
||||||
|
|
||||||
2010-04-13 Doug Kwan <dougkwan@google.com>
|
2010-04-13 Doug Kwan <dougkwan@google.com>
|
||||||
|
|
||||||
* arm.cc (Arm_input_section::set_final_data_size): Compute
|
* arm.cc (Arm_input_section::set_final_data_size): Compute
|
||||||
|
|
|
@ -5696,8 +5696,10 @@ Arm_output_section<big_endian>::fix_exidx_coverage(
|
||||||
unsigned int text_shndx = exidx_input_section->link();
|
unsigned int text_shndx = exidx_input_section->link();
|
||||||
gold_assert(symtab->is_section_folded(p->relobj(), text_shndx));
|
gold_assert(symtab->is_section_folded(p->relobj(), text_shndx));
|
||||||
|
|
||||||
// Remove this from link.
|
// Remove this from link. We also need to recount the
|
||||||
|
// local symbols.
|
||||||
p->relobj()->set_output_section(p->shndx(), NULL);
|
p->relobj()->set_output_section(p->shndx(), NULL);
|
||||||
|
arm_relobj->set_output_local_symbol_count_needs_update();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
10
gold/gold.cc
10
gold/gold.cc
|
@ -276,6 +276,16 @@ queue_middle_gc_tasks(const General_options& options,
|
||||||
next_blocker));
|
next_blocker));
|
||||||
this_blocker = next_blocker;
|
this_blocker = next_blocker;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If we are given only archives in input, we have no regular
|
||||||
|
// objects and THIS_BLOCKER is NULL here. Create a dummy
|
||||||
|
// blocker here so that we can run the middle tasks immediately.
|
||||||
|
if (this_blocker == NULL)
|
||||||
|
{
|
||||||
|
gold_assert(input_objects->number_of_relobjs() == 0);
|
||||||
|
this_blocker = new Task_token(true);
|
||||||
|
}
|
||||||
|
|
||||||
workqueue->queue(new Task_function(new Middle_runner(options,
|
workqueue->queue(new Task_function(new Middle_runner(options,
|
||||||
input_objects,
|
input_objects,
|
||||||
symtab,
|
symtab,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue