diff options
author | Alan Modra <amodra@gmail.com> | 2013-05-03 09:30:24 +0000 |
---|---|---|
committer | Alan Modra <amodra@gmail.com> | 2013-05-03 09:30:24 +0000 |
commit | f31ae5b84b1fb6d66e1b6c6be8efb201748b303b (patch) | |
tree | 580f5f6531c3bba2da1251cc214caa2b12c34a01 /gold/merge.cc | |
parent | 6945071a39a9d30786f23e9e5135492a8544a664 (diff) | |
download | binutils-gdb-f31ae5b84b1fb6d66e1b6c6be8efb201748b303b.tar.gz |
* merge.cc (Output_merge_string::do_add_input_section): Correct
scan for number of strings. Rename vars to avoid shadowing.
Include missing terminator in input_size_.
Diffstat (limited to 'gold/merge.cc')
-rw-r--r-- | gold/merge.cc | 23 |
1 files changed, 13 insertions, 10 deletions
diff --git a/gold/merge.cc b/gold/merge.cc index 2d014629356..f370c9cb9bc 100644 --- a/gold/merge.cc +++ b/gold/merge.cc @@ -505,17 +505,17 @@ bool Output_merge_string<Char_type>::do_add_input_section(Relobj* object, unsigned int shndx) { - section_size_type len; + section_size_type sec_len; bool is_new; const unsigned char* pdata = object->decompressed_section_contents(shndx, - &len, + &sec_len, &is_new); const Char_type* p = reinterpret_cast<const Char_type*>(pdata); - const Char_type* pend = p + len / sizeof(Char_type); + const Char_type* pend = p + sec_len / sizeof(Char_type); const Char_type* pend0 = pend; - if (len % sizeof(Char_type) != 0) + if (sec_len % sizeof(Char_type) != 0) { object->error(_("mergeable string section length not multiple of " "character size")); @@ -542,11 +542,14 @@ Output_merge_string<Char_type>::do_add_input_section(Relobj* object, // Count the number of non-null strings in the section and size the list. size_t count = 0; - for (const Char_type* pt = p, len = string_length(pt); - pt < pend0; - pt += len + 1) - if (len != 0) - ++count; + const Char_type* pt = p; + while (pt < pend0) + { + size_t len = string_length(pt); + if (len != 0) + ++count; + pt += len + 1; + } if (pend0 < pend) ++count; merged_strings.reserve(count + 1); @@ -595,7 +598,7 @@ Output_merge_string<Char_type>::do_add_input_section(Relobj* object, merged_strings.push_back(Merged_string(i, 0)); this->input_count_ += count; - this->input_size_ += len; + this->input_size_ += i; if (has_misaligned_strings) gold_warning(_("%s: section %s contains incorrectly aligned strings;" |