]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-98608: Fix Failure-handling in new_interpreter() (gh-102658)
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>
Tue, 21 Mar 2023 19:10:36 +0000 (12:10 -0700)
committerGitHub <noreply@github.com>
Tue, 21 Mar 2023 19:10:36 +0000 (12:10 -0700)
The error-handling code in new_interpreter() has been broken for a while.  We hadn't noticed because those code mostly doesn't fail.  (I noticed while working on gh-101660.)  The problem is that we try to clear/delete the newly-created thread/interpreter using itself, which just failed.  The solution is to switch back to the calling thread state first.

(cherry picked from commit d1b883b52a99427d234c20e4a92ddfa6a1da8880)

Co-authored-by: Eric Snow <ericsnowcurrently@gmail.com>
https: //github.com/python/cpython/issues/98608

Python/pylifecycle.c

index eeaf20b4617a2095bc6702199e509f5435870a4a..b0c5da56c4fff9f55db5be0b28f77f37dbe08597 100644 (file)
@@ -1962,10 +1962,10 @@ error:
 
     /* Oops, it didn't work.  Undo it all. */
     PyErr_PrintEx(0);
+    PyThreadState_Swap(save_tstate);
     PyThreadState_Clear(tstate);
     PyThreadState_Delete(tstate);
     PyInterpreterState_Delete(interp);
-    PyThreadState_Swap(save_tstate);
 
     return status;
 }