aboutsummaryrefslogtreecommitdiff
path: root/gold/dwarf_reader.cc
diff options
context:
space:
mode:
authorCary Coutant <ccoutant@google.com>2014-06-09 14:55:02 -0700
committerCary Coutant <ccoutant@google.com>2014-06-09 14:55:02 -0700
commit9baa787b14d9a92067ecb1731407c5abe37d7c3c (patch)
treed4d875ec5c7edc8025a556d34a33cb151323120b /gold/dwarf_reader.cc
parent8f89af0abe40c9231f42ad3193a45e8fccb35720 (diff)
downloadfsf-binutils-gdb-9baa787b14d9a92067ecb1731407c5abe37d7c3c.zip
fsf-binutils-gdb-9baa787b14d9a92067ecb1731407c5abe37d7c3c.tar.gz
fsf-binutils-gdb-9baa787b14d9a92067ecb1731407c5abe37d7c3c.tar.bz2
Add check to keep from segfaulting on a corrupt .debug_pubnames section.
gold/ * dwarf_reader.cc (Dwarf_pubnames_table::read_header): Check that unit_length is within section bounds.
Diffstat (limited to 'gold/dwarf_reader.cc')
-rw-r--r--gold/dwarf_reader.cc6
1 files changed, 6 insertions, 0 deletions
diff --git a/gold/dwarf_reader.cc b/gold/dwarf_reader.cc
index df14bd5..30aea10 100644
--- a/gold/dwarf_reader.cc
+++ b/gold/dwarf_reader.cc
@@ -580,6 +580,12 @@ Dwarf_pubnames_table::read_header(off_t offset)
}
this->end_of_table_ = pinfo + unit_length;
+ // If unit_length is too big, maybe we should reject the whole table,
+ // but in cases we know about, it seems OK to assume that the table
+ // is valid through the actual end of the section.
+ if (this->end_of_table_ > this->buffer_end_)
+ this->end_of_table_ = this->buffer_end_;
+
// Check the version.
unsigned int version = this->dwinfo_->read_from_pointer<16>(pinfo);
pinfo += 2;