[llvm] r207199 - [python] Fix getting section contents.

Anders Waldenborg anders at 0x63.nu
Thu Apr 24 23:25:15 PDT 2014


Author: andersg
Date: Fri Apr 25 01:25:15 2014
New Revision: 207199

URL: http://llvm.org/viewvc/llvm-project?rev=207199&view=rev
Log:
[python] Fix getting section contents.

The returnvalue was handled as c_char_p which ment that ctypes
handled it as a NUL-terminated string making it cut the contents
at first NUL (or even worse - overrunning the buffer if it doesn't
contain a NUL).

Differential Revision: http://reviews.llvm.org/D3474


Modified:
    llvm/trunk/bindings/python/llvm/object.py
    llvm/trunk/bindings/python/llvm/tests/test_object.py

Modified: llvm/trunk/bindings/python/llvm/object.py
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/bindings/python/llvm/object.py?rev=207199&r1=207198&r2=207199&view=diff
==============================================================================
--- llvm/trunk/bindings/python/llvm/object.py (original)
+++ llvm/trunk/bindings/python/llvm/object.py Fri Apr 25 01:25:15 2014
@@ -78,7 +78,10 @@ Here are some examples on how to perform
 """
 
 from ctypes import c_char_p
+from ctypes import c_char
+from ctypes import POINTER
 from ctypes import c_uint64
+from ctypes import string_at
 
 from .common import CachedProperty
 from .common import LLVMObject
@@ -211,7 +214,12 @@ class Section(LLVMObject):
         if self.expired:
             raise Exception('Section instance has expired.')
 
-        return lib.LLVMGetSectionContents(self)
+        siz = self.size
+
+        r = lib.LLVMGetSectionContents(self)
+        if r:
+            return string_at(r, siz)
+        return None
 
     @CachedProperty
     def address(self):
@@ -462,7 +470,8 @@ def register_library(library):
     library.LLVMGetSectionSize.restype = c_uint64
 
     library.LLVMGetSectionContents.argtypes = [c_object_p]
-    library.LLVMGetSectionContents.restype = c_char_p
+    # Can't use c_char_p here as it isn't a NUL-terminated string.
+    library.LLVMGetSectionContents.restype = POINTER(c_char)
 
     library.LLVMGetSectionAddress.argtypes = [c_object_p]
     library.LLVMGetSectionAddress.restype = c_uint64

Modified: llvm/trunk/bindings/python/llvm/tests/test_object.py
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/bindings/python/llvm/tests/test_object.py?rev=207199&r1=207198&r2=207199&view=diff
==============================================================================
--- llvm/trunk/bindings/python/llvm/tests/test_object.py (original)
+++ llvm/trunk/bindings/python/llvm/tests/test_object.py Fri Apr 25 01:25:15 2014
@@ -23,6 +23,7 @@ class TestObjectFile(TestBase):
             assert isinstance(section.size, long)
             assert isinstance(section.contents, str)
             assert isinstance(section.address, long)
+            assert len(section.contents) == section.size
 
         self.assertGreater(count, 0)
 





More information about the llvm-commits mailing list