[Python-checkins] bpo-40048: Fix _PyCode_InitOpcache() error path (GH-19691) (GH-19698)

Victor Stinner webhook-mailer at python.org
Thu Apr 23 21:07:28 EDT 2020


https://github.com/python/cpython/commit/d9df63deab78f70061a5a24c1f92e6d389fc45f7
commit: d9df63deab78f70061a5a24c1f92e6d389fc45f7
branch: 3.8
author: Victor Stinner <vstinner at python.org>
committer: GitHub <noreply at github.com>
date: 2020-04-24T03:07:20+02:00
summary:

bpo-40048: Fix _PyCode_InitOpcache() error path (GH-19691) (GH-19698)

If _PyCode_InitOpcache() fails in _PyEval_EvalFrameDefault(), use
"goto exit_eval_frame;" rather than "return NULL;" to exit the
function in a consistent state. For example, tstate->frame is now
reset properly.

(cherry picked from commit 25104949a5a60ff86c10691e184ce2ecb500159b)

files:
M Python/ceval.c

diff --git a/Python/ceval.c b/Python/ceval.c
index 2db6e6bf8ebdb..1873e37cf608e 100644
--- a/Python/ceval.c
+++ b/Python/ceval.c
@@ -1159,7 +1159,7 @@ _PyEval_EvalFrameDefault(PyFrameObject *f, int throwflag)
         co->co_opcache_flag++;
         if (co->co_opcache_flag == OPCACHE_MIN_RUNS) {
             if (_PyCode_InitOpcache(co) < 0) {
-                return NULL;
+                goto exit_eval_frame;
             }
 #if OPCACHE_STATS
             opcache_code_objects_extra_mem +=



More information about the Python-checkins mailing list