summaryrefslogtreecommitdiffstats
path: root/Objects
diff options
context:
space:
mode:
authorTim Peters <tim.peters@gmail.com>2001-10-06 19:04:01 (GMT)
committerTim Peters <tim.peters@gmail.com>2001-10-06 19:04:01 (GMT)
commit406fe3b1c029e2526f4aeab070cc93177512f164 (patch)
treeff9400cc654378fbf1c57fadc34a32c5d05533c9 /Objects
parent7254e5a3edd85563d333ba5aa2978d7cd7daa96a (diff)
downloadcpython-406fe3b1c029e2526f4aeab070cc93177512f164.zip
cpython-406fe3b1c029e2526f4aeab070cc93177512f164.tar.gz
cpython-406fe3b1c029e2526f4aeab070cc93177512f164.tar.bz2
Repaired the debug Windows deaths in test_descr, by allocating enough
pad memory to properly align the __dict__ pointer in all cases. gcmodule.c/objimpl.h, _PyObject_GC_Malloc: + Added a "padding" argument so that this flavor of malloc can allocate enough bytes for alignment padding (it can't know this is needed, but its callers do). typeobject.c, PyType_GenericAlloc: + Allocated enough bytes to align the __dict__ pointer. + Sped and simplified the round-up-to-PTRSIZE logic. + Added blank lines so I could parse the if/else blocks <0.7 wink>.
Diffstat (limited to 'Objects')
-rw-r--r--Objects/typeobject.c36
1 files changed, 23 insertions, 13 deletions
diff --git a/Objects/typeobject.c b/Objects/typeobject.c
index fed6c43..59ec588 100644
--- a/Objects/typeobject.c
+++ b/Objects/typeobject.c
@@ -192,32 +192,42 @@ PyType_GenericAlloc(PyTypeObject *type, int nitems)
{
#define PTRSIZE (sizeof(PyObject *))
- int size;
+ size_t size = (size_t)_PyObject_VAR_SIZE(type, nitems);
+ size_t padding = 0;
PyObject *obj;
- /* Inline PyObject_New() so we can zero the memory */
- size = _PyObject_VAR_SIZE(type, nitems);
- /* Round up size, if necessary, so we fully zero out __dict__ */
- if (type->tp_itemsize % PTRSIZE != 0) {
- size += PTRSIZE - 1;
- size /= PTRSIZE;
- size *= PTRSIZE;
- }
- if (PyType_IS_GC(type)) {
- obj = _PyObject_GC_Malloc(type, nitems);
+ /* Round up size, if necessary, so that the __dict__ pointer
+ following the variable part is properly aligned for the platform.
+ This is needed only for types with a vrbl number of items
+ before the __dict__ pointer == types that record the dict offset
+ as a negative offset from the end of the object. If tp_dictoffset
+ is 0, there is no __dict__; if positive, tp_dict was declared in a C
+ struct so the compiler already took care of aligning it. */
+ if (type->tp_dictoffset < 0) {
+ padding = PTRSIZE - size % PTRSIZE;
+ if (padding == PTRSIZE)
+ padding = 0;
+ size += padding;
}
- else {
+
+ if (PyType_IS_GC(type))
+ obj = _PyObject_GC_Malloc(type, nitems, padding);
+ else
obj = PyObject_MALLOC(size);
- }
+
if (obj == NULL)
return PyErr_NoMemory();
+
memset(obj, '\0', size);
+
if (type->tp_flags & Py_TPFLAGS_HEAPTYPE)
Py_INCREF(type);
+
if (type->tp_itemsize == 0)
PyObject_INIT(obj, type);
else
(void) PyObject_INIT_VAR((PyVarObject *)obj, type, nitems);
+
if (PyType_IS_GC(type))
_PyObject_GC_TRACK(obj);
return obj;