diff options
Diffstat (limited to 'bfd')
-rw-r--r-- | bfd/ChangeLog | 8 | ||||
-rw-r--r-- | bfd/compress.c | 33 |
2 files changed, 10 insertions, 31 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog index 4400a36..4291fc7 100644 --- a/bfd/ChangeLog +++ b/bfd/ChangeLog @@ -1,3 +1,11 @@ +2015-04-06 H.J. Lu <hongjiu.lu@intel.com> + + * compress.c (get_uncompressed_size): Removed. + (bfd_compress_section_contents): Use bfd_putb64 to write + uncompressed section size. + (bfd_init_section_decompress_status): Replace + get_uncompressed_size with bfd_getb64. + 2015-04-04 H.J. Lu <hongjiu.lu@intel.com> * elf.c (_bfd_elf_init_private_section_data): Also preserve the diff --git a/bfd/compress.c b/bfd/compress.c index 56d49fe..b57650f 100644 --- a/bfd/compress.c +++ b/bfd/compress.c @@ -59,27 +59,6 @@ decompress_contents (bfd_byte *compressed_buffer, return rc == Z_OK && strm.avail_out == 0; } -static bfd_size_type -get_uncompressed_size (bfd_byte *compressed_size_buffer) -{ - bfd_size_type uncompressed_size = compressed_size_buffer[0]; - uncompressed_size <<= 8; - uncompressed_size += compressed_size_buffer[1]; - uncompressed_size <<= 8; - uncompressed_size += compressed_size_buffer[2]; - uncompressed_size <<= 8; - uncompressed_size += compressed_size_buffer[3]; - uncompressed_size <<= 8; - uncompressed_size += compressed_size_buffer[4]; - uncompressed_size <<= 8; - uncompressed_size += compressed_size_buffer[5]; - uncompressed_size <<= 8; - uncompressed_size += compressed_size_buffer[6]; - uncompressed_size <<= 8; - uncompressed_size += compressed_size_buffer[7]; - return uncompressed_size;; -} - /* Compress data of the size specified in @var{uncompressed_size} and pointed to by @var{uncompressed_buffer} using zlib and store as the contents field. This function assumes the contents @@ -122,15 +101,7 @@ bfd_compress_section_contents (bfd *abfd ATTRIBUTE_UNUSED, sec_ptr sec, /* Write the zlib header. In this case, it should be "ZLIB" followed by the uncompressed section size, 8 bytes in big-endian order. */ memcpy (compressed_buffer, "ZLIB", 4); - compressed_buffer[11] = uncompressed_size; uncompressed_size >>= 8; - compressed_buffer[10] = uncompressed_size; uncompressed_size >>= 8; - compressed_buffer[9] = uncompressed_size; uncompressed_size >>= 8; - compressed_buffer[8] = uncompressed_size; uncompressed_size >>= 8; - compressed_buffer[7] = uncompressed_size; uncompressed_size >>= 8; - compressed_buffer[6] = uncompressed_size; uncompressed_size >>= 8; - compressed_buffer[5] = uncompressed_size; uncompressed_size >>= 8; - compressed_buffer[4] = uncompressed_size; - + bfd_putb64 (uncompressed_size, compressed_buffer + 4); free (uncompressed_buffer); sec->contents = compressed_buffer; sec->size = compressed_size; @@ -368,7 +339,7 @@ bfd_init_section_decompress_status (bfd *abfd, sec_ptr sec) return FALSE; } - uncompressed_size = get_uncompressed_size (compressed_buffer + 4); + uncompressed_size = bfd_getb64 (compressed_buffer + 4); sec->compressed_size = sec->size; sec->size = uncompressed_size; sec->compress_status = DECOMPRESS_SECTION_SIZED; |