summaryrefslogtreecommitdiffstats
path: root/Python/pystate.c
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@haypocalc.com>2010-03-03 23:32:07 (GMT)
committerVictor Stinner <victor.stinner@haypocalc.com>2010-03-03 23:32:07 (GMT)
commitef32bc856982b25b869fc6f89a44993ab7e86de1 (patch)
treea25d709a9b58d26e958985038e2b78b48c111d79 /Python/pystate.c
parent925ca76ae7cf25eb0706145447e695c0c98973bb (diff)
downloadcpython-ef32bc856982b25b869fc6f89a44993ab7e86de1.zip
cpython-ef32bc856982b25b869fc6f89a44993ab7e86de1.tar.gz
cpython-ef32bc856982b25b869fc6f89a44993ab7e86de1.tar.bz2
Merged revisions 78639 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/py3k ................ r78639 | victor.stinner | 2010-03-04 00:28:07 +0100 (jeu., 04 mars 2010) | 10 lines Merged revisions 78638 via svnmerge from svn+ssh://pythondev@svn.python.org/python/trunk ........ r78638 | victor.stinner | 2010-03-04 00:20:25 +0100 (jeu., 04 mars 2010) | 3 lines Issue #7544: Preallocate thread memory before creating the thread to avoid a fatal error in low memory condition. ........ ................
Diffstat (limited to 'Python/pystate.c')
-rw-r--r--Python/pystate.c29
1 files changed, 24 insertions, 5 deletions
diff --git a/Python/pystate.c b/Python/pystate.c
index fe5de5f..3d5cf04 100644
--- a/Python/pystate.c
+++ b/Python/pystate.c
@@ -157,8 +157,8 @@ threadstate_getframe(PyThreadState *self)
return self->frame;
}
-PyThreadState *
-PyThreadState_New(PyInterpreterState *interp)
+static PyThreadState *
+new_threadstate(PyInterpreterState *interp, int init)
{
PyThreadState *tstate = (PyThreadState *)malloc(sizeof(PyThreadState));
@@ -198,9 +198,8 @@ PyThreadState_New(PyInterpreterState *interp)
tstate->c_profileobj = NULL;
tstate->c_traceobj = NULL;
-#ifdef WITH_THREAD
- _PyGILState_NoteThreadState(tstate);
-#endif
+ if (init)
+ _PyThreadState_Init(tstate);
HEAD_LOCK();
tstate->next = interp->tstate_head;
@@ -211,6 +210,26 @@ PyThreadState_New(PyInterpreterState *interp)
return tstate;
}
+PyThreadState *
+PyThreadState_New(PyInterpreterState *interp)
+{
+ return new_threadstate(interp, 1);
+}
+
+PyThreadState *
+_PyThreadState_Prealloc(PyInterpreterState *interp)
+{
+ return new_threadstate(interp, 0);
+}
+
+void
+_PyThreadState_Init(PyThreadState *tstate)
+{
+#ifdef WITH_THREAD
+ _PyGILState_NoteThreadState(tstate);
+#endif
+}
+
PyObject*
PyState_FindModule(struct PyModuleDef* m)
{