mirror of
				https://github.com/python/cpython.git
				synced 2025-10-26 03:04:41 +00:00 
			
		
		
		
	Change PyEval_SaveThread() and PyEval_RestoreThread() to always do the
tstate swapping. Only the acquiring and releasing of the lock is conditional (twice, under ``#ifdef WITH_THREAD'' and inside ``if (interpreter_lock)'').
This commit is contained in:
		
							parent
							
								
									b4102bf5f8
								
							
						
					
					
						commit
						b74eca9349
					
				
					 1 changed files with 9 additions and 12 deletions
				
			
		|  | @ -171,33 +171,30 @@ PyEval_ReleaseThread(tstate) | ||||||
| PyThreadState * | PyThreadState * | ||||||
| PyEval_SaveThread() | PyEval_SaveThread() | ||||||
| { | { | ||||||
| #ifdef WITH_THREAD |  | ||||||
| 	if (interpreter_lock) { |  | ||||||
| 	PyThreadState *tstate = PyThreadState_Swap(NULL); | 	PyThreadState *tstate = PyThreadState_Swap(NULL); | ||||||
| 	if (tstate == NULL) | 	if (tstate == NULL) | ||||||
| 		Py_FatalError("PyEval_SaveThread: NULL tstate"); | 		Py_FatalError("PyEval_SaveThread: NULL tstate"); | ||||||
|  | #ifdef WITH_THREAD | ||||||
|  | 	if (interpreter_lock) | ||||||
| 		release_lock(interpreter_lock); | 		release_lock(interpreter_lock); | ||||||
| 		return tstate; |  | ||||||
| 	} |  | ||||||
| #endif | #endif | ||||||
| 	return NULL; | 	return tstate; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| PyEval_RestoreThread(tstate) | PyEval_RestoreThread(tstate) | ||||||
| 	PyThreadState *tstate; | 	PyThreadState *tstate; | ||||||
| { | { | ||||||
| #ifdef WITH_THREAD |  | ||||||
| 	if (interpreter_lock) { |  | ||||||
| 		int err; |  | ||||||
| 		err = errno; |  | ||||||
| 	if (tstate == NULL) | 	if (tstate == NULL) | ||||||
| 		Py_FatalError("PyEval_RestoreThread: NULL tstate"); | 		Py_FatalError("PyEval_RestoreThread: NULL tstate"); | ||||||
|  | #ifdef WITH_THREAD | ||||||
|  | 	if (interpreter_lock) { | ||||||
|  | 		int err = errno; | ||||||
| 		acquire_lock(interpreter_lock, 1); | 		acquire_lock(interpreter_lock, 1); | ||||||
| 		PyThreadState_Swap(tstate); |  | ||||||
| 		errno = err; | 		errno = err; | ||||||
| 	} | 	} | ||||||
| #endif | #endif | ||||||
|  | 	PyThreadState_Swap(tstate); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Guido van Rossum
						Guido van Rossum