Add file size to ELF symbol labelling start of a binary file.
authorCary Coutant <ccoutant@google.com>
Tue, 25 Nov 2014 22:33:51 +0000 (14:33 -0800)
committerCary Coutant <ccoutant@google.com>
Tue, 25 Nov 2014 22:33:51 +0000 (14:33 -0800)
gold/
* binary.cc (Binary_to_elf::sized_convert): Add size to _start symbol.
(Binary_to_elf::write_symbol): Add st_size parameter.
* binary.h (Binary_to_elf::write_symbol): Add st_size parameter.

gold/ChangeLog
gold/binary.cc
gold/binary.h

index a447b42ae47c7290dacc0740ea29d4ef0a05a1ac..9f3f529659ce1d15f8bdaced985bab1903bb162a 100644 (file)
@@ -1,3 +1,9 @@
+2014-11-25  Cary Coutant  <ccoutant@google.com>
+
+       * binary.cc (Binary_to_elf::sized_convert): Add size to _start symbol.
+       (Binary_to_elf::write_symbol): Add st_size parameter.
+       * binary.h (Binary_to_elf::write_symbol): Add st_size parameter.
+
 2014-11-25  Cary Coutant  <ccoutant@google.com>
 
        PR gold/17639
index 4dab52cd6bfd108b849bf4b21cf3221c2618b5b7..a933b2d475df8afac3aa8ef6023fd6e4bcee2135 100644 (file)
@@ -235,12 +235,12 @@ Binary_to_elf::sized_convert(const Task* task)
       pout += aligned_filesize - filesize;
     }
 
-  this->write_symbol<size, big_endian>("", &strtab, 0, 0, &pout);
-  this->write_symbol<size, big_endian>(start_symbol_name, &strtab, 0, 1,
-                                      &pout);
-  this->write_symbol<size, big_endian>(end_symbol_name, &strtab, filesize, 1,
-                                      &pout);
-  this->write_symbol<size, big_endian>(size_symbol_name, &strtab, filesize,
+  this->write_symbol<size, big_endian>("", &strtab, 0, 0, 0, &pout);
+  this->write_symbol<size, big_endian>(start_symbol_name, &strtab, 0, filesize,
+                                      1, &pout);
+  this->write_symbol<size, big_endian>(end_symbol_name, &strtab, filesize, 0,
+                                      1, &pout);
+  this->write_symbol<size, big_endian>(size_symbol_name, &strtab, filesize, 0,
                                       elfcpp::SHN_ABS, &pout);
 
   strtab.write_to_buffer(pout, strtab.get_strtab_size());
@@ -343,6 +343,7 @@ Binary_to_elf::write_symbol(
     const std::string& name,
     const Stringpool* strtab,
     section_size_type value,
+    typename elfcpp::Elf_types<32>::Elf_WXword st_size,
     unsigned int shndx,
     unsigned char** ppout)
 {
@@ -351,7 +352,7 @@ Binary_to_elf::write_symbol(
   elfcpp::Sym_write<size, big_endian> osym(pout);
   osym.put_st_name(name.empty() ? 0 : strtab->get_offset(name.c_str()));
   osym.put_st_value(value);
-  osym.put_st_size(0);
+  osym.put_st_size(st_size);
   osym.put_st_info(name.empty() ? elfcpp::STB_LOCAL : elfcpp::STB_GLOBAL,
                   elfcpp::STT_NOTYPE);
   osym.put_st_other(elfcpp::STV_DEFAULT, 0);
index 3ce84c2ea2da4aa75b751300a941fc75b6cc9fe5..a611e955871533eab7f8f873952d616b36e53ed2 100644 (file)
@@ -95,7 +95,8 @@ class Binary_to_elf
   template<int size, bool big_endian>
   void
   write_symbol(const std::string&, const Stringpool_template<char>*,
-              section_size_type, unsigned int, unsigned char**);
+              section_size_type, typename elfcpp::Elf_types<32>::Elf_WXword,
+              unsigned int, unsigned char**);
 
   // The ELF machine code of the file to create.
   elfcpp::EM elf_machine_;