bfd/elf-attrs.c: Fix possible infinite loop parsing attributes
authorWill Newton <will.newton@linaro.org>
Wed, 5 Nov 2014 15:24:30 +0000 (15:24 +0000)
committerWill Newton <will.newton@linaro.org>
Thu, 6 Nov 2014 13:01:18 +0000 (13:01 +0000)
Handle the case of a zero length section or sub-section in
_bfd_elf_parse_attributes and in doing so prevent an infinite loop
in the parser.

bfd/ChangeLog:

2014-11-06  Will Newton  <will.newton@linaro.org>

* elf-attrs.c (_bfd_elf_parse_attributes): Handle zero
length sections and sub-sections.

bfd/ChangeLog
bfd/elf-attrs.c

index 16724b3..7a57b12 100644 (file)
@@ -1,3 +1,8 @@
+2014-11-06  Will Newton  <will.newton@linaro.org>
+
+       * elf-attrs.c (_bfd_elf_parse_attributes): Handle zero
+       length sections and sub-sections.
+
 2014-11-04  Nick Clifton  <nickc@redhat.com>
 
        PR binutils/17512
index cd0cbca..6bc2944 100644 (file)
@@ -455,6 +455,8 @@ _bfd_elf_parse_attributes (bfd *abfd, Elf_Internal_Shdr * hdr)
 
          section_len = bfd_get_32 (abfd, p);
          p += 4;
+         if (section_len == 0)
+           break;
          if (section_len > len)
            section_len = len;
          len -= section_len;
@@ -487,6 +489,8 @@ _bfd_elf_parse_attributes (bfd *abfd, Elf_Internal_Shdr * hdr)
              p += n;
              subsection_len = bfd_get_32 (abfd, p);
              p += 4;
+             if (subsection_len == 0)
+               break;
              if (subsection_len > section_len)
                subsection_len = section_len;
              section_len -= subsection_len;