From ab8056e082820630f09bde048adbebbee05d6ddb Mon Sep 17 00:00:00 2001 From: Cary Coutant Date: Wed, 17 Nov 2010 01:53:22 +0000 Subject: [PATCH] * dwarf_reader.cc (Sized_dwarf_line_info::Sized_dwarf_line_info): Check for ".zdebug_line". --- gold/ChangeLog | 6 ++++++ gold/dwarf_reader.cc | 23 +++++++++++++---------- 2 files changed, 19 insertions(+), 10 deletions(-) diff --git a/gold/ChangeLog b/gold/ChangeLog index 2e3b87f..97e6e28 100644 --- a/gold/ChangeLog +++ b/gold/ChangeLog @@ -1,3 +1,9 @@ +2010-11-16 Cary Coutant + + PR gold/12220 + * dwarf_reader.cc (Sized_dwarf_line_info::Sized_dwarf_line_info): + Check for ".zdebug_line". + 2010-11-16 Doug Kwan Cary Coutant diff --git a/gold/dwarf_reader.cc b/gold/dwarf_reader.cc index c0188fb..e83e7fb 100644 --- a/gold/dwarf_reader.cc +++ b/gold/dwarf_reader.cc @@ -68,16 +68,19 @@ Sized_dwarf_line_info::Sized_dwarf_line_info(Object* object, directories_(), files_(), current_header_index_(-1) { unsigned int debug_shndx; - for (debug_shndx = 0; debug_shndx < object->shnum(); ++debug_shndx) - // FIXME: do this more efficiently: section_name() isn't super-fast - if (object->section_name(debug_shndx) == ".debug_line") - { - section_size_type buffer_size; - this->buffer_ = object->section_contents(debug_shndx, &buffer_size, - false); - this->buffer_end_ = this->buffer_ + buffer_size; - break; - } + for (debug_shndx = 1; debug_shndx < object->shnum(); ++debug_shndx) + { + // FIXME: do this more efficiently: section_name() isn't super-fast + std::string name = object->section_name(debug_shndx); + if (name == ".debug_line" || name == ".zdebug_line") + { + section_size_type buffer_size; + this->buffer_ = object->section_contents(debug_shndx, &buffer_size, + false); + this->buffer_end_ = this->buffer_ + buffer_size; + break; + } + } if (this->buffer_ == NULL) return; -- 2.7.4