diff options
author | Ian Lance Taylor <ian@airs.com> | 2010-03-06 02:34:13 +0000 |
---|---|---|
committer | Ian Lance Taylor <ian@airs.com> | 2010-03-06 02:34:13 +0000 |
commit | 9e9e071b2e0501d3413f48030f0f0edb0131305a (patch) | |
tree | b397dca9925ab979588440c4f91539ae0b9ec3b6 /gold/output.cc | |
parent | bce522a2604ef89eceb4c7b7987a30e3d6c58825 (diff) | |
download | gdb-9e9e071b2e0501d3413f48030f0f0edb0131305a.zip gdb-9e9e071b2e0501d3413f48030f0f0edb0131305a.tar.gz gdb-9e9e071b2e0501d3413f48030f0f0edb0131305a.tar.bz2 |
* options.h (class General_options): Add --spare-dynamic-tags.
* output.cc (Output_data_dynamic::set_final_data_size): Implement
--spare-dynamic-tags.
Diffstat (limited to 'gold/output.cc')
-rw-r--r-- | gold/output.cc | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/gold/output.cc b/gold/output.cc index d49f08b..0627cbe 100644 --- a/gold/output.cc +++ b/gold/output.cc @@ -1622,9 +1622,13 @@ Output_data_dynamic::set_final_data_size() { // Add the terminating entry if it hasn't been added. // Because of relaxation, we can run this multiple times. - if (this->entries_.empty() - || this->entries_.rbegin()->tag() != elfcpp::DT_NULL) - this->add_constant(elfcpp::DT_NULL, 0); + if (this->entries_.empty() || this->entries_.back().tag() != elfcpp::DT_NULL) + { + int extra = parameters->options().spare_dynamic_tags(); + for (int i = 0; i < extra; ++i) + this->add_constant(elfcpp::DT_NULL, 0); + this->add_constant(elfcpp::DT_NULL, 0); + } int dyn_size; if (parameters->target().get_size() == 32) |