diff options
| -rw-r--r-- | Include/pystate.h | 2 | ||||
| -rw-r--r-- | Misc/NEWS | 3 | ||||
| -rw-r--r-- | Modules/_threadmodule.c | 12 | ||||
| -rw-r--r-- | Python/pystate.c | 29 | 
4 files changed, 39 insertions, 7 deletions
| diff --git a/Include/pystate.h b/Include/pystate.h index e02df88f8c..81de569112 100644 --- a/Include/pystate.h +++ b/Include/pystate.h @@ -113,6 +113,8 @@ PyAPI_FUNC(int) _PyState_AddModule(PyObject*, struct PyModuleDef*);  PyAPI_FUNC(PyObject*) PyState_FindModule(struct PyModuleDef*);  PyAPI_FUNC(PyThreadState *) PyThreadState_New(PyInterpreterState *); +PyAPI_FUNC(PyThreadState *) _PyThreadState_Prealloc(PyInterpreterState *); +PyAPI_FUNC(void) _PyThreadState_Init(PyThreadState *);  PyAPI_FUNC(void) PyThreadState_Clear(PyThreadState *);  PyAPI_FUNC(void) PyThreadState_Delete(PyThreadState *);  #ifdef WITH_THREAD @@ -12,6 +12,9 @@ What's New in Python 3.1.2?  Core and Builtins  ----------------- +- Issue #7544: Preallocate thread memory before creating the thread to avoid +  a fatal error in low memory condition. +  - Issue #7820: The parser tokenizer restores all bytes in the right if    the BOM check fails. diff --git a/Modules/_threadmodule.c b/Modules/_threadmodule.c index 5181d0705e..3d4578a3d8 100644 --- a/Modules/_threadmodule.c +++ b/Modules/_threadmodule.c @@ -423,6 +423,7 @@ struct bootstate {  	PyObject *func;  	PyObject *args;  	PyObject *keyw; +	PyThreadState *tstate;  };  static void @@ -432,8 +433,9 @@ t_bootstrap(void *boot_raw)  	PyThreadState *tstate;  	PyObject *res; -	tstate = PyThreadState_New(boot->interp); - +	tstate = boot->tstate; +	tstate->thread_id = PyThread_get_thread_ident(); +	_PyThreadState_Init(tstate);  	PyEval_AcquireThread(tstate);  	res = PyEval_CallObjectWithKeywords(  		boot->func, boot->args, boot->keyw); @@ -496,6 +498,11 @@ thread_PyThread_start_new_thread(PyObject *self, PyObject *fargs)  	boot->func = func;  	boot->args = args;  	boot->keyw = keyw; +	boot->tstate = _PyThreadState_Prealloc(boot->interp); +	if (boot->tstate == NULL) { +		PyMem_DEL(boot); +		return PyErr_NoMemory(); +	}  	Py_INCREF(func);  	Py_INCREF(args);  	Py_XINCREF(keyw); @@ -506,6 +513,7 @@ thread_PyThread_start_new_thread(PyObject *self, PyObject *fargs)  		Py_DECREF(func);  		Py_DECREF(args);  		Py_XDECREF(keyw); +		PyThreadState_Clear(boot->tstate);  		PyMem_DEL(boot);  		return NULL;  	} diff --git a/Python/pystate.c b/Python/pystate.c index fe5de5f4d2..3d5cf04baa 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)  { | 
