mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 18:54:53 +00:00 
			
		
		
		
	bpo-36854: Clear the current thread later (GH-17279)
Clear the current thread later in the Python finalization. * The PyInterpreterState_Delete() function is now responsible to call PyThreadState_Swap(NULL). * The tstate_delete_common() function is now responsible to clear the "autoTSSKey" thread local storage and it only clears it once the thread state is fully cleared. It allows to still get the current thread from TSS in tstate_delete_common().
This commit is contained in:
		
							parent
							
								
									d51a363a43
								
							
						
					
					
						commit
						9da7430675
					
				
					 3 changed files with 35 additions and 28 deletions
				
			
		|  | @ -1226,9 +1226,6 @@ finalize_interp_delete(PyThreadState *tstate, int is_main_interp) | |||
|         _PyGILState_Fini(tstate); | ||||
|     } | ||||
| 
 | ||||
|     /* Delete current thread. After this, many C API calls become crashy. */ | ||||
|     PyThreadState_Swap(NULL); | ||||
| 
 | ||||
|     PyInterpreterState_Delete(tstate->interp); | ||||
| } | ||||
| 
 | ||||
|  | @ -1577,9 +1574,9 @@ new_interpreter(PyThreadState **tstate_p) | |||
| 
 | ||||
|     PyErr_PrintEx(0); | ||||
|     PyThreadState_Clear(tstate); | ||||
|     PyThreadState_Swap(save_tstate); | ||||
|     PyThreadState_Delete(tstate); | ||||
|     PyInterpreterState_Delete(interp); | ||||
|     PyThreadState_Swap(save_tstate); | ||||
| 
 | ||||
|     *tstate_p = NULL; | ||||
|     return _PyStatus_OK(); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Victor Stinner
						Victor Stinner