diff options
author | Victor Stinner <victor.stinner@haypocalc.com> | 2010-03-03 23:32:07 (GMT) |
---|---|---|
committer | Victor Stinner <victor.stinner@haypocalc.com> | 2010-03-03 23:32:07 (GMT) |
commit | ef32bc856982b25b869fc6f89a44993ab7e86de1 (patch) | |
tree | a25d709a9b58d26e958985038e2b78b48c111d79 /Python/pystate.c | |
parent | 925ca76ae7cf25eb0706145447e695c0c98973bb (diff) | |
download | cpython-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.c | 29 |
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) { |