Jakub Jelinek 873b54
--- bfd/compress.c.jj	2010-12-24 11:40:19.000000000 +0100
Jakub Jelinek 873b54
+++ bfd/compress.c	2011-01-28 15:40:19.869777126 +0100
Jakub Jelinek 873b54
@@ -174,7 +174,7 @@ bfd_get_full_section_contents (bfd *abfd
Jakub Jelinek 873b54
     case COMPRESS_SECTION_NONE:
Jakub Jelinek 873b54
       if (p == NULL)
Jakub Jelinek 873b54
 	{
Jakub Jelinek 873b54
-	  p = (bfd_byte *) bfd_malloc (sz);
Jakub Jelinek 873b54
+	  p = (bfd_byte *) bfd_zmalloc (sz);
Jakub Jelinek 873b54
 	  if (p == NULL)
Jakub Jelinek 873b54
 	    return FALSE;
Jakub Jelinek 873b54
 	}
Jakub Jelinek 873b54
@@ -214,7 +214,7 @@ bfd_get_full_section_contents (bfd *abfd
Jakub Jelinek 873b54
       if (!ret)
Jakub Jelinek 873b54
 	goto fail_compressed;
Jakub Jelinek 873b54
 
Jakub Jelinek 873b54
-      uncompressed_buffer = (bfd_byte *) bfd_malloc (uncompressed_size);
Jakub Jelinek 873b54
+      uncompressed_buffer = (bfd_byte *) bfd_zmalloc (uncompressed_size);
Jakub Jelinek 873b54
       if (uncompressed_buffer == NULL)
Jakub Jelinek 873b54
 	goto fail_compressed;
Jakub Jelinek 873b54
 
Jakub Jelinek 873b54
--- bfd/elfcode.h.jj	2010-12-31 03:43:21.000000000 +0100
Jakub Jelinek 873b54
+++ bfd/elfcode.h	2011-01-28 15:34:39.055388479 +0100
Jakub Jelinek 873b54
@@ -1158,6 +1158,24 @@ elf_checksum_contents (bfd *abfd,
Jakub Jelinek 873b54
 
Jakub Jelinek 873b54
       if (i_shdr.contents)
Jakub Jelinek 873b54
 	(*process) (i_shdr.contents, i_shdr.sh_size, arg);
Jakub Jelinek 873b54
+      else
Jakub Jelinek 873b54
+	{
Jakub Jelinek 873b54
+	  asection *sec;
Jakub Jelinek 873b54
+
Jakub Jelinek 873b54
+	  sec = bfd_section_from_elf_index (abfd, count);
Jakub Jelinek 873b54
+	  if (sec != NULL)
Jakub Jelinek 873b54
+	    {
Jakub Jelinek 873b54
+	      if (sec->contents == NULL)
Jakub Jelinek 873b54
+		{
Jakub Jelinek 873b54
+		  /* Force rereading from file.  */
Jakub Jelinek 873b54
+		  sec->flags &= ~SEC_IN_MEMORY;
Jakub Jelinek 873b54
+		  if (! bfd_malloc_and_get_section (abfd, sec, & sec->contents))
Jakub Jelinek 873b54
+		    continue;
Jakub Jelinek 873b54
+		}
Jakub Jelinek 873b54
+	      if (sec->contents != NULL)
Jakub Jelinek 873b54
+		(*process) (sec->contents, i_shdr.sh_size, arg);
Jakub Jelinek 873b54
+	    }
Jakub Jelinek 873b54
+	}
Jakub Jelinek 873b54
     }
Jakub Jelinek 873b54
 
Jakub Jelinek 873b54
   return TRUE;