aboutsummaryrefslogtreecommitdiff
path: root/binutils/dwarf.c
diff options
context:
space:
mode:
authorH.J. Lu <hjl.tools@gmail.com>2015-01-12 13:34:24 -0800
committerH.J. Lu <hjl.tools@gmail.com>2015-01-12 13:34:24 -0800
commita0a3b04c61d7aa79e265224540930cf4057acfb3 (patch)
tree77c887f8143781e16b85dccd9f41762810404840 /binutils/dwarf.c
parent1306a7421c764d1f5e2a08afdb9b5818662c9e9c (diff)
downloadgdb-a0a3b04c61d7aa79e265224540930cf4057acfb3.zip
gdb-a0a3b04c61d7aa79e265224540930cf4057acfb3.tar.gz
gdb-a0a3b04c61d7aa79e265224540930cf4057acfb3.tar.bz2
Properly check abbrev size
abbrev_base is independent of abbrev_size. We should use abbrev_base + abbrev_size to check abbrev section size. * dwarf.c (process_debug_info): Properly check abbrev size.
Diffstat (limited to 'binutils/dwarf.c')
-rw-r--r--binutils/dwarf.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/binutils/dwarf.c b/binutils/dwarf.c
index a7310c8..d82c89c 100644
--- a/binutils/dwarf.c
+++ b/binutils/dwarf.c
@@ -2467,10 +2467,11 @@ process_debug_info (struct dwarf_section *section,
(unsigned long) compunit.cu_abbrev_offset,
(unsigned long) abbrev_size);
/* PR 17531: file:4bcd9ce9. */
- else if (abbrev_base >= abbrev_size)
- warn (_("Debug info is corrupted, abbrev base (%lx) is larger than abbrev section size (%lx)\n"),
- (unsigned long) abbrev_base,
- (unsigned long) abbrev_size);
+ else if ((abbrev_base + abbrev_size)
+ > debug_displays [abbrev_sec].section.size)
+ warn (_("Debug info is corrupted, abbrev size (%lx) is larger than abbrev section size (%lx)\n"),
+ (unsigned long) abbrev_base + abbrev_size,
+ (unsigned long) debug_displays [abbrev_sec].section.size);
else
process_abbrev_section
(((unsigned char *) debug_displays [abbrev_sec].section.start