[Beignet] [PATCH 2/4] Modify the elfio lib, make it generate memory image.

junyan.he at inbox.com junyan.he at inbox.com
Wed Feb 8 08:13:50 UTC 2017


From: Junyan He <junyan.he at intel.com>

We do not want to write the elf binary directly to a file.
We prefer to keep it in the memory and analyse the elf image
in runtime.

Signed-off-by: Junyan He <junyan.he at intel.com>
---
 backend/src/elfio/elfio.hpp        | 37 ++++++++++++++++++++++---------------
 backend/src/elfio/elfio_header.hpp |  1 -
 2 files changed, 22 insertions(+), 16 deletions(-)

diff --git a/backend/src/elfio/elfio.hpp b/backend/src/elfio/elfio.hpp
index 3a86c93..7b9501c 100644
--- a/backend/src/elfio/elfio.hpp
+++ b/backend/src/elfio/elfio.hpp
@@ -148,14 +148,7 @@ class elfio
     }
 
 //------------------------------------------------------------------------------
-    bool save( const std::string& file_name )
-    {
-        std::ofstream f( file_name.c_str(), std::ios::out | std::ios::binary );
-
-        if ( !f ) {
-            return false;
-        }
-
+    bool save( std::ostream &stream) {
         bool is_still_good = true;
 
         // Define layout specific header fields
@@ -175,15 +168,29 @@ class elfio
         is_still_good = is_still_good && layout_sections_without_segments();
         is_still_good = is_still_good && layout_section_table();
 
-        is_still_good = is_still_good && save_header( f );
-        is_still_good = is_still_good && save_sections( f );
-        is_still_good = is_still_good && save_segments( f );
+        is_still_good = is_still_good && save_header( stream );
+        is_still_good = is_still_good && save_sections( stream );
+        is_still_good = is_still_good && save_segments( stream );
 
-        f.close();
 
         return is_still_good;
     }
 
+    bool save( const std::string& file_name )
+    {
+        bool ret;
+
+        std::ofstream f( file_name.c_str(), std::ios::out | std::ios::binary );
+
+        if ( !f ) {
+            return false;
+        }
+
+        ret = save( f );
+        f.close();
+        return ret;
+    }
+
 //------------------------------------------------------------------------------
     // ELF header access functions
     ELFIO_HEADER_ACCESS_GET( unsigned char, class              );
@@ -435,13 +442,13 @@ class elfio
     }
 
 //------------------------------------------------------------------------------
-    bool save_header( std::ofstream& f )
+    bool save_header( std::ostream& f )
     {
         return header->save( f );
     }
 
 //------------------------------------------------------------------------------
-    bool save_sections( std::ofstream& f )
+    bool save_sections( std::ostream& f )
     {
         for ( unsigned int i = 0; i < sections_.size(); ++i ) {
             section *sec = sections_.at(i);
@@ -456,7 +463,7 @@ class elfio
     }
 
 //------------------------------------------------------------------------------
-    bool save_segments( std::ofstream& f )
+    bool save_segments( std::ostream& f )
     {
         for ( unsigned int i = 0; i < segments_.size(); ++i ) {
             segment *seg = segments_.at(i);
diff --git a/backend/src/elfio/elfio_header.hpp b/backend/src/elfio/elfio_header.hpp
index d689a88..16e1dee 100644
--- a/backend/src/elfio/elfio_header.hpp
+++ b/backend/src/elfio/elfio_header.hpp
@@ -111,7 +111,6 @@ template< class T > class elf_header_impl : public elf_header
     {
         stream.seekp( 0 );
         stream.write( reinterpret_cast<const char*>( &header ), sizeof( header ) );
-
         return stream.good();
     }
 
-- 
2.7.4



More information about the Beignet mailing list