Commit 1efb33a6 authored by Meador Inge's avatar Meador Inge

Issue #12881: ctypes: Fix segfault with large structure field names.

parent 5d0de3fb
...@@ -326,6 +326,18 @@ class StructureTestCase(unittest.TestCase): ...@@ -326,6 +326,18 @@ class StructureTestCase(unittest.TestCase):
else: else:
self.assertEqual(msg, "(Phone) TypeError: too many initializers") self.assertEqual(msg, "(Phone) TypeError: too many initializers")
def test_huge_field_name(self):
# issue12881: segfault with large structure field names
def create_class(length):
class S(Structure):
_fields_ = [('x' * length, c_int)]
for length in [10 ** i for i in range(0, 8)]:
try:
create_class(length)
except MemoryError:
# MemoryErrors are OK, we just don't want to segfault
pass
def get_except(self, func, *args): def get_except(self, func, *args):
try: try:
......
...@@ -87,6 +87,8 @@ Tests ...@@ -87,6 +87,8 @@ Tests
Extension Modules Extension Modules
----------------- -----------------
- Issue #12881: ctypes: Fix segfault with large structure field names.
- Issue #13058: ossaudiodev: fix a file descriptor leak on error. Patch by - Issue #13058: ossaudiodev: fix a file descriptor leak on error. Patch by
Thomas Jarosch. Thomas Jarosch.
......
...@@ -496,13 +496,19 @@ PyCStructUnionType_update_stgdict(PyObject *type, PyObject *fields, int isStruct ...@@ -496,13 +496,19 @@ PyCStructUnionType_update_stgdict(PyObject *type, PyObject *fields, int isStruct
} }
len = strlen(fieldname) + strlen(fieldfmt); len = strlen(fieldname) + strlen(fieldfmt);
buf = alloca(len + 2 + 1);
buf = PyMem_Malloc(len + 2 + 1);
if (buf == NULL) {
Py_DECREF(pair);
PyErr_NoMemory();
return -1;
}
sprintf(buf, "%s:%s:", fieldfmt, fieldname); sprintf(buf, "%s:%s:", fieldfmt, fieldname);
ptr = stgdict->format; ptr = stgdict->format;
stgdict->format = _ctypes_alloc_format_string(stgdict->format, buf); stgdict->format = _ctypes_alloc_format_string(stgdict->format, buf);
PyMem_Free(ptr); PyMem_Free(ptr);
PyMem_Free(buf);
if (stgdict->format == NULL) { if (stgdict->format == NULL) {
Py_DECREF(pair); Py_DECREF(pair);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment