Commit 93d7918f authored by Serhiy Storchaka's avatar Serhiy Storchaka Committed by GitHub

[2.7] bpo-16865: Support arrays >=2GB in ctypes. (GH-3006). (GH-7441)

(cherry picked from commit 735abadd)
Co-Authored-By: default avatarSegev Finer <segev208@gmail.com>
parent eab421bf
import unittest import unittest
from test.support import precisionbigmemtest, _2G
import sys
from ctypes import * from ctypes import *
from ctypes.test import need_symbol from ctypes.test import need_symbol
...@@ -132,5 +134,10 @@ class ArrayTestCase(unittest.TestCase): ...@@ -132,5 +134,10 @@ class ArrayTestCase(unittest.TestCase):
t2 = my_int * 1 t2 = my_int * 1
self.assertIs(t1, t2) self.assertIs(t1, t2)
@unittest.skipUnless(sys.maxsize > 2**32, 'requires 64bit platform')
@precisionbigmemtest(size=_2G, memuse=1, dry_run=False)
def test_large_array(self, size):
a = c_char * size
if __name__ == '__main__': if __name__ == '__main__':
unittest.main() unittest.main()
Support arrays >=2GiB in :mod:`ctypes`. Patch by Segev Finer.
...@@ -1460,24 +1460,36 @@ PyCArrayType_new(PyTypeObject *type, PyObject *args, PyObject *kwds) ...@@ -1460,24 +1460,36 @@ PyCArrayType_new(PyTypeObject *type, PyObject *args, PyObject *kwds)
PyTypeObject *result; PyTypeObject *result;
StgDictObject *stgdict; StgDictObject *stgdict;
StgDictObject *itemdict; StgDictObject *itemdict;
PyObject *proto; PyObject *proto, *length_attr;
PyObject *typedict; PyObject *typedict;
long length; Py_ssize_t length;
Py_ssize_t itemsize, itemalign; Py_ssize_t itemsize, itemalign;
typedict = PyTuple_GetItem(args, 2); typedict = PyTuple_GetItem(args, 2);
if (!typedict) if (!typedict)
return NULL; return NULL;
proto = PyDict_GetItemString(typedict, "_length_"); /* Borrowed ref */ length_attr = PyDict_GetItemString(typedict, "_length_"); /* Borrowed ref */
if (!proto || !PyInt_Check(proto)) { if (!length_attr || !_PyAnyInt_Check(length_attr)) {
PyErr_SetString(PyExc_AttributeError, PyErr_SetString(PyExc_AttributeError,
"class must define a '_length_' attribute, " "class must define a '_length_' attribute, "
"which must be a positive integer"); "which must be a positive integer");
return NULL; return NULL;
} }
length = PyInt_AS_LONG(proto); if (PyInt_Check(length_attr)) {
length = PyInt_AS_LONG(length_attr);
}
else {
assert(PyLong_Check(length_attr));
length = PyLong_AsSsize_t(length_attr);
if (length == -1 && PyErr_Occurred()) {
if (PyErr_ExceptionMatches(PyExc_OverflowError)) {
PyErr_SetString(PyExc_OverflowError,
"The '_length_' attribute is too large");
}
return NULL;
}
}
proto = PyDict_GetItemString(typedict, "_type_"); /* Borrowed ref */ proto = PyDict_GetItemString(typedict, "_type_"); /* Borrowed ref */
if (!proto) { if (!proto) {
......
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