blob: bd9454b2812ddf7cc4d2f79647342beeeaa5ba74 [file] [log] [blame]
Guido van Rossumf70e43a1991-02-19 12:39:46 +00001
Guido van Rossum3f5da241990-12-20 15:06:42 +00002/* Execute compiled code */
Guido van Rossum10dc2e81990-11-18 17:27:39 +00003
Guido van Rossum681d79a1995-07-18 14:51:37 +00004/* XXX TO DO:
Guido van Rossum681d79a1995-07-18 14:51:37 +00005 XXX speed up searching for keywords by using a dictionary
Guido van Rossum681d79a1995-07-18 14:51:37 +00006 XXX document it!
7 */
8
Thomas Wouters477c8d52006-05-27 19:21:47 +00009/* enable more aggressive intra-module optimizations, where available */
10#define PY_LOCAL_AGGRESSIVE
11
Guido van Rossumb209a111997-04-29 18:18:01 +000012#include "Python.h"
Victor Stinner4d231bc2019-11-14 13:36:21 +010013#include "pycore_call.h"
Victor Stinner09532fe2019-05-10 23:39:09 +020014#include "pycore_ceval.h"
Inada Naoki91234a12019-06-03 21:30:58 +090015#include "pycore_code.h"
Victor Stinnerbcda8f12018-11-21 22:27:47 +010016#include "pycore_object.h"
Victor Stinner438a12d2019-05-24 17:01:38 +020017#include "pycore_pyerrors.h"
18#include "pycore_pylifecycle.h"
Victor Stinner621cebe2018-11-12 16:53:38 +010019#include "pycore_pystate.h"
Victor Stinnerec13b932018-11-25 23:56:17 +010020#include "pycore_tupleobject.h"
Guido van Rossum10dc2e81990-11-18 17:27:39 +000021
Jeremy Hylton3e0055f2005-10-20 19:59:25 +000022#include "code.h"
Benjamin Peterson025e9eb2015-05-05 20:16:41 -040023#include "dictobject.h"
Guido van Rossum3f5da241990-12-20 15:06:42 +000024#include "frameobject.h"
Guido van Rossum10dc2e81990-11-18 17:27:39 +000025#include "opcode.h"
Łukasz Langaa785c872016-09-09 17:37:37 -070026#include "pydtrace.h"
Benjamin Peterson025e9eb2015-05-05 20:16:41 -040027#include "setobject.h"
Tim Peters6d6c1a32001-08-02 04:15:00 +000028#include "structmember.h"
Guido van Rossum10dc2e81990-11-18 17:27:39 +000029
Guido van Rossumc6004111993-11-05 10:22:19 +000030#include <ctype.h>
31
Guido van Rossum408027e1996-12-30 16:17:54 +000032#ifdef Py_DEBUG
Guido van Rossum96a42c81992-01-12 02:29:51 +000033/* For debugging the interpreter: */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000034#define LLTRACE 1 /* Low-level trace feature */
35#define CHECKEXC 1 /* Double-check exception checking */
Guido van Rossum10dc2e81990-11-18 17:27:39 +000036#endif
37
Victor Stinner5c75f372019-04-17 23:02:26 +020038#if !defined(Py_BUILD_CORE)
39# error "ceval.c must be build with Py_BUILD_CORE define for best performance"
40#endif
41
Guido van Rossum5b722181993-03-30 17:46:03 +000042
Guido van Rossum374a9221991-04-04 10:40:29 +000043/* Forward declarations */
Victor Stinner09532fe2019-05-10 23:39:09 +020044Py_LOCAL_INLINE(PyObject *) call_function(
45 PyThreadState *tstate, PyObject ***pp_stack,
46 Py_ssize_t oparg, PyObject *kwnames);
47static PyObject * do_call_core(
48 PyThreadState *tstate, PyObject *func,
49 PyObject *callargs, PyObject *kwdict);
Jeremy Hylton52820442001-01-03 23:52:36 +000050
Guido van Rossum0a066c01992-03-27 17:29:15 +000051#ifdef LLTRACE
Guido van Rossumc2e20742006-02-27 22:32:47 +000052static int lltrace;
Victor Stinner438a12d2019-05-24 17:01:38 +020053static int prtrace(PyThreadState *, PyObject *, const char *);
Guido van Rossum0a066c01992-03-27 17:29:15 +000054#endif
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +010055static int call_trace(Py_tracefunc, PyObject *,
56 PyThreadState *, PyFrameObject *,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000057 int, PyObject *);
Amaury Forgeot d'Arcf05149a2007-11-13 01:05:30 +000058static int call_trace_protected(Py_tracefunc, PyObject *,
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +010059 PyThreadState *, PyFrameObject *,
60 int, PyObject *);
61static void call_exc_trace(Py_tracefunc, PyObject *,
62 PyThreadState *, PyFrameObject *);
Tim Peters8a5c3c72004-04-05 19:36:21 +000063static int maybe_call_line_trace(Py_tracefunc, PyObject *,
Eric Snow2ebc5ce2017-09-07 23:51:28 -060064 PyThreadState *, PyFrameObject *,
65 int *, int *, int *);
Łukasz Langaa785c872016-09-09 17:37:37 -070066static void maybe_dtrace_line(PyFrameObject *, int *, int *, int *);
67static void dtrace_function_entry(PyFrameObject *);
68static void dtrace_function_return(PyFrameObject *);
Michael W. Hudsondd32a912002-08-15 14:59:02 +000069
Victor Stinner438a12d2019-05-24 17:01:38 +020070static PyObject * cmp_outcome(PyThreadState *, int, PyObject *, PyObject *);
71static PyObject * import_name(PyThreadState *, PyFrameObject *,
72 PyObject *, PyObject *, PyObject *);
73static PyObject * import_from(PyThreadState *, PyObject *, PyObject *);
74static int import_all_from(PyThreadState *, PyObject *, PyObject *);
75static void format_exc_check_arg(PyThreadState *, PyObject *, const char *, PyObject *);
76static void format_exc_unbound(PyThreadState *tstate, PyCodeObject *co, int oparg);
77static PyObject * unicode_concatenate(PyThreadState *, PyObject *, PyObject *,
Serhiy Storchakaab874002016-09-11 13:48:15 +030078 PyFrameObject *, const _Py_CODEUNIT *);
Victor Stinner438a12d2019-05-24 17:01:38 +020079static PyObject * special_lookup(PyThreadState *, PyObject *, _Py_Identifier *);
80static int check_args_iterable(PyThreadState *, PyObject *func, PyObject *vararg);
81static void format_kwargs_error(PyThreadState *, PyObject *func, PyObject *kwargs);
Mark Shannonfee55262019-11-21 09:11:43 +000082static void format_awaitable_error(PyThreadState *, PyTypeObject *, int, int);
Guido van Rossum374a9221991-04-04 10:40:29 +000083
Paul Prescode68140d2000-08-30 20:25:01 +000084#define NAME_ERROR_MSG \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000085 "name '%.200s' is not defined"
Paul Prescode68140d2000-08-30 20:25:01 +000086#define UNBOUNDLOCAL_ERROR_MSG \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000087 "local variable '%.200s' referenced before assignment"
Jeremy Hyltonc76770c2001-04-13 16:51:46 +000088#define UNBOUNDFREE_ERROR_MSG \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +000089 "free variable '%.200s' referenced before assignment" \
90 " in enclosing scope"
Guido van Rossum374a9221991-04-04 10:40:29 +000091
Guido van Rossum950361c1997-01-24 13:49:28 +000092/* Dynamic execution profile */
93#ifdef DYNAMIC_EXECUTION_PROFILE
94#ifdef DXPAIRS
95static long dxpairs[257][256];
96#define dxp dxpairs[256]
97#else
98static long dxp[256];
99#endif
100#endif
101
Inada Naoki91234a12019-06-03 21:30:58 +0900102/* per opcode cache */
Inada Naokieddef862019-06-04 07:38:10 +0900103#ifdef Py_DEBUG
104// --with-pydebug is used to find memory leak. opcache makes it harder.
105// So we disable opcache when Py_DEBUG is defined.
106// See bpo-37146
107#define OPCACHE_MIN_RUNS 0 /* disable opcache */
108#else
Inada Naoki91234a12019-06-03 21:30:58 +0900109#define OPCACHE_MIN_RUNS 1024 /* create opcache when code executed this time */
Inada Naokieddef862019-06-04 07:38:10 +0900110#endif
Inada Naoki91234a12019-06-03 21:30:58 +0900111#define OPCACHE_STATS 0 /* Enable stats */
112
113#if OPCACHE_STATS
114static size_t opcache_code_objects = 0;
115static size_t opcache_code_objects_extra_mem = 0;
116
117static size_t opcache_global_opts = 0;
118static size_t opcache_global_hits = 0;
119static size_t opcache_global_misses = 0;
120#endif
121
Victor Stinnere225beb2019-06-03 18:14:24 +0200122#define GIL_REQUEST _Py_atomic_load_relaxed(&ceval->gil_drop_request)
Inada Naoki91234a12019-06-03 21:30:58 +0900123
Jeffrey Yasskin39370832010-05-03 19:29:34 +0000124/* This can set eval_breaker to 0 even though gil_drop_request became
125 1. We believe this is all right because the eval loop will release
126 the GIL eventually anyway. */
Victor Stinnere225beb2019-06-03 18:14:24 +0200127#define COMPUTE_EVAL_BREAKER(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000128 _Py_atomic_store_relaxed( \
Victor Stinnere225beb2019-06-03 18:14:24 +0200129 &(ceval)->eval_breaker, \
130 GIL_REQUEST | \
131 _Py_atomic_load_relaxed(&(ceval)->signals_pending) | \
132 _Py_atomic_load_relaxed(&(ceval)->pending.calls_to_do) | \
133 (ceval)->pending.async_exc)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000134
Victor Stinnere225beb2019-06-03 18:14:24 +0200135#define SET_GIL_DROP_REQUEST(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000136 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200137 _Py_atomic_store_relaxed(&(ceval)->gil_drop_request, 1); \
138 _Py_atomic_store_relaxed(&(ceval)->eval_breaker, 1); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000139 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000140
Victor Stinnere225beb2019-06-03 18:14:24 +0200141#define RESET_GIL_DROP_REQUEST(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000142 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200143 _Py_atomic_store_relaxed(&(ceval)->gil_drop_request, 0); \
144 COMPUTE_EVAL_BREAKER(ceval); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000145 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000146
Jeffrey Yasskin39370832010-05-03 19:29:34 +0000147/* Pending calls are only modified under pending_lock */
Victor Stinnere225beb2019-06-03 18:14:24 +0200148#define SIGNAL_PENDING_CALLS(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000149 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200150 _Py_atomic_store_relaxed(&(ceval)->pending.calls_to_do, 1); \
151 _Py_atomic_store_relaxed(&(ceval)->eval_breaker, 1); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000152 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000153
Victor Stinnere225beb2019-06-03 18:14:24 +0200154#define UNSIGNAL_PENDING_CALLS(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000155 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200156 _Py_atomic_store_relaxed(&(ceval)->pending.calls_to_do, 0); \
157 COMPUTE_EVAL_BREAKER(ceval); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000158 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000159
Victor Stinnere225beb2019-06-03 18:14:24 +0200160#define SIGNAL_PENDING_SIGNALS(ceval) \
Eric Snowfdf282d2019-01-11 14:26:55 -0700161 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200162 _Py_atomic_store_relaxed(&(ceval)->signals_pending, 1); \
163 _Py_atomic_store_relaxed(&(ceval)->eval_breaker, 1); \
Eric Snowfdf282d2019-01-11 14:26:55 -0700164 } while (0)
165
Victor Stinnere225beb2019-06-03 18:14:24 +0200166#define UNSIGNAL_PENDING_SIGNALS(ceval) \
Eric Snowfdf282d2019-01-11 14:26:55 -0700167 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200168 _Py_atomic_store_relaxed(&(ceval)->signals_pending, 0); \
169 COMPUTE_EVAL_BREAKER(ceval); \
Eric Snowfdf282d2019-01-11 14:26:55 -0700170 } while (0)
171
Victor Stinnere225beb2019-06-03 18:14:24 +0200172#define SIGNAL_ASYNC_EXC(ceval) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000173 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200174 (ceval)->pending.async_exc = 1; \
175 _Py_atomic_store_relaxed(&(ceval)->eval_breaker, 1); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000176 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000177
Victor Stinnere225beb2019-06-03 18:14:24 +0200178#define UNSIGNAL_ASYNC_EXC(ceval) \
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600179 do { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200180 (ceval)->pending.async_exc = 0; \
181 COMPUTE_EVAL_BREAKER(ceval); \
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600182 } while (0)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000183
184
Thomas Wouters0e3f5912006-08-11 14:57:12 +0000185#ifdef HAVE_ERRNO_H
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000186#include <errno.h>
Guido van Rossum2571cc81999-04-07 16:07:23 +0000187#endif
Guido van Rossum49b56061998-10-01 20:42:43 +0000188#include "pythread.h"
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000189#include "ceval_gil.h"
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000190
Tim Peters7f468f22004-10-11 02:40:51 +0000191int
192PyEval_ThreadsInitialized(void)
193{
Victor Stinner01b1cc12019-11-20 02:27:56 +0100194 _PyRuntimeState *runtime = &_PyRuntime;
195 return gil_created(&runtime->ceval.gil);
Tim Peters7f468f22004-10-11 02:40:51 +0000196}
197
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000198void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000199PyEval_InitThreads(void)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000200{
Victor Stinner09532fe2019-05-10 23:39:09 +0200201 _PyRuntimeState *runtime = &_PyRuntime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200202 struct _ceval_runtime_state *ceval = &runtime->ceval;
203 struct _gil_runtime_state *gil = &ceval->gil;
Victor Stinner09532fe2019-05-10 23:39:09 +0200204 if (gil_created(gil)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000205 return;
Victor Stinnera7126792019-03-19 14:19:38 +0100206 }
207
Inada Naoki001fee12019-02-20 10:00:09 +0900208 PyThread_init_thread();
Victor Stinner09532fe2019-05-10 23:39:09 +0200209 create_gil(gil);
210 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
Victor Stinnere225beb2019-06-03 18:14:24 +0200211 take_gil(ceval, tstate);
Eric Snow8479a342019-03-08 23:44:33 -0700212
Victor Stinnere225beb2019-06-03 18:14:24 +0200213 struct _pending_calls *pending = &ceval->pending;
214 pending->lock = PyThread_allocate_lock();
215 if (pending->lock == NULL) {
216 Py_FatalError("Can't initialize threads for pending calls");
217 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000218}
Guido van Rossumff4949e1992-08-05 19:58:53 +0000219
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000220void
Victor Stinnere225beb2019-06-03 18:14:24 +0200221_PyEval_FiniThreads(struct _ceval_runtime_state *ceval)
Antoine Pitrou1df15362010-09-13 14:16:46 +0000222{
Victor Stinnere225beb2019-06-03 18:14:24 +0200223 struct _gil_runtime_state *gil = &ceval->gil;
Victor Stinner09532fe2019-05-10 23:39:09 +0200224 if (!gil_created(gil)) {
Antoine Pitrou1df15362010-09-13 14:16:46 +0000225 return;
Victor Stinnera7126792019-03-19 14:19:38 +0100226 }
227
Victor Stinner09532fe2019-05-10 23:39:09 +0200228 destroy_gil(gil);
229 assert(!gil_created(gil));
Victor Stinner99fcc612019-04-29 13:04:07 +0200230
Victor Stinnere225beb2019-06-03 18:14:24 +0200231 struct _pending_calls *pending = &ceval->pending;
232 if (pending->lock != NULL) {
233 PyThread_free_lock(pending->lock);
234 pending->lock = NULL;
235 }
Antoine Pitrou1df15362010-09-13 14:16:46 +0000236}
237
Joannah Nanjekyef781d202019-04-29 04:38:45 -0400238static inline void
Victor Stinner01b1cc12019-11-20 02:27:56 +0100239exit_thread_if_finalizing(PyThreadState *tstate)
Joannah Nanjekyef781d202019-04-29 04:38:45 -0400240{
Victor Stinner01b1cc12019-11-20 02:27:56 +0100241 _PyRuntimeState *runtime = tstate->interp->runtime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200242 /* _Py_Finalizing is protected by the GIL */
Victor Stinner09532fe2019-05-10 23:39:09 +0200243 if (runtime->finalizing != NULL && !_Py_CURRENTLY_FINALIZING(runtime, tstate)) {
Victor Stinnere225beb2019-06-03 18:14:24 +0200244 drop_gil(&runtime->ceval, tstate);
Joannah Nanjekyef781d202019-04-29 04:38:45 -0400245 PyThread_exit_thread();
Joannah Nanjekyef781d202019-04-29 04:38:45 -0400246 }
247}
248
Antoine Pitrou1df15362010-09-13 14:16:46 +0000249void
Inada Naoki91234a12019-06-03 21:30:58 +0900250_PyEval_Fini(void)
251{
252#if OPCACHE_STATS
253 fprintf(stderr, "-- Opcode cache number of objects = %zd\n",
254 opcache_code_objects);
255
256 fprintf(stderr, "-- Opcode cache total extra mem = %zd\n",
257 opcache_code_objects_extra_mem);
258
259 fprintf(stderr, "\n");
260
261 fprintf(stderr, "-- Opcode cache LOAD_GLOBAL hits = %zd (%d%%)\n",
262 opcache_global_hits,
263 (int) (100.0 * opcache_global_hits /
264 (opcache_global_hits + opcache_global_misses)));
265
266 fprintf(stderr, "-- Opcode cache LOAD_GLOBAL misses = %zd (%d%%)\n",
267 opcache_global_misses,
268 (int) (100.0 * opcache_global_misses /
269 (opcache_global_hits + opcache_global_misses)));
270
271 fprintf(stderr, "-- Opcode cache LOAD_GLOBAL opts = %zd\n",
272 opcache_global_opts);
273
274 fprintf(stderr, "\n");
275#endif
276}
277
278void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000279PyEval_AcquireLock(void)
Guido van Rossum25ce5661997-08-02 03:10:38 +0000280{
Victor Stinner09532fe2019-05-10 23:39:09 +0200281 _PyRuntimeState *runtime = &_PyRuntime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200282 struct _ceval_runtime_state *ceval = &runtime->ceval;
Victor Stinner09532fe2019-05-10 23:39:09 +0200283 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
284 if (tstate == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000285 Py_FatalError("PyEval_AcquireLock: current thread state is NULL");
Victor Stinner09532fe2019-05-10 23:39:09 +0200286 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200287 take_gil(ceval, tstate);
Victor Stinner01b1cc12019-11-20 02:27:56 +0100288 exit_thread_if_finalizing(tstate);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000289}
290
291void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000292PyEval_ReleaseLock(void)
Guido van Rossum25ce5661997-08-02 03:10:38 +0000293{
Victor Stinner09532fe2019-05-10 23:39:09 +0200294 _PyRuntimeState *runtime = &_PyRuntime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200295 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000296 /* This function must succeed when the current thread state is NULL.
Victor Stinner50b48572018-11-01 01:51:40 +0100297 We therefore avoid PyThreadState_Get() which dumps a fatal error
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000298 in debug mode.
299 */
Victor Stinnere225beb2019-06-03 18:14:24 +0200300 drop_gil(&runtime->ceval, tstate);
Guido van Rossum25ce5661997-08-02 03:10:38 +0000301}
302
303void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000304PyEval_AcquireThread(PyThreadState *tstate)
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000305{
Victor Stinner09532fe2019-05-10 23:39:09 +0200306 if (tstate == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000307 Py_FatalError("PyEval_AcquireThread: NULL new thread state");
Victor Stinner09532fe2019-05-10 23:39:09 +0200308 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200309
Victor Stinner01b1cc12019-11-20 02:27:56 +0100310 _PyRuntimeState *runtime = tstate->interp->runtime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200311 struct _ceval_runtime_state *ceval = &runtime->ceval;
Victor Stinner09532fe2019-05-10 23:39:09 +0200312
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000313 /* Check someone has called PyEval_InitThreads() to create the lock */
Victor Stinnere225beb2019-06-03 18:14:24 +0200314 assert(gil_created(&ceval->gil));
315 take_gil(ceval, tstate);
Victor Stinner01b1cc12019-11-20 02:27:56 +0100316 exit_thread_if_finalizing(tstate);
Victor Stinner09532fe2019-05-10 23:39:09 +0200317 if (_PyThreadState_Swap(&runtime->gilstate, tstate) != NULL) {
318 Py_FatalError("PyEval_AcquireThread: non-NULL old thread state");
319 }
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000320}
321
322void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000323PyEval_ReleaseThread(PyThreadState *tstate)
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000324{
Victor Stinner09532fe2019-05-10 23:39:09 +0200325 if (tstate == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000326 Py_FatalError("PyEval_ReleaseThread: NULL thread state");
Victor Stinner09532fe2019-05-10 23:39:09 +0200327 }
328
Victor Stinner01b1cc12019-11-20 02:27:56 +0100329 _PyRuntimeState *runtime = tstate->interp->runtime;
Victor Stinner09532fe2019-05-10 23:39:09 +0200330 PyThreadState *new_tstate = _PyThreadState_Swap(&runtime->gilstate, NULL);
331 if (new_tstate != tstate) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000332 Py_FatalError("PyEval_ReleaseThread: wrong thread state");
Victor Stinner09532fe2019-05-10 23:39:09 +0200333 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200334 drop_gil(&runtime->ceval, tstate);
Guido van Rossum9cc8a201997-07-19 19:55:50 +0000335}
Guido van Rossumfee3a2d2000-08-27 17:34:07 +0000336
Antoine Pitrouf7ecfac2017-05-28 11:35:14 +0200337/* This function is called from PyOS_AfterFork_Child to destroy all threads
338 * which are not running in the child process, and clear internal locks
339 * which might be held by those threads.
340 */
Guido van Rossumfee3a2d2000-08-27 17:34:07 +0000341
342void
Victor Stinnerd5d9e812019-05-13 12:35:37 +0200343_PyEval_ReInitThreads(_PyRuntimeState *runtime)
Guido van Rossumfee3a2d2000-08-27 17:34:07 +0000344{
Victor Stinnere225beb2019-06-03 18:14:24 +0200345 struct _ceval_runtime_state *ceval = &runtime->ceval;
346 if (!gil_created(&ceval->gil)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000347 return;
Victor Stinner09532fe2019-05-10 23:39:09 +0200348 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200349 recreate_gil(&ceval->gil);
Victor Stinner09532fe2019-05-10 23:39:09 +0200350 PyThreadState *current_tstate = _PyRuntimeState_GetThreadState(runtime);
Victor Stinnere225beb2019-06-03 18:14:24 +0200351 take_gil(ceval, current_tstate);
Eric Snow8479a342019-03-08 23:44:33 -0700352
Victor Stinnere225beb2019-06-03 18:14:24 +0200353 struct _pending_calls *pending = &ceval->pending;
Victor Stinner09532fe2019-05-10 23:39:09 +0200354 pending->lock = PyThread_allocate_lock();
355 if (pending->lock == NULL) {
Eric Snow8479a342019-03-08 23:44:33 -0700356 Py_FatalError("Can't initialize threads for pending calls");
357 }
Jesse Nollera8513972008-07-17 16:49:17 +0000358
Antoine Pitrou8408cea2013-05-05 23:47:09 +0200359 /* Destroy all threads except the current one */
Victor Stinner0fd2c302019-06-04 03:15:09 +0200360 _PyThreadState_DeleteExcept(runtime, current_tstate);
Guido van Rossumfee3a2d2000-08-27 17:34:07 +0000361}
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000362
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000363/* This function is used to signal that async exceptions are waiting to be
Zackery Spytzeef05962018-09-29 10:07:11 -0600364 raised. */
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000365
366void
Victor Stinnere225beb2019-06-03 18:14:24 +0200367_PyEval_SignalAsyncExc(struct _ceval_runtime_state *ceval)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000368{
Victor Stinnere225beb2019-06-03 18:14:24 +0200369 SIGNAL_ASYNC_EXC(ceval);
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000370}
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000371
Guido van Rossum2fca21f71997-07-18 23:56:58 +0000372PyThreadState *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000373PyEval_SaveThread(void)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000374{
Victor Stinner09532fe2019-05-10 23:39:09 +0200375 _PyRuntimeState *runtime = &_PyRuntime;
Victor Stinnere225beb2019-06-03 18:14:24 +0200376 struct _ceval_runtime_state *ceval = &runtime->ceval;
Victor Stinner09532fe2019-05-10 23:39:09 +0200377 PyThreadState *tstate = _PyThreadState_Swap(&runtime->gilstate, NULL);
378 if (tstate == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000379 Py_FatalError("PyEval_SaveThread: NULL tstate");
Victor Stinner09532fe2019-05-10 23:39:09 +0200380 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200381 assert(gil_created(&ceval->gil));
382 drop_gil(ceval, tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000383 return tstate;
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000384}
385
386void
Thomas Woutersf70ef4f2000-07-22 18:47:25 +0000387PyEval_RestoreThread(PyThreadState *tstate)
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000388{
Victor Stinner01b1cc12019-11-20 02:27:56 +0100389 _PyRuntimeState *runtime = tstate->interp->runtime;
Victor Stinner0fd2c302019-06-04 03:15:09 +0200390 struct _ceval_runtime_state *ceval = &runtime->ceval;
391
Victor Stinner09532fe2019-05-10 23:39:09 +0200392 if (tstate == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000393 Py_FatalError("PyEval_RestoreThread: NULL tstate");
Victor Stinner09532fe2019-05-10 23:39:09 +0200394 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200395 assert(gil_created(&ceval->gil));
Victor Stinner2914bb32018-01-29 11:57:45 +0100396
397 int err = errno;
Victor Stinnere225beb2019-06-03 18:14:24 +0200398 take_gil(ceval, tstate);
Victor Stinner01b1cc12019-11-20 02:27:56 +0100399 exit_thread_if_finalizing(tstate);
Victor Stinner2914bb32018-01-29 11:57:45 +0100400 errno = err;
401
Victor Stinner09532fe2019-05-10 23:39:09 +0200402 _PyThreadState_Swap(&runtime->gilstate, tstate);
Guido van Rossum1984f1e1992-08-04 12:41:02 +0000403}
404
405
Guido van Rossuma9672091994-09-14 13:31:22 +0000406/* Mechanism whereby asynchronously executing callbacks (e.g. UNIX
407 signal handlers or Mac I/O completion routines) can schedule calls
408 to a function to be called synchronously.
409 The synchronous function is called with one void* argument.
410 It should return 0 for success or -1 for failure -- failure should
411 be accompanied by an exception.
412
413 If registry succeeds, the registry function returns 0; if it fails
414 (e.g. due to too many pending calls) it returns -1 (without setting
415 an exception condition).
416
417 Note that because registry may occur from within signal handlers,
418 or other asynchronous events, calling malloc() is unsafe!
419
Guido van Rossuma9672091994-09-14 13:31:22 +0000420 Any thread can schedule pending calls, but only the main thread
421 will execute them.
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000422 There is no facility to schedule calls to a particular thread, but
423 that should be easy to change, should that ever be required. In
424 that case, the static variables here should go into the python
425 threadstate.
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000426*/
Guido van Rossuma9672091994-09-14 13:31:22 +0000427
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200428void
Victor Stinnere225beb2019-06-03 18:14:24 +0200429_PyEval_SignalReceived(struct _ceval_runtime_state *ceval)
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200430{
431 /* bpo-30703: Function called when the C signal handler of Python gets a
432 signal. We cannot queue a callback using Py_AddPendingCall() since
433 that function is not async-signal-safe. */
Victor Stinnere225beb2019-06-03 18:14:24 +0200434 SIGNAL_PENDING_SIGNALS(ceval);
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200435}
436
Eric Snow5be45a62019-03-08 22:47:07 -0700437/* Push one item onto the queue while holding the lock. */
438static int
Victor Stinnere225beb2019-06-03 18:14:24 +0200439_push_pending_call(struct _pending_calls *pending,
Eric Snow842a2f02019-03-15 15:47:51 -0600440 int (*func)(void *), void *arg)
Eric Snow5be45a62019-03-08 22:47:07 -0700441{
Eric Snow842a2f02019-03-15 15:47:51 -0600442 int i = pending->last;
Eric Snow5be45a62019-03-08 22:47:07 -0700443 int j = (i + 1) % NPENDINGCALLS;
Eric Snow842a2f02019-03-15 15:47:51 -0600444 if (j == pending->first) {
Eric Snow5be45a62019-03-08 22:47:07 -0700445 return -1; /* Queue full */
446 }
Eric Snow842a2f02019-03-15 15:47:51 -0600447 pending->calls[i].func = func;
448 pending->calls[i].arg = arg;
449 pending->last = j;
Eric Snow5be45a62019-03-08 22:47:07 -0700450 return 0;
451}
452
453/* Pop one item off the queue while holding the lock. */
454static void
Victor Stinnere225beb2019-06-03 18:14:24 +0200455_pop_pending_call(struct _pending_calls *pending,
Eric Snow842a2f02019-03-15 15:47:51 -0600456 int (**func)(void *), void **arg)
Eric Snow5be45a62019-03-08 22:47:07 -0700457{
Eric Snow842a2f02019-03-15 15:47:51 -0600458 int i = pending->first;
459 if (i == pending->last) {
Eric Snow5be45a62019-03-08 22:47:07 -0700460 return; /* Queue empty */
461 }
462
Eric Snow842a2f02019-03-15 15:47:51 -0600463 *func = pending->calls[i].func;
464 *arg = pending->calls[i].arg;
465 pending->first = (i + 1) % NPENDINGCALLS;
Eric Snow5be45a62019-03-08 22:47:07 -0700466}
467
Antoine Pitroua6a4dc82017-09-07 18:56:24 +0200468/* This implementation is thread-safe. It allows
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000469 scheduling to be made from any thread, and even from an executing
470 callback.
471 */
472
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000473int
Victor Stinner438a12d2019-05-24 17:01:38 +0200474_PyEval_AddPendingCall(PyThreadState *tstate,
Victor Stinnere225beb2019-06-03 18:14:24 +0200475 struct _ceval_runtime_state *ceval,
Victor Stinner09532fe2019-05-10 23:39:09 +0200476 int (*func)(void *), void *arg)
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000477{
Victor Stinnere225beb2019-06-03 18:14:24 +0200478 struct _pending_calls *pending = &ceval->pending;
Eric Snow842a2f02019-03-15 15:47:51 -0600479
480 PyThread_acquire_lock(pending->lock, WAIT_LOCK);
481 if (pending->finishing) {
482 PyThread_release_lock(pending->lock);
483
484 PyObject *exc, *val, *tb;
Victor Stinner438a12d2019-05-24 17:01:38 +0200485 _PyErr_Fetch(tstate, &exc, &val, &tb);
486 _PyErr_SetString(tstate, PyExc_SystemError,
Eric Snow842a2f02019-03-15 15:47:51 -0600487 "Py_AddPendingCall: cannot add pending calls "
488 "(Python shutting down)");
Victor Stinner438a12d2019-05-24 17:01:38 +0200489 _PyErr_Print(tstate);
490 _PyErr_Restore(tstate, exc, val, tb);
Eric Snow842a2f02019-03-15 15:47:51 -0600491 return -1;
492 }
Victor Stinnere225beb2019-06-03 18:14:24 +0200493 int result = _push_pending_call(pending, func, arg);
Eric Snow842a2f02019-03-15 15:47:51 -0600494 PyThread_release_lock(pending->lock);
Eric Snow5be45a62019-03-08 22:47:07 -0700495
Victor Stinnere225beb2019-06-03 18:14:24 +0200496 /* signal main loop */
497 SIGNAL_PENDING_CALLS(ceval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000498 return result;
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000499}
500
Victor Stinner09532fe2019-05-10 23:39:09 +0200501int
502Py_AddPendingCall(int (*func)(void *), void *arg)
503{
Victor Stinner438a12d2019-05-24 17:01:38 +0200504 _PyRuntimeState *runtime = &_PyRuntime;
505 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
Victor Stinnere225beb2019-06-03 18:14:24 +0200506 return _PyEval_AddPendingCall(tstate, &runtime->ceval, func, arg);
Victor Stinner09532fe2019-05-10 23:39:09 +0200507}
508
Eric Snowfdf282d2019-01-11 14:26:55 -0700509static int
Victor Stinner09532fe2019-05-10 23:39:09 +0200510handle_signals(_PyRuntimeState *runtime)
Eric Snowfdf282d2019-01-11 14:26:55 -0700511{
Eric Snow5be45a62019-03-08 22:47:07 -0700512 /* Only handle signals on main thread. PyEval_InitThreads must
513 * have been called already.
514 */
Victor Stinner09532fe2019-05-10 23:39:09 +0200515 if (PyThread_get_thread_ident() != runtime->main_thread) {
Eric Snowfdf282d2019-01-11 14:26:55 -0700516 return 0;
517 }
Eric Snow64d6cc82019-02-23 15:40:43 -0700518 /*
519 * Ensure that the thread isn't currently running some other
520 * interpreter.
521 */
Victor Stinner09532fe2019-05-10 23:39:09 +0200522 PyInterpreterState *interp = _PyRuntimeState_GetThreadState(runtime)->interp;
523 if (interp != runtime->interpreters.main) {
Eric Snow64d6cc82019-02-23 15:40:43 -0700524 return 0;
525 }
Eric Snowfdf282d2019-01-11 14:26:55 -0700526
Victor Stinnere225beb2019-06-03 18:14:24 +0200527 struct _ceval_runtime_state *ceval = &runtime->ceval;
528 UNSIGNAL_PENDING_SIGNALS(ceval);
Eric Snow64d6cc82019-02-23 15:40:43 -0700529 if (_PyErr_CheckSignals() < 0) {
Victor Stinnere225beb2019-06-03 18:14:24 +0200530 SIGNAL_PENDING_SIGNALS(ceval); /* We're not done yet */
Eric Snowfdf282d2019-01-11 14:26:55 -0700531 return -1;
532 }
533 return 0;
534}
535
536static int
Victor Stinnere225beb2019-06-03 18:14:24 +0200537make_pending_calls(_PyRuntimeState *runtime)
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000538{
Eric Snow6a150bc2019-06-01 15:39:46 -0600539 static int busy = 0;
Eric Snowb75b1a352019-04-12 10:20:10 -0600540
Victor Stinnere225beb2019-06-03 18:14:24 +0200541 /* only service pending calls on main thread */
542 if (PyThread_get_thread_ident() != runtime->main_thread) {
543 return 0;
544 }
545
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000546 /* don't perform recursive pending calls */
Eric Snowfdf282d2019-01-11 14:26:55 -0700547 if (busy) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000548 return 0;
Eric Snowfdf282d2019-01-11 14:26:55 -0700549 }
Charles-François Natalif23339a2011-07-23 18:15:43 +0200550 busy = 1;
Victor Stinnere225beb2019-06-03 18:14:24 +0200551 struct _ceval_runtime_state *ceval = &runtime->ceval;
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200552 /* unsignal before starting to call callbacks, so that any callback
553 added in-between re-signals */
Victor Stinnere225beb2019-06-03 18:14:24 +0200554 UNSIGNAL_PENDING_CALLS(ceval);
Eric Snowfdf282d2019-01-11 14:26:55 -0700555 int res = 0;
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200556
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000557 /* perform a bounded number of calls, in case of recursion */
Victor Stinnere225beb2019-06-03 18:14:24 +0200558 struct _pending_calls *pending = &ceval->pending;
Eric Snowfdf282d2019-01-11 14:26:55 -0700559 for (int i=0; i<NPENDINGCALLS; i++) {
Eric Snow5be45a62019-03-08 22:47:07 -0700560 int (*func)(void *) = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000561 void *arg = NULL;
562
563 /* pop one item off the queue while holding the lock */
Eric Snow842a2f02019-03-15 15:47:51 -0600564 PyThread_acquire_lock(pending->lock, WAIT_LOCK);
Victor Stinnere225beb2019-06-03 18:14:24 +0200565 _pop_pending_call(pending, &func, &arg);
Eric Snow842a2f02019-03-15 15:47:51 -0600566 PyThread_release_lock(pending->lock);
Eric Snow5be45a62019-03-08 22:47:07 -0700567
Victor Stinner4d61e6e2019-03-04 14:21:28 +0100568 /* having released the lock, perform the callback */
Eric Snow5be45a62019-03-08 22:47:07 -0700569 if (func == NULL) {
Victor Stinner4d61e6e2019-03-04 14:21:28 +0100570 break;
Eric Snow5be45a62019-03-08 22:47:07 -0700571 }
Eric Snowfdf282d2019-01-11 14:26:55 -0700572 res = func(arg);
573 if (res) {
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200574 goto error;
575 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000576 }
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200577
Charles-François Natalif23339a2011-07-23 18:15:43 +0200578 busy = 0;
Eric Snowfdf282d2019-01-11 14:26:55 -0700579 return res;
Antoine Pitrouc08177a2017-06-28 23:29:29 +0200580
581error:
582 busy = 0;
Victor Stinnere225beb2019-06-03 18:14:24 +0200583 SIGNAL_PENDING_CALLS(ceval);
Eric Snowfdf282d2019-01-11 14:26:55 -0700584 return res;
585}
586
Eric Snow842a2f02019-03-15 15:47:51 -0600587void
Victor Stinnere225beb2019-06-03 18:14:24 +0200588_Py_FinishPendingCalls(_PyRuntimeState *runtime)
Eric Snow842a2f02019-03-15 15:47:51 -0600589{
Eric Snow842a2f02019-03-15 15:47:51 -0600590 assert(PyGILState_Check());
591
Victor Stinnere225beb2019-06-03 18:14:24 +0200592 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
593 struct _pending_calls *pending = &runtime->ceval.pending;
Victor Stinner09532fe2019-05-10 23:39:09 +0200594
Eric Snow842a2f02019-03-15 15:47:51 -0600595 PyThread_acquire_lock(pending->lock, WAIT_LOCK);
596 pending->finishing = 1;
597 PyThread_release_lock(pending->lock);
598
599 if (!_Py_atomic_load_relaxed(&(pending->calls_to_do))) {
600 return;
601 }
602
Victor Stinnere225beb2019-06-03 18:14:24 +0200603 if (make_pending_calls(runtime) < 0) {
604 PyObject *exc, *val, *tb;
605 _PyErr_Fetch(tstate, &exc, &val, &tb);
606 PyErr_BadInternalCall();
607 _PyErr_ChainExceptions(exc, val, tb);
608 _PyErr_Print(tstate);
Eric Snow842a2f02019-03-15 15:47:51 -0600609 }
610}
611
Eric Snowfdf282d2019-01-11 14:26:55 -0700612/* Py_MakePendingCalls() is a simple wrapper for the sake
613 of backward-compatibility. */
614int
615Py_MakePendingCalls(void)
616{
617 assert(PyGILState_Check());
618
619 /* Python signal handler doesn't really queue a callback: it only signals
620 that a signal was received, see _PyEval_SignalReceived(). */
Victor Stinner09532fe2019-05-10 23:39:09 +0200621 _PyRuntimeState *runtime = &_PyRuntime;
622 int res = handle_signals(runtime);
Eric Snowfdf282d2019-01-11 14:26:55 -0700623 if (res != 0) {
624 return res;
625 }
626
Victor Stinnere225beb2019-06-03 18:14:24 +0200627 res = make_pending_calls(runtime);
Eric Snowb75b1a352019-04-12 10:20:10 -0600628 if (res != 0) {
629 return res;
630 }
631
632 return 0;
Benjamin Petersone5bf3832009-01-17 23:43:58 +0000633}
634
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000635/* The interpreter's recursion limit */
636
Hye-Shik Changb6fa2812005-04-04 15:49:02 +0000637#ifndef Py_DEFAULT_RECURSION_LIMIT
638#define Py_DEFAULT_RECURSION_LIMIT 1000
639#endif
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600640
Eric Snow05351c12017-09-05 21:43:08 -0700641int _Py_CheckRecursionLimit = Py_DEFAULT_RECURSION_LIMIT;
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000642
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600643void
Victor Stinnere225beb2019-06-03 18:14:24 +0200644_PyEval_Initialize(struct _ceval_runtime_state *state)
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600645{
Victor Stinnere225beb2019-06-03 18:14:24 +0200646 state->recursion_limit = Py_DEFAULT_RECURSION_LIMIT;
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600647 _Py_CheckRecursionLimit = Py_DEFAULT_RECURSION_LIMIT;
Victor Stinnere225beb2019-06-03 18:14:24 +0200648 _gil_initialize(&state->gil);
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600649}
650
Vladimir Marangozov7bd25be2000-09-01 11:07:19 +0000651int
652Py_GetRecursionLimit(void)
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000653{
Victor Stinner01b1cc12019-11-20 02:27:56 +0100654 struct _ceval_runtime_state *ceval = &_PyRuntime.ceval;
655 return ceval->recursion_limit;
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000656}
657
Vladimir Marangozov7bd25be2000-09-01 11:07:19 +0000658void
659Py_SetRecursionLimit(int new_limit)
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000660{
Victor Stinnere225beb2019-06-03 18:14:24 +0200661 struct _ceval_runtime_state *ceval = &_PyRuntime.ceval;
662 ceval->recursion_limit = new_limit;
663 _Py_CheckRecursionLimit = ceval->recursion_limit;
Jeremy Hyltonee5adfb2000-08-31 19:23:01 +0000664}
665
Victor Stinnerbe434dc2019-11-05 00:51:22 +0100666/* The function _Py_EnterRecursiveCall() only calls _Py_CheckRecursiveCall()
Armin Rigo2b3eb402003-10-28 12:05:48 +0000667 if the recursion_depth reaches _Py_CheckRecursionLimit.
668 If USE_STACKCHECK, the macro decrements _Py_CheckRecursionLimit
669 to guarantee that _Py_CheckRecursiveCall() is regularly called.
670 Without USE_STACKCHECK, there is no need for this. */
671int
Victor Stinnerbe434dc2019-11-05 00:51:22 +0100672_Py_CheckRecursiveCall(PyThreadState *tstate, const char *where)
Armin Rigo2b3eb402003-10-28 12:05:48 +0000673{
Victor Stinner01b1cc12019-11-20 02:27:56 +0100674 _PyRuntimeState *runtime = tstate->interp->runtime;
Victor Stinner09532fe2019-05-10 23:39:09 +0200675 int recursion_limit = runtime->ceval.recursion_limit;
Armin Rigo2b3eb402003-10-28 12:05:48 +0000676
677#ifdef USE_STACKCHECK
pdox18967932017-10-25 23:03:01 -0700678 tstate->stackcheck_counter = 0;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000679 if (PyOS_CheckStack()) {
680 --tstate->recursion_depth;
Victor Stinner438a12d2019-05-24 17:01:38 +0200681 _PyErr_SetString(tstate, PyExc_MemoryError, "Stack overflow");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000682 return -1;
683 }
pdox18967932017-10-25 23:03:01 -0700684 /* Needed for ABI backwards-compatibility (see bpo-31857) */
Eric Snow05351c12017-09-05 21:43:08 -0700685 _Py_CheckRecursionLimit = recursion_limit;
pdox18967932017-10-25 23:03:01 -0700686#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000687 if (tstate->recursion_critical)
688 /* Somebody asked that we don't check for recursion. */
689 return 0;
690 if (tstate->overflowed) {
691 if (tstate->recursion_depth > recursion_limit + 50) {
692 /* Overflowing while handling an overflow. Give up. */
693 Py_FatalError("Cannot recover from stack overflow.");
694 }
695 return 0;
696 }
697 if (tstate->recursion_depth > recursion_limit) {
698 --tstate->recursion_depth;
699 tstate->overflowed = 1;
Victor Stinner438a12d2019-05-24 17:01:38 +0200700 _PyErr_Format(tstate, PyExc_RecursionError,
701 "maximum recursion depth exceeded%s",
702 where);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000703 return -1;
704 }
705 return 0;
Armin Rigo2b3eb402003-10-28 12:05:48 +0000706}
707
Victor Stinner09532fe2019-05-10 23:39:09 +0200708static int do_raise(PyThreadState *tstate, PyObject *exc, PyObject *cause);
Victor Stinner438a12d2019-05-24 17:01:38 +0200709static int unpack_iterable(PyThreadState *, PyObject *, int, int, PyObject **);
Guido van Rossum1aa14831997-01-21 05:34:20 +0000710
Victor Stinnere225beb2019-06-03 18:14:24 +0200711#define _Py_TracingPossible(ceval) ((ceval)->tracing_possible)
Antoine Pitrou074e5ed2009-11-10 19:50:40 +0000712
Guido van Rossum374a9221991-04-04 10:40:29 +0000713
Guido van Rossumb209a111997-04-29 18:18:01 +0000714PyObject *
Martin v. Löwis4d0d4712010-12-03 20:14:31 +0000715PyEval_EvalCode(PyObject *co, PyObject *globals, PyObject *locals)
Guido van Rossum681d79a1995-07-18 14:51:37 +0000716{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000717 return PyEval_EvalCodeEx(co,
718 globals, locals,
719 (PyObject **)NULL, 0,
720 (PyObject **)NULL, 0,
721 (PyObject **)NULL, 0,
722 NULL, NULL);
Guido van Rossum681d79a1995-07-18 14:51:37 +0000723}
724
725
726/* Interpreter main loop */
727
Martin v. Löwis8d97e332004-06-27 15:43:12 +0000728PyObject *
Victor Stinnerb9e68122019-11-14 12:20:46 +0100729PyEval_EvalFrame(PyFrameObject *f)
730{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000731 /* This is for backward compatibility with extension modules that
732 used this API; core interpreter code should call
733 PyEval_EvalFrameEx() */
Victor Stinnerb9e68122019-11-14 12:20:46 +0100734 PyThreadState *tstate = _PyThreadState_GET();
735 return _PyEval_EvalFrame(tstate, f, 0);
Phillip J. Eby0d6615f2005-08-02 00:46:46 +0000736}
737
738PyObject *
Thomas Wouters49fd7fa2006-04-21 10:40:58 +0000739PyEval_EvalFrameEx(PyFrameObject *f, int throwflag)
Guido van Rossum374a9221991-04-04 10:40:29 +0000740{
Victor Stinnerb9e68122019-11-14 12:20:46 +0100741 PyThreadState *tstate = _PyThreadState_GET();
742 return _PyEval_EvalFrame(tstate, f, throwflag);
Brett Cannon3cebf932016-09-05 15:33:46 -0700743}
744
Victor Stinnerc6944e72016-11-11 02:13:35 +0100745PyObject* _Py_HOT_FUNCTION
Brett Cannon3cebf932016-09-05 15:33:46 -0700746_PyEval_EvalFrameDefault(PyFrameObject *f, int throwflag)
747{
Guido van Rossum950361c1997-01-24 13:49:28 +0000748#ifdef DXPAIRS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000749 int lastopcode = 0;
Guido van Rossum950361c1997-01-24 13:49:28 +0000750#endif
Antoine Pitrou9ed5f272013-08-13 20:18:52 +0200751 PyObject **stack_pointer; /* Next free slot in value stack */
Serhiy Storchakaab874002016-09-11 13:48:15 +0300752 const _Py_CODEUNIT *next_instr;
Antoine Pitrou9ed5f272013-08-13 20:18:52 +0200753 int opcode; /* Current opcode */
754 int oparg; /* Current opcode argument, if any */
Antoine Pitrou9ed5f272013-08-13 20:18:52 +0200755 PyObject **fastlocals, **freevars;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000756 PyObject *retval = NULL; /* Return value */
Victor Stinner09532fe2019-05-10 23:39:09 +0200757 _PyRuntimeState * const runtime = &_PyRuntime;
758 PyThreadState * const tstate = _PyRuntimeState_GetThreadState(runtime);
Victor Stinnere225beb2019-06-03 18:14:24 +0200759 struct _ceval_runtime_state * const ceval = &runtime->ceval;
760 _Py_atomic_int * const eval_breaker = &ceval->eval_breaker;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000761 PyCodeObject *co;
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000762
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000763 /* when tracing we set things up so that
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000764
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000765 not (instr_lb <= current_bytecode_offset < instr_ub)
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000766
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000767 is true when the line being executed has changed. The
768 initial values are such as to make this false the first
769 time it is tested. */
770 int instr_ub = -1, instr_lb = 0, instr_prev = -1;
Michael W. Hudsondd32a912002-08-15 14:59:02 +0000771
Serhiy Storchakaab874002016-09-11 13:48:15 +0300772 const _Py_CODEUNIT *first_instr;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000773 PyObject *names;
774 PyObject *consts;
Inada Naoki91234a12019-06-03 21:30:58 +0900775 _PyOpcache *co_opcache;
Guido van Rossum374a9221991-04-04 10:40:29 +0000776
Brett Cannon368b4b72012-04-02 12:17:59 -0400777#ifdef LLTRACE
Victor Stinner3c1e4812012-03-26 22:10:51 +0200778 _Py_IDENTIFIER(__ltrace__);
Brett Cannon368b4b72012-04-02 12:17:59 -0400779#endif
Victor Stinner3c1e4812012-03-26 22:10:51 +0200780
Antoine Pitroub52ec782009-01-25 16:34:23 +0000781/* Computed GOTOs, or
782 the-optimization-commonly-but-improperly-known-as-"threaded code"
783 using gcc's labels-as-values extension
784 (http://gcc.gnu.org/onlinedocs/gcc/Labels-as-Values.html).
785
786 The traditional bytecode evaluation loop uses a "switch" statement, which
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000787 decent compilers will optimize as a single indirect branch instruction
Antoine Pitroub52ec782009-01-25 16:34:23 +0000788 combined with a lookup table of jump addresses. However, since the
789 indirect jump instruction is shared by all opcodes, the CPU will have a
790 hard time making the right prediction for where to jump next (actually,
791 it will be always wrong except in the uncommon case of a sequence of
792 several identical opcodes).
793
794 "Threaded code" in contrast, uses an explicit jump table and an explicit
795 indirect jump instruction at the end of each opcode. Since the jump
796 instruction is at a different address for each opcode, the CPU will make a
797 separate prediction for each of these instructions, which is equivalent to
798 predicting the second opcode of each opcode pair. These predictions have
799 a much better chance to turn out valid, especially in small bytecode loops.
800
801 A mispredicted branch on a modern CPU flushes the whole pipeline and
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000802 can cost several CPU cycles (depending on the pipeline depth),
Antoine Pitroub52ec782009-01-25 16:34:23 +0000803 and potentially many more instructions (depending on the pipeline width).
804 A correctly predicted branch, however, is nearly free.
805
806 At the time of this writing, the "threaded code" version is up to 15-20%
807 faster than the normal "switch" version, depending on the compiler and the
808 CPU architecture.
809
810 We disable the optimization if DYNAMIC_EXECUTION_PROFILE is defined,
811 because it would render the measurements invalid.
812
813
814 NOTE: care must be taken that the compiler doesn't try to "optimize" the
815 indirect jumps by sharing them between all opcodes. Such optimizations
816 can be disabled on gcc by using the -fno-gcse flag (or possibly
817 -fno-crossjumping).
818*/
819
Antoine Pitrou042b1282010-08-13 21:15:58 +0000820#ifdef DYNAMIC_EXECUTION_PROFILE
Antoine Pitroub52ec782009-01-25 16:34:23 +0000821#undef USE_COMPUTED_GOTOS
Antoine Pitrou042b1282010-08-13 21:15:58 +0000822#define USE_COMPUTED_GOTOS 0
Antoine Pitroub52ec782009-01-25 16:34:23 +0000823#endif
824
Antoine Pitrou042b1282010-08-13 21:15:58 +0000825#ifdef HAVE_COMPUTED_GOTOS
826 #ifndef USE_COMPUTED_GOTOS
827 #define USE_COMPUTED_GOTOS 1
828 #endif
829#else
830 #if defined(USE_COMPUTED_GOTOS) && USE_COMPUTED_GOTOS
831 #error "Computed gotos are not supported on this compiler."
832 #endif
833 #undef USE_COMPUTED_GOTOS
834 #define USE_COMPUTED_GOTOS 0
835#endif
836
837#if USE_COMPUTED_GOTOS
Antoine Pitroub52ec782009-01-25 16:34:23 +0000838/* Import the static jump table */
839#include "opcode_targets.h"
840
Antoine Pitroub52ec782009-01-25 16:34:23 +0000841#define TARGET(op) \
Benjamin Petersonddd19492018-09-16 22:38:02 -0700842 op: \
843 TARGET_##op
Antoine Pitroub52ec782009-01-25 16:34:23 +0000844
Antoine Pitroub52ec782009-01-25 16:34:23 +0000845#ifdef LLTRACE
846#define FAST_DISPATCH() \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000847 { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200848 if (!lltrace && !_Py_TracingPossible(ceval) && !PyDTrace_LINE_ENABLED()) { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000849 f->f_lasti = INSTR_OFFSET(); \
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300850 NEXTOPARG(); \
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300851 goto *opcode_targets[opcode]; \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000852 } \
853 goto fast_next_opcode; \
854 }
Antoine Pitroub52ec782009-01-25 16:34:23 +0000855#else
856#define FAST_DISPATCH() \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000857 { \
Victor Stinnere225beb2019-06-03 18:14:24 +0200858 if (!_Py_TracingPossible(ceval) && !PyDTrace_LINE_ENABLED()) { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000859 f->f_lasti = INSTR_OFFSET(); \
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300860 NEXTOPARG(); \
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300861 goto *opcode_targets[opcode]; \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000862 } \
863 goto fast_next_opcode; \
864 }
Antoine Pitroub52ec782009-01-25 16:34:23 +0000865#endif
866
Victor Stinner09532fe2019-05-10 23:39:09 +0200867#define DISPATCH() \
868 { \
869 if (!_Py_atomic_load_relaxed(eval_breaker)) { \
870 FAST_DISPATCH(); \
871 } \
872 continue; \
873 }
874
Antoine Pitroub52ec782009-01-25 16:34:23 +0000875#else
Benjamin Petersonddd19492018-09-16 22:38:02 -0700876#define TARGET(op) op
Antoine Pitroub52ec782009-01-25 16:34:23 +0000877#define FAST_DISPATCH() goto fast_next_opcode
Victor Stinner09532fe2019-05-10 23:39:09 +0200878#define DISPATCH() continue
Antoine Pitroub52ec782009-01-25 16:34:23 +0000879#endif
880
881
Neal Norwitza81d2202002-07-14 00:27:26 +0000882/* Tuple access macros */
883
884#ifndef Py_DEBUG
885#define GETITEM(v, i) PyTuple_GET_ITEM((PyTupleObject *)(v), (i))
886#else
887#define GETITEM(v, i) PyTuple_GetItem((v), (i))
888#endif
889
Guido van Rossum374a9221991-04-04 10:40:29 +0000890/* Code access macros */
891
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300892/* The integer overflow is checked by an assertion below. */
Eric Snow2ebc5ce2017-09-07 23:51:28 -0600893#define INSTR_OFFSET() \
894 (sizeof(_Py_CODEUNIT) * (int)(next_instr - first_instr))
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300895#define NEXTOPARG() do { \
Serhiy Storchakaab874002016-09-11 13:48:15 +0300896 _Py_CODEUNIT word = *next_instr; \
897 opcode = _Py_OPCODE(word); \
898 oparg = _Py_OPARG(word); \
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300899 next_instr++; \
900 } while (0)
Serhiy Storchakaab874002016-09-11 13:48:15 +0300901#define JUMPTO(x) (next_instr = first_instr + (x) / sizeof(_Py_CODEUNIT))
902#define JUMPBY(x) (next_instr += (x) / sizeof(_Py_CODEUNIT))
Guido van Rossum374a9221991-04-04 10:40:29 +0000903
Raymond Hettingerf606f872003-03-16 03:11:04 +0000904/* OpCode prediction macros
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000905 Some opcodes tend to come in pairs thus making it possible to
906 predict the second code when the first is run. For example,
Serhiy Storchakada9c5132016-06-27 18:58:57 +0300907 COMPARE_OP is often followed by POP_JUMP_IF_FALSE or POP_JUMP_IF_TRUE.
Raymond Hettingerf606f872003-03-16 03:11:04 +0000908
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000909 Verifying the prediction costs a single high-speed test of a register
910 variable against a constant. If the pairing was good, then the
911 processor's own internal branch predication has a high likelihood of
912 success, resulting in a nearly zero-overhead transition to the
913 next opcode. A successful prediction saves a trip through the eval-loop
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300914 including its unpredictable switch-case branch. Combined with the
915 processor's internal branch prediction, a successful PREDICT has the
916 effect of making the two opcodes run as if they were a single new opcode
917 with the bodies combined.
Raymond Hettingerf606f872003-03-16 03:11:04 +0000918
Georg Brandl86b2fb92008-07-16 03:43:04 +0000919 If collecting opcode statistics, your choices are to either keep the
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000920 predictions turned-on and interpret the results as if some opcodes
921 had been combined or turn-off predictions so that the opcode frequency
922 counter updates for both opcodes.
Antoine Pitroub52ec782009-01-25 16:34:23 +0000923
924 Opcode prediction is disabled with threaded code, since the latter allows
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000925 the CPU to record separate branch prediction information for each
926 opcode.
Antoine Pitroub52ec782009-01-25 16:34:23 +0000927
Raymond Hettingerf606f872003-03-16 03:11:04 +0000928*/
929
Antoine Pitrou042b1282010-08-13 21:15:58 +0000930#if defined(DYNAMIC_EXECUTION_PROFILE) || USE_COMPUTED_GOTOS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000931#define PREDICT(op) if (0) goto PRED_##op
Raymond Hettingera7216982004-02-08 19:59:27 +0000932#else
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300933#define PREDICT(op) \
934 do{ \
Serhiy Storchakaab874002016-09-11 13:48:15 +0300935 _Py_CODEUNIT word = *next_instr; \
936 opcode = _Py_OPCODE(word); \
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300937 if (opcode == op){ \
Serhiy Storchakaab874002016-09-11 13:48:15 +0300938 oparg = _Py_OPARG(word); \
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +0300939 next_instr++; \
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300940 goto PRED_##op; \
941 } \
942 } while(0)
Antoine Pitroub52ec782009-01-25 16:34:23 +0000943#endif
Serhiy Storchakab0f80b02016-05-24 09:15:14 +0300944#define PREDICTED(op) PRED_##op:
Antoine Pitroub52ec782009-01-25 16:34:23 +0000945
Raymond Hettingerf606f872003-03-16 03:11:04 +0000946
Guido van Rossum374a9221991-04-04 10:40:29 +0000947/* Stack manipulation macros */
948
Martin v. Löwis18e16552006-02-15 17:27:45 +0000949/* The stack can grow at most MAXINT deep, as co_nlocals and
950 co_stacksize are ints. */
Stefan Krahb7e10102010-06-23 18:42:39 +0000951#define STACK_LEVEL() ((int)(stack_pointer - f->f_valuestack))
952#define EMPTY() (STACK_LEVEL() == 0)
953#define TOP() (stack_pointer[-1])
954#define SECOND() (stack_pointer[-2])
955#define THIRD() (stack_pointer[-3])
956#define FOURTH() (stack_pointer[-4])
957#define PEEK(n) (stack_pointer[-(n)])
958#define SET_TOP(v) (stack_pointer[-1] = (v))
959#define SET_SECOND(v) (stack_pointer[-2] = (v))
960#define SET_THIRD(v) (stack_pointer[-3] = (v))
961#define SET_FOURTH(v) (stack_pointer[-4] = (v))
962#define SET_VALUE(n, v) (stack_pointer[-(n)] = (v))
963#define BASIC_STACKADJ(n) (stack_pointer += n)
964#define BASIC_PUSH(v) (*stack_pointer++ = (v))
965#define BASIC_POP() (*--stack_pointer)
Guido van Rossum374a9221991-04-04 10:40:29 +0000966
Guido van Rossum96a42c81992-01-12 02:29:51 +0000967#ifdef LLTRACE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000968#define PUSH(v) { (void)(BASIC_PUSH(v), \
Victor Stinner438a12d2019-05-24 17:01:38 +0200969 lltrace && prtrace(tstate, TOP(), "push")); \
Stefan Krahb7e10102010-06-23 18:42:39 +0000970 assert(STACK_LEVEL() <= co->co_stacksize); }
Victor Stinner438a12d2019-05-24 17:01:38 +0200971#define POP() ((void)(lltrace && prtrace(tstate, TOP(), "pop")), \
Stefan Krahb7e10102010-06-23 18:42:39 +0000972 BASIC_POP())
costypetrisor8ed317f2018-07-31 20:55:14 +0000973#define STACK_GROW(n) do { \
974 assert(n >= 0); \
975 (void)(BASIC_STACKADJ(n), \
Victor Stinner438a12d2019-05-24 17:01:38 +0200976 lltrace && prtrace(tstate, TOP(), "stackadj")); \
costypetrisor8ed317f2018-07-31 20:55:14 +0000977 assert(STACK_LEVEL() <= co->co_stacksize); \
978 } while (0)
979#define STACK_SHRINK(n) do { \
980 assert(n >= 0); \
Victor Stinner438a12d2019-05-24 17:01:38 +0200981 (void)(lltrace && prtrace(tstate, TOP(), "stackadj")); \
costypetrisor8ed317f2018-07-31 20:55:14 +0000982 (void)(BASIC_STACKADJ(-n)); \
983 assert(STACK_LEVEL() <= co->co_stacksize); \
984 } while (0)
Christian Heimes0449f632007-12-15 01:27:15 +0000985#define EXT_POP(STACK_POINTER) ((void)(lltrace && \
Victor Stinner438a12d2019-05-24 17:01:38 +0200986 prtrace(tstate, (STACK_POINTER)[-1], "ext_pop")), \
Stefan Krahb7e10102010-06-23 18:42:39 +0000987 *--(STACK_POINTER))
Guido van Rossum374a9221991-04-04 10:40:29 +0000988#else
Stefan Krahb7e10102010-06-23 18:42:39 +0000989#define PUSH(v) BASIC_PUSH(v)
990#define POP() BASIC_POP()
costypetrisor8ed317f2018-07-31 20:55:14 +0000991#define STACK_GROW(n) BASIC_STACKADJ(n)
992#define STACK_SHRINK(n) BASIC_STACKADJ(-n)
Guido van Rossumc2e20742006-02-27 22:32:47 +0000993#define EXT_POP(STACK_POINTER) (*--(STACK_POINTER))
Guido van Rossum374a9221991-04-04 10:40:29 +0000994#endif
995
Guido van Rossum681d79a1995-07-18 14:51:37 +0000996/* Local variable macros */
997
Antoine Pitrouf95a1b32010-05-09 15:52:27 +0000998#define GETLOCAL(i) (fastlocals[i])
Guido van Rossumcfbf1a32002-03-28 20:17:52 +0000999
1000/* The SETLOCAL() macro must not DECREF the local variable in-place and
1001 then store the new value; it must copy the old value to a temporary
1002 value, then store the new value, and then DECREF the temporary value.
1003 This is because it is possible that during the DECREF the frame is
1004 accessed by other code (e.g. a __del__ method or gc.collect()) and the
1005 variable would be pointing to already-freed memory. */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001006#define SETLOCAL(i, value) do { PyObject *tmp = GETLOCAL(i); \
Stefan Krahb7e10102010-06-23 18:42:39 +00001007 GETLOCAL(i) = value; \
1008 Py_XDECREF(tmp); } while (0)
Guido van Rossum681d79a1995-07-18 14:51:37 +00001009
Benjamin Petersoneec3d712008-06-11 15:59:43 +00001010
1011#define UNWIND_BLOCK(b) \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001012 while (STACK_LEVEL() > (b)->b_level) { \
1013 PyObject *v = POP(); \
1014 Py_XDECREF(v); \
1015 }
Benjamin Petersoneec3d712008-06-11 15:59:43 +00001016
1017#define UNWIND_EXCEPT_HANDLER(b) \
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001018 do { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001019 PyObject *type, *value, *traceback; \
Mark Shannonae3087c2017-10-22 22:41:51 +01001020 _PyErr_StackItem *exc_info; \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001021 assert(STACK_LEVEL() >= (b)->b_level + 3); \
1022 while (STACK_LEVEL() > (b)->b_level + 3) { \
1023 value = POP(); \
1024 Py_XDECREF(value); \
1025 } \
Mark Shannonae3087c2017-10-22 22:41:51 +01001026 exc_info = tstate->exc_info; \
1027 type = exc_info->exc_type; \
1028 value = exc_info->exc_value; \
1029 traceback = exc_info->exc_traceback; \
1030 exc_info->exc_type = POP(); \
1031 exc_info->exc_value = POP(); \
1032 exc_info->exc_traceback = POP(); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001033 Py_XDECREF(type); \
1034 Py_XDECREF(value); \
1035 Py_XDECREF(traceback); \
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001036 } while(0)
Benjamin Petersoneec3d712008-06-11 15:59:43 +00001037
Inada Naoki91234a12019-06-03 21:30:58 +09001038 /* macros for opcode cache */
1039#define OPCACHE_CHECK() \
1040 do { \
1041 co_opcache = NULL; \
1042 if (co->co_opcache != NULL) { \
1043 unsigned char co_opt_offset = \
1044 co->co_opcache_map[next_instr - first_instr]; \
1045 if (co_opt_offset > 0) { \
1046 assert(co_opt_offset <= co->co_opcache_size); \
1047 co_opcache = &co->co_opcache[co_opt_offset - 1]; \
1048 assert(co_opcache != NULL); \
Inada Naoki91234a12019-06-03 21:30:58 +09001049 } \
1050 } \
1051 } while (0)
1052
1053#if OPCACHE_STATS
1054
1055#define OPCACHE_STAT_GLOBAL_HIT() \
1056 do { \
1057 if (co->co_opcache != NULL) opcache_global_hits++; \
1058 } while (0)
1059
1060#define OPCACHE_STAT_GLOBAL_MISS() \
1061 do { \
1062 if (co->co_opcache != NULL) opcache_global_misses++; \
1063 } while (0)
1064
1065#define OPCACHE_STAT_GLOBAL_OPT() \
1066 do { \
1067 if (co->co_opcache != NULL) opcache_global_opts++; \
1068 } while (0)
1069
1070#else /* OPCACHE_STATS */
1071
1072#define OPCACHE_STAT_GLOBAL_HIT()
1073#define OPCACHE_STAT_GLOBAL_MISS()
1074#define OPCACHE_STAT_GLOBAL_OPT()
1075
1076#endif
1077
Guido van Rossuma027efa1997-05-05 20:56:21 +00001078/* Start of code */
1079
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001080 /* push frame */
Victor Stinnerbe434dc2019-11-05 00:51:22 +01001081 if (_Py_EnterRecursiveCall(tstate, "")) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001082 return NULL;
Victor Stinnerbe434dc2019-11-05 00:51:22 +01001083 }
Guido van Rossum8861b741996-07-30 16:49:37 +00001084
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001085 tstate->frame = f;
Tim Peters5ca576e2001-06-18 22:08:13 +00001086
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001087 if (tstate->use_tracing) {
1088 if (tstate->c_tracefunc != NULL) {
1089 /* tstate->c_tracefunc, if defined, is a
1090 function that will be called on *every* entry
1091 to a code block. Its return value, if not
1092 None, is a function that will be called at
1093 the start of each executed line of code.
1094 (Actually, the function must return itself
1095 in order to continue tracing.) The trace
1096 functions are called with three arguments:
1097 a pointer to the current frame, a string
1098 indicating why the function is called, and
1099 an argument which depends on the situation.
1100 The global trace function is also called
1101 whenever an exception is detected. */
1102 if (call_trace_protected(tstate->c_tracefunc,
1103 tstate->c_traceobj,
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01001104 tstate, f, PyTrace_CALL, Py_None)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001105 /* Trace function raised an error */
1106 goto exit_eval_frame;
1107 }
1108 }
1109 if (tstate->c_profilefunc != NULL) {
1110 /* Similar for c_profilefunc, except it needn't
1111 return itself and isn't called for "line" events */
1112 if (call_trace_protected(tstate->c_profilefunc,
1113 tstate->c_profileobj,
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01001114 tstate, f, PyTrace_CALL, Py_None)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001115 /* Profile function raised an error */
1116 goto exit_eval_frame;
1117 }
1118 }
1119 }
Neil Schemenauer6c0f2002001-09-04 19:03:35 +00001120
Łukasz Langaa785c872016-09-09 17:37:37 -07001121 if (PyDTrace_FUNCTION_ENTRY_ENABLED())
1122 dtrace_function_entry(f);
1123
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001124 co = f->f_code;
1125 names = co->co_names;
1126 consts = co->co_consts;
1127 fastlocals = f->f_localsplus;
1128 freevars = f->f_localsplus + co->co_nlocals;
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03001129 assert(PyBytes_Check(co->co_code));
1130 assert(PyBytes_GET_SIZE(co->co_code) <= INT_MAX);
Serhiy Storchakaab874002016-09-11 13:48:15 +03001131 assert(PyBytes_GET_SIZE(co->co_code) % sizeof(_Py_CODEUNIT) == 0);
1132 assert(_Py_IS_ALIGNED(PyBytes_AS_STRING(co->co_code), sizeof(_Py_CODEUNIT)));
1133 first_instr = (_Py_CODEUNIT *) PyBytes_AS_STRING(co->co_code);
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001134 /*
1135 f->f_lasti refers to the index of the last instruction,
1136 unless it's -1 in which case next_instr should be first_instr.
Michael W. Hudson019a78e2002-11-08 12:53:11 +00001137
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001138 YIELD_FROM sets f_lasti to itself, in order to repeatedly yield
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05001139 multiple values.
Thomas Wouters902d6eb2007-01-09 23:18:33 +00001140
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001141 When the PREDICT() macros are enabled, some opcode pairs follow in
1142 direct succession without updating f->f_lasti. A successful
1143 prediction effectively links the two codes together as if they
1144 were a single new opcode; accordingly,f->f_lasti will point to
1145 the first code in the pair (for instance, GET_ITER followed by
1146 FOR_ITER is effectively a single opcode and f->f_lasti will point
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001147 to the beginning of the combined pair.)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001148 */
Serhiy Storchakaab874002016-09-11 13:48:15 +03001149 assert(f->f_lasti >= -1);
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001150 next_instr = first_instr;
1151 if (f->f_lasti >= 0) {
Serhiy Storchakaab874002016-09-11 13:48:15 +03001152 assert(f->f_lasti % sizeof(_Py_CODEUNIT) == 0);
1153 next_instr += f->f_lasti / sizeof(_Py_CODEUNIT) + 1;
Serhiy Storchakab0f80b02016-05-24 09:15:14 +03001154 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001155 stack_pointer = f->f_stacktop;
1156 assert(stack_pointer != NULL);
1157 f->f_stacktop = NULL; /* remains NULL unless yield suspends frame */
Antoine Pitrou58720d62013-08-05 23:26:40 +02001158 f->f_executing = 1;
Michael W. Hudson019a78e2002-11-08 12:53:11 +00001159
Inada Naoki91234a12019-06-03 21:30:58 +09001160 if (co->co_opcache_flag < OPCACHE_MIN_RUNS) {
1161 co->co_opcache_flag++;
1162 if (co->co_opcache_flag == OPCACHE_MIN_RUNS) {
1163 if (_PyCode_InitOpcache(co) < 0) {
1164 return NULL;
1165 }
1166#if OPCACHE_STATS
1167 opcache_code_objects_extra_mem +=
1168 PyBytes_Size(co->co_code) / sizeof(_Py_CODEUNIT) +
1169 sizeof(_PyOpcache) * co->co_opcache_size;
1170 opcache_code_objects++;
1171#endif
1172 }
1173 }
Benjamin Petersoneec3d712008-06-11 15:59:43 +00001174
Tim Peters5ca576e2001-06-18 22:08:13 +00001175#ifdef LLTRACE
Victor Stinner3c1e4812012-03-26 22:10:51 +02001176 lltrace = _PyDict_GetItemId(f->f_globals, &PyId___ltrace__) != NULL;
Tim Peters5ca576e2001-06-18 22:08:13 +00001177#endif
Guido van Rossumac7be682001-01-17 15:42:30 +00001178
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001179 if (throwflag) /* support for generator.throw() */
1180 goto error;
Thomas Wouters477c8d52006-05-27 19:21:47 +00001181
Victor Stinnerace47d72013-07-18 01:41:08 +02001182#ifdef Py_DEBUG
1183 /* PyEval_EvalFrameEx() must not be called with an exception set,
Victor Stinnera8cb5152017-01-18 14:12:51 +01001184 because it can clear it (directly or indirectly) and so the
Martin Panter9955a372015-10-07 10:26:23 +00001185 caller loses its exception */
Victor Stinner438a12d2019-05-24 17:01:38 +02001186 assert(!_PyErr_Occurred(tstate));
Victor Stinnerace47d72013-07-18 01:41:08 +02001187#endif
1188
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02001189main_loop:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001190 for (;;) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001191 assert(stack_pointer >= f->f_valuestack); /* else underflow */
1192 assert(STACK_LEVEL() <= co->co_stacksize); /* else overflow */
Victor Stinner438a12d2019-05-24 17:01:38 +02001193 assert(!_PyErr_Occurred(tstate));
Michael W. Hudsondd32a912002-08-15 14:59:02 +00001194
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001195 /* Do periodic things. Doing this every time through
1196 the loop would add too much overhead, so we do it
1197 only every Nth instruction. We also do it if
1198 ``pendingcalls_to_do'' is set, i.e. when an asynchronous
1199 event needs attention (e.g. a signal handler or
1200 async I/O handler); see Py_AddPendingCall() and
1201 Py_MakePendingCalls() above. */
Guido van Rossumac7be682001-01-17 15:42:30 +00001202
Eric Snow7bda9de2019-03-08 17:25:54 -07001203 if (_Py_atomic_load_relaxed(eval_breaker)) {
Serhiy Storchaka3f4d90d2018-07-09 15:40:14 +03001204 opcode = _Py_OPCODE(*next_instr);
1205 if (opcode == SETUP_FINALLY ||
1206 opcode == SETUP_WITH ||
1207 opcode == BEFORE_ASYNC_WITH ||
1208 opcode == YIELD_FROM) {
1209 /* Few cases where we skip running signal handlers and other
Nathaniel J. Smithab4413a2017-05-17 13:33:23 -07001210 pending calls:
Serhiy Storchaka3f4d90d2018-07-09 15:40:14 +03001211 - If we're about to enter the 'with:'. It will prevent
1212 emitting a resource warning in the common idiom
1213 'with open(path) as file:'.
1214 - If we're about to enter the 'async with:'.
1215 - If we're about to enter the 'try:' of a try/finally (not
Nathaniel J. Smithab4413a2017-05-17 13:33:23 -07001216 *very* useful, but might help in some cases and it's
1217 traditional)
1218 - If we're resuming a chain of nested 'yield from' or
1219 'await' calls, then each frame is parked with YIELD_FROM
1220 as its next opcode. If the user hit control-C we want to
1221 wait until we've reached the innermost frame before
1222 running the signal handler and raising KeyboardInterrupt
1223 (see bpo-30039).
1224 */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001225 goto fast_next_opcode;
1226 }
Eric Snowfdf282d2019-01-11 14:26:55 -07001227
Victor Stinnere225beb2019-06-03 18:14:24 +02001228 if (_Py_atomic_load_relaxed(&ceval->signals_pending)) {
Victor Stinner09532fe2019-05-10 23:39:09 +02001229 if (handle_signals(runtime) != 0) {
Eric Snowfdf282d2019-01-11 14:26:55 -07001230 goto error;
1231 }
1232 }
Victor Stinnere225beb2019-06-03 18:14:24 +02001233 if (_Py_atomic_load_relaxed(&ceval->pending.calls_to_do)) {
1234 if (make_pending_calls(runtime) != 0) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001235 goto error;
Eric Snowfdf282d2019-01-11 14:26:55 -07001236 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001237 }
Eric Snowfdf282d2019-01-11 14:26:55 -07001238
Victor Stinnere225beb2019-06-03 18:14:24 +02001239 if (_Py_atomic_load_relaxed(&ceval->gil_drop_request)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001240 /* Give another thread a chance */
Victor Stinner09532fe2019-05-10 23:39:09 +02001241 if (_PyThreadState_Swap(&runtime->gilstate, NULL) != tstate) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001242 Py_FatalError("ceval: tstate mix-up");
Victor Stinner09532fe2019-05-10 23:39:09 +02001243 }
Victor Stinnere225beb2019-06-03 18:14:24 +02001244 drop_gil(ceval, tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001245
1246 /* Other threads may run now */
1247
Victor Stinnere225beb2019-06-03 18:14:24 +02001248 take_gil(ceval, tstate);
Benjamin Peterson17548dd2014-06-16 22:59:07 -07001249
1250 /* Check if we should make a quick exit. */
Victor Stinner01b1cc12019-11-20 02:27:56 +01001251 exit_thread_if_finalizing(tstate);
Benjamin Peterson17548dd2014-06-16 22:59:07 -07001252
Victor Stinner09532fe2019-05-10 23:39:09 +02001253 if (_PyThreadState_Swap(&runtime->gilstate, tstate) != NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001254 Py_FatalError("ceval: orphan tstate");
Victor Stinner09532fe2019-05-10 23:39:09 +02001255 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001256 }
1257 /* Check for asynchronous exceptions. */
1258 if (tstate->async_exc != NULL) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001259 PyObject *exc = tstate->async_exc;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001260 tstate->async_exc = NULL;
Victor Stinnere225beb2019-06-03 18:14:24 +02001261 UNSIGNAL_ASYNC_EXC(ceval);
Victor Stinner438a12d2019-05-24 17:01:38 +02001262 _PyErr_SetNone(tstate, exc);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001263 Py_DECREF(exc);
1264 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001265 }
1266 }
Guido van Rossum1984f1e1992-08-04 12:41:02 +00001267
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001268 fast_next_opcode:
1269 f->f_lasti = INSTR_OFFSET();
Guido van Rossumac7be682001-01-17 15:42:30 +00001270
Łukasz Langaa785c872016-09-09 17:37:37 -07001271 if (PyDTrace_LINE_ENABLED())
1272 maybe_dtrace_line(f, &instr_lb, &instr_ub, &instr_prev);
1273
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001274 /* line-by-line tracing support */
Michael W. Hudson019a78e2002-11-08 12:53:11 +00001275
Victor Stinnere225beb2019-06-03 18:14:24 +02001276 if (_Py_TracingPossible(ceval) &&
Benjamin Peterson51f46162013-01-23 08:38:47 -05001277 tstate->c_tracefunc != NULL && !tstate->tracing) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001278 int err;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001279 /* see maybe_call_line_trace
1280 for expository comments */
1281 f->f_stacktop = stack_pointer;
Tim Peters8a5c3c72004-04-05 19:36:21 +00001282
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001283 err = maybe_call_line_trace(tstate->c_tracefunc,
1284 tstate->c_traceobj,
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01001285 tstate, f,
1286 &instr_lb, &instr_ub, &instr_prev);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001287 /* Reload possibly changed frame fields */
1288 JUMPTO(f->f_lasti);
1289 if (f->f_stacktop != NULL) {
1290 stack_pointer = f->f_stacktop;
1291 f->f_stacktop = NULL;
1292 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001293 if (err)
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001294 /* trace function raised an exception */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001295 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001296 }
Michael W. Hudson019a78e2002-11-08 12:53:11 +00001297
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001298 /* Extract opcode and argument */
Michael W. Hudson019a78e2002-11-08 12:53:11 +00001299
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03001300 NEXTOPARG();
Stefan Krahb7e10102010-06-23 18:42:39 +00001301 dispatch_opcode:
Guido van Rossum950361c1997-01-24 13:49:28 +00001302#ifdef DYNAMIC_EXECUTION_PROFILE
1303#ifdef DXPAIRS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001304 dxpairs[lastopcode][opcode]++;
1305 lastopcode = opcode;
Guido van Rossum950361c1997-01-24 13:49:28 +00001306#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001307 dxp[opcode]++;
Guido van Rossum950361c1997-01-24 13:49:28 +00001308#endif
Guido van Rossum374a9221991-04-04 10:40:29 +00001309
Guido van Rossum96a42c81992-01-12 02:29:51 +00001310#ifdef LLTRACE
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001311 /* Instruction tracing */
Guido van Rossumac7be682001-01-17 15:42:30 +00001312
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001313 if (lltrace) {
1314 if (HAS_ARG(opcode)) {
1315 printf("%d: %d, %d\n",
1316 f->f_lasti, opcode, oparg);
1317 }
1318 else {
1319 printf("%d: %d\n",
1320 f->f_lasti, opcode);
1321 }
1322 }
Guido van Rossum374a9221991-04-04 10:40:29 +00001323#endif
Michael W. Hudsondd32a912002-08-15 14:59:02 +00001324
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001325 switch (opcode) {
Guido van Rossumac7be682001-01-17 15:42:30 +00001326
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001327 /* BEWARE!
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02001328 It is essential that any operation that fails must goto error
1329 and that all operation that succeed call [FAST_]DISPATCH() ! */
Guido van Rossumac7be682001-01-17 15:42:30 +00001330
Benjamin Petersonddd19492018-09-16 22:38:02 -07001331 case TARGET(NOP): {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001332 FAST_DISPATCH();
Benjamin Petersonddd19492018-09-16 22:38:02 -07001333 }
Raymond Hettinger9c18e812004-06-21 16:31:15 +00001334
Benjamin Petersonddd19492018-09-16 22:38:02 -07001335 case TARGET(LOAD_FAST): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001336 PyObject *value = GETLOCAL(oparg);
1337 if (value == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02001338 format_exc_check_arg(tstate, PyExc_UnboundLocalError,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001339 UNBOUNDLOCAL_ERROR_MSG,
1340 PyTuple_GetItem(co->co_varnames, oparg));
1341 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001342 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001343 Py_INCREF(value);
1344 PUSH(value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001345 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001346 }
1347
Benjamin Petersonddd19492018-09-16 22:38:02 -07001348 case TARGET(LOAD_CONST): {
1349 PREDICTED(LOAD_CONST);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001350 PyObject *value = GETITEM(consts, oparg);
1351 Py_INCREF(value);
1352 PUSH(value);
1353 FAST_DISPATCH();
1354 }
Neil Schemenauer63543862002-02-17 19:10:14 +00001355
Benjamin Petersonddd19492018-09-16 22:38:02 -07001356 case TARGET(STORE_FAST): {
1357 PREDICTED(STORE_FAST);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001358 PyObject *value = POP();
1359 SETLOCAL(oparg, value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001360 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001361 }
Neil Schemenauer63543862002-02-17 19:10:14 +00001362
Benjamin Petersonddd19492018-09-16 22:38:02 -07001363 case TARGET(POP_TOP): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001364 PyObject *value = POP();
1365 Py_DECREF(value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001366 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001367 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001368
Benjamin Petersonddd19492018-09-16 22:38:02 -07001369 case TARGET(ROT_TWO): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001370 PyObject *top = TOP();
1371 PyObject *second = SECOND();
1372 SET_TOP(second);
1373 SET_SECOND(top);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001374 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001375 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001376
Benjamin Petersonddd19492018-09-16 22:38:02 -07001377 case TARGET(ROT_THREE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001378 PyObject *top = TOP();
1379 PyObject *second = SECOND();
1380 PyObject *third = THIRD();
1381 SET_TOP(second);
1382 SET_SECOND(third);
1383 SET_THIRD(top);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001384 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001385 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001386
Benjamin Petersonddd19492018-09-16 22:38:02 -07001387 case TARGET(ROT_FOUR): {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02001388 PyObject *top = TOP();
1389 PyObject *second = SECOND();
1390 PyObject *third = THIRD();
1391 PyObject *fourth = FOURTH();
1392 SET_TOP(second);
1393 SET_SECOND(third);
1394 SET_THIRD(fourth);
1395 SET_FOURTH(top);
1396 FAST_DISPATCH();
1397 }
1398
Benjamin Petersonddd19492018-09-16 22:38:02 -07001399 case TARGET(DUP_TOP): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001400 PyObject *top = TOP();
1401 Py_INCREF(top);
1402 PUSH(top);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001403 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001404 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001405
Benjamin Petersonddd19492018-09-16 22:38:02 -07001406 case TARGET(DUP_TOP_TWO): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001407 PyObject *top = TOP();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001408 PyObject *second = SECOND();
Benjamin Petersonf208df32012-10-12 11:37:56 -04001409 Py_INCREF(top);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001410 Py_INCREF(second);
costypetrisor8ed317f2018-07-31 20:55:14 +00001411 STACK_GROW(2);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001412 SET_TOP(top);
1413 SET_SECOND(second);
Antoine Pitrou74a69fa2010-09-04 18:43:52 +00001414 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001415 }
Thomas Wouters434d0822000-08-24 20:11:32 +00001416
Benjamin Petersonddd19492018-09-16 22:38:02 -07001417 case TARGET(UNARY_POSITIVE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001418 PyObject *value = TOP();
1419 PyObject *res = PyNumber_Positive(value);
1420 Py_DECREF(value);
1421 SET_TOP(res);
1422 if (res == NULL)
1423 goto error;
1424 DISPATCH();
1425 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001426
Benjamin Petersonddd19492018-09-16 22:38:02 -07001427 case TARGET(UNARY_NEGATIVE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001428 PyObject *value = TOP();
1429 PyObject *res = PyNumber_Negative(value);
1430 Py_DECREF(value);
1431 SET_TOP(res);
1432 if (res == NULL)
1433 goto error;
1434 DISPATCH();
1435 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001436
Benjamin Petersonddd19492018-09-16 22:38:02 -07001437 case TARGET(UNARY_NOT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001438 PyObject *value = TOP();
1439 int err = PyObject_IsTrue(value);
1440 Py_DECREF(value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001441 if (err == 0) {
1442 Py_INCREF(Py_True);
1443 SET_TOP(Py_True);
1444 DISPATCH();
1445 }
1446 else if (err > 0) {
1447 Py_INCREF(Py_False);
1448 SET_TOP(Py_False);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001449 DISPATCH();
1450 }
costypetrisor8ed317f2018-07-31 20:55:14 +00001451 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001452 goto error;
1453 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001454
Benjamin Petersonddd19492018-09-16 22:38:02 -07001455 case TARGET(UNARY_INVERT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001456 PyObject *value = TOP();
1457 PyObject *res = PyNumber_Invert(value);
1458 Py_DECREF(value);
1459 SET_TOP(res);
1460 if (res == NULL)
1461 goto error;
1462 DISPATCH();
1463 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001464
Benjamin Petersonddd19492018-09-16 22:38:02 -07001465 case TARGET(BINARY_POWER): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001466 PyObject *exp = POP();
1467 PyObject *base = TOP();
1468 PyObject *res = PyNumber_Power(base, exp, Py_None);
1469 Py_DECREF(base);
1470 Py_DECREF(exp);
1471 SET_TOP(res);
1472 if (res == NULL)
1473 goto error;
1474 DISPATCH();
1475 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001476
Benjamin Petersonddd19492018-09-16 22:38:02 -07001477 case TARGET(BINARY_MULTIPLY): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001478 PyObject *right = POP();
1479 PyObject *left = TOP();
1480 PyObject *res = PyNumber_Multiply(left, right);
1481 Py_DECREF(left);
1482 Py_DECREF(right);
1483 SET_TOP(res);
1484 if (res == NULL)
1485 goto error;
1486 DISPATCH();
1487 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001488
Benjamin Petersonddd19492018-09-16 22:38:02 -07001489 case TARGET(BINARY_MATRIX_MULTIPLY): {
Benjamin Petersond51374e2014-04-09 23:55:56 -04001490 PyObject *right = POP();
1491 PyObject *left = TOP();
1492 PyObject *res = PyNumber_MatrixMultiply(left, right);
1493 Py_DECREF(left);
1494 Py_DECREF(right);
1495 SET_TOP(res);
1496 if (res == NULL)
1497 goto error;
1498 DISPATCH();
1499 }
1500
Benjamin Petersonddd19492018-09-16 22:38:02 -07001501 case TARGET(BINARY_TRUE_DIVIDE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001502 PyObject *divisor = POP();
1503 PyObject *dividend = TOP();
1504 PyObject *quotient = PyNumber_TrueDivide(dividend, divisor);
1505 Py_DECREF(dividend);
1506 Py_DECREF(divisor);
1507 SET_TOP(quotient);
1508 if (quotient == NULL)
1509 goto error;
1510 DISPATCH();
1511 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001512
Benjamin Petersonddd19492018-09-16 22:38:02 -07001513 case TARGET(BINARY_FLOOR_DIVIDE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001514 PyObject *divisor = POP();
1515 PyObject *dividend = TOP();
1516 PyObject *quotient = PyNumber_FloorDivide(dividend, divisor);
1517 Py_DECREF(dividend);
1518 Py_DECREF(divisor);
1519 SET_TOP(quotient);
1520 if (quotient == NULL)
1521 goto error;
1522 DISPATCH();
1523 }
Guido van Rossum4668b002001-08-08 05:00:18 +00001524
Benjamin Petersonddd19492018-09-16 22:38:02 -07001525 case TARGET(BINARY_MODULO): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001526 PyObject *divisor = POP();
1527 PyObject *dividend = TOP();
Martijn Pietersd7e64332017-02-23 13:38:04 +00001528 PyObject *res;
1529 if (PyUnicode_CheckExact(dividend) && (
1530 !PyUnicode_Check(divisor) || PyUnicode_CheckExact(divisor))) {
1531 // fast path; string formatting, but not if the RHS is a str subclass
1532 // (see issue28598)
1533 res = PyUnicode_Format(dividend, divisor);
1534 } else {
1535 res = PyNumber_Remainder(dividend, divisor);
1536 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001537 Py_DECREF(divisor);
1538 Py_DECREF(dividend);
1539 SET_TOP(res);
1540 if (res == NULL)
1541 goto error;
1542 DISPATCH();
1543 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001544
Benjamin Petersonddd19492018-09-16 22:38:02 -07001545 case TARGET(BINARY_ADD): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001546 PyObject *right = POP();
1547 PyObject *left = TOP();
1548 PyObject *sum;
Victor Stinnerd65f42a2016-10-20 12:18:10 +02001549 /* NOTE(haypo): Please don't try to micro-optimize int+int on
1550 CPython using bytecode, it is simply worthless.
1551 See http://bugs.python.org/issue21955 and
1552 http://bugs.python.org/issue10044 for the discussion. In short,
1553 no patch shown any impact on a realistic benchmark, only a minor
1554 speedup on microbenchmarks. */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001555 if (PyUnicode_CheckExact(left) &&
1556 PyUnicode_CheckExact(right)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02001557 sum = unicode_concatenate(tstate, left, right, f, next_instr);
Martin Panter95f53c12016-07-18 08:23:26 +00001558 /* unicode_concatenate consumed the ref to left */
Victor Stinnerd2a915d2011-10-02 20:34:20 +02001559 }
1560 else {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001561 sum = PyNumber_Add(left, right);
1562 Py_DECREF(left);
Victor Stinnerd2a915d2011-10-02 20:34:20 +02001563 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001564 Py_DECREF(right);
1565 SET_TOP(sum);
1566 if (sum == NULL)
1567 goto error;
1568 DISPATCH();
1569 }
1570
Benjamin Petersonddd19492018-09-16 22:38:02 -07001571 case TARGET(BINARY_SUBTRACT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001572 PyObject *right = POP();
1573 PyObject *left = TOP();
1574 PyObject *diff = PyNumber_Subtract(left, right);
1575 Py_DECREF(right);
1576 Py_DECREF(left);
1577 SET_TOP(diff);
1578 if (diff == NULL)
1579 goto error;
1580 DISPATCH();
1581 }
1582
Benjamin Petersonddd19492018-09-16 22:38:02 -07001583 case TARGET(BINARY_SUBSCR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001584 PyObject *sub = POP();
1585 PyObject *container = TOP();
1586 PyObject *res = PyObject_GetItem(container, sub);
1587 Py_DECREF(container);
1588 Py_DECREF(sub);
1589 SET_TOP(res);
1590 if (res == NULL)
1591 goto error;
1592 DISPATCH();
1593 }
1594
Benjamin Petersonddd19492018-09-16 22:38:02 -07001595 case TARGET(BINARY_LSHIFT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001596 PyObject *right = POP();
1597 PyObject *left = TOP();
1598 PyObject *res = PyNumber_Lshift(left, right);
1599 Py_DECREF(left);
1600 Py_DECREF(right);
1601 SET_TOP(res);
1602 if (res == NULL)
1603 goto error;
1604 DISPATCH();
1605 }
1606
Benjamin Petersonddd19492018-09-16 22:38:02 -07001607 case TARGET(BINARY_RSHIFT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001608 PyObject *right = POP();
1609 PyObject *left = TOP();
1610 PyObject *res = PyNumber_Rshift(left, right);
1611 Py_DECREF(left);
1612 Py_DECREF(right);
1613 SET_TOP(res);
1614 if (res == NULL)
1615 goto error;
1616 DISPATCH();
1617 }
1618
Benjamin Petersonddd19492018-09-16 22:38:02 -07001619 case TARGET(BINARY_AND): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001620 PyObject *right = POP();
1621 PyObject *left = TOP();
1622 PyObject *res = PyNumber_And(left, right);
1623 Py_DECREF(left);
1624 Py_DECREF(right);
1625 SET_TOP(res);
1626 if (res == NULL)
1627 goto error;
1628 DISPATCH();
1629 }
1630
Benjamin Petersonddd19492018-09-16 22:38:02 -07001631 case TARGET(BINARY_XOR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001632 PyObject *right = POP();
1633 PyObject *left = TOP();
1634 PyObject *res = PyNumber_Xor(left, right);
1635 Py_DECREF(left);
1636 Py_DECREF(right);
1637 SET_TOP(res);
1638 if (res == NULL)
1639 goto error;
1640 DISPATCH();
1641 }
1642
Benjamin Petersonddd19492018-09-16 22:38:02 -07001643 case TARGET(BINARY_OR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001644 PyObject *right = POP();
1645 PyObject *left = TOP();
1646 PyObject *res = PyNumber_Or(left, right);
1647 Py_DECREF(left);
1648 Py_DECREF(right);
1649 SET_TOP(res);
1650 if (res == NULL)
1651 goto error;
1652 DISPATCH();
1653 }
1654
Benjamin Petersonddd19492018-09-16 22:38:02 -07001655 case TARGET(LIST_APPEND): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001656 PyObject *v = POP();
1657 PyObject *list = PEEK(oparg);
1658 int err;
1659 err = PyList_Append(list, v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001660 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001661 if (err != 0)
1662 goto error;
1663 PREDICT(JUMP_ABSOLUTE);
1664 DISPATCH();
1665 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001666
Benjamin Petersonddd19492018-09-16 22:38:02 -07001667 case TARGET(SET_ADD): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001668 PyObject *v = POP();
Raymond Hettinger41862222016-10-15 19:03:06 -07001669 PyObject *set = PEEK(oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001670 int err;
1671 err = PySet_Add(set, v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001672 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001673 if (err != 0)
1674 goto error;
1675 PREDICT(JUMP_ABSOLUTE);
1676 DISPATCH();
1677 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001678
Benjamin Petersonddd19492018-09-16 22:38:02 -07001679 case TARGET(INPLACE_POWER): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001680 PyObject *exp = POP();
1681 PyObject *base = TOP();
1682 PyObject *res = PyNumber_InPlacePower(base, exp, Py_None);
1683 Py_DECREF(base);
1684 Py_DECREF(exp);
1685 SET_TOP(res);
1686 if (res == NULL)
1687 goto error;
1688 DISPATCH();
1689 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001690
Benjamin Petersonddd19492018-09-16 22:38:02 -07001691 case TARGET(INPLACE_MULTIPLY): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001692 PyObject *right = POP();
1693 PyObject *left = TOP();
1694 PyObject *res = PyNumber_InPlaceMultiply(left, right);
1695 Py_DECREF(left);
1696 Py_DECREF(right);
1697 SET_TOP(res);
1698 if (res == NULL)
1699 goto error;
1700 DISPATCH();
1701 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001702
Benjamin Petersonddd19492018-09-16 22:38:02 -07001703 case TARGET(INPLACE_MATRIX_MULTIPLY): {
Benjamin Petersond51374e2014-04-09 23:55:56 -04001704 PyObject *right = POP();
1705 PyObject *left = TOP();
1706 PyObject *res = PyNumber_InPlaceMatrixMultiply(left, right);
1707 Py_DECREF(left);
1708 Py_DECREF(right);
1709 SET_TOP(res);
1710 if (res == NULL)
1711 goto error;
1712 DISPATCH();
1713 }
1714
Benjamin Petersonddd19492018-09-16 22:38:02 -07001715 case TARGET(INPLACE_TRUE_DIVIDE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001716 PyObject *divisor = POP();
1717 PyObject *dividend = TOP();
1718 PyObject *quotient = PyNumber_InPlaceTrueDivide(dividend, divisor);
1719 Py_DECREF(dividend);
1720 Py_DECREF(divisor);
1721 SET_TOP(quotient);
1722 if (quotient == NULL)
1723 goto error;
1724 DISPATCH();
1725 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001726
Benjamin Petersonddd19492018-09-16 22:38:02 -07001727 case TARGET(INPLACE_FLOOR_DIVIDE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001728 PyObject *divisor = POP();
1729 PyObject *dividend = TOP();
1730 PyObject *quotient = PyNumber_InPlaceFloorDivide(dividend, divisor);
1731 Py_DECREF(dividend);
1732 Py_DECREF(divisor);
1733 SET_TOP(quotient);
1734 if (quotient == NULL)
1735 goto error;
1736 DISPATCH();
1737 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001738
Benjamin Petersonddd19492018-09-16 22:38:02 -07001739 case TARGET(INPLACE_MODULO): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001740 PyObject *right = POP();
1741 PyObject *left = TOP();
1742 PyObject *mod = PyNumber_InPlaceRemainder(left, right);
1743 Py_DECREF(left);
1744 Py_DECREF(right);
1745 SET_TOP(mod);
1746 if (mod == NULL)
1747 goto error;
1748 DISPATCH();
1749 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001750
Benjamin Petersonddd19492018-09-16 22:38:02 -07001751 case TARGET(INPLACE_ADD): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001752 PyObject *right = POP();
1753 PyObject *left = TOP();
1754 PyObject *sum;
1755 if (PyUnicode_CheckExact(left) && PyUnicode_CheckExact(right)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02001756 sum = unicode_concatenate(tstate, left, right, f, next_instr);
Martin Panter95f53c12016-07-18 08:23:26 +00001757 /* unicode_concatenate consumed the ref to left */
Victor Stinnerd2a915d2011-10-02 20:34:20 +02001758 }
1759 else {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001760 sum = PyNumber_InPlaceAdd(left, right);
1761 Py_DECREF(left);
Victor Stinnerd2a915d2011-10-02 20:34:20 +02001762 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001763 Py_DECREF(right);
1764 SET_TOP(sum);
1765 if (sum == NULL)
1766 goto error;
1767 DISPATCH();
1768 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001769
Benjamin Petersonddd19492018-09-16 22:38:02 -07001770 case TARGET(INPLACE_SUBTRACT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001771 PyObject *right = POP();
1772 PyObject *left = TOP();
1773 PyObject *diff = PyNumber_InPlaceSubtract(left, right);
1774 Py_DECREF(left);
1775 Py_DECREF(right);
1776 SET_TOP(diff);
1777 if (diff == NULL)
1778 goto error;
1779 DISPATCH();
1780 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001781
Benjamin Petersonddd19492018-09-16 22:38:02 -07001782 case TARGET(INPLACE_LSHIFT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001783 PyObject *right = POP();
1784 PyObject *left = TOP();
1785 PyObject *res = PyNumber_InPlaceLshift(left, right);
1786 Py_DECREF(left);
1787 Py_DECREF(right);
1788 SET_TOP(res);
1789 if (res == NULL)
1790 goto error;
1791 DISPATCH();
1792 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001793
Benjamin Petersonddd19492018-09-16 22:38:02 -07001794 case TARGET(INPLACE_RSHIFT): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001795 PyObject *right = POP();
1796 PyObject *left = TOP();
1797 PyObject *res = PyNumber_InPlaceRshift(left, right);
1798 Py_DECREF(left);
1799 Py_DECREF(right);
1800 SET_TOP(res);
1801 if (res == NULL)
1802 goto error;
1803 DISPATCH();
1804 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001805
Benjamin Petersonddd19492018-09-16 22:38:02 -07001806 case TARGET(INPLACE_AND): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001807 PyObject *right = POP();
1808 PyObject *left = TOP();
1809 PyObject *res = PyNumber_InPlaceAnd(left, right);
1810 Py_DECREF(left);
1811 Py_DECREF(right);
1812 SET_TOP(res);
1813 if (res == NULL)
1814 goto error;
1815 DISPATCH();
1816 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001817
Benjamin Petersonddd19492018-09-16 22:38:02 -07001818 case TARGET(INPLACE_XOR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001819 PyObject *right = POP();
1820 PyObject *left = TOP();
1821 PyObject *res = PyNumber_InPlaceXor(left, right);
1822 Py_DECREF(left);
1823 Py_DECREF(right);
1824 SET_TOP(res);
1825 if (res == NULL)
1826 goto error;
1827 DISPATCH();
1828 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001829
Benjamin Petersonddd19492018-09-16 22:38:02 -07001830 case TARGET(INPLACE_OR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001831 PyObject *right = POP();
1832 PyObject *left = TOP();
1833 PyObject *res = PyNumber_InPlaceOr(left, right);
1834 Py_DECREF(left);
1835 Py_DECREF(right);
1836 SET_TOP(res);
1837 if (res == NULL)
1838 goto error;
1839 DISPATCH();
1840 }
Thomas Wouters434d0822000-08-24 20:11:32 +00001841
Benjamin Petersonddd19492018-09-16 22:38:02 -07001842 case TARGET(STORE_SUBSCR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001843 PyObject *sub = TOP();
1844 PyObject *container = SECOND();
1845 PyObject *v = THIRD();
1846 int err;
costypetrisor8ed317f2018-07-31 20:55:14 +00001847 STACK_SHRINK(3);
Martin Panter95f53c12016-07-18 08:23:26 +00001848 /* container[sub] = v */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001849 err = PyObject_SetItem(container, sub, v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001850 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001851 Py_DECREF(container);
1852 Py_DECREF(sub);
1853 if (err != 0)
1854 goto error;
1855 DISPATCH();
1856 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001857
Benjamin Petersonddd19492018-09-16 22:38:02 -07001858 case TARGET(DELETE_SUBSCR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001859 PyObject *sub = TOP();
1860 PyObject *container = SECOND();
1861 int err;
costypetrisor8ed317f2018-07-31 20:55:14 +00001862 STACK_SHRINK(2);
Martin Panter95f53c12016-07-18 08:23:26 +00001863 /* del container[sub] */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001864 err = PyObject_DelItem(container, sub);
1865 Py_DECREF(container);
1866 Py_DECREF(sub);
1867 if (err != 0)
1868 goto error;
1869 DISPATCH();
1870 }
Barry Warsaw23c9ec82000-08-21 15:44:01 +00001871
Benjamin Petersonddd19492018-09-16 22:38:02 -07001872 case TARGET(PRINT_EXPR): {
Victor Stinnercab75e32013-11-06 22:38:37 +01001873 _Py_IDENTIFIER(displayhook);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001874 PyObject *value = POP();
Victor Stinnercab75e32013-11-06 22:38:37 +01001875 PyObject *hook = _PySys_GetObjectId(&PyId_displayhook);
Benjamin Petersonfe1bcb62012-10-12 11:40:01 -04001876 PyObject *res;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001877 if (hook == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02001878 _PyErr_SetString(tstate, PyExc_RuntimeError,
1879 "lost sys.displayhook");
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001880 Py_DECREF(value);
1881 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001882 }
Jeroen Demeyer196a5302019-07-04 12:31:34 +02001883 res = _PyObject_CallOneArg(hook, value);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001884 Py_DECREF(value);
1885 if (res == NULL)
1886 goto error;
1887 Py_DECREF(res);
1888 DISPATCH();
1889 }
Moshe Zadkaf68f2fe2001-01-11 05:41:27 +00001890
Benjamin Petersonddd19492018-09-16 22:38:02 -07001891 case TARGET(RAISE_VARARGS): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001892 PyObject *cause = NULL, *exc = NULL;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001893 switch (oparg) {
1894 case 2:
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001895 cause = POP(); /* cause */
Stefan Krahf432a322017-08-21 13:09:59 +02001896 /* fall through */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001897 case 1:
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001898 exc = POP(); /* exc */
Stefan Krahf432a322017-08-21 13:09:59 +02001899 /* fall through */
1900 case 0:
Victor Stinner09532fe2019-05-10 23:39:09 +02001901 if (do_raise(tstate, exc, cause)) {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02001902 goto exception_unwind;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001903 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001904 break;
1905 default:
Victor Stinner438a12d2019-05-24 17:01:38 +02001906 _PyErr_SetString(tstate, PyExc_SystemError,
1907 "bad RAISE_VARARGS oparg");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001908 break;
1909 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001910 goto error;
1911 }
Guido van Rossumac7be682001-01-17 15:42:30 +00001912
Benjamin Petersonddd19492018-09-16 22:38:02 -07001913 case TARGET(RETURN_VALUE): {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00001914 retval = POP();
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02001915 assert(f->f_iblock == 0);
Pablo Galindof00828a2019-05-09 16:52:02 +01001916 goto exit_returning;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04001917 }
Guido van Rossumdb3165e1993-10-18 17:06:59 +00001918
Benjamin Petersonddd19492018-09-16 22:38:02 -07001919 case TARGET(GET_AITER): {
Yury Selivanov6ef05902015-05-28 11:21:31 -04001920 unaryfunc getter = NULL;
Yury Selivanov75445082015-05-11 22:57:16 -04001921 PyObject *iter = NULL;
Yury Selivanov75445082015-05-11 22:57:16 -04001922 PyObject *obj = TOP();
1923 PyTypeObject *type = Py_TYPE(obj);
1924
Yury Selivanova6f6edb2016-06-09 15:08:31 -04001925 if (type->tp_as_async != NULL) {
Yury Selivanov75445082015-05-11 22:57:16 -04001926 getter = type->tp_as_async->am_aiter;
Yury Selivanova6f6edb2016-06-09 15:08:31 -04001927 }
Yury Selivanov75445082015-05-11 22:57:16 -04001928
1929 if (getter != NULL) {
1930 iter = (*getter)(obj);
1931 Py_DECREF(obj);
1932 if (iter == NULL) {
1933 SET_TOP(NULL);
1934 goto error;
1935 }
1936 }
1937 else {
1938 SET_TOP(NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02001939 _PyErr_Format(tstate, PyExc_TypeError,
1940 "'async for' requires an object with "
1941 "__aiter__ method, got %.100s",
1942 type->tp_name);
Yury Selivanov75445082015-05-11 22:57:16 -04001943 Py_DECREF(obj);
1944 goto error;
1945 }
1946
Yury Selivanovfaa135a2017-10-06 02:08:57 -04001947 if (Py_TYPE(iter)->tp_as_async == NULL ||
1948 Py_TYPE(iter)->tp_as_async->am_anext == NULL) {
Yury Selivanov75445082015-05-11 22:57:16 -04001949
Yury Selivanov398ff912017-03-02 22:20:00 -05001950 SET_TOP(NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02001951 _PyErr_Format(tstate, PyExc_TypeError,
1952 "'async for' received an object from __aiter__ "
1953 "that does not implement __anext__: %.100s",
1954 Py_TYPE(iter)->tp_name);
Yury Selivanov75445082015-05-11 22:57:16 -04001955 Py_DECREF(iter);
1956 goto error;
Yury Selivanova6f6edb2016-06-09 15:08:31 -04001957 }
1958
Yury Selivanovfaa135a2017-10-06 02:08:57 -04001959 SET_TOP(iter);
Yury Selivanov75445082015-05-11 22:57:16 -04001960 DISPATCH();
1961 }
1962
Benjamin Petersonddd19492018-09-16 22:38:02 -07001963 case TARGET(GET_ANEXT): {
Yury Selivanov6ef05902015-05-28 11:21:31 -04001964 unaryfunc getter = NULL;
Yury Selivanov75445082015-05-11 22:57:16 -04001965 PyObject *next_iter = NULL;
1966 PyObject *awaitable = NULL;
1967 PyObject *aiter = TOP();
1968 PyTypeObject *type = Py_TYPE(aiter);
1969
Yury Selivanoveb636452016-09-08 22:01:51 -07001970 if (PyAsyncGen_CheckExact(aiter)) {
1971 awaitable = type->tp_as_async->am_anext(aiter);
1972 if (awaitable == NULL) {
Yury Selivanov75445082015-05-11 22:57:16 -04001973 goto error;
1974 }
Yury Selivanoveb636452016-09-08 22:01:51 -07001975 } else {
1976 if (type->tp_as_async != NULL){
1977 getter = type->tp_as_async->am_anext;
1978 }
Yury Selivanov75445082015-05-11 22:57:16 -04001979
Yury Selivanoveb636452016-09-08 22:01:51 -07001980 if (getter != NULL) {
1981 next_iter = (*getter)(aiter);
1982 if (next_iter == NULL) {
1983 goto error;
1984 }
1985 }
1986 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02001987 _PyErr_Format(tstate, PyExc_TypeError,
1988 "'async for' requires an iterator with "
1989 "__anext__ method, got %.100s",
1990 type->tp_name);
Yury Selivanoveb636452016-09-08 22:01:51 -07001991 goto error;
1992 }
Yury Selivanov75445082015-05-11 22:57:16 -04001993
Yury Selivanoveb636452016-09-08 22:01:51 -07001994 awaitable = _PyCoro_GetAwaitableIter(next_iter);
1995 if (awaitable == NULL) {
Yury Selivanov398ff912017-03-02 22:20:00 -05001996 _PyErr_FormatFromCause(
Yury Selivanoveb636452016-09-08 22:01:51 -07001997 PyExc_TypeError,
1998 "'async for' received an invalid object "
1999 "from __anext__: %.100s",
2000 Py_TYPE(next_iter)->tp_name);
2001
2002 Py_DECREF(next_iter);
2003 goto error;
2004 } else {
2005 Py_DECREF(next_iter);
2006 }
2007 }
Yury Selivanov75445082015-05-11 22:57:16 -04002008
2009 PUSH(awaitable);
Serhiy Storchakada9c5132016-06-27 18:58:57 +03002010 PREDICT(LOAD_CONST);
Yury Selivanov75445082015-05-11 22:57:16 -04002011 DISPATCH();
2012 }
2013
Benjamin Petersonddd19492018-09-16 22:38:02 -07002014 case TARGET(GET_AWAITABLE): {
2015 PREDICTED(GET_AWAITABLE);
Yury Selivanov75445082015-05-11 22:57:16 -04002016 PyObject *iterable = TOP();
Yury Selivanov5376ba92015-06-22 12:19:30 -04002017 PyObject *iter = _PyCoro_GetAwaitableIter(iterable);
Yury Selivanov75445082015-05-11 22:57:16 -04002018
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03002019 if (iter == NULL) {
Mark Shannonfee55262019-11-21 09:11:43 +00002020 int opcode_at_minus_3 = 0;
2021 if ((next_instr - first_instr) > 2) {
2022 opcode_at_minus_3 = _Py_OPCODE(next_instr[-3]);
2023 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002024 format_awaitable_error(tstate, Py_TYPE(iterable),
Mark Shannonfee55262019-11-21 09:11:43 +00002025 opcode_at_minus_3,
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03002026 _Py_OPCODE(next_instr[-2]));
2027 }
2028
Yury Selivanov75445082015-05-11 22:57:16 -04002029 Py_DECREF(iterable);
2030
Yury Selivanovc724bae2016-03-02 11:30:46 -05002031 if (iter != NULL && PyCoro_CheckExact(iter)) {
2032 PyObject *yf = _PyGen_yf((PyGenObject*)iter);
2033 if (yf != NULL) {
2034 /* `iter` is a coroutine object that is being
2035 awaited, `yf` is a pointer to the current awaitable
2036 being awaited on. */
2037 Py_DECREF(yf);
2038 Py_CLEAR(iter);
Victor Stinner438a12d2019-05-24 17:01:38 +02002039 _PyErr_SetString(tstate, PyExc_RuntimeError,
2040 "coroutine is being awaited already");
Yury Selivanovc724bae2016-03-02 11:30:46 -05002041 /* The code below jumps to `error` if `iter` is NULL. */
2042 }
2043 }
2044
Yury Selivanov75445082015-05-11 22:57:16 -04002045 SET_TOP(iter); /* Even if it's NULL */
2046
2047 if (iter == NULL) {
2048 goto error;
2049 }
2050
Serhiy Storchakada9c5132016-06-27 18:58:57 +03002051 PREDICT(LOAD_CONST);
Yury Selivanov75445082015-05-11 22:57:16 -04002052 DISPATCH();
2053 }
2054
Benjamin Petersonddd19492018-09-16 22:38:02 -07002055 case TARGET(YIELD_FROM): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002056 PyObject *v = POP();
Raymond Hettinger15f44ab2016-08-30 10:47:49 -07002057 PyObject *receiver = TOP();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002058 int err;
Raymond Hettinger15f44ab2016-08-30 10:47:49 -07002059 if (PyGen_CheckExact(receiver) || PyCoro_CheckExact(receiver)) {
2060 retval = _PyGen_Send((PyGenObject *)receiver, v);
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05002061 } else {
Benjamin Peterson302e7902012-03-20 23:17:04 -04002062 _Py_IDENTIFIER(send);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002063 if (v == Py_None)
Raymond Hettinger15f44ab2016-08-30 10:47:49 -07002064 retval = Py_TYPE(receiver)->tp_iternext(receiver);
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05002065 else
Jeroen Demeyer59ad1102019-07-11 10:59:05 +02002066 retval = _PyObject_CallMethodIdOneArg(receiver, &PyId_send, v);
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05002067 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002068 Py_DECREF(v);
2069 if (retval == NULL) {
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05002070 PyObject *val;
Guido van Rossum8820c232013-11-21 11:30:06 -08002071 if (tstate->c_tracefunc != NULL
Victor Stinner438a12d2019-05-24 17:01:38 +02002072 && _PyErr_ExceptionMatches(tstate, PyExc_StopIteration))
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01002073 call_exc_trace(tstate->c_tracefunc, tstate->c_traceobj, tstate, f);
Nick Coghlanc40bc092012-06-17 15:15:49 +10002074 err = _PyGen_FetchStopIterationValue(&val);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002075 if (err < 0)
2076 goto error;
Raymond Hettinger15f44ab2016-08-30 10:47:49 -07002077 Py_DECREF(receiver);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002078 SET_TOP(val);
2079 DISPATCH();
Nick Coghlan1f7ce622012-01-13 21:43:40 +10002080 }
Martin Panter95f53c12016-07-18 08:23:26 +00002081 /* receiver remains on stack, retval is value to be yielded */
Nick Coghlan1f7ce622012-01-13 21:43:40 +10002082 f->f_stacktop = stack_pointer;
Benjamin Peterson2afe6ae2012-03-15 15:37:39 -05002083 /* and repeat... */
Victor Stinnerf7d199f2016-11-24 22:33:01 +01002084 assert(f->f_lasti >= (int)sizeof(_Py_CODEUNIT));
Serhiy Storchakaab874002016-09-11 13:48:15 +03002085 f->f_lasti -= sizeof(_Py_CODEUNIT);
Pablo Galindof00828a2019-05-09 16:52:02 +01002086 goto exit_yielding;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002087 }
Nick Coghlan1f7ce622012-01-13 21:43:40 +10002088
Benjamin Petersonddd19492018-09-16 22:38:02 -07002089 case TARGET(YIELD_VALUE): {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002090 retval = POP();
Yury Selivanoveb636452016-09-08 22:01:51 -07002091
2092 if (co->co_flags & CO_ASYNC_GENERATOR) {
2093 PyObject *w = _PyAsyncGenValueWrapperNew(retval);
2094 Py_DECREF(retval);
2095 if (w == NULL) {
2096 retval = NULL;
2097 goto error;
2098 }
2099 retval = w;
2100 }
2101
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002102 f->f_stacktop = stack_pointer;
Pablo Galindof00828a2019-05-09 16:52:02 +01002103 goto exit_yielding;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002104 }
Tim Peters5ca576e2001-06-18 22:08:13 +00002105
Benjamin Petersonddd19492018-09-16 22:38:02 -07002106 case TARGET(POP_EXCEPT): {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02002107 PyObject *type, *value, *traceback;
2108 _PyErr_StackItem *exc_info;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002109 PyTryBlock *b = PyFrame_BlockPop(f);
2110 if (b->b_type != EXCEPT_HANDLER) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002111 _PyErr_SetString(tstate, PyExc_SystemError,
2112 "popped block is not an except handler");
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002113 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002114 }
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02002115 assert(STACK_LEVEL() >= (b)->b_level + 3 &&
2116 STACK_LEVEL() <= (b)->b_level + 4);
2117 exc_info = tstate->exc_info;
2118 type = exc_info->exc_type;
2119 value = exc_info->exc_value;
2120 traceback = exc_info->exc_traceback;
2121 exc_info->exc_type = POP();
2122 exc_info->exc_value = POP();
2123 exc_info->exc_traceback = POP();
2124 Py_XDECREF(type);
2125 Py_XDECREF(value);
2126 Py_XDECREF(traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002127 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002128 }
Benjamin Petersoneec3d712008-06-11 15:59:43 +00002129
Benjamin Petersonddd19492018-09-16 22:38:02 -07002130 case TARGET(POP_BLOCK): {
2131 PREDICTED(POP_BLOCK);
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02002132 PyFrame_BlockPop(f);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002133 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002134 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002135
Mark Shannonfee55262019-11-21 09:11:43 +00002136 case TARGET(RERAISE): {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02002137 PyObject *exc = POP();
Mark Shannonfee55262019-11-21 09:11:43 +00002138 PyObject *val = POP();
2139 PyObject *tb = POP();
2140 assert(PyExceptionClass_Check(exc));
2141 PyErr_Restore(exc, val, tb);
2142 goto exception_unwind;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002143 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002144
Benjamin Petersonddd19492018-09-16 22:38:02 -07002145 case TARGET(END_ASYNC_FOR): {
Serhiy Storchaka702f8f32018-03-23 14:34:35 +02002146 PyObject *exc = POP();
2147 assert(PyExceptionClass_Check(exc));
2148 if (PyErr_GivenExceptionMatches(exc, PyExc_StopAsyncIteration)) {
2149 PyTryBlock *b = PyFrame_BlockPop(f);
2150 assert(b->b_type == EXCEPT_HANDLER);
2151 Py_DECREF(exc);
2152 UNWIND_EXCEPT_HANDLER(b);
2153 Py_DECREF(POP());
2154 JUMPBY(oparg);
2155 FAST_DISPATCH();
2156 }
2157 else {
2158 PyObject *val = POP();
2159 PyObject *tb = POP();
Victor Stinner438a12d2019-05-24 17:01:38 +02002160 _PyErr_Restore(tstate, exc, val, tb);
Serhiy Storchaka702f8f32018-03-23 14:34:35 +02002161 goto exception_unwind;
2162 }
2163 }
2164
Zackery Spytzce6a0702019-08-25 03:44:09 -06002165 case TARGET(LOAD_ASSERTION_ERROR): {
2166 PyObject *value = PyExc_AssertionError;
2167 Py_INCREF(value);
2168 PUSH(value);
2169 FAST_DISPATCH();
2170 }
2171
Benjamin Petersonddd19492018-09-16 22:38:02 -07002172 case TARGET(LOAD_BUILD_CLASS): {
Victor Stinner3c1e4812012-03-26 22:10:51 +02002173 _Py_IDENTIFIER(__build_class__);
Victor Stinnerb0b22422012-04-19 00:57:45 +02002174
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002175 PyObject *bc;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002176 if (PyDict_CheckExact(f->f_builtins)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002177 bc = _PyDict_GetItemIdWithError(f->f_builtins, &PyId___build_class__);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002178 if (bc == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002179 if (!_PyErr_Occurred(tstate)) {
2180 _PyErr_SetString(tstate, PyExc_NameError,
2181 "__build_class__ not found");
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002182 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002183 goto error;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002184 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002185 Py_INCREF(bc);
Victor Stinnerb0b22422012-04-19 00:57:45 +02002186 }
2187 else {
2188 PyObject *build_class_str = _PyUnicode_FromId(&PyId___build_class__);
2189 if (build_class_str == NULL)
Serhiy Storchaka70b72f02016-11-08 23:12:46 +02002190 goto error;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002191 bc = PyObject_GetItem(f->f_builtins, build_class_str);
2192 if (bc == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002193 if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError))
2194 _PyErr_SetString(tstate, PyExc_NameError,
2195 "__build_class__ not found");
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002196 goto error;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002197 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002198 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002199 PUSH(bc);
Benjamin Peterson00f86f22012-10-10 14:10:33 -04002200 DISPATCH();
Victor Stinner3c1e4812012-03-26 22:10:51 +02002201 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002202
Benjamin Petersonddd19492018-09-16 22:38:02 -07002203 case TARGET(STORE_NAME): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002204 PyObject *name = GETITEM(names, oparg);
2205 PyObject *v = POP();
2206 PyObject *ns = f->f_locals;
2207 int err;
2208 if (ns == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002209 _PyErr_Format(tstate, PyExc_SystemError,
2210 "no locals found when storing %R", name);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002211 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002212 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002213 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002214 if (PyDict_CheckExact(ns))
2215 err = PyDict_SetItem(ns, name, v);
2216 else
2217 err = PyObject_SetItem(ns, name, v);
2218 Py_DECREF(v);
2219 if (err != 0)
2220 goto error;
2221 DISPATCH();
2222 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002223
Benjamin Petersonddd19492018-09-16 22:38:02 -07002224 case TARGET(DELETE_NAME): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002225 PyObject *name = GETITEM(names, oparg);
2226 PyObject *ns = f->f_locals;
2227 int err;
2228 if (ns == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002229 _PyErr_Format(tstate, PyExc_SystemError,
2230 "no locals when deleting %R", name);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002231 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002232 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002233 err = PyObject_DelItem(ns, name);
2234 if (err != 0) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002235 format_exc_check_arg(tstate, PyExc_NameError,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002236 NAME_ERROR_MSG,
2237 name);
2238 goto error;
2239 }
2240 DISPATCH();
2241 }
Guido van Rossum04691fc1992-08-12 15:35:34 +00002242
Benjamin Petersonddd19492018-09-16 22:38:02 -07002243 case TARGET(UNPACK_SEQUENCE): {
2244 PREDICTED(UNPACK_SEQUENCE);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002245 PyObject *seq = POP(), *item, **items;
2246 if (PyTuple_CheckExact(seq) &&
2247 PyTuple_GET_SIZE(seq) == oparg) {
2248 items = ((PyTupleObject *)seq)->ob_item;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002249 while (oparg--) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002250 item = items[oparg];
2251 Py_INCREF(item);
2252 PUSH(item);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002253 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002254 } else if (PyList_CheckExact(seq) &&
2255 PyList_GET_SIZE(seq) == oparg) {
2256 items = ((PyListObject *)seq)->ob_item;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002257 while (oparg--) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002258 item = items[oparg];
2259 Py_INCREF(item);
2260 PUSH(item);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002261 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002262 } else if (unpack_iterable(tstate, seq, oparg, -1,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002263 stack_pointer + oparg)) {
costypetrisor8ed317f2018-07-31 20:55:14 +00002264 STACK_GROW(oparg);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002265 } else {
2266 /* unpack_iterable() raised an exception */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002267 Py_DECREF(seq);
2268 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002269 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002270 Py_DECREF(seq);
Benjamin Peterson00f86f22012-10-10 14:10:33 -04002271 DISPATCH();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002272 }
Guido van Rossum0368b722007-05-11 16:50:42 +00002273
Benjamin Petersonddd19492018-09-16 22:38:02 -07002274 case TARGET(UNPACK_EX): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002275 int totalargs = 1 + (oparg & 0xFF) + (oparg >> 8);
2276 PyObject *seq = POP();
2277
Victor Stinner438a12d2019-05-24 17:01:38 +02002278 if (unpack_iterable(tstate, seq, oparg & 0xFF, oparg >> 8,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002279 stack_pointer + totalargs)) {
2280 stack_pointer += totalargs;
2281 } else {
2282 Py_DECREF(seq);
2283 goto error;
2284 }
2285 Py_DECREF(seq);
2286 DISPATCH();
2287 }
2288
Benjamin Petersonddd19492018-09-16 22:38:02 -07002289 case TARGET(STORE_ATTR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002290 PyObject *name = GETITEM(names, oparg);
2291 PyObject *owner = TOP();
2292 PyObject *v = SECOND();
2293 int err;
costypetrisor8ed317f2018-07-31 20:55:14 +00002294 STACK_SHRINK(2);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002295 err = PyObject_SetAttr(owner, name, v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002296 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002297 Py_DECREF(owner);
2298 if (err != 0)
2299 goto error;
2300 DISPATCH();
2301 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002302
Benjamin Petersonddd19492018-09-16 22:38:02 -07002303 case TARGET(DELETE_ATTR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002304 PyObject *name = GETITEM(names, oparg);
2305 PyObject *owner = POP();
2306 int err;
2307 err = PyObject_SetAttr(owner, name, (PyObject *)NULL);
2308 Py_DECREF(owner);
2309 if (err != 0)
2310 goto error;
2311 DISPATCH();
2312 }
2313
Benjamin Petersonddd19492018-09-16 22:38:02 -07002314 case TARGET(STORE_GLOBAL): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002315 PyObject *name = GETITEM(names, oparg);
2316 PyObject *v = POP();
2317 int err;
2318 err = PyDict_SetItem(f->f_globals, name, v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002319 Py_DECREF(v);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002320 if (err != 0)
2321 goto error;
2322 DISPATCH();
2323 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002324
Benjamin Petersonddd19492018-09-16 22:38:02 -07002325 case TARGET(DELETE_GLOBAL): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002326 PyObject *name = GETITEM(names, oparg);
2327 int err;
2328 err = PyDict_DelItem(f->f_globals, name);
2329 if (err != 0) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002330 if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
2331 format_exc_check_arg(tstate, PyExc_NameError,
2332 NAME_ERROR_MSG, name);
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002333 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002334 goto error;
Benjamin Peterson00f86f22012-10-10 14:10:33 -04002335 }
2336 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002337 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002338
Benjamin Petersonddd19492018-09-16 22:38:02 -07002339 case TARGET(LOAD_NAME): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002340 PyObject *name = GETITEM(names, oparg);
2341 PyObject *locals = f->f_locals;
2342 PyObject *v;
2343 if (locals == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002344 _PyErr_Format(tstate, PyExc_SystemError,
2345 "no locals when loading %R", name);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002346 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002347 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002348 if (PyDict_CheckExact(locals)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002349 v = PyDict_GetItemWithError(locals, name);
2350 if (v != NULL) {
2351 Py_INCREF(v);
2352 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002353 else if (_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002354 goto error;
2355 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002356 }
2357 else {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002358 v = PyObject_GetItem(locals, name);
Victor Stinnere20310f2015-11-05 13:56:58 +01002359 if (v == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002360 if (!_PyErr_ExceptionMatches(tstate, PyExc_KeyError))
Benjamin Peterson92722792012-12-15 12:51:05 -05002361 goto error;
Victor Stinner438a12d2019-05-24 17:01:38 +02002362 _PyErr_Clear(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002363 }
2364 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002365 if (v == NULL) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002366 v = PyDict_GetItemWithError(f->f_globals, name);
2367 if (v != NULL) {
2368 Py_INCREF(v);
2369 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002370 else if (_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002371 goto error;
2372 }
2373 else {
Victor Stinnerb0b22422012-04-19 00:57:45 +02002374 if (PyDict_CheckExact(f->f_builtins)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002375 v = PyDict_GetItemWithError(f->f_builtins, name);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002376 if (v == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002377 if (!_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002378 format_exc_check_arg(
Victor Stinner438a12d2019-05-24 17:01:38 +02002379 tstate, PyExc_NameError,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002380 NAME_ERROR_MSG, name);
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002381 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002382 goto error;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002383 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002384 Py_INCREF(v);
Victor Stinnerb0b22422012-04-19 00:57:45 +02002385 }
2386 else {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002387 v = PyObject_GetItem(f->f_builtins, name);
2388 if (v == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002389 if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Victor Stinnerb0b22422012-04-19 00:57:45 +02002390 format_exc_check_arg(
Victor Stinner438a12d2019-05-24 17:01:38 +02002391 tstate, PyExc_NameError,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002392 NAME_ERROR_MSG, name);
Victor Stinner438a12d2019-05-24 17:01:38 +02002393 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002394 goto error;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002395 }
Benjamin Peterson20f9c3c2010-07-20 22:39:34 +00002396 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002397 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002398 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002399 PUSH(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002400 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002401 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002402
Benjamin Petersonddd19492018-09-16 22:38:02 -07002403 case TARGET(LOAD_GLOBAL): {
Inada Naoki91234a12019-06-03 21:30:58 +09002404 PyObject *name;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002405 PyObject *v;
Victor Stinnerb0b22422012-04-19 00:57:45 +02002406 if (PyDict_CheckExact(f->f_globals)
Victor Stinnerb4efc962015-11-20 09:24:02 +01002407 && PyDict_CheckExact(f->f_builtins))
2408 {
Inada Naoki91234a12019-06-03 21:30:58 +09002409 OPCACHE_CHECK();
2410 if (co_opcache != NULL && co_opcache->optimized > 0) {
2411 _PyOpcache_LoadGlobal *lg = &co_opcache->u.lg;
2412
2413 if (lg->globals_ver ==
2414 ((PyDictObject *)f->f_globals)->ma_version_tag
2415 && lg->builtins_ver ==
2416 ((PyDictObject *)f->f_builtins)->ma_version_tag)
2417 {
2418 PyObject *ptr = lg->ptr;
2419 OPCACHE_STAT_GLOBAL_HIT();
2420 assert(ptr != NULL);
2421 Py_INCREF(ptr);
2422 PUSH(ptr);
2423 DISPATCH();
2424 }
2425 }
2426
2427 name = GETITEM(names, oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002428 v = _PyDict_LoadGlobal((PyDictObject *)f->f_globals,
Benjamin Peterson7d95e402012-04-23 11:24:50 -04002429 (PyDictObject *)f->f_builtins,
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002430 name);
2431 if (v == NULL) {
Victor Stinnerb4efc962015-11-20 09:24:02 +01002432 if (!_PyErr_OCCURRED()) {
2433 /* _PyDict_LoadGlobal() returns NULL without raising
2434 * an exception if the key doesn't exist */
Victor Stinner438a12d2019-05-24 17:01:38 +02002435 format_exc_check_arg(tstate, PyExc_NameError,
Ezio Melotti04a29552013-03-03 15:12:44 +02002436 NAME_ERROR_MSG, name);
Victor Stinnerb4efc962015-11-20 09:24:02 +01002437 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002438 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002439 }
Inada Naoki91234a12019-06-03 21:30:58 +09002440
2441 if (co_opcache != NULL) {
2442 _PyOpcache_LoadGlobal *lg = &co_opcache->u.lg;
2443
2444 if (co_opcache->optimized == 0) {
2445 /* Wasn't optimized before. */
2446 OPCACHE_STAT_GLOBAL_OPT();
2447 } else {
2448 OPCACHE_STAT_GLOBAL_MISS();
2449 }
2450
2451 co_opcache->optimized = 1;
2452 lg->globals_ver =
2453 ((PyDictObject *)f->f_globals)->ma_version_tag;
2454 lg->builtins_ver =
2455 ((PyDictObject *)f->f_builtins)->ma_version_tag;
2456 lg->ptr = v; /* borrowed */
2457 }
2458
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002459 Py_INCREF(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002460 }
Benjamin Peterson7d95e402012-04-23 11:24:50 -04002461 else {
2462 /* Slow-path if globals or builtins is not a dict */
Victor Stinnerb4efc962015-11-20 09:24:02 +01002463
2464 /* namespace 1: globals */
Inada Naoki91234a12019-06-03 21:30:58 +09002465 name = GETITEM(names, oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002466 v = PyObject_GetItem(f->f_globals, name);
2467 if (v == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002468 if (!_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Victor Stinner60a1d3c2015-11-05 13:55:20 +01002469 goto error;
Victor Stinner438a12d2019-05-24 17:01:38 +02002470 }
2471 _PyErr_Clear(tstate);
Victor Stinner60a1d3c2015-11-05 13:55:20 +01002472
Victor Stinnerb4efc962015-11-20 09:24:02 +01002473 /* namespace 2: builtins */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002474 v = PyObject_GetItem(f->f_builtins, name);
2475 if (v == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002476 if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Benjamin Peterson7d95e402012-04-23 11:24:50 -04002477 format_exc_check_arg(
Victor Stinner438a12d2019-05-24 17:01:38 +02002478 tstate, PyExc_NameError,
Ezio Melotti04a29552013-03-03 15:12:44 +02002479 NAME_ERROR_MSG, name);
Victor Stinner438a12d2019-05-24 17:01:38 +02002480 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002481 goto error;
Benjamin Peterson7d95e402012-04-23 11:24:50 -04002482 }
2483 }
2484 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002485 PUSH(v);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002486 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002487 }
Guido van Rossum681d79a1995-07-18 14:51:37 +00002488
Benjamin Petersonddd19492018-09-16 22:38:02 -07002489 case TARGET(DELETE_FAST): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002490 PyObject *v = GETLOCAL(oparg);
2491 if (v != NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002492 SETLOCAL(oparg, NULL);
2493 DISPATCH();
2494 }
2495 format_exc_check_arg(
Victor Stinner438a12d2019-05-24 17:01:38 +02002496 tstate, PyExc_UnboundLocalError,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002497 UNBOUNDLOCAL_ERROR_MSG,
2498 PyTuple_GetItem(co->co_varnames, oparg)
2499 );
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002500 goto error;
2501 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002502
Benjamin Petersonddd19492018-09-16 22:38:02 -07002503 case TARGET(DELETE_DEREF): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002504 PyObject *cell = freevars[oparg];
Raymond Hettingerc32f9db2016-11-12 04:10:35 -05002505 PyObject *oldobj = PyCell_GET(cell);
2506 if (oldobj != NULL) {
2507 PyCell_SET(cell, NULL);
2508 Py_DECREF(oldobj);
Benjamin Peterson00ebe2c2010-09-10 22:02:31 +00002509 DISPATCH();
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00002510 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002511 format_exc_unbound(tstate, co, oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002512 goto error;
2513 }
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00002514
Benjamin Petersonddd19492018-09-16 22:38:02 -07002515 case TARGET(LOAD_CLOSURE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002516 PyObject *cell = freevars[oparg];
2517 Py_INCREF(cell);
2518 PUSH(cell);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002519 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002520 }
Jeremy Hylton64949cb2001-01-25 20:06:59 +00002521
Benjamin Petersonddd19492018-09-16 22:38:02 -07002522 case TARGET(LOAD_CLASSDEREF): {
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002523 PyObject *name, *value, *locals = f->f_locals;
Victor Stinnerd3dfd0e2013-05-16 23:48:01 +02002524 Py_ssize_t idx;
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002525 assert(locals);
2526 assert(oparg >= PyTuple_GET_SIZE(co->co_cellvars));
2527 idx = oparg - PyTuple_GET_SIZE(co->co_cellvars);
2528 assert(idx >= 0 && idx < PyTuple_GET_SIZE(co->co_freevars));
2529 name = PyTuple_GET_ITEM(co->co_freevars, idx);
2530 if (PyDict_CheckExact(locals)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002531 value = PyDict_GetItemWithError(locals, name);
2532 if (value != NULL) {
2533 Py_INCREF(value);
2534 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002535 else if (_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002536 goto error;
2537 }
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002538 }
2539 else {
2540 value = PyObject_GetItem(locals, name);
Victor Stinnere20310f2015-11-05 13:56:58 +01002541 if (value == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002542 if (!_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002543 goto error;
Victor Stinner438a12d2019-05-24 17:01:38 +02002544 }
2545 _PyErr_Clear(tstate);
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002546 }
2547 }
2548 if (!value) {
2549 PyObject *cell = freevars[oparg];
2550 value = PyCell_GET(cell);
2551 if (value == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002552 format_exc_unbound(tstate, co, oparg);
Benjamin Peterson3b0431d2013-04-30 09:41:40 -04002553 goto error;
2554 }
2555 Py_INCREF(value);
2556 }
2557 PUSH(value);
2558 DISPATCH();
2559 }
2560
Benjamin Petersonddd19492018-09-16 22:38:02 -07002561 case TARGET(LOAD_DEREF): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002562 PyObject *cell = freevars[oparg];
2563 PyObject *value = PyCell_GET(cell);
2564 if (value == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002565 format_exc_unbound(tstate, co, oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002566 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002567 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002568 Py_INCREF(value);
2569 PUSH(value);
2570 DISPATCH();
2571 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002572
Benjamin Petersonddd19492018-09-16 22:38:02 -07002573 case TARGET(STORE_DEREF): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002574 PyObject *v = POP();
2575 PyObject *cell = freevars[oparg];
Raymond Hettingerb2b15432016-11-11 04:32:11 -08002576 PyObject *oldobj = PyCell_GET(cell);
2577 PyCell_SET(cell, v);
2578 Py_XDECREF(oldobj);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002579 DISPATCH();
2580 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002581
Benjamin Petersonddd19492018-09-16 22:38:02 -07002582 case TARGET(BUILD_STRING): {
Serhiy Storchakaea525a22016-09-06 22:07:53 +03002583 PyObject *str;
2584 PyObject *empty = PyUnicode_New(0, 0);
2585 if (empty == NULL) {
2586 goto error;
2587 }
2588 str = _PyUnicode_JoinArray(empty, stack_pointer - oparg, oparg);
2589 Py_DECREF(empty);
2590 if (str == NULL)
2591 goto error;
2592 while (--oparg >= 0) {
2593 PyObject *item = POP();
2594 Py_DECREF(item);
2595 }
2596 PUSH(str);
2597 DISPATCH();
2598 }
2599
Benjamin Petersonddd19492018-09-16 22:38:02 -07002600 case TARGET(BUILD_TUPLE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002601 PyObject *tup = PyTuple_New(oparg);
2602 if (tup == NULL)
2603 goto error;
2604 while (--oparg >= 0) {
2605 PyObject *item = POP();
2606 PyTuple_SET_ITEM(tup, oparg, item);
2607 }
2608 PUSH(tup);
2609 DISPATCH();
2610 }
2611
Benjamin Petersonddd19492018-09-16 22:38:02 -07002612 case TARGET(BUILD_LIST): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002613 PyObject *list = PyList_New(oparg);
2614 if (list == NULL)
2615 goto error;
2616 while (--oparg >= 0) {
2617 PyObject *item = POP();
2618 PyList_SET_ITEM(list, oparg, item);
2619 }
2620 PUSH(list);
2621 DISPATCH();
2622 }
2623
Benjamin Petersonddd19492018-09-16 22:38:02 -07002624 case TARGET(BUILD_TUPLE_UNPACK_WITH_CALL):
2625 case TARGET(BUILD_TUPLE_UNPACK):
2626 case TARGET(BUILD_LIST_UNPACK): {
Serhiy Storchaka73442852016-10-02 10:33:46 +03002627 int convert_to_tuple = opcode != BUILD_LIST_UNPACK;
Victor Stinner74319ae2016-08-25 00:04:09 +02002628 Py_ssize_t i;
Serhiy Storchakab7281052016-09-12 00:52:40 +03002629 PyObject *sum = PyList_New(0);
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002630 PyObject *return_value;
Victor Stinnerf9b760f2016-09-09 10:17:08 -07002631
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002632 if (sum == NULL)
2633 goto error;
2634
2635 for (i = oparg; i > 0; i--) {
2636 PyObject *none_val;
2637
2638 none_val = _PyList_Extend((PyListObject *)sum, PEEK(i));
2639 if (none_val == NULL) {
Serhiy Storchaka73442852016-10-02 10:33:46 +03002640 if (opcode == BUILD_TUPLE_UNPACK_WITH_CALL &&
Victor Stinner438a12d2019-05-24 17:01:38 +02002641 _PyErr_ExceptionMatches(tstate, PyExc_TypeError))
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03002642 {
Victor Stinner438a12d2019-05-24 17:01:38 +02002643 check_args_iterable(tstate, PEEK(1 + oparg), PEEK(i));
Serhiy Storchaka73442852016-10-02 10:33:46 +03002644 }
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002645 Py_DECREF(sum);
2646 goto error;
2647 }
2648 Py_DECREF(none_val);
2649 }
2650
2651 if (convert_to_tuple) {
2652 return_value = PyList_AsTuple(sum);
2653 Py_DECREF(sum);
2654 if (return_value == NULL)
2655 goto error;
2656 }
2657 else {
2658 return_value = sum;
2659 }
2660
2661 while (oparg--)
2662 Py_DECREF(POP());
2663 PUSH(return_value);
2664 DISPATCH();
2665 }
2666
Benjamin Petersonddd19492018-09-16 22:38:02 -07002667 case TARGET(BUILD_SET): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002668 PyObject *set = PySet_New(NULL);
2669 int err = 0;
Raymond Hettinger4c483ad2016-09-08 14:45:40 -07002670 int i;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002671 if (set == NULL)
2672 goto error;
Raymond Hettinger4c483ad2016-09-08 14:45:40 -07002673 for (i = oparg; i > 0; i--) {
2674 PyObject *item = PEEK(i);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002675 if (err == 0)
2676 err = PySet_Add(set, item);
2677 Py_DECREF(item);
2678 }
costypetrisor8ed317f2018-07-31 20:55:14 +00002679 STACK_SHRINK(oparg);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002680 if (err != 0) {
2681 Py_DECREF(set);
2682 goto error;
2683 }
2684 PUSH(set);
2685 DISPATCH();
2686 }
2687
Benjamin Petersonddd19492018-09-16 22:38:02 -07002688 case TARGET(BUILD_SET_UNPACK): {
Victor Stinner74319ae2016-08-25 00:04:09 +02002689 Py_ssize_t i;
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002690 PyObject *sum = PySet_New(NULL);
2691 if (sum == NULL)
2692 goto error;
2693
2694 for (i = oparg; i > 0; i--) {
2695 if (_PySet_Update(sum, PEEK(i)) < 0) {
2696 Py_DECREF(sum);
2697 goto error;
2698 }
2699 }
2700
2701 while (oparg--)
2702 Py_DECREF(POP());
2703 PUSH(sum);
2704 DISPATCH();
2705 }
2706
Benjamin Petersonddd19492018-09-16 22:38:02 -07002707 case TARGET(BUILD_MAP): {
Victor Stinner74319ae2016-08-25 00:04:09 +02002708 Py_ssize_t i;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002709 PyObject *map = _PyDict_NewPresized((Py_ssize_t)oparg);
2710 if (map == NULL)
2711 goto error;
Benjamin Petersond5d77aa2015-07-05 10:37:25 -05002712 for (i = oparg; i > 0; i--) {
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002713 int err;
Benjamin Petersond5d77aa2015-07-05 10:37:25 -05002714 PyObject *key = PEEK(2*i);
2715 PyObject *value = PEEK(2*i - 1);
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002716 err = PyDict_SetItem(map, key, value);
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002717 if (err != 0) {
2718 Py_DECREF(map);
2719 goto error;
2720 }
2721 }
Benjamin Petersond5d77aa2015-07-05 10:37:25 -05002722
2723 while (oparg--) {
2724 Py_DECREF(POP());
2725 Py_DECREF(POP());
2726 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002727 PUSH(map);
2728 DISPATCH();
2729 }
2730
Benjamin Petersonddd19492018-09-16 22:38:02 -07002731 case TARGET(SETUP_ANNOTATIONS): {
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002732 _Py_IDENTIFIER(__annotations__);
2733 int err;
2734 PyObject *ann_dict;
2735 if (f->f_locals == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002736 _PyErr_Format(tstate, PyExc_SystemError,
2737 "no locals found when setting up annotations");
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002738 goto error;
2739 }
2740 /* check if __annotations__ in locals()... */
2741 if (PyDict_CheckExact(f->f_locals)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002742 ann_dict = _PyDict_GetItemIdWithError(f->f_locals,
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002743 &PyId___annotations__);
2744 if (ann_dict == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002745 if (_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02002746 goto error;
2747 }
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002748 /* ...if not, create a new one */
2749 ann_dict = PyDict_New();
2750 if (ann_dict == NULL) {
2751 goto error;
2752 }
2753 err = _PyDict_SetItemId(f->f_locals,
2754 &PyId___annotations__, ann_dict);
2755 Py_DECREF(ann_dict);
2756 if (err != 0) {
2757 goto error;
2758 }
2759 }
2760 }
2761 else {
2762 /* do the same if locals() is not a dict */
2763 PyObject *ann_str = _PyUnicode_FromId(&PyId___annotations__);
2764 if (ann_str == NULL) {
Serhiy Storchaka4678b2f2016-11-08 23:13:36 +02002765 goto error;
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002766 }
2767 ann_dict = PyObject_GetItem(f->f_locals, ann_str);
2768 if (ann_dict == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002769 if (!_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002770 goto error;
2771 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002772 _PyErr_Clear(tstate);
Yury Selivanovf8cb8a12016-09-08 20:50:03 -07002773 ann_dict = PyDict_New();
2774 if (ann_dict == NULL) {
2775 goto error;
2776 }
2777 err = PyObject_SetItem(f->f_locals, ann_str, ann_dict);
2778 Py_DECREF(ann_dict);
2779 if (err != 0) {
2780 goto error;
2781 }
2782 }
2783 else {
2784 Py_DECREF(ann_dict);
2785 }
2786 }
2787 DISPATCH();
2788 }
2789
Benjamin Petersonddd19492018-09-16 22:38:02 -07002790 case TARGET(BUILD_CONST_KEY_MAP): {
Victor Stinner74319ae2016-08-25 00:04:09 +02002791 Py_ssize_t i;
Serhiy Storchaka6a7506a2016-06-12 00:39:41 +03002792 PyObject *map;
2793 PyObject *keys = TOP();
2794 if (!PyTuple_CheckExact(keys) ||
2795 PyTuple_GET_SIZE(keys) != (Py_ssize_t)oparg) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002796 _PyErr_SetString(tstate, PyExc_SystemError,
2797 "bad BUILD_CONST_KEY_MAP keys argument");
Serhiy Storchaka6a7506a2016-06-12 00:39:41 +03002798 goto error;
2799 }
2800 map = _PyDict_NewPresized((Py_ssize_t)oparg);
2801 if (map == NULL) {
2802 goto error;
2803 }
2804 for (i = oparg; i > 0; i--) {
2805 int err;
2806 PyObject *key = PyTuple_GET_ITEM(keys, oparg - i);
2807 PyObject *value = PEEK(i + 1);
2808 err = PyDict_SetItem(map, key, value);
2809 if (err != 0) {
2810 Py_DECREF(map);
2811 goto error;
2812 }
2813 }
2814
2815 Py_DECREF(POP());
2816 while (oparg--) {
2817 Py_DECREF(POP());
2818 }
2819 PUSH(map);
2820 DISPATCH();
2821 }
2822
Benjamin Petersonddd19492018-09-16 22:38:02 -07002823 case TARGET(BUILD_MAP_UNPACK): {
Victor Stinner74319ae2016-08-25 00:04:09 +02002824 Py_ssize_t i;
Serhiy Storchakab7281052016-09-12 00:52:40 +03002825 PyObject *sum = PyDict_New();
Victor Stinnerf9b760f2016-09-09 10:17:08 -07002826 if (sum == NULL)
2827 goto error;
2828
2829 for (i = oparg; i > 0; i--) {
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002830 PyObject *arg = PEEK(i);
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002831 if (PyDict_Update(sum, arg) < 0) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002832 if (_PyErr_ExceptionMatches(tstate, PyExc_AttributeError)) {
2833 _PyErr_Format(tstate, PyExc_TypeError,
2834 "'%.200s' object is not a mapping",
2835 arg->ob_type->tp_name);
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002836 }
2837 Py_DECREF(sum);
2838 goto error;
2839 }
2840 }
2841
Victor Stinnerf9b760f2016-09-09 10:17:08 -07002842 while (oparg--)
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04002843 Py_DECREF(POP());
2844 PUSH(sum);
2845 DISPATCH();
2846 }
2847
Benjamin Petersonddd19492018-09-16 22:38:02 -07002848 case TARGET(BUILD_MAP_UNPACK_WITH_CALL): {
Serhiy Storchakae036ef82016-10-02 11:06:43 +03002849 Py_ssize_t i;
2850 PyObject *sum = PyDict_New();
2851 if (sum == NULL)
2852 goto error;
2853
2854 for (i = oparg; i > 0; i--) {
2855 PyObject *arg = PEEK(i);
2856 if (_PyDict_MergeEx(sum, arg, 2) < 0) {
Serhiy Storchakae036ef82016-10-02 11:06:43 +03002857 Py_DECREF(sum);
Victor Stinner438a12d2019-05-24 17:01:38 +02002858 format_kwargs_error(tstate, PEEK(2 + oparg), arg);
Serhiy Storchakae036ef82016-10-02 11:06:43 +03002859 goto error;
2860 }
2861 }
2862
2863 while (oparg--)
2864 Py_DECREF(POP());
2865 PUSH(sum);
Brandt Bucherf185a732019-09-28 17:12:49 -07002866 PREDICT(CALL_FUNCTION_EX);
Serhiy Storchakae036ef82016-10-02 11:06:43 +03002867 DISPATCH();
2868 }
2869
Benjamin Petersonddd19492018-09-16 22:38:02 -07002870 case TARGET(MAP_ADD): {
Jörn Heisslerc8a35412019-06-22 16:40:55 +02002871 PyObject *value = TOP();
2872 PyObject *key = SECOND();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002873 PyObject *map;
2874 int err;
costypetrisor8ed317f2018-07-31 20:55:14 +00002875 STACK_SHRINK(2);
Raymond Hettinger41862222016-10-15 19:03:06 -07002876 map = PEEK(oparg); /* dict */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002877 assert(PyDict_CheckExact(map));
Martin Panter95f53c12016-07-18 08:23:26 +00002878 err = PyDict_SetItem(map, key, value); /* map[key] = value */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002879 Py_DECREF(value);
2880 Py_DECREF(key);
2881 if (err != 0)
2882 goto error;
2883 PREDICT(JUMP_ABSOLUTE);
2884 DISPATCH();
2885 }
2886
Benjamin Petersonddd19492018-09-16 22:38:02 -07002887 case TARGET(LOAD_ATTR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002888 PyObject *name = GETITEM(names, oparg);
2889 PyObject *owner = TOP();
2890 PyObject *res = PyObject_GetAttr(owner, name);
2891 Py_DECREF(owner);
2892 SET_TOP(res);
2893 if (res == NULL)
2894 goto error;
2895 DISPATCH();
2896 }
2897
Benjamin Petersonddd19492018-09-16 22:38:02 -07002898 case TARGET(COMPARE_OP): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002899 PyObject *right = POP();
2900 PyObject *left = TOP();
Victor Stinner438a12d2019-05-24 17:01:38 +02002901 PyObject *res = cmp_outcome(tstate, oparg, left, right);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002902 Py_DECREF(left);
2903 Py_DECREF(right);
2904 SET_TOP(res);
2905 if (res == NULL)
2906 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002907 PREDICT(POP_JUMP_IF_FALSE);
2908 PREDICT(POP_JUMP_IF_TRUE);
2909 DISPATCH();
Victor Stinner3c1e4812012-03-26 22:10:51 +02002910 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002911
Benjamin Petersonddd19492018-09-16 22:38:02 -07002912 case TARGET(IMPORT_NAME): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002913 PyObject *name = GETITEM(names, oparg);
Serhiy Storchaka133138a2016-08-02 22:51:21 +03002914 PyObject *fromlist = POP();
2915 PyObject *level = TOP();
2916 PyObject *res;
Victor Stinner438a12d2019-05-24 17:01:38 +02002917 res = import_name(tstate, f, name, fromlist, level);
Serhiy Storchaka133138a2016-08-02 22:51:21 +03002918 Py_DECREF(level);
2919 Py_DECREF(fromlist);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002920 SET_TOP(res);
2921 if (res == NULL)
2922 goto error;
2923 DISPATCH();
2924 }
2925
Benjamin Petersonddd19492018-09-16 22:38:02 -07002926 case TARGET(IMPORT_STAR): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002927 PyObject *from = POP(), *locals;
2928 int err;
Matthias Bussonnier160edb42017-02-25 21:58:05 -08002929 if (PyFrame_FastToLocalsWithError(f) < 0) {
2930 Py_DECREF(from);
Victor Stinner41bb43a2013-10-29 01:19:37 +01002931 goto error;
Matthias Bussonnier160edb42017-02-25 21:58:05 -08002932 }
Victor Stinner41bb43a2013-10-29 01:19:37 +01002933
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002934 locals = f->f_locals;
2935 if (locals == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02002936 _PyErr_SetString(tstate, PyExc_SystemError,
2937 "no locals found during 'import *'");
Matthias Bussonnier160edb42017-02-25 21:58:05 -08002938 Py_DECREF(from);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002939 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002940 }
Victor Stinner438a12d2019-05-24 17:01:38 +02002941 err = import_all_from(tstate, locals, from);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002942 PyFrame_LocalsToFast(f, 0);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002943 Py_DECREF(from);
2944 if (err != 0)
2945 goto error;
2946 DISPATCH();
2947 }
Guido van Rossum25831651993-05-19 14:50:45 +00002948
Benjamin Petersonddd19492018-09-16 22:38:02 -07002949 case TARGET(IMPORT_FROM): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002950 PyObject *name = GETITEM(names, oparg);
2951 PyObject *from = TOP();
2952 PyObject *res;
Victor Stinner438a12d2019-05-24 17:01:38 +02002953 res = import_from(tstate, from, name);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002954 PUSH(res);
2955 if (res == NULL)
2956 goto error;
2957 DISPATCH();
2958 }
Thomas Wouters52152252000-08-17 22:55:00 +00002959
Benjamin Petersonddd19492018-09-16 22:38:02 -07002960 case TARGET(JUMP_FORWARD): {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002961 JUMPBY(oparg);
2962 FAST_DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002963 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002964
Benjamin Petersonddd19492018-09-16 22:38:02 -07002965 case TARGET(POP_JUMP_IF_FALSE): {
2966 PREDICTED(POP_JUMP_IF_FALSE);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002967 PyObject *cond = POP();
2968 int err;
2969 if (cond == Py_True) {
2970 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002971 FAST_DISPATCH();
2972 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002973 if (cond == Py_False) {
2974 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002975 JUMPTO(oparg);
2976 FAST_DISPATCH();
2977 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002978 err = PyObject_IsTrue(cond);
2979 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002980 if (err > 0)
Adrian Wielgosik50c28502017-06-23 13:35:41 -07002981 ;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002982 else if (err == 0)
2983 JUMPTO(oparg);
2984 else
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002985 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002986 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002987 }
Guido van Rossumac7be682001-01-17 15:42:30 +00002988
Benjamin Petersonddd19492018-09-16 22:38:02 -07002989 case TARGET(POP_JUMP_IF_TRUE): {
2990 PREDICTED(POP_JUMP_IF_TRUE);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002991 PyObject *cond = POP();
2992 int err;
2993 if (cond == Py_False) {
2994 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002995 FAST_DISPATCH();
2996 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04002997 if (cond == Py_True) {
2998 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00002999 JUMPTO(oparg);
3000 FAST_DISPATCH();
3001 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003002 err = PyObject_IsTrue(cond);
3003 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003004 if (err > 0) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003005 JUMPTO(oparg);
3006 }
3007 else if (err == 0)
3008 ;
3009 else
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003010 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003011 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003012 }
Jeffrey Yasskin9de7ec72009-02-25 02:25:04 +00003013
Benjamin Petersonddd19492018-09-16 22:38:02 -07003014 case TARGET(JUMP_IF_FALSE_OR_POP): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003015 PyObject *cond = TOP();
3016 int err;
3017 if (cond == Py_True) {
costypetrisor8ed317f2018-07-31 20:55:14 +00003018 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003019 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003020 FAST_DISPATCH();
3021 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003022 if (cond == Py_False) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003023 JUMPTO(oparg);
3024 FAST_DISPATCH();
3025 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003026 err = PyObject_IsTrue(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003027 if (err > 0) {
costypetrisor8ed317f2018-07-31 20:55:14 +00003028 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003029 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003030 }
3031 else if (err == 0)
3032 JUMPTO(oparg);
3033 else
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003034 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003035 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003036 }
Jeffrey Yasskin9de7ec72009-02-25 02:25:04 +00003037
Benjamin Petersonddd19492018-09-16 22:38:02 -07003038 case TARGET(JUMP_IF_TRUE_OR_POP): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003039 PyObject *cond = TOP();
3040 int err;
3041 if (cond == Py_False) {
costypetrisor8ed317f2018-07-31 20:55:14 +00003042 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003043 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003044 FAST_DISPATCH();
3045 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003046 if (cond == Py_True) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003047 JUMPTO(oparg);
3048 FAST_DISPATCH();
3049 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003050 err = PyObject_IsTrue(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003051 if (err > 0) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003052 JUMPTO(oparg);
3053 }
3054 else if (err == 0) {
costypetrisor8ed317f2018-07-31 20:55:14 +00003055 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003056 Py_DECREF(cond);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003057 }
3058 else
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003059 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003060 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003061 }
Guido van Rossumac7be682001-01-17 15:42:30 +00003062
Benjamin Petersonddd19492018-09-16 22:38:02 -07003063 case TARGET(JUMP_ABSOLUTE): {
3064 PREDICTED(JUMP_ABSOLUTE);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003065 JUMPTO(oparg);
Guido van Rossum58da9312007-11-10 23:39:45 +00003066#if FAST_LOOPS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003067 /* Enabling this path speeds-up all while and for-loops by bypassing
3068 the per-loop checks for signals. By default, this should be turned-off
3069 because it prevents detection of a control-break in tight loops like
3070 "while 1: pass". Compile with this option turned-on when you need
3071 the speed-up and do not need break checking inside tight loops (ones
3072 that contain only instructions ending with FAST_DISPATCH).
3073 */
3074 FAST_DISPATCH();
Guido van Rossum58da9312007-11-10 23:39:45 +00003075#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003076 DISPATCH();
Guido van Rossum58da9312007-11-10 23:39:45 +00003077#endif
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003078 }
Guido van Rossumac7be682001-01-17 15:42:30 +00003079
Benjamin Petersonddd19492018-09-16 22:38:02 -07003080 case TARGET(GET_ITER): {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003081 /* before: [obj]; after [getiter(obj)] */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003082 PyObject *iterable = TOP();
Yury Selivanov5376ba92015-06-22 12:19:30 -04003083 PyObject *iter = PyObject_GetIter(iterable);
3084 Py_DECREF(iterable);
3085 SET_TOP(iter);
3086 if (iter == NULL)
3087 goto error;
3088 PREDICT(FOR_ITER);
Serhiy Storchakada9c5132016-06-27 18:58:57 +03003089 PREDICT(CALL_FUNCTION);
Yury Selivanov5376ba92015-06-22 12:19:30 -04003090 DISPATCH();
3091 }
3092
Benjamin Petersonddd19492018-09-16 22:38:02 -07003093 case TARGET(GET_YIELD_FROM_ITER): {
Yury Selivanov5376ba92015-06-22 12:19:30 -04003094 /* before: [obj]; after [getiter(obj)] */
3095 PyObject *iterable = TOP();
Yury Selivanov75445082015-05-11 22:57:16 -04003096 PyObject *iter;
Yury Selivanov5376ba92015-06-22 12:19:30 -04003097 if (PyCoro_CheckExact(iterable)) {
3098 /* `iterable` is a coroutine */
3099 if (!(co->co_flags & (CO_COROUTINE | CO_ITERABLE_COROUTINE))) {
3100 /* and it is used in a 'yield from' expression of a
3101 regular generator. */
3102 Py_DECREF(iterable);
3103 SET_TOP(NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02003104 _PyErr_SetString(tstate, PyExc_TypeError,
3105 "cannot 'yield from' a coroutine object "
3106 "in a non-coroutine generator");
Yury Selivanov5376ba92015-06-22 12:19:30 -04003107 goto error;
3108 }
3109 }
3110 else if (!PyGen_CheckExact(iterable)) {
Yury Selivanov75445082015-05-11 22:57:16 -04003111 /* `iterable` is not a generator. */
3112 iter = PyObject_GetIter(iterable);
3113 Py_DECREF(iterable);
3114 SET_TOP(iter);
3115 if (iter == NULL)
3116 goto error;
3117 }
Serhiy Storchakada9c5132016-06-27 18:58:57 +03003118 PREDICT(LOAD_CONST);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003119 DISPATCH();
3120 }
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00003121
Benjamin Petersonddd19492018-09-16 22:38:02 -07003122 case TARGET(FOR_ITER): {
3123 PREDICTED(FOR_ITER);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003124 /* before: [iter]; after: [iter, iter()] *or* [] */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003125 PyObject *iter = TOP();
3126 PyObject *next = (*iter->ob_type->tp_iternext)(iter);
3127 if (next != NULL) {
3128 PUSH(next);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003129 PREDICT(STORE_FAST);
3130 PREDICT(UNPACK_SEQUENCE);
3131 DISPATCH();
3132 }
Victor Stinner438a12d2019-05-24 17:01:38 +02003133 if (_PyErr_Occurred(tstate)) {
3134 if (!_PyErr_ExceptionMatches(tstate, PyExc_StopIteration)) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003135 goto error;
Victor Stinner438a12d2019-05-24 17:01:38 +02003136 }
3137 else if (tstate->c_tracefunc != NULL) {
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01003138 call_exc_trace(tstate->c_tracefunc, tstate->c_traceobj, tstate, f);
Victor Stinner438a12d2019-05-24 17:01:38 +02003139 }
3140 _PyErr_Clear(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003141 }
3142 /* iterator ended normally */
costypetrisor8ed317f2018-07-31 20:55:14 +00003143 STACK_SHRINK(1);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003144 Py_DECREF(iter);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003145 JUMPBY(oparg);
Serhiy Storchakada9c5132016-06-27 18:58:57 +03003146 PREDICT(POP_BLOCK);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003147 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003148 }
Guido van Rossum59d1d2b2001-04-20 19:13:02 +00003149
Benjamin Petersonddd19492018-09-16 22:38:02 -07003150 case TARGET(SETUP_FINALLY): {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003151 PyFrame_BlockSetup(f, SETUP_FINALLY, INSTR_OFFSET() + oparg,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003152 STACK_LEVEL());
3153 DISPATCH();
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003154 }
Guido van Rossumac7be682001-01-17 15:42:30 +00003155
Benjamin Petersonddd19492018-09-16 22:38:02 -07003156 case TARGET(BEFORE_ASYNC_WITH): {
Yury Selivanov75445082015-05-11 22:57:16 -04003157 _Py_IDENTIFIER(__aexit__);
3158 _Py_IDENTIFIER(__aenter__);
3159
3160 PyObject *mgr = TOP();
Victor Stinner438a12d2019-05-24 17:01:38 +02003161 PyObject *exit = special_lookup(tstate, mgr, &PyId___aexit__),
Yury Selivanov75445082015-05-11 22:57:16 -04003162 *enter;
3163 PyObject *res;
3164 if (exit == NULL)
3165 goto error;
3166 SET_TOP(exit);
Victor Stinner438a12d2019-05-24 17:01:38 +02003167 enter = special_lookup(tstate, mgr, &PyId___aenter__);
Yury Selivanov75445082015-05-11 22:57:16 -04003168 Py_DECREF(mgr);
3169 if (enter == NULL)
3170 goto error;
Victor Stinnerf17c3de2016-12-06 18:46:19 +01003171 res = _PyObject_CallNoArg(enter);
Yury Selivanov75445082015-05-11 22:57:16 -04003172 Py_DECREF(enter);
3173 if (res == NULL)
3174 goto error;
3175 PUSH(res);
Serhiy Storchakada9c5132016-06-27 18:58:57 +03003176 PREDICT(GET_AWAITABLE);
Yury Selivanov75445082015-05-11 22:57:16 -04003177 DISPATCH();
3178 }
3179
Benjamin Petersonddd19492018-09-16 22:38:02 -07003180 case TARGET(SETUP_ASYNC_WITH): {
Yury Selivanov75445082015-05-11 22:57:16 -04003181 PyObject *res = POP();
3182 /* Setup the finally block before pushing the result
3183 of __aenter__ on the stack. */
3184 PyFrame_BlockSetup(f, SETUP_FINALLY, INSTR_OFFSET() + oparg,
3185 STACK_LEVEL());
3186 PUSH(res);
3187 DISPATCH();
3188 }
3189
Benjamin Petersonddd19492018-09-16 22:38:02 -07003190 case TARGET(SETUP_WITH): {
Benjamin Petersonce798522012-01-22 11:24:29 -05003191 _Py_IDENTIFIER(__exit__);
3192 _Py_IDENTIFIER(__enter__);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003193 PyObject *mgr = TOP();
Victor Stinner438a12d2019-05-24 17:01:38 +02003194 PyObject *enter = special_lookup(tstate, mgr, &PyId___enter__);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003195 PyObject *res;
Victor Stinner438a12d2019-05-24 17:01:38 +02003196 if (enter == NULL) {
Raymond Hettingera3fec152016-11-21 17:24:23 -08003197 goto error;
Victor Stinner438a12d2019-05-24 17:01:38 +02003198 }
3199 PyObject *exit = special_lookup(tstate, mgr, &PyId___exit__);
Raymond Hettinger64e2f9a2016-11-22 11:50:40 -08003200 if (exit == NULL) {
3201 Py_DECREF(enter);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003202 goto error;
Raymond Hettinger64e2f9a2016-11-22 11:50:40 -08003203 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003204 SET_TOP(exit);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003205 Py_DECREF(mgr);
Victor Stinnerf17c3de2016-12-06 18:46:19 +01003206 res = _PyObject_CallNoArg(enter);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003207 Py_DECREF(enter);
3208 if (res == NULL)
3209 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003210 /* Setup the finally block before pushing the result
3211 of __enter__ on the stack. */
3212 PyFrame_BlockSetup(f, SETUP_FINALLY, INSTR_OFFSET() + oparg,
3213 STACK_LEVEL());
Benjamin Peterson876b2f22009-06-28 03:18:59 +00003214
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003215 PUSH(res);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003216 DISPATCH();
3217 }
Benjamin Peterson876b2f22009-06-28 03:18:59 +00003218
Mark Shannonfee55262019-11-21 09:11:43 +00003219 case TARGET(WITH_EXCEPT_START): {
3220 /* At the top of the stack are 7 values:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003221 - (TOP, SECOND, THIRD) = exc_info()
Mark Shannonfee55262019-11-21 09:11:43 +00003222 - (FOURTH, FIFTH, SIXTH) = previous exception for EXCEPT_HANDLER
3223 - SEVENTH: the context.__exit__ bound method
3224 We call SEVENTH(TOP, SECOND, THIRD).
3225 Then we push again the TOP exception and the __exit__
3226 return value.
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003227 */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003228 PyObject *exit_func;
Victor Stinner842cfff2016-12-01 14:45:31 +01003229 PyObject *exc, *val, *tb, *res;
3230
Victor Stinner842cfff2016-12-01 14:45:31 +01003231 exc = TOP();
Mark Shannonfee55262019-11-21 09:11:43 +00003232 val = SECOND();
3233 tb = THIRD();
3234 assert(exc != Py_None);
3235 assert(!PyLong_Check(exc));
3236 exit_func = PEEK(7);
Jeroen Demeyer469d1a72019-07-03 12:52:21 +02003237 PyObject *stack[4] = {NULL, exc, val, tb};
3238 res = _PyObject_Vectorcall(exit_func, stack + 1,
3239 3 | PY_VECTORCALL_ARGUMENTS_OFFSET, NULL);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003240 if (res == NULL)
3241 goto error;
Amaury Forgeot d'Arc10b24e82008-12-10 23:49:33 +00003242
Yury Selivanov75445082015-05-11 22:57:16 -04003243 PUSH(res);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003244 DISPATCH();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003245 }
Guido van Rossumc2e20742006-02-27 22:32:47 +00003246
Benjamin Petersonddd19492018-09-16 22:38:02 -07003247 case TARGET(LOAD_METHOD): {
Andreyb021ba52019-04-29 14:33:26 +10003248 /* Designed to work in tandem with CALL_METHOD. */
Yury Selivanovf2392132016-12-13 19:03:51 -05003249 PyObject *name = GETITEM(names, oparg);
3250 PyObject *obj = TOP();
3251 PyObject *meth = NULL;
3252
3253 int meth_found = _PyObject_GetMethod(obj, name, &meth);
3254
Yury Selivanovf2392132016-12-13 19:03:51 -05003255 if (meth == NULL) {
3256 /* Most likely attribute wasn't found. */
Yury Selivanovf2392132016-12-13 19:03:51 -05003257 goto error;
3258 }
3259
3260 if (meth_found) {
INADA Naoki015bce62017-01-16 17:23:30 +09003261 /* We can bypass temporary bound method object.
3262 meth is unbound method and obj is self.
Victor Stinnera8cb5152017-01-18 14:12:51 +01003263
INADA Naoki015bce62017-01-16 17:23:30 +09003264 meth | self | arg1 | ... | argN
3265 */
3266 SET_TOP(meth);
3267 PUSH(obj); // self
Yury Selivanovf2392132016-12-13 19:03:51 -05003268 }
3269 else {
INADA Naoki015bce62017-01-16 17:23:30 +09003270 /* meth is not an unbound method (but a regular attr, or
3271 something was returned by a descriptor protocol). Set
3272 the second element of the stack to NULL, to signal
Yury Selivanovf2392132016-12-13 19:03:51 -05003273 CALL_METHOD that it's not a method call.
INADA Naoki015bce62017-01-16 17:23:30 +09003274
3275 NULL | meth | arg1 | ... | argN
Yury Selivanovf2392132016-12-13 19:03:51 -05003276 */
INADA Naoki015bce62017-01-16 17:23:30 +09003277 SET_TOP(NULL);
Yury Selivanovf2392132016-12-13 19:03:51 -05003278 Py_DECREF(obj);
INADA Naoki015bce62017-01-16 17:23:30 +09003279 PUSH(meth);
Yury Selivanovf2392132016-12-13 19:03:51 -05003280 }
3281 DISPATCH();
3282 }
3283
Benjamin Petersonddd19492018-09-16 22:38:02 -07003284 case TARGET(CALL_METHOD): {
Yury Selivanovf2392132016-12-13 19:03:51 -05003285 /* Designed to work in tamdem with LOAD_METHOD. */
INADA Naoki015bce62017-01-16 17:23:30 +09003286 PyObject **sp, *res, *meth;
Yury Selivanovf2392132016-12-13 19:03:51 -05003287
3288 sp = stack_pointer;
3289
INADA Naoki015bce62017-01-16 17:23:30 +09003290 meth = PEEK(oparg + 2);
3291 if (meth == NULL) {
3292 /* `meth` is NULL when LOAD_METHOD thinks that it's not
3293 a method call.
Yury Selivanovf2392132016-12-13 19:03:51 -05003294
3295 Stack layout:
3296
INADA Naoki015bce62017-01-16 17:23:30 +09003297 ... | NULL | callable | arg1 | ... | argN
3298 ^- TOP()
3299 ^- (-oparg)
3300 ^- (-oparg-1)
3301 ^- (-oparg-2)
Yury Selivanovf2392132016-12-13 19:03:51 -05003302
Ville Skyttä49b27342017-08-03 09:00:59 +03003303 `callable` will be POPed by call_function.
INADA Naoki015bce62017-01-16 17:23:30 +09003304 NULL will will be POPed manually later.
Yury Selivanovf2392132016-12-13 19:03:51 -05003305 */
Victor Stinner09532fe2019-05-10 23:39:09 +02003306 res = call_function(tstate, &sp, oparg, NULL);
Yury Selivanovf2392132016-12-13 19:03:51 -05003307 stack_pointer = sp;
INADA Naoki015bce62017-01-16 17:23:30 +09003308 (void)POP(); /* POP the NULL. */
Yury Selivanovf2392132016-12-13 19:03:51 -05003309 }
3310 else {
3311 /* This is a method call. Stack layout:
3312
INADA Naoki015bce62017-01-16 17:23:30 +09003313 ... | method | self | arg1 | ... | argN
Yury Selivanovf2392132016-12-13 19:03:51 -05003314 ^- TOP()
3315 ^- (-oparg)
INADA Naoki015bce62017-01-16 17:23:30 +09003316 ^- (-oparg-1)
3317 ^- (-oparg-2)
Yury Selivanovf2392132016-12-13 19:03:51 -05003318
INADA Naoki015bce62017-01-16 17:23:30 +09003319 `self` and `method` will be POPed by call_function.
Yury Selivanovf2392132016-12-13 19:03:51 -05003320 We'll be passing `oparg + 1` to call_function, to
INADA Naoki015bce62017-01-16 17:23:30 +09003321 make it accept the `self` as a first argument.
Yury Selivanovf2392132016-12-13 19:03:51 -05003322 */
Victor Stinner09532fe2019-05-10 23:39:09 +02003323 res = call_function(tstate, &sp, oparg + 1, NULL);
Yury Selivanovf2392132016-12-13 19:03:51 -05003324 stack_pointer = sp;
3325 }
3326
3327 PUSH(res);
3328 if (res == NULL)
3329 goto error;
3330 DISPATCH();
3331 }
3332
Benjamin Petersonddd19492018-09-16 22:38:02 -07003333 case TARGET(CALL_FUNCTION): {
3334 PREDICTED(CALL_FUNCTION);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003335 PyObject **sp, *res;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003336 sp = stack_pointer;
Victor Stinner09532fe2019-05-10 23:39:09 +02003337 res = call_function(tstate, &sp, oparg, NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003338 stack_pointer = sp;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003339 PUSH(res);
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003340 if (res == NULL) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003341 goto error;
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003342 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003343 DISPATCH();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003344 }
Guido van Rossumac7be682001-01-17 15:42:30 +00003345
Benjamin Petersonddd19492018-09-16 22:38:02 -07003346 case TARGET(CALL_FUNCTION_KW): {
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003347 PyObject **sp, *res, *names;
3348
3349 names = POP();
Jeroen Demeyer05677862019-08-16 12:41:27 +02003350 assert(PyTuple_Check(names));
3351 assert(PyTuple_GET_SIZE(names) <= oparg);
3352 /* We assume without checking that names contains only strings */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003353 sp = stack_pointer;
Victor Stinner09532fe2019-05-10 23:39:09 +02003354 res = call_function(tstate, &sp, oparg, names);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003355 stack_pointer = sp;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003356 PUSH(res);
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003357 Py_DECREF(names);
3358
3359 if (res == NULL) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003360 goto error;
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003361 }
3362 DISPATCH();
3363 }
3364
Benjamin Petersonddd19492018-09-16 22:38:02 -07003365 case TARGET(CALL_FUNCTION_EX): {
Brandt Bucherf185a732019-09-28 17:12:49 -07003366 PREDICTED(CALL_FUNCTION_EX);
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003367 PyObject *func, *callargs, *kwargs = NULL, *result;
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003368 if (oparg & 0x01) {
3369 kwargs = POP();
Serhiy Storchakab7281052016-09-12 00:52:40 +03003370 if (!PyDict_CheckExact(kwargs)) {
3371 PyObject *d = PyDict_New();
3372 if (d == NULL)
3373 goto error;
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02003374 if (_PyDict_MergeEx(d, kwargs, 2) < 0) {
Serhiy Storchakab7281052016-09-12 00:52:40 +03003375 Py_DECREF(d);
Victor Stinner438a12d2019-05-24 17:01:38 +02003376 format_kwargs_error(tstate, SECOND(), kwargs);
Victor Stinnereece2222016-09-12 11:16:37 +02003377 Py_DECREF(kwargs);
Serhiy Storchakab7281052016-09-12 00:52:40 +03003378 goto error;
3379 }
3380 Py_DECREF(kwargs);
3381 kwargs = d;
3382 }
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003383 assert(PyDict_CheckExact(kwargs));
3384 }
3385 callargs = POP();
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003386 func = TOP();
Serhiy Storchaka63dc5482016-09-22 19:41:20 +03003387 if (!PyTuple_CheckExact(callargs)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02003388 if (check_args_iterable(tstate, func, callargs) < 0) {
Victor Stinnereece2222016-09-12 11:16:37 +02003389 Py_DECREF(callargs);
Serhiy Storchakab7281052016-09-12 00:52:40 +03003390 goto error;
3391 }
3392 Py_SETREF(callargs, PySequence_Tuple(callargs));
3393 if (callargs == NULL) {
3394 goto error;
3395 }
3396 }
Serhiy Storchaka63dc5482016-09-22 19:41:20 +03003397 assert(PyTuple_CheckExact(callargs));
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003398
Victor Stinner09532fe2019-05-10 23:39:09 +02003399 result = do_call_core(tstate, func, callargs, kwargs);
Victor Stinnerf9b760f2016-09-09 10:17:08 -07003400 Py_DECREF(func);
3401 Py_DECREF(callargs);
3402 Py_XDECREF(kwargs);
3403
3404 SET_TOP(result);
3405 if (result == NULL) {
3406 goto error;
3407 }
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003408 DISPATCH();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003409 }
Guido van Rossumac7be682001-01-17 15:42:30 +00003410
Benjamin Petersonddd19492018-09-16 22:38:02 -07003411 case TARGET(MAKE_FUNCTION): {
Serhiy Storchaka64204de2016-06-12 17:36:24 +03003412 PyObject *qualname = POP();
3413 PyObject *codeobj = POP();
3414 PyFunctionObject *func = (PyFunctionObject *)
3415 PyFunction_NewWithQualName(codeobj, f->f_globals, qualname);
Guido van Rossum4f72a782006-10-27 23:31:49 +00003416
Serhiy Storchaka64204de2016-06-12 17:36:24 +03003417 Py_DECREF(codeobj);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003418 Py_DECREF(qualname);
Serhiy Storchaka64204de2016-06-12 17:36:24 +03003419 if (func == NULL) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003420 goto error;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003421 }
Neal Norwitzc1505362006-12-28 06:47:50 +00003422
Serhiy Storchaka64204de2016-06-12 17:36:24 +03003423 if (oparg & 0x08) {
3424 assert(PyTuple_CheckExact(TOP()));
3425 func ->func_closure = POP();
3426 }
3427 if (oparg & 0x04) {
3428 assert(PyDict_CheckExact(TOP()));
3429 func->func_annotations = POP();
3430 }
3431 if (oparg & 0x02) {
3432 assert(PyDict_CheckExact(TOP()));
3433 func->func_kwdefaults = POP();
3434 }
3435 if (oparg & 0x01) {
3436 assert(PyTuple_CheckExact(TOP()));
3437 func->func_defaults = POP();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003438 }
Neal Norwitzc1505362006-12-28 06:47:50 +00003439
Serhiy Storchaka64204de2016-06-12 17:36:24 +03003440 PUSH((PyObject *)func);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003441 DISPATCH();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003442 }
Guido van Rossum8861b741996-07-30 16:49:37 +00003443
Benjamin Petersonddd19492018-09-16 22:38:02 -07003444 case TARGET(BUILD_SLICE): {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003445 PyObject *start, *stop, *step, *slice;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003446 if (oparg == 3)
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003447 step = POP();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003448 else
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003449 step = NULL;
3450 stop = POP();
3451 start = TOP();
3452 slice = PySlice_New(start, stop, step);
3453 Py_DECREF(start);
3454 Py_DECREF(stop);
3455 Py_XDECREF(step);
3456 SET_TOP(slice);
3457 if (slice == NULL)
3458 goto error;
3459 DISPATCH();
3460 }
Guido van Rossum8861b741996-07-30 16:49:37 +00003461
Benjamin Petersonddd19492018-09-16 22:38:02 -07003462 case TARGET(FORMAT_VALUE): {
Eric V. Smitha78c7952015-11-03 12:45:05 -05003463 /* Handles f-string value formatting. */
3464 PyObject *result;
3465 PyObject *fmt_spec;
3466 PyObject *value;
3467 PyObject *(*conv_fn)(PyObject *);
3468 int which_conversion = oparg & FVC_MASK;
3469 int have_fmt_spec = (oparg & FVS_MASK) == FVS_HAVE_SPEC;
3470
3471 fmt_spec = have_fmt_spec ? POP() : NULL;
Eric V. Smith135d5f42016-02-05 18:23:08 -05003472 value = POP();
Eric V. Smitha78c7952015-11-03 12:45:05 -05003473
3474 /* See if any conversion is specified. */
3475 switch (which_conversion) {
Eric V. Smith9a4135e2019-05-08 16:28:48 -04003476 case FVC_NONE: conv_fn = NULL; break;
Eric V. Smitha78c7952015-11-03 12:45:05 -05003477 case FVC_STR: conv_fn = PyObject_Str; break;
3478 case FVC_REPR: conv_fn = PyObject_Repr; break;
3479 case FVC_ASCII: conv_fn = PyObject_ASCII; break;
Eric V. Smith9a4135e2019-05-08 16:28:48 -04003480 default:
Victor Stinner438a12d2019-05-24 17:01:38 +02003481 _PyErr_Format(tstate, PyExc_SystemError,
3482 "unexpected conversion flag %d",
3483 which_conversion);
Eric V. Smith9a4135e2019-05-08 16:28:48 -04003484 goto error;
Eric V. Smitha78c7952015-11-03 12:45:05 -05003485 }
3486
3487 /* If there's a conversion function, call it and replace
3488 value with that result. Otherwise, just use value,
3489 without conversion. */
Eric V. Smitheb588a12016-02-05 18:26:20 -05003490 if (conv_fn != NULL) {
Eric V. Smitha78c7952015-11-03 12:45:05 -05003491 result = conv_fn(value);
3492 Py_DECREF(value);
Eric V. Smitheb588a12016-02-05 18:26:20 -05003493 if (result == NULL) {
Eric V. Smitha78c7952015-11-03 12:45:05 -05003494 Py_XDECREF(fmt_spec);
3495 goto error;
3496 }
3497 value = result;
3498 }
3499
3500 /* If value is a unicode object, and there's no fmt_spec,
3501 then we know the result of format(value) is value
3502 itself. In that case, skip calling format(). I plan to
3503 move this optimization in to PyObject_Format()
3504 itself. */
3505 if (PyUnicode_CheckExact(value) && fmt_spec == NULL) {
3506 /* Do nothing, just transfer ownership to result. */
3507 result = value;
3508 } else {
3509 /* Actually call format(). */
3510 result = PyObject_Format(value, fmt_spec);
3511 Py_DECREF(value);
3512 Py_XDECREF(fmt_spec);
Eric V. Smitheb588a12016-02-05 18:26:20 -05003513 if (result == NULL) {
Eric V. Smitha78c7952015-11-03 12:45:05 -05003514 goto error;
Eric V. Smitheb588a12016-02-05 18:26:20 -05003515 }
Eric V. Smitha78c7952015-11-03 12:45:05 -05003516 }
3517
Eric V. Smith135d5f42016-02-05 18:23:08 -05003518 PUSH(result);
Eric V. Smitha78c7952015-11-03 12:45:05 -05003519 DISPATCH();
3520 }
3521
Benjamin Petersonddd19492018-09-16 22:38:02 -07003522 case TARGET(EXTENDED_ARG): {
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03003523 int oldoparg = oparg;
3524 NEXTOPARG();
3525 oparg |= oldoparg << 8;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003526 goto dispatch_opcode;
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003527 }
Guido van Rossum8861b741996-07-30 16:49:37 +00003528
Benjamin Peterson025e9eb2015-05-05 20:16:41 -04003529
Antoine Pitrou042b1282010-08-13 21:15:58 +00003530#if USE_COMPUTED_GOTOS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003531 _unknown_opcode:
Antoine Pitroub52ec782009-01-25 16:34:23 +00003532#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003533 default:
3534 fprintf(stderr,
3535 "XXX lineno: %d, opcode: %d\n",
3536 PyFrame_GetLineNumber(f),
3537 opcode);
Victor Stinner438a12d2019-05-24 17:01:38 +02003538 _PyErr_SetString(tstate, PyExc_SystemError, "unknown opcode");
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003539 goto error;
Guido van Rossum04691fc1992-08-12 15:35:34 +00003540
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003541 } /* switch */
Guido van Rossum374a9221991-04-04 10:40:29 +00003542
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003543 /* This should never be reached. Every opcode should end with DISPATCH()
3544 or goto error. */
Barry Warsawb2e57942017-09-14 18:13:16 -07003545 Py_UNREACHABLE();
Guido van Rossumac7be682001-01-17 15:42:30 +00003546
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003547error:
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003548 /* Double-check exception status. */
Victor Stinner365b6932013-07-12 00:11:58 +02003549#ifdef NDEBUG
Victor Stinner438a12d2019-05-24 17:01:38 +02003550 if (!_PyErr_Occurred(tstate)) {
3551 _PyErr_SetString(tstate, PyExc_SystemError,
3552 "error return without exception set");
3553 }
Victor Stinner365b6932013-07-12 00:11:58 +02003554#else
Victor Stinner438a12d2019-05-24 17:01:38 +02003555 assert(_PyErr_Occurred(tstate));
Victor Stinner365b6932013-07-12 00:11:58 +02003556#endif
Guido van Rossum374a9221991-04-04 10:40:29 +00003557
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003558 /* Log traceback info. */
3559 PyTraceBack_Here(f);
Guido van Rossumac7be682001-01-17 15:42:30 +00003560
Benjamin Peterson51f46162013-01-23 08:38:47 -05003561 if (tstate->c_tracefunc != NULL)
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01003562 call_exc_trace(tstate->c_tracefunc, tstate->c_traceobj,
3563 tstate, f);
Guido van Rossumac7be682001-01-17 15:42:30 +00003564
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003565exception_unwind:
3566 /* Unwind stacks if an exception occurred */
3567 while (f->f_iblock > 0) {
3568 /* Pop the current block. */
3569 PyTryBlock *b = &f->f_blockstack[--f->f_iblock];
Jeremy Hylton3faa52e2001-02-01 22:48:12 +00003570
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003571 if (b->b_type == EXCEPT_HANDLER) {
3572 UNWIND_EXCEPT_HANDLER(b);
3573 continue;
3574 }
3575 UNWIND_BLOCK(b);
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003576 if (b->b_type == SETUP_FINALLY) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003577 PyObject *exc, *val, *tb;
3578 int handler = b->b_handler;
Mark Shannonae3087c2017-10-22 22:41:51 +01003579 _PyErr_StackItem *exc_info = tstate->exc_info;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003580 /* Beware, this invalidates all b->b_* fields */
3581 PyFrame_BlockSetup(f, EXCEPT_HANDLER, -1, STACK_LEVEL());
Mark Shannonae3087c2017-10-22 22:41:51 +01003582 PUSH(exc_info->exc_traceback);
3583 PUSH(exc_info->exc_value);
3584 if (exc_info->exc_type != NULL) {
3585 PUSH(exc_info->exc_type);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003586 }
3587 else {
3588 Py_INCREF(Py_None);
3589 PUSH(Py_None);
3590 }
Victor Stinner438a12d2019-05-24 17:01:38 +02003591 _PyErr_Fetch(tstate, &exc, &val, &tb);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003592 /* Make the raw exception data
3593 available to the handler,
3594 so a program can emulate the
3595 Python main loop. */
Victor Stinner438a12d2019-05-24 17:01:38 +02003596 _PyErr_NormalizeException(tstate, &exc, &val, &tb);
Victor Stinner7eab0d02013-07-15 21:16:27 +02003597 if (tb != NULL)
3598 PyException_SetTraceback(val, tb);
3599 else
3600 PyException_SetTraceback(val, Py_None);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003601 Py_INCREF(exc);
Mark Shannonae3087c2017-10-22 22:41:51 +01003602 exc_info->exc_type = exc;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003603 Py_INCREF(val);
Mark Shannonae3087c2017-10-22 22:41:51 +01003604 exc_info->exc_value = val;
3605 exc_info->exc_traceback = tb;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003606 if (tb == NULL)
3607 tb = Py_None;
3608 Py_INCREF(tb);
3609 PUSH(tb);
3610 PUSH(val);
3611 PUSH(exc);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003612 JUMPTO(handler);
Pablo Galindo04ec7a12020-01-02 11:38:44 +00003613 if (_Py_TracingPossible(ceval) &&
3614 ((f->f_lasti < instr_lb || f->f_lasti >= instr_ub) ||
3615 !(f->f_lasti == instr_lb || f->f_lasti < instr_prev))) {
Mark Shannonfee55262019-11-21 09:11:43 +00003616 /* Make sure that we trace line after exception */
3617 instr_prev = INT_MAX;
3618 }
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003619 /* Resume normal execution */
3620 goto main_loop;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003621 }
3622 } /* unwind stack */
Guido van Rossum374a9221991-04-04 10:40:29 +00003623
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003624 /* End the loop as we still have an error */
3625 break;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003626 } /* main loop */
Guido van Rossumac7be682001-01-17 15:42:30 +00003627
Pablo Galindof00828a2019-05-09 16:52:02 +01003628 assert(retval == NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02003629 assert(_PyErr_Occurred(tstate));
Pablo Galindof00828a2019-05-09 16:52:02 +01003630
3631exit_returning:
3632
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003633 /* Pop remaining stack entries. */
3634 while (!EMPTY()) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003635 PyObject *o = POP();
3636 Py_XDECREF(o);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003637 }
Guido van Rossum35974fb2001-12-06 21:28:18 +00003638
Pablo Galindof00828a2019-05-09 16:52:02 +01003639exit_yielding:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003640 if (tstate->use_tracing) {
Benjamin Peterson51f46162013-01-23 08:38:47 -05003641 if (tstate->c_tracefunc) {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003642 if (call_trace_protected(tstate->c_tracefunc, tstate->c_traceobj,
3643 tstate, f, PyTrace_RETURN, retval)) {
3644 Py_CLEAR(retval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003645 }
3646 }
3647 if (tstate->c_profilefunc) {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003648 if (call_trace_protected(tstate->c_profilefunc, tstate->c_profileobj,
3649 tstate, f, PyTrace_RETURN, retval)) {
Serhiy Storchaka505ff752014-02-09 13:33:53 +02003650 Py_CLEAR(retval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003651 }
3652 }
3653 }
Guido van Rossuma4240131997-01-21 21:18:36 +00003654
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003655 /* pop frame */
Thomas Woutersce272b62007-09-19 21:19:28 +00003656exit_eval_frame:
Łukasz Langaa785c872016-09-09 17:37:37 -07003657 if (PyDTrace_FUNCTION_RETURN_ENABLED())
3658 dtrace_function_return(f);
Victor Stinnerbe434dc2019-11-05 00:51:22 +01003659 _Py_LeaveRecursiveCall(tstate);
Antoine Pitrou58720d62013-08-05 23:26:40 +02003660 f->f_executing = 0;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003661 tstate->frame = f->f_back;
Guido van Rossumac7be682001-01-17 15:42:30 +00003662
Victor Stinner17269092019-11-05 01:22:12 +01003663 return _Py_CheckFunctionResult(tstate, NULL, retval, "PyEval_EvalFrameEx");
Guido van Rossum374a9221991-04-04 10:40:29 +00003664}
3665
Benjamin Petersonb204a422011-06-05 22:04:07 -05003666static void
Victor Stinner438a12d2019-05-24 17:01:38 +02003667format_missing(PyThreadState *tstate, const char *kind,
3668 PyCodeObject *co, PyObject *names)
Benjamin Petersone109c702011-06-24 09:37:26 -05003669{
3670 int err;
3671 Py_ssize_t len = PyList_GET_SIZE(names);
3672 PyObject *name_str, *comma, *tail, *tmp;
3673
3674 assert(PyList_CheckExact(names));
3675 assert(len >= 1);
3676 /* Deal with the joys of natural language. */
3677 switch (len) {
3678 case 1:
3679 name_str = PyList_GET_ITEM(names, 0);
3680 Py_INCREF(name_str);
3681 break;
3682 case 2:
3683 name_str = PyUnicode_FromFormat("%U and %U",
3684 PyList_GET_ITEM(names, len - 2),
3685 PyList_GET_ITEM(names, len - 1));
3686 break;
3687 default:
3688 tail = PyUnicode_FromFormat(", %U, and %U",
3689 PyList_GET_ITEM(names, len - 2),
3690 PyList_GET_ITEM(names, len - 1));
Benjamin Petersond1ab6082012-06-01 11:18:22 -07003691 if (tail == NULL)
3692 return;
Benjamin Petersone109c702011-06-24 09:37:26 -05003693 /* Chop off the last two objects in the list. This shouldn't actually
3694 fail, but we can't be too careful. */
3695 err = PyList_SetSlice(names, len - 2, len, NULL);
3696 if (err == -1) {
3697 Py_DECREF(tail);
3698 return;
3699 }
3700 /* Stitch everything up into a nice comma-separated list. */
3701 comma = PyUnicode_FromString(", ");
3702 if (comma == NULL) {
3703 Py_DECREF(tail);
3704 return;
3705 }
3706 tmp = PyUnicode_Join(comma, names);
3707 Py_DECREF(comma);
3708 if (tmp == NULL) {
3709 Py_DECREF(tail);
3710 return;
3711 }
3712 name_str = PyUnicode_Concat(tmp, tail);
3713 Py_DECREF(tmp);
3714 Py_DECREF(tail);
3715 break;
3716 }
3717 if (name_str == NULL)
3718 return;
Victor Stinner438a12d2019-05-24 17:01:38 +02003719 _PyErr_Format(tstate, PyExc_TypeError,
3720 "%U() missing %i required %s argument%s: %U",
3721 co->co_name,
3722 len,
3723 kind,
3724 len == 1 ? "" : "s",
3725 name_str);
Benjamin Petersone109c702011-06-24 09:37:26 -05003726 Py_DECREF(name_str);
3727}
3728
3729static void
Victor Stinner438a12d2019-05-24 17:01:38 +02003730missing_arguments(PyThreadState *tstate, PyCodeObject *co,
3731 Py_ssize_t missing, Py_ssize_t defcount,
Benjamin Petersone109c702011-06-24 09:37:26 -05003732 PyObject **fastlocals)
3733{
Victor Stinner74319ae2016-08-25 00:04:09 +02003734 Py_ssize_t i, j = 0;
3735 Py_ssize_t start, end;
3736 int positional = (defcount != -1);
Benjamin Petersone109c702011-06-24 09:37:26 -05003737 const char *kind = positional ? "positional" : "keyword-only";
3738 PyObject *missing_names;
3739
3740 /* Compute the names of the arguments that are missing. */
3741 missing_names = PyList_New(missing);
3742 if (missing_names == NULL)
3743 return;
3744 if (positional) {
3745 start = 0;
Pablo Galindocd74e662019-06-01 18:08:04 +01003746 end = co->co_argcount - defcount;
Benjamin Petersone109c702011-06-24 09:37:26 -05003747 }
3748 else {
Pablo Galindocd74e662019-06-01 18:08:04 +01003749 start = co->co_argcount;
Benjamin Petersone109c702011-06-24 09:37:26 -05003750 end = start + co->co_kwonlyargcount;
3751 }
3752 for (i = start; i < end; i++) {
3753 if (GETLOCAL(i) == NULL) {
3754 PyObject *raw = PyTuple_GET_ITEM(co->co_varnames, i);
3755 PyObject *name = PyObject_Repr(raw);
3756 if (name == NULL) {
3757 Py_DECREF(missing_names);
3758 return;
3759 }
3760 PyList_SET_ITEM(missing_names, j++, name);
3761 }
3762 }
3763 assert(j == missing);
Victor Stinner438a12d2019-05-24 17:01:38 +02003764 format_missing(tstate, kind, co, missing_names);
Benjamin Petersone109c702011-06-24 09:37:26 -05003765 Py_DECREF(missing_names);
3766}
3767
3768static void
Victor Stinner438a12d2019-05-24 17:01:38 +02003769too_many_positional(PyThreadState *tstate, PyCodeObject *co,
3770 Py_ssize_t given, Py_ssize_t defcount,
Victor Stinner74319ae2016-08-25 00:04:09 +02003771 PyObject **fastlocals)
Benjamin Petersonb204a422011-06-05 22:04:07 -05003772{
3773 int plural;
Victor Stinner74319ae2016-08-25 00:04:09 +02003774 Py_ssize_t kwonly_given = 0;
3775 Py_ssize_t i;
Benjamin Petersonb204a422011-06-05 22:04:07 -05003776 PyObject *sig, *kwonly_sig;
Victor Stinner74319ae2016-08-25 00:04:09 +02003777 Py_ssize_t co_argcount = co->co_argcount;
Benjamin Petersonb204a422011-06-05 22:04:07 -05003778
Benjamin Petersone109c702011-06-24 09:37:26 -05003779 assert((co->co_flags & CO_VARARGS) == 0);
3780 /* Count missing keyword-only args. */
Pablo Galindocd74e662019-06-01 18:08:04 +01003781 for (i = co_argcount; i < co_argcount + co->co_kwonlyargcount; i++) {
Victor Stinner74319ae2016-08-25 00:04:09 +02003782 if (GETLOCAL(i) != NULL) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003783 kwonly_given++;
Victor Stinner74319ae2016-08-25 00:04:09 +02003784 }
3785 }
Benjamin Petersone109c702011-06-24 09:37:26 -05003786 if (defcount) {
Pablo Galindocd74e662019-06-01 18:08:04 +01003787 Py_ssize_t atleast = co_argcount - defcount;
Benjamin Petersonb204a422011-06-05 22:04:07 -05003788 plural = 1;
Pablo Galindocd74e662019-06-01 18:08:04 +01003789 sig = PyUnicode_FromFormat("from %zd to %zd", atleast, co_argcount);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003790 }
3791 else {
Pablo Galindocd74e662019-06-01 18:08:04 +01003792 plural = (co_argcount != 1);
3793 sig = PyUnicode_FromFormat("%zd", co_argcount);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003794 }
3795 if (sig == NULL)
3796 return;
3797 if (kwonly_given) {
Victor Stinner74319ae2016-08-25 00:04:09 +02003798 const char *format = " positional argument%s (and %zd keyword-only argument%s)";
3799 kwonly_sig = PyUnicode_FromFormat(format,
3800 given != 1 ? "s" : "",
3801 kwonly_given,
3802 kwonly_given != 1 ? "s" : "");
Benjamin Petersonb204a422011-06-05 22:04:07 -05003803 if (kwonly_sig == NULL) {
3804 Py_DECREF(sig);
3805 return;
3806 }
3807 }
3808 else {
3809 /* This will not fail. */
3810 kwonly_sig = PyUnicode_FromString("");
Benjamin Petersone109c702011-06-24 09:37:26 -05003811 assert(kwonly_sig != NULL);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003812 }
Victor Stinner438a12d2019-05-24 17:01:38 +02003813 _PyErr_Format(tstate, PyExc_TypeError,
3814 "%U() takes %U positional argument%s but %zd%U %s given",
3815 co->co_name,
3816 sig,
3817 plural ? "s" : "",
3818 given,
3819 kwonly_sig,
3820 given == 1 && !kwonly_given ? "was" : "were");
Benjamin Petersonb204a422011-06-05 22:04:07 -05003821 Py_DECREF(sig);
3822 Py_DECREF(kwonly_sig);
3823}
3824
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003825static int
Victor Stinner438a12d2019-05-24 17:01:38 +02003826positional_only_passed_as_keyword(PyThreadState *tstate, PyCodeObject *co,
3827 Py_ssize_t kwcount, PyObject* const* kwnames)
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003828{
3829 int posonly_conflicts = 0;
3830 PyObject* posonly_names = PyList_New(0);
3831
3832 for(int k=0; k < co->co_posonlyargcount; k++){
3833 PyObject* posonly_name = PyTuple_GET_ITEM(co->co_varnames, k);
3834
3835 for (int k2=0; k2<kwcount; k2++){
3836 /* Compare the pointers first and fallback to PyObject_RichCompareBool*/
3837 PyObject* kwname = kwnames[k2];
3838 if (kwname == posonly_name){
3839 if(PyList_Append(posonly_names, kwname) != 0) {
3840 goto fail;
3841 }
3842 posonly_conflicts++;
3843 continue;
3844 }
3845
3846 int cmp = PyObject_RichCompareBool(posonly_name, kwname, Py_EQ);
3847
3848 if ( cmp > 0) {
3849 if(PyList_Append(posonly_names, kwname) != 0) {
3850 goto fail;
3851 }
3852 posonly_conflicts++;
3853 } else if (cmp < 0) {
3854 goto fail;
3855 }
3856
3857 }
3858 }
3859 if (posonly_conflicts) {
3860 PyObject* comma = PyUnicode_FromString(", ");
3861 if (comma == NULL) {
3862 goto fail;
3863 }
3864 PyObject* error_names = PyUnicode_Join(comma, posonly_names);
3865 Py_DECREF(comma);
3866 if (error_names == NULL) {
3867 goto fail;
3868 }
Victor Stinner438a12d2019-05-24 17:01:38 +02003869 _PyErr_Format(tstate, PyExc_TypeError,
3870 "%U() got some positional-only arguments passed"
3871 " as keyword arguments: '%U'",
3872 co->co_name, error_names);
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003873 Py_DECREF(error_names);
3874 goto fail;
3875 }
3876
3877 Py_DECREF(posonly_names);
3878 return 0;
3879
3880fail:
3881 Py_XDECREF(posonly_names);
3882 return 1;
3883
3884}
3885
Guido van Rossumc2e20742006-02-27 22:32:47 +00003886/* This is gonna seem *real weird*, but if you put some other code between
Marcel Plch3a9ccee2018-04-06 23:22:04 +02003887 PyEval_EvalFrame() and _PyEval_EvalFrameDefault() you will need to adjust
Guido van Rossumc2e20742006-02-27 22:32:47 +00003888 the test in the if statements in Misc/gdbinit (pystack and pystackv). */
Skip Montanaro786ea6b2004-03-01 15:44:05 +00003889
Victor Stinnerc22bfaa2017-02-12 19:27:05 +01003890PyObject *
Victor Stinnerb5e170f2019-11-16 01:03:22 +01003891_PyEval_EvalCode(PyThreadState *tstate,
3892 PyObject *_co, PyObject *globals, PyObject *locals,
Serhiy Storchakaa5552f02017-12-15 13:11:11 +02003893 PyObject *const *args, Py_ssize_t argcount,
3894 PyObject *const *kwnames, PyObject *const *kwargs,
Serhiy Storchakab7281052016-09-12 00:52:40 +03003895 Py_ssize_t kwcount, int kwstep,
Serhiy Storchakaa5552f02017-12-15 13:11:11 +02003896 PyObject *const *defs, Py_ssize_t defcount,
Victor Stinner74319ae2016-08-25 00:04:09 +02003897 PyObject *kwdefs, PyObject *closure,
Victor Stinner40ee3012014-06-16 15:59:28 +02003898 PyObject *name, PyObject *qualname)
Tim Peters5ca576e2001-06-18 22:08:13 +00003899{
Victor Stinnerb5e170f2019-11-16 01:03:22 +01003900 assert(tstate != NULL);
3901
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00003902 PyCodeObject* co = (PyCodeObject*)_co;
Antoine Pitrou9ed5f272013-08-13 20:18:52 +02003903 PyFrameObject *f;
3904 PyObject *retval = NULL;
3905 PyObject **fastlocals, **freevars;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003906 PyObject *x, *u;
Pablo Galindocd74e662019-06-01 18:08:04 +01003907 const Py_ssize_t total_args = co->co_argcount + co->co_kwonlyargcount;
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003908 Py_ssize_t i, j, n;
Victor Stinnerc7020012016-08-16 23:40:29 +02003909 PyObject *kwdict;
Tim Peters5ca576e2001-06-18 22:08:13 +00003910
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003911 if (globals == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02003912 _PyErr_SetString(tstate, PyExc_SystemError,
3913 "PyEval_EvalCodeEx: NULL globals");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003914 return NULL;
3915 }
Tim Peters5ca576e2001-06-18 22:08:13 +00003916
Victor Stinnerc7020012016-08-16 23:40:29 +02003917 /* Create the frame */
INADA Naoki5a625d02016-12-24 20:19:08 +09003918 f = _PyFrame_New_NoTrack(tstate, co, globals, locals);
Victor Stinnerc7020012016-08-16 23:40:29 +02003919 if (f == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003920 return NULL;
Victor Stinnerc7020012016-08-16 23:40:29 +02003921 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003922 fastlocals = f->f_localsplus;
3923 freevars = f->f_localsplus + co->co_nlocals;
Tim Peters5ca576e2001-06-18 22:08:13 +00003924
Victor Stinnerc7020012016-08-16 23:40:29 +02003925 /* Create a dictionary for keyword parameters (**kwags) */
Benjamin Petersonb204a422011-06-05 22:04:07 -05003926 if (co->co_flags & CO_VARKEYWORDS) {
3927 kwdict = PyDict_New();
3928 if (kwdict == NULL)
3929 goto fail;
3930 i = total_args;
Victor Stinnerc7020012016-08-16 23:40:29 +02003931 if (co->co_flags & CO_VARARGS) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003932 i++;
Victor Stinnerc7020012016-08-16 23:40:29 +02003933 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05003934 SETLOCAL(i, kwdict);
3935 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003936 else {
3937 kwdict = NULL;
3938 }
3939
Pablo Galindocd74e662019-06-01 18:08:04 +01003940 /* Copy all positional arguments into local variables */
3941 if (argcount > co->co_argcount) {
3942 n = co->co_argcount;
Victor Stinnerc7020012016-08-16 23:40:29 +02003943 }
3944 else {
3945 n = argcount;
3946 }
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003947 for (j = 0; j < n; j++) {
3948 x = args[j];
3949 Py_INCREF(x);
3950 SETLOCAL(j, x);
3951 }
3952
Victor Stinnerc7020012016-08-16 23:40:29 +02003953 /* Pack other positional arguments into the *args argument */
Benjamin Petersonb204a422011-06-05 22:04:07 -05003954 if (co->co_flags & CO_VARARGS) {
Sergey Fedoseev234531b2019-02-25 21:59:12 +05003955 u = _PyTuple_FromArray(args + n, argcount - n);
Victor Stinnerc7020012016-08-16 23:40:29 +02003956 if (u == NULL) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003957 goto fail;
Victor Stinnerc7020012016-08-16 23:40:29 +02003958 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05003959 SETLOCAL(total_args, u);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003960 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003961
Serhiy Storchakab7281052016-09-12 00:52:40 +03003962 /* Handle keyword arguments passed as two strided arrays */
3963 kwcount *= kwstep;
3964 for (i = 0; i < kwcount; i += kwstep) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003965 PyObject **co_varnames;
Serhiy Storchakab7281052016-09-12 00:52:40 +03003966 PyObject *keyword = kwnames[i];
3967 PyObject *value = kwargs[i];
Victor Stinner17061a92016-08-16 23:39:42 +02003968 Py_ssize_t j;
Victor Stinnerc7020012016-08-16 23:40:29 +02003969
Benjamin Petersonb204a422011-06-05 22:04:07 -05003970 if (keyword == NULL || !PyUnicode_Check(keyword)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02003971 _PyErr_Format(tstate, PyExc_TypeError,
3972 "%U() keywords must be strings",
3973 co->co_name);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003974 goto fail;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003975 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003976
Benjamin Petersonb204a422011-06-05 22:04:07 -05003977 /* Speed hack: do raw pointer compares. As names are
3978 normally interned this should almost always hit. */
3979 co_varnames = ((PyTupleObject *)(co->co_varnames))->ob_item;
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003980 for (j = co->co_posonlyargcount; j < total_args; j++) {
Victor Stinner6fea7f72016-08-22 23:17:30 +02003981 PyObject *name = co_varnames[j];
3982 if (name == keyword) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003983 goto kw_found;
Victor Stinner6fea7f72016-08-22 23:17:30 +02003984 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05003985 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003986
Benjamin Petersonb204a422011-06-05 22:04:07 -05003987 /* Slow fallback, just in case */
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003988 for (j = co->co_posonlyargcount; j < total_args; j++) {
Victor Stinner6fea7f72016-08-22 23:17:30 +02003989 PyObject *name = co_varnames[j];
3990 int cmp = PyObject_RichCompareBool( keyword, name, Py_EQ);
3991 if (cmp > 0) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003992 goto kw_found;
Victor Stinner6fea7f72016-08-22 23:17:30 +02003993 }
3994 else if (cmp < 0) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003995 goto fail;
Victor Stinner6fea7f72016-08-22 23:17:30 +02003996 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05003997 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003998
Victor Stinner231d1f32017-01-11 02:12:06 +01003999 assert(j >= total_args);
4000 if (kwdict == NULL) {
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01004001
Victor Stinner438a12d2019-05-24 17:01:38 +02004002 if (co->co_posonlyargcount
4003 && positional_only_passed_as_keyword(tstate, co,
4004 kwcount, kwnames))
4005 {
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01004006 goto fail;
4007 }
4008
Victor Stinner438a12d2019-05-24 17:01:38 +02004009 _PyErr_Format(tstate, PyExc_TypeError,
4010 "%U() got an unexpected keyword argument '%S'",
4011 co->co_name, keyword);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004012 goto fail;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004013 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004014
Christian Heimes0bd447f2013-07-20 14:48:10 +02004015 if (PyDict_SetItem(kwdict, keyword, value) == -1) {
4016 goto fail;
4017 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05004018 continue;
Victor Stinnerc7020012016-08-16 23:40:29 +02004019
Benjamin Petersonb204a422011-06-05 22:04:07 -05004020 kw_found:
4021 if (GETLOCAL(j) != NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004022 _PyErr_Format(tstate, PyExc_TypeError,
4023 "%U() got multiple values for argument '%S'",
4024 co->co_name, keyword);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004025 goto fail;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004026 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05004027 Py_INCREF(value);
4028 SETLOCAL(j, value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004029 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004030
4031 /* Check the number of positional arguments */
Pablo Galindocd74e662019-06-01 18:08:04 +01004032 if ((argcount > co->co_argcount) && !(co->co_flags & CO_VARARGS)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004033 too_many_positional(tstate, co, argcount, defcount, fastlocals);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004034 goto fail;
4035 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004036
4037 /* Add missing positional arguments (copy default values from defs) */
Pablo Galindocd74e662019-06-01 18:08:04 +01004038 if (argcount < co->co_argcount) {
4039 Py_ssize_t m = co->co_argcount - defcount;
Victor Stinner17061a92016-08-16 23:39:42 +02004040 Py_ssize_t missing = 0;
4041 for (i = argcount; i < m; i++) {
4042 if (GETLOCAL(i) == NULL) {
Benjamin Petersone109c702011-06-24 09:37:26 -05004043 missing++;
Victor Stinner17061a92016-08-16 23:39:42 +02004044 }
4045 }
Benjamin Petersone109c702011-06-24 09:37:26 -05004046 if (missing) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004047 missing_arguments(tstate, co, missing, defcount, fastlocals);
Benjamin Petersone109c702011-06-24 09:37:26 -05004048 goto fail;
Benjamin Petersonb204a422011-06-05 22:04:07 -05004049 }
4050 if (n > m)
4051 i = n - m;
4052 else
4053 i = 0;
4054 for (; i < defcount; i++) {
4055 if (GETLOCAL(m+i) == NULL) {
4056 PyObject *def = defs[i];
4057 Py_INCREF(def);
4058 SETLOCAL(m+i, def);
4059 }
4060 }
4061 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004062
4063 /* Add missing keyword arguments (copy default values from kwdefs) */
Benjamin Petersonb204a422011-06-05 22:04:07 -05004064 if (co->co_kwonlyargcount > 0) {
Victor Stinner17061a92016-08-16 23:39:42 +02004065 Py_ssize_t missing = 0;
Pablo Galindocd74e662019-06-01 18:08:04 +01004066 for (i = co->co_argcount; i < total_args; i++) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05004067 PyObject *name;
4068 if (GETLOCAL(i) != NULL)
4069 continue;
4070 name = PyTuple_GET_ITEM(co->co_varnames, i);
4071 if (kwdefs != NULL) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02004072 PyObject *def = PyDict_GetItemWithError(kwdefs, name);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004073 if (def) {
4074 Py_INCREF(def);
4075 SETLOCAL(i, def);
4076 continue;
4077 }
Victor Stinner438a12d2019-05-24 17:01:38 +02004078 else if (_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02004079 goto fail;
4080 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05004081 }
Benjamin Petersone109c702011-06-24 09:37:26 -05004082 missing++;
4083 }
4084 if (missing) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004085 missing_arguments(tstate, co, missing, -1, fastlocals);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004086 goto fail;
4087 }
4088 }
4089
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004090 /* Allocate and initialize storage for cell vars, and copy free
Benjamin Peterson90037602011-06-25 22:54:45 -05004091 vars into frame. */
4092 for (i = 0; i < PyTuple_GET_SIZE(co->co_cellvars); ++i) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004093 PyObject *c;
Serhiy Storchaka5bb8b912016-12-16 19:19:02 +02004094 Py_ssize_t arg;
Benjamin Peterson90037602011-06-25 22:54:45 -05004095 /* Possibly account for the cell variable being an argument. */
4096 if (co->co_cell2arg != NULL &&
Guido van Rossum6832c812013-05-10 08:47:42 -07004097 (arg = co->co_cell2arg[i]) != CO_CELL_NOT_AN_ARG) {
Benjamin Peterson90037602011-06-25 22:54:45 -05004098 c = PyCell_New(GETLOCAL(arg));
Benjamin Peterson159ae412013-05-12 18:16:06 -05004099 /* Clear the local copy. */
4100 SETLOCAL(arg, NULL);
Guido van Rossum6832c812013-05-10 08:47:42 -07004101 }
4102 else {
Benjamin Peterson90037602011-06-25 22:54:45 -05004103 c = PyCell_New(NULL);
Guido van Rossum6832c812013-05-10 08:47:42 -07004104 }
Benjamin Peterson159ae412013-05-12 18:16:06 -05004105 if (c == NULL)
4106 goto fail;
Benjamin Peterson90037602011-06-25 22:54:45 -05004107 SETLOCAL(co->co_nlocals + i, c);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004108 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004109
4110 /* Copy closure variables to free variables */
Benjamin Peterson90037602011-06-25 22:54:45 -05004111 for (i = 0; i < PyTuple_GET_SIZE(co->co_freevars); ++i) {
4112 PyObject *o = PyTuple_GET_ITEM(closure, i);
4113 Py_INCREF(o);
4114 freevars[PyTuple_GET_SIZE(co->co_cellvars) + i] = o;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004115 }
Tim Peters5ca576e2001-06-18 22:08:13 +00004116
Yury Selivanoveb636452016-09-08 22:01:51 -07004117 /* Handle generator/coroutine/asynchronous generator */
4118 if (co->co_flags & (CO_GENERATOR | CO_COROUTINE | CO_ASYNC_GENERATOR)) {
Yury Selivanov75445082015-05-11 22:57:16 -04004119 PyObject *gen;
Yury Selivanov5376ba92015-06-22 12:19:30 -04004120 int is_coro = co->co_flags & CO_COROUTINE;
Yury Selivanov94c22632015-06-04 10:16:51 -04004121
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004122 /* Don't need to keep the reference to f_back, it will be set
4123 * when the generator is resumed. */
Serhiy Storchaka505ff752014-02-09 13:33:53 +02004124 Py_CLEAR(f->f_back);
Neil Schemenauer2b13ce82001-06-21 02:41:10 +00004125
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004126 /* Create a new generator that owns the ready to run frame
4127 * and return that as the value. */
Yury Selivanov5376ba92015-06-22 12:19:30 -04004128 if (is_coro) {
4129 gen = PyCoro_New(f, name, qualname);
Yury Selivanoveb636452016-09-08 22:01:51 -07004130 } else if (co->co_flags & CO_ASYNC_GENERATOR) {
4131 gen = PyAsyncGen_New(f, name, qualname);
Yury Selivanov5376ba92015-06-22 12:19:30 -04004132 } else {
4133 gen = PyGen_NewWithQualName(f, name, qualname);
4134 }
INADA Naoki6a3cedf2016-12-26 18:01:46 +09004135 if (gen == NULL) {
Yury Selivanov75445082015-05-11 22:57:16 -04004136 return NULL;
INADA Naoki6a3cedf2016-12-26 18:01:46 +09004137 }
INADA Naoki9c157762016-12-26 18:52:46 +09004138
INADA Naoki6a3cedf2016-12-26 18:01:46 +09004139 _PyObject_GC_TRACK(f);
Yury Selivanov75445082015-05-11 22:57:16 -04004140
Yury Selivanov75445082015-05-11 22:57:16 -04004141 return gen;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004142 }
Tim Peters5ca576e2001-06-18 22:08:13 +00004143
Victor Stinnerb9e68122019-11-14 12:20:46 +01004144 retval = _PyEval_EvalFrame(tstate, f, 0);
Tim Peters5ca576e2001-06-18 22:08:13 +00004145
Thomas Woutersce272b62007-09-19 21:19:28 +00004146fail: /* Jump here from prelude on failure */
Tim Peters5ca576e2001-06-18 22:08:13 +00004147
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004148 /* decref'ing the frame can cause __del__ methods to get invoked,
4149 which can call back into Python. While we're done with the
4150 current Python frame (f), the associated C stack is still in use,
4151 so recursion_depth must be boosted for the duration.
4152 */
INADA Naoki5a625d02016-12-24 20:19:08 +09004153 if (Py_REFCNT(f) > 1) {
4154 Py_DECREF(f);
4155 _PyObject_GC_TRACK(f);
4156 }
4157 else {
4158 ++tstate->recursion_depth;
4159 Py_DECREF(f);
4160 --tstate->recursion_depth;
4161 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004162 return retval;
Tim Peters5ca576e2001-06-18 22:08:13 +00004163}
4164
Victor Stinnerb5e170f2019-11-16 01:03:22 +01004165
4166PyObject *
4167_PyEval_EvalCodeWithName(PyObject *_co, PyObject *globals, PyObject *locals,
4168 PyObject *const *args, Py_ssize_t argcount,
4169 PyObject *const *kwnames, PyObject *const *kwargs,
4170 Py_ssize_t kwcount, int kwstep,
4171 PyObject *const *defs, Py_ssize_t defcount,
4172 PyObject *kwdefs, PyObject *closure,
4173 PyObject *name, PyObject *qualname)
4174{
4175 PyThreadState *tstate = _PyThreadState_GET();
4176 return _PyEval_EvalCode(tstate, _co, globals, locals,
4177 args, argcount,
4178 kwnames, kwargs,
4179 kwcount, kwstep,
4180 defs, defcount,
4181 kwdefs, closure,
4182 name, qualname);
4183}
4184
Victor Stinner40ee3012014-06-16 15:59:28 +02004185PyObject *
4186PyEval_EvalCodeEx(PyObject *_co, PyObject *globals, PyObject *locals,
Serhiy Storchakaa5552f02017-12-15 13:11:11 +02004187 PyObject *const *args, int argcount,
4188 PyObject *const *kws, int kwcount,
4189 PyObject *const *defs, int defcount,
4190 PyObject *kwdefs, PyObject *closure)
Victor Stinner40ee3012014-06-16 15:59:28 +02004191{
4192 return _PyEval_EvalCodeWithName(_co, globals, locals,
Victor Stinner9be7e7b2016-08-19 16:11:43 +02004193 args, argcount,
Zackery Spytzc6ea8972017-07-31 08:24:37 -06004194 kws, kws != NULL ? kws + 1 : NULL,
4195 kwcount, 2,
Victor Stinner9be7e7b2016-08-19 16:11:43 +02004196 defs, defcount,
4197 kwdefs, closure,
Victor Stinner40ee3012014-06-16 15:59:28 +02004198 NULL, NULL);
4199}
Tim Peters5ca576e2001-06-18 22:08:13 +00004200
Benjamin Peterson876b2f22009-06-28 03:18:59 +00004201static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02004202special_lookup(PyThreadState *tstate, PyObject *o, _Py_Identifier *id)
Benjamin Peterson876b2f22009-06-28 03:18:59 +00004203{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004204 PyObject *res;
Benjamin Petersonce798522012-01-22 11:24:29 -05004205 res = _PyObject_LookupSpecial(o, id);
Victor Stinner438a12d2019-05-24 17:01:38 +02004206 if (res == NULL && !_PyErr_Occurred(tstate)) {
4207 _PyErr_SetObject(tstate, PyExc_AttributeError, id->object);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004208 return NULL;
4209 }
4210 return res;
Benjamin Peterson876b2f22009-06-28 03:18:59 +00004211}
4212
4213
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004214/* Logic for the raise statement (too complicated for inlining).
4215 This *consumes* a reference count to each of its arguments. */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004216static int
Victor Stinner09532fe2019-05-10 23:39:09 +02004217do_raise(PyThreadState *tstate, PyObject *exc, PyObject *cause)
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004218{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004219 PyObject *type = NULL, *value = NULL;
Collin Winter828f04a2007-08-31 00:04:24 +00004220
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004221 if (exc == NULL) {
4222 /* Reraise */
Mark Shannonae3087c2017-10-22 22:41:51 +01004223 _PyErr_StackItem *exc_info = _PyErr_GetTopmostException(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004224 PyObject *tb;
Mark Shannonae3087c2017-10-22 22:41:51 +01004225 type = exc_info->exc_type;
4226 value = exc_info->exc_value;
4227 tb = exc_info->exc_traceback;
Victor Stinnereec93312016-08-18 18:13:10 +02004228 if (type == Py_None || type == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004229 _PyErr_SetString(tstate, PyExc_RuntimeError,
4230 "No active exception to reraise");
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004231 return 0;
4232 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004233 Py_XINCREF(type);
4234 Py_XINCREF(value);
4235 Py_XINCREF(tb);
Victor Stinner438a12d2019-05-24 17:01:38 +02004236 _PyErr_Restore(tstate, type, value, tb);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004237 return 1;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004238 }
Guido van Rossumac7be682001-01-17 15:42:30 +00004239
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004240 /* We support the following forms of raise:
4241 raise
Collin Winter828f04a2007-08-31 00:04:24 +00004242 raise <instance>
4243 raise <type> */
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004244
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004245 if (PyExceptionClass_Check(exc)) {
4246 type = exc;
Victor Stinnera5ed5f02016-12-06 18:45:50 +01004247 value = _PyObject_CallNoArg(exc);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004248 if (value == NULL)
4249 goto raise_error;
Benjamin Peterson5afa03a2011-07-15 14:09:26 -05004250 if (!PyExceptionInstance_Check(value)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004251 _PyErr_Format(tstate, PyExc_TypeError,
4252 "calling %R should have returned an instance of "
4253 "BaseException, not %R",
4254 type, Py_TYPE(value));
4255 goto raise_error;
Benjamin Peterson5afa03a2011-07-15 14:09:26 -05004256 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004257 }
4258 else if (PyExceptionInstance_Check(exc)) {
4259 value = exc;
4260 type = PyExceptionInstance_Class(exc);
4261 Py_INCREF(type);
4262 }
4263 else {
4264 /* Not something you can raise. You get an exception
4265 anyway, just not what you specified :-) */
4266 Py_DECREF(exc);
Victor Stinner438a12d2019-05-24 17:01:38 +02004267 _PyErr_SetString(tstate, PyExc_TypeError,
4268 "exceptions must derive from BaseException");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004269 goto raise_error;
4270 }
Collin Winter828f04a2007-08-31 00:04:24 +00004271
Serhiy Storchakac0191582016-09-27 11:37:10 +03004272 assert(type != NULL);
4273 assert(value != NULL);
4274
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004275 if (cause) {
4276 PyObject *fixed_cause;
4277 if (PyExceptionClass_Check(cause)) {
Victor Stinnera5ed5f02016-12-06 18:45:50 +01004278 fixed_cause = _PyObject_CallNoArg(cause);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004279 if (fixed_cause == NULL)
4280 goto raise_error;
Benjamin Petersond5a1c442012-05-14 22:09:31 -07004281 Py_DECREF(cause);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004282 }
Benjamin Petersond5a1c442012-05-14 22:09:31 -07004283 else if (PyExceptionInstance_Check(cause)) {
4284 fixed_cause = cause;
4285 }
4286 else if (cause == Py_None) {
4287 Py_DECREF(cause);
4288 fixed_cause = NULL;
4289 }
4290 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004291 _PyErr_SetString(tstate, PyExc_TypeError,
4292 "exception causes must derive from "
4293 "BaseException");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004294 goto raise_error;
4295 }
Benjamin Petersond5a1c442012-05-14 22:09:31 -07004296 PyException_SetCause(value, fixed_cause);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004297 }
Collin Winter828f04a2007-08-31 00:04:24 +00004298
Victor Stinner438a12d2019-05-24 17:01:38 +02004299 _PyErr_SetObject(tstate, type, value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004300 /* PyErr_SetObject incref's its arguments */
Serhiy Storchakac0191582016-09-27 11:37:10 +03004301 Py_DECREF(value);
4302 Py_DECREF(type);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004303 return 0;
Collin Winter828f04a2007-08-31 00:04:24 +00004304
4305raise_error:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004306 Py_XDECREF(value);
4307 Py_XDECREF(type);
4308 Py_XDECREF(cause);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004309 return 0;
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004310}
4311
Tim Petersd6d010b2001-06-21 02:49:55 +00004312/* Iterate v argcnt times and store the results on the stack (via decreasing
Guido van Rossum0368b722007-05-11 16:50:42 +00004313 sp). Return 1 for success, 0 if error.
Antoine Pitrou9a2310d2008-07-25 22:39:39 +00004314
Guido van Rossum0368b722007-05-11 16:50:42 +00004315 If argcntafter == -1, do a simple unpack. If it is >= 0, do an unpack
4316 with a variable target.
4317*/
Tim Petersd6d010b2001-06-21 02:49:55 +00004318
Barry Warsawe42b18f1997-08-25 22:13:04 +00004319static int
Victor Stinner438a12d2019-05-24 17:01:38 +02004320unpack_iterable(PyThreadState *tstate, PyObject *v,
4321 int argcnt, int argcntafter, PyObject **sp)
Barry Warsawe42b18f1997-08-25 22:13:04 +00004322{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004323 int i = 0, j = 0;
4324 Py_ssize_t ll = 0;
4325 PyObject *it; /* iter(v) */
4326 PyObject *w;
4327 PyObject *l = NULL; /* variable list */
Guido van Rossumac7be682001-01-17 15:42:30 +00004328
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004329 assert(v != NULL);
Tim Petersd6d010b2001-06-21 02:49:55 +00004330
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004331 it = PyObject_GetIter(v);
Serhiy Storchaka13a6c092017-12-26 12:30:41 +02004332 if (it == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004333 if (_PyErr_ExceptionMatches(tstate, PyExc_TypeError) &&
Serhiy Storchaka13a6c092017-12-26 12:30:41 +02004334 v->ob_type->tp_iter == NULL && !PySequence_Check(v))
4335 {
Victor Stinner438a12d2019-05-24 17:01:38 +02004336 _PyErr_Format(tstate, PyExc_TypeError,
4337 "cannot unpack non-iterable %.200s object",
4338 v->ob_type->tp_name);
Serhiy Storchaka13a6c092017-12-26 12:30:41 +02004339 }
4340 return 0;
4341 }
Tim Petersd6d010b2001-06-21 02:49:55 +00004342
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004343 for (; i < argcnt; i++) {
4344 w = PyIter_Next(it);
4345 if (w == NULL) {
4346 /* Iterator done, via error or exhaustion. */
Victor Stinner438a12d2019-05-24 17:01:38 +02004347 if (!_PyErr_Occurred(tstate)) {
R David Murray4171bbe2015-04-15 17:08:45 -04004348 if (argcntafter == -1) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004349 _PyErr_Format(tstate, PyExc_ValueError,
4350 "not enough values to unpack "
4351 "(expected %d, got %d)",
4352 argcnt, i);
R David Murray4171bbe2015-04-15 17:08:45 -04004353 }
4354 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004355 _PyErr_Format(tstate, PyExc_ValueError,
4356 "not enough values to unpack "
4357 "(expected at least %d, got %d)",
4358 argcnt + argcntafter, i);
R David Murray4171bbe2015-04-15 17:08:45 -04004359 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004360 }
4361 goto Error;
4362 }
4363 *--sp = w;
4364 }
Tim Petersd6d010b2001-06-21 02:49:55 +00004365
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004366 if (argcntafter == -1) {
4367 /* We better have exhausted the iterator now. */
4368 w = PyIter_Next(it);
4369 if (w == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004370 if (_PyErr_Occurred(tstate))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004371 goto Error;
4372 Py_DECREF(it);
4373 return 1;
4374 }
4375 Py_DECREF(w);
Victor Stinner438a12d2019-05-24 17:01:38 +02004376 _PyErr_Format(tstate, PyExc_ValueError,
4377 "too many values to unpack (expected %d)",
4378 argcnt);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004379 goto Error;
4380 }
Guido van Rossum0368b722007-05-11 16:50:42 +00004381
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004382 l = PySequence_List(it);
4383 if (l == NULL)
4384 goto Error;
4385 *--sp = l;
4386 i++;
Guido van Rossum0368b722007-05-11 16:50:42 +00004387
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004388 ll = PyList_GET_SIZE(l);
4389 if (ll < argcntafter) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004390 _PyErr_Format(tstate, PyExc_ValueError,
R David Murray4171bbe2015-04-15 17:08:45 -04004391 "not enough values to unpack (expected at least %d, got %zd)",
4392 argcnt + argcntafter, argcnt + ll);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004393 goto Error;
4394 }
Guido van Rossum0368b722007-05-11 16:50:42 +00004395
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004396 /* Pop the "after-variable" args off the list. */
4397 for (j = argcntafter; j > 0; j--, i++) {
4398 *--sp = PyList_GET_ITEM(l, ll - j);
4399 }
4400 /* Resize the list. */
4401 Py_SIZE(l) = ll - argcntafter;
4402 Py_DECREF(it);
4403 return 1;
Guido van Rossum0368b722007-05-11 16:50:42 +00004404
Tim Petersd6d010b2001-06-21 02:49:55 +00004405Error:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004406 for (; i > 0; i--, sp++)
4407 Py_DECREF(*sp);
4408 Py_XDECREF(it);
4409 return 0;
Barry Warsawe42b18f1997-08-25 22:13:04 +00004410}
4411
4412
Guido van Rossum96a42c81992-01-12 02:29:51 +00004413#ifdef LLTRACE
Guido van Rossum3f5da241990-12-20 15:06:42 +00004414static int
Victor Stinner438a12d2019-05-24 17:01:38 +02004415prtrace(PyThreadState *tstate, PyObject *v, const char *str)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004416{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004417 printf("%s ", str);
Victor Stinner438a12d2019-05-24 17:01:38 +02004418 if (PyObject_Print(v, stdout, 0) != 0) {
4419 /* Don't know what else to do */
4420 _PyErr_Clear(tstate);
4421 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004422 printf("\n");
4423 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004424}
Guido van Rossum3f5da241990-12-20 15:06:42 +00004425#endif
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004426
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004427static void
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004428call_exc_trace(Py_tracefunc func, PyObject *self,
4429 PyThreadState *tstate, PyFrameObject *f)
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004430{
Victor Stinneraaa8ed82013-07-10 13:57:55 +02004431 PyObject *type, *value, *traceback, *orig_traceback, *arg;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004432 int err;
Victor Stinner438a12d2019-05-24 17:01:38 +02004433 _PyErr_Fetch(tstate, &type, &value, &orig_traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004434 if (value == NULL) {
4435 value = Py_None;
4436 Py_INCREF(value);
4437 }
Victor Stinner438a12d2019-05-24 17:01:38 +02004438 _PyErr_NormalizeException(tstate, &type, &value, &orig_traceback);
Antoine Pitrou89335212013-11-23 14:05:23 +01004439 traceback = (orig_traceback != NULL) ? orig_traceback : Py_None;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004440 arg = PyTuple_Pack(3, type, value, traceback);
4441 if (arg == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004442 _PyErr_Restore(tstate, type, value, orig_traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004443 return;
4444 }
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004445 err = call_trace(func, self, tstate, f, PyTrace_EXCEPTION, arg);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004446 Py_DECREF(arg);
Victor Stinner438a12d2019-05-24 17:01:38 +02004447 if (err == 0) {
4448 _PyErr_Restore(tstate, type, value, orig_traceback);
4449 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004450 else {
4451 Py_XDECREF(type);
4452 Py_XDECREF(value);
Victor Stinneraaa8ed82013-07-10 13:57:55 +02004453 Py_XDECREF(orig_traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004454 }
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004455}
4456
Amaury Forgeot d'Arcf05149a2007-11-13 01:05:30 +00004457static int
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004458call_trace_protected(Py_tracefunc func, PyObject *obj,
4459 PyThreadState *tstate, PyFrameObject *frame,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004460 int what, PyObject *arg)
Fred Drake4ec5d562001-10-04 19:26:43 +00004461{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004462 PyObject *type, *value, *traceback;
4463 int err;
Victor Stinner438a12d2019-05-24 17:01:38 +02004464 _PyErr_Fetch(tstate, &type, &value, &traceback);
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004465 err = call_trace(func, obj, tstate, frame, what, arg);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004466 if (err == 0)
4467 {
Victor Stinner438a12d2019-05-24 17:01:38 +02004468 _PyErr_Restore(tstate, type, value, traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004469 return 0;
4470 }
4471 else {
4472 Py_XDECREF(type);
4473 Py_XDECREF(value);
4474 Py_XDECREF(traceback);
4475 return -1;
4476 }
Fred Drake4ec5d562001-10-04 19:26:43 +00004477}
4478
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004479static int
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004480call_trace(Py_tracefunc func, PyObject *obj,
4481 PyThreadState *tstate, PyFrameObject *frame,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004482 int what, PyObject *arg)
Guido van Rossum96a42c81992-01-12 02:29:51 +00004483{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004484 int result;
4485 if (tstate->tracing)
4486 return 0;
4487 tstate->tracing++;
4488 tstate->use_tracing = 0;
4489 result = func(obj, frame, what, arg);
4490 tstate->use_tracing = ((tstate->c_tracefunc != NULL)
4491 || (tstate->c_profilefunc != NULL));
4492 tstate->tracing--;
4493 return result;
Guido van Rossum96a42c81992-01-12 02:29:51 +00004494}
4495
Guido van Rossuma12fe4e2003-04-09 19:06:21 +00004496PyObject *
4497_PyEval_CallTracing(PyObject *func, PyObject *args)
4498{
Victor Stinner50b48572018-11-01 01:51:40 +01004499 PyThreadState *tstate = _PyThreadState_GET();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004500 int save_tracing = tstate->tracing;
4501 int save_use_tracing = tstate->use_tracing;
4502 PyObject *result;
Guido van Rossuma12fe4e2003-04-09 19:06:21 +00004503
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004504 tstate->tracing = 0;
4505 tstate->use_tracing = ((tstate->c_tracefunc != NULL)
4506 || (tstate->c_profilefunc != NULL));
4507 result = PyObject_Call(func, args, NULL);
4508 tstate->tracing = save_tracing;
4509 tstate->use_tracing = save_use_tracing;
4510 return result;
Guido van Rossuma12fe4e2003-04-09 19:06:21 +00004511}
4512
Alexandre Vassalotti7b82b402009-07-21 04:30:03 +00004513/* See Objects/lnotab_notes.txt for a description of how tracing works. */
Michael W. Hudson006c7522002-11-08 13:08:46 +00004514static int
Tim Peters8a5c3c72004-04-05 19:36:21 +00004515maybe_call_line_trace(Py_tracefunc func, PyObject *obj,
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004516 PyThreadState *tstate, PyFrameObject *frame,
4517 int *instr_lb, int *instr_ub, int *instr_prev)
Michael W. Hudsondd32a912002-08-15 14:59:02 +00004518{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004519 int result = 0;
4520 int line = frame->f_lineno;
Michael W. Hudson006c7522002-11-08 13:08:46 +00004521
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004522 /* If the last instruction executed isn't in the current
4523 instruction window, reset the window.
4524 */
4525 if (frame->f_lasti < *instr_lb || frame->f_lasti >= *instr_ub) {
4526 PyAddrPair bounds;
4527 line = _PyCode_CheckLineNumber(frame->f_code, frame->f_lasti,
4528 &bounds);
4529 *instr_lb = bounds.ap_lower;
4530 *instr_ub = bounds.ap_upper;
4531 }
Nick Coghlan5a851672017-09-08 10:14:16 +10004532 /* If the last instruction falls at the start of a line or if it
4533 represents a jump backwards, update the frame's line number and
4534 then call the trace function if we're tracing source lines.
4535 */
4536 if ((frame->f_lasti == *instr_lb || frame->f_lasti < *instr_prev)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004537 frame->f_lineno = line;
Nick Coghlan5a851672017-09-08 10:14:16 +10004538 if (frame->f_trace_lines) {
4539 result = call_trace(func, obj, tstate, frame, PyTrace_LINE, Py_None);
4540 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004541 }
George King20faa682017-10-18 17:44:22 -07004542 /* Always emit an opcode event if we're tracing all opcodes. */
4543 if (frame->f_trace_opcodes) {
4544 result = call_trace(func, obj, tstate, frame, PyTrace_OPCODE, Py_None);
4545 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004546 *instr_prev = frame->f_lasti;
4547 return result;
Michael W. Hudsondd32a912002-08-15 14:59:02 +00004548}
4549
Fred Drake5755ce62001-06-27 19:19:46 +00004550void
4551PyEval_SetProfile(Py_tracefunc func, PyObject *arg)
Fred Draked0838392001-06-16 21:02:31 +00004552{
Steve Dowerb82e17e2019-05-23 08:45:22 -07004553 if (PySys_Audit("sys.setprofile", NULL) < 0) {
4554 return;
4555 }
4556
Victor Stinner50b48572018-11-01 01:51:40 +01004557 PyThreadState *tstate = _PyThreadState_GET();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004558 PyObject *temp = tstate->c_profileobj;
4559 Py_XINCREF(arg);
4560 tstate->c_profilefunc = NULL;
4561 tstate->c_profileobj = NULL;
4562 /* Must make sure that tracing is not ignored if 'temp' is freed */
4563 tstate->use_tracing = tstate->c_tracefunc != NULL;
4564 Py_XDECREF(temp);
4565 tstate->c_profilefunc = func;
4566 tstate->c_profileobj = arg;
4567 /* Flag that tracing or profiling is turned on */
4568 tstate->use_tracing = (func != NULL) || (tstate->c_tracefunc != NULL);
Fred Drake5755ce62001-06-27 19:19:46 +00004569}
4570
4571void
4572PyEval_SetTrace(Py_tracefunc func, PyObject *arg)
4573{
Steve Dowerb82e17e2019-05-23 08:45:22 -07004574 if (PySys_Audit("sys.settrace", NULL) < 0) {
4575 return;
4576 }
4577
Victor Stinner09532fe2019-05-10 23:39:09 +02004578 _PyRuntimeState *runtime = &_PyRuntime;
4579 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004580 PyObject *temp = tstate->c_traceobj;
Victor Stinner09532fe2019-05-10 23:39:09 +02004581 runtime->ceval.tracing_possible += (func != NULL) - (tstate->c_tracefunc != NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004582 Py_XINCREF(arg);
4583 tstate->c_tracefunc = NULL;
4584 tstate->c_traceobj = NULL;
4585 /* Must make sure that profiling is not ignored if 'temp' is freed */
4586 tstate->use_tracing = tstate->c_profilefunc != NULL;
4587 Py_XDECREF(temp);
4588 tstate->c_tracefunc = func;
4589 tstate->c_traceobj = arg;
4590 /* Flag that tracing or profiling is turned on */
4591 tstate->use_tracing = ((func != NULL)
4592 || (tstate->c_profilefunc != NULL));
Fred Draked0838392001-06-16 21:02:31 +00004593}
4594
Yury Selivanov75445082015-05-11 22:57:16 -04004595void
Victor Stinner838f2642019-06-13 22:41:23 +02004596_PyEval_SetCoroutineOriginTrackingDepth(PyThreadState *tstate, int new_depth)
Nathaniel J. Smithfc2f4072018-01-21 06:44:07 -08004597{
4598 assert(new_depth >= 0);
Nathaniel J. Smithfc2f4072018-01-21 06:44:07 -08004599 tstate->coroutine_origin_tracking_depth = new_depth;
4600}
4601
4602int
4603_PyEval_GetCoroutineOriginTrackingDepth(void)
4604{
Victor Stinner50b48572018-11-01 01:51:40 +01004605 PyThreadState *tstate = _PyThreadState_GET();
Nathaniel J. Smithfc2f4072018-01-21 06:44:07 -08004606 return tstate->coroutine_origin_tracking_depth;
4607}
4608
4609void
Yury Selivanoveb636452016-09-08 22:01:51 -07004610_PyEval_SetAsyncGenFirstiter(PyObject *firstiter)
4611{
Victor Stinner50b48572018-11-01 01:51:40 +01004612 PyThreadState *tstate = _PyThreadState_GET();
Steve Dowerb82e17e2019-05-23 08:45:22 -07004613
4614 if (PySys_Audit("sys.set_asyncgen_hook_firstiter", NULL) < 0) {
4615 return;
4616 }
4617
Yury Selivanoveb636452016-09-08 22:01:51 -07004618 Py_XINCREF(firstiter);
4619 Py_XSETREF(tstate->async_gen_firstiter, firstiter);
4620}
4621
4622PyObject *
4623_PyEval_GetAsyncGenFirstiter(void)
4624{
Victor Stinner50b48572018-11-01 01:51:40 +01004625 PyThreadState *tstate = _PyThreadState_GET();
Yury Selivanoveb636452016-09-08 22:01:51 -07004626 return tstate->async_gen_firstiter;
4627}
4628
4629void
4630_PyEval_SetAsyncGenFinalizer(PyObject *finalizer)
4631{
Victor Stinner50b48572018-11-01 01:51:40 +01004632 PyThreadState *tstate = _PyThreadState_GET();
Steve Dowerb82e17e2019-05-23 08:45:22 -07004633
4634 if (PySys_Audit("sys.set_asyncgen_hook_finalizer", NULL) < 0) {
4635 return;
4636 }
4637
Yury Selivanoveb636452016-09-08 22:01:51 -07004638 Py_XINCREF(finalizer);
4639 Py_XSETREF(tstate->async_gen_finalizer, finalizer);
4640}
4641
4642PyObject *
4643_PyEval_GetAsyncGenFinalizer(void)
4644{
Victor Stinner50b48572018-11-01 01:51:40 +01004645 PyThreadState *tstate = _PyThreadState_GET();
Yury Selivanoveb636452016-09-08 22:01:51 -07004646 return tstate->async_gen_finalizer;
4647}
4648
Victor Stinner438a12d2019-05-24 17:01:38 +02004649static PyFrameObject *
4650_PyEval_GetFrame(PyThreadState *tstate)
4651{
Victor Stinner01b1cc12019-11-20 02:27:56 +01004652 _PyRuntimeState *runtime = tstate->interp->runtime;
4653 return runtime->gilstate.getframe(tstate);
Victor Stinner438a12d2019-05-24 17:01:38 +02004654}
4655
4656PyFrameObject *
4657PyEval_GetFrame(void)
4658{
4659 PyThreadState *tstate = _PyThreadState_GET();
4660 return _PyEval_GetFrame(tstate);
4661}
4662
Guido van Rossumb209a111997-04-29 18:18:01 +00004663PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00004664PyEval_GetBuiltins(void)
Guido van Rossum6135a871995-01-09 17:53:26 +00004665{
Victor Stinner438a12d2019-05-24 17:01:38 +02004666 PyThreadState *tstate = _PyThreadState_GET();
4667 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004668 if (current_frame == NULL)
Victor Stinner438a12d2019-05-24 17:01:38 +02004669 return tstate->interp->builtins;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004670 else
4671 return current_frame->f_builtins;
Guido van Rossum6135a871995-01-09 17:53:26 +00004672}
4673
Serhiy Storchakabb86bf42018-12-11 08:28:18 +02004674/* Convenience function to get a builtin from its name */
4675PyObject *
4676_PyEval_GetBuiltinId(_Py_Identifier *name)
4677{
Victor Stinner438a12d2019-05-24 17:01:38 +02004678 PyThreadState *tstate = _PyThreadState_GET();
Serhiy Storchakabb86bf42018-12-11 08:28:18 +02004679 PyObject *attr = _PyDict_GetItemIdWithError(PyEval_GetBuiltins(), name);
4680 if (attr) {
4681 Py_INCREF(attr);
4682 }
Victor Stinner438a12d2019-05-24 17:01:38 +02004683 else if (!_PyErr_Occurred(tstate)) {
4684 _PyErr_SetObject(tstate, PyExc_AttributeError, _PyUnicode_FromId(name));
Serhiy Storchakabb86bf42018-12-11 08:28:18 +02004685 }
4686 return attr;
4687}
4688
Guido van Rossumb209a111997-04-29 18:18:01 +00004689PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00004690PyEval_GetLocals(void)
Guido van Rossum5b722181993-03-30 17:46:03 +00004691{
Victor Stinner438a12d2019-05-24 17:01:38 +02004692 PyThreadState *tstate = _PyThreadState_GET();
4693 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
Victor Stinner41bb43a2013-10-29 01:19:37 +01004694 if (current_frame == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004695 _PyErr_SetString(tstate, PyExc_SystemError, "frame does not exist");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004696 return NULL;
Victor Stinner41bb43a2013-10-29 01:19:37 +01004697 }
4698
Victor Stinner438a12d2019-05-24 17:01:38 +02004699 if (PyFrame_FastToLocalsWithError(current_frame) < 0) {
Victor Stinner41bb43a2013-10-29 01:19:37 +01004700 return NULL;
Victor Stinner438a12d2019-05-24 17:01:38 +02004701 }
Victor Stinner41bb43a2013-10-29 01:19:37 +01004702
4703 assert(current_frame->f_locals != NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004704 return current_frame->f_locals;
Guido van Rossum5b722181993-03-30 17:46:03 +00004705}
4706
Guido van Rossumb209a111997-04-29 18:18:01 +00004707PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00004708PyEval_GetGlobals(void)
Guido van Rossum3f5da241990-12-20 15:06:42 +00004709{
Victor Stinner438a12d2019-05-24 17:01:38 +02004710 PyThreadState *tstate = _PyThreadState_GET();
4711 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
4712 if (current_frame == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004713 return NULL;
Victor Stinner438a12d2019-05-24 17:01:38 +02004714 }
Victor Stinner41bb43a2013-10-29 01:19:37 +01004715
4716 assert(current_frame->f_globals != NULL);
4717 return current_frame->f_globals;
Guido van Rossum3f5da241990-12-20 15:06:42 +00004718}
4719
Guido van Rossum6135a871995-01-09 17:53:26 +00004720int
Tim Peters5ba58662001-07-16 02:29:45 +00004721PyEval_MergeCompilerFlags(PyCompilerFlags *cf)
Jeremy Hylton061d1062001-03-22 02:32:48 +00004722{
Victor Stinner438a12d2019-05-24 17:01:38 +02004723 PyThreadState *tstate = _PyThreadState_GET();
4724 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004725 int result = cf->cf_flags != 0;
Tim Peters5ba58662001-07-16 02:29:45 +00004726
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004727 if (current_frame != NULL) {
4728 const int codeflags = current_frame->f_code->co_flags;
4729 const int compilerflags = codeflags & PyCF_MASK;
4730 if (compilerflags) {
4731 result = 1;
4732 cf->cf_flags |= compilerflags;
4733 }
Neil Schemenauerc24ea082002-03-22 23:53:36 +00004734#if 0 /* future keyword */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004735 if (codeflags & CO_GENERATOR_ALLOWED) {
4736 result = 1;
4737 cf->cf_flags |= CO_GENERATOR_ALLOWED;
4738 }
Neil Schemenauerc24ea082002-03-22 23:53:36 +00004739#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004740 }
4741 return result;
Jeremy Hylton061d1062001-03-22 02:32:48 +00004742}
4743
Guido van Rossum3f5da241990-12-20 15:06:42 +00004744
Jeremy Hyltonaf68c872005-12-10 18:50:16 +00004745const char *
Tim Peters6d6c1a32001-08-02 04:15:00 +00004746PyEval_GetFuncName(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00004747{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004748 if (PyMethod_Check(func))
4749 return PyEval_GetFuncName(PyMethod_GET_FUNCTION(func));
4750 else if (PyFunction_Check(func))
Serhiy Storchaka06515832016-11-20 09:13:07 +02004751 return PyUnicode_AsUTF8(((PyFunctionObject*)func)->func_name);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004752 else if (PyCFunction_Check(func))
4753 return ((PyCFunctionObject*)func)->m_ml->ml_name;
4754 else
4755 return func->ob_type->tp_name;
Jeremy Hylton512a2372001-04-11 13:52:29 +00004756}
4757
Jeremy Hyltonaf68c872005-12-10 18:50:16 +00004758const char *
Tim Peters6d6c1a32001-08-02 04:15:00 +00004759PyEval_GetFuncDesc(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00004760{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004761 if (PyMethod_Check(func))
4762 return "()";
4763 else if (PyFunction_Check(func))
4764 return "()";
4765 else if (PyCFunction_Check(func))
4766 return "()";
4767 else
4768 return " object";
Jeremy Hylton512a2372001-04-11 13:52:29 +00004769}
4770
Armin Rigo1c2d7e52005-09-20 18:34:01 +00004771#define C_TRACE(x, call) \
Nicholas Bastind858a772004-06-25 23:31:06 +00004772if (tstate->use_tracing && tstate->c_profilefunc) { \
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004773 if (call_trace(tstate->c_profilefunc, tstate->c_profileobj, \
4774 tstate, tstate->frame, \
4775 PyTrace_C_CALL, func)) { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004776 x = NULL; \
4777 } \
4778 else { \
4779 x = call; \
4780 if (tstate->c_profilefunc != NULL) { \
4781 if (x == NULL) { \
4782 call_trace_protected(tstate->c_profilefunc, \
4783 tstate->c_profileobj, \
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004784 tstate, tstate->frame, \
4785 PyTrace_C_EXCEPTION, func); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004786 /* XXX should pass (type, value, tb) */ \
4787 } else { \
4788 if (call_trace(tstate->c_profilefunc, \
4789 tstate->c_profileobj, \
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004790 tstate, tstate->frame, \
4791 PyTrace_C_RETURN, func)) { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004792 Py_DECREF(x); \
4793 x = NULL; \
4794 } \
4795 } \
4796 } \
4797 } \
Nicholas Bastind858a772004-06-25 23:31:06 +00004798} else { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004799 x = call; \
4800 }
Nicholas Bastinc69ebe82004-03-24 21:57:10 +00004801
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004802
4803static PyObject *
4804trace_call_function(PyThreadState *tstate,
4805 PyObject *func,
4806 PyObject **args, Py_ssize_t nargs,
4807 PyObject *kwnames)
4808{
4809 PyObject *x;
4810 if (PyCFunction_Check(func)) {
Jeroen Demeyer0d722f32019-07-05 14:48:24 +02004811 C_TRACE(x, _PyObject_Vectorcall(func, args, nargs, kwnames));
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004812 return x;
4813 }
4814 else if (Py_TYPE(func) == &PyMethodDescr_Type && nargs > 0) {
4815 /* We need to create a temporary bound method as argument
4816 for profiling.
4817
4818 If nargs == 0, then this cannot work because we have no
4819 "self". In any case, the call itself would raise
4820 TypeError (foo needs an argument), so we just skip
4821 profiling. */
4822 PyObject *self = args[0];
4823 func = Py_TYPE(func)->tp_descr_get(func, self, (PyObject*)Py_TYPE(self));
4824 if (func == NULL) {
4825 return NULL;
4826 }
Jeroen Demeyer0d722f32019-07-05 14:48:24 +02004827 C_TRACE(x, _PyObject_Vectorcall(func,
4828 args+1, nargs-1,
4829 kwnames));
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004830 Py_DECREF(func);
4831 return x;
4832 }
4833 return _PyObject_Vectorcall(func, args, nargs | PY_VECTORCALL_ARGUMENTS_OFFSET, kwnames);
4834}
4835
Victor Stinner415c5102017-01-11 00:54:57 +01004836/* Issue #29227: Inline call_function() into _PyEval_EvalFrameDefault()
4837 to reduce the stack consumption. */
4838Py_LOCAL_INLINE(PyObject *) _Py_HOT_FUNCTION
Victor Stinner09532fe2019-05-10 23:39:09 +02004839call_function(PyThreadState *tstate, PyObject ***pp_stack, Py_ssize_t oparg, PyObject *kwnames)
Jeremy Hyltone8c04322002-08-16 17:47:26 +00004840{
Victor Stinnerf9b760f2016-09-09 10:17:08 -07004841 PyObject **pfunc = (*pp_stack) - oparg - 1;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004842 PyObject *func = *pfunc;
4843 PyObject *x, *w;
Victor Stinnerd8735722016-09-09 12:36:44 -07004844 Py_ssize_t nkwargs = (kwnames == NULL) ? 0 : PyTuple_GET_SIZE(kwnames);
4845 Py_ssize_t nargs = oparg - nkwargs;
INADA Naoki5566bbb2017-02-03 07:43:03 +09004846 PyObject **stack = (*pp_stack) - nargs - nkwargs;
Jeremy Hyltone8c04322002-08-16 17:47:26 +00004847
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004848 if (tstate->use_tracing) {
4849 x = trace_call_function(tstate, func, stack, nargs, kwnames);
INADA Naoki5566bbb2017-02-03 07:43:03 +09004850 }
Victor Stinner4a7cc882015-03-06 23:35:27 +01004851 else {
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004852 x = _PyObject_Vectorcall(func, stack, nargs | PY_VECTORCALL_ARGUMENTS_OFFSET, kwnames);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004853 }
Tim Peters8a5c3c72004-04-05 19:36:21 +00004854
Victor Stinner438a12d2019-05-24 17:01:38 +02004855 assert((x != NULL) ^ (_PyErr_Occurred(tstate) != NULL));
Victor Stinnerf9b760f2016-09-09 10:17:08 -07004856
Victor Stinnerc22bfaa2017-02-12 19:27:05 +01004857 /* Clear the stack of the function object. */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004858 while ((*pp_stack) > pfunc) {
4859 w = EXT_POP(*pp_stack);
4860 Py_DECREF(w);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004861 }
Victor Stinnerace47d72013-07-18 01:41:08 +02004862
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004863 return x;
Jeremy Hyltone8c04322002-08-16 17:47:26 +00004864}
4865
Jeremy Hylton52820442001-01-03 23:52:36 +00004866static PyObject *
Victor Stinner09532fe2019-05-10 23:39:09 +02004867do_call_core(PyThreadState *tstate, PyObject *func, PyObject *callargs, PyObject *kwdict)
Jeremy Hylton52820442001-01-03 23:52:36 +00004868{
jdemeyere89de732018-09-19 12:06:20 +02004869 PyObject *result;
4870
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004871 if (PyCFunction_Check(func)) {
Jeroen Demeyer7a6873c2019-09-11 13:01:01 +02004872 C_TRACE(result, PyObject_Call(func, callargs, kwdict));
Victor Stinnerf9b760f2016-09-09 10:17:08 -07004873 return result;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004874 }
jdemeyere89de732018-09-19 12:06:20 +02004875 else if (Py_TYPE(func) == &PyMethodDescr_Type) {
jdemeyere89de732018-09-19 12:06:20 +02004876 Py_ssize_t nargs = PyTuple_GET_SIZE(callargs);
4877 if (nargs > 0 && tstate->use_tracing) {
4878 /* We need to create a temporary bound method as argument
4879 for profiling.
4880
4881 If nargs == 0, then this cannot work because we have no
4882 "self". In any case, the call itself would raise
4883 TypeError (foo needs an argument), so we just skip
4884 profiling. */
4885 PyObject *self = PyTuple_GET_ITEM(callargs, 0);
4886 func = Py_TYPE(func)->tp_descr_get(func, self, (PyObject*)Py_TYPE(self));
4887 if (func == NULL) {
4888 return NULL;
4889 }
4890
Victor Stinner4d231bc2019-11-14 13:36:21 +01004891 C_TRACE(result, _PyObject_FastCallDictTstate(
4892 tstate, func,
4893 &_PyTuple_ITEMS(callargs)[1],
4894 nargs - 1,
4895 kwdict));
jdemeyere89de732018-09-19 12:06:20 +02004896 Py_DECREF(func);
4897 return result;
4898 }
Victor Stinner74319ae2016-08-25 00:04:09 +02004899 }
jdemeyere89de732018-09-19 12:06:20 +02004900 return PyObject_Call(func, callargs, kwdict);
Jeremy Hylton52820442001-01-03 23:52:36 +00004901}
4902
Serhiy Storchaka483405b2015-02-17 10:14:30 +02004903/* Extract a slice index from a PyLong or an object with the
Guido van Rossum38fff8c2006-03-07 18:50:55 +00004904 nb_index slot defined, and store in *pi.
4905 Silently reduce values larger than PY_SSIZE_T_MAX to PY_SSIZE_T_MAX,
Xiang Zhang2ddf5a12017-05-10 18:19:41 +08004906 and silently boost values less than PY_SSIZE_T_MIN to PY_SSIZE_T_MIN.
Martin v. Löwisdde99d22006-02-17 15:57:41 +00004907 Return 0 on error, 1 on success.
Tim Peterscb479e72001-12-16 19:11:44 +00004908*/
Guido van Rossum20c6add2000-05-08 14:06:50 +00004909int
Martin v. Löwis18e16552006-02-15 17:27:45 +00004910_PyEval_SliceIndex(PyObject *v, Py_ssize_t *pi)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004911{
Victor Stinner438a12d2019-05-24 17:01:38 +02004912 PyThreadState *tstate = _PyThreadState_GET();
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004913 if (v != Py_None) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004914 Py_ssize_t x;
4915 if (PyIndex_Check(v)) {
4916 x = PyNumber_AsSsize_t(v, NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02004917 if (x == -1 && _PyErr_Occurred(tstate))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004918 return 0;
4919 }
4920 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004921 _PyErr_SetString(tstate, PyExc_TypeError,
4922 "slice indices must be integers or "
4923 "None or have an __index__ method");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004924 return 0;
4925 }
4926 *pi = x;
4927 }
4928 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004929}
4930
Serhiy Storchaka80ec8362017-03-19 19:37:40 +02004931int
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004932_PyEval_SliceIndexNotNone(PyObject *v, Py_ssize_t *pi)
Serhiy Storchaka80ec8362017-03-19 19:37:40 +02004933{
Victor Stinner438a12d2019-05-24 17:01:38 +02004934 PyThreadState *tstate = _PyThreadState_GET();
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004935 Py_ssize_t x;
4936 if (PyIndex_Check(v)) {
4937 x = PyNumber_AsSsize_t(v, NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02004938 if (x == -1 && _PyErr_Occurred(tstate))
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004939 return 0;
4940 }
4941 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004942 _PyErr_SetString(tstate, PyExc_TypeError,
4943 "slice indices must be integers or "
4944 "have an __index__ method");
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004945 return 0;
4946 }
4947 *pi = x;
4948 return 1;
Serhiy Storchaka80ec8362017-03-19 19:37:40 +02004949}
4950
4951
Guido van Rossum486364b2007-06-30 05:01:58 +00004952#define CANNOT_CATCH_MSG "catching classes that do not inherit from "\
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004953 "BaseException is not allowed"
Brett Cannonf74225d2007-02-26 21:10:16 +00004954
Guido van Rossumb209a111997-04-29 18:18:01 +00004955static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02004956cmp_outcome(PyThreadState *tstate, int op, PyObject *v, PyObject *w)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004957{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004958 int res = 0;
4959 switch (op) {
4960 case PyCmp_IS:
4961 res = (v == w);
4962 break;
4963 case PyCmp_IS_NOT:
4964 res = (v != w);
4965 break;
4966 case PyCmp_IN:
4967 res = PySequence_Contains(w, v);
4968 if (res < 0)
4969 return NULL;
4970 break;
4971 case PyCmp_NOT_IN:
4972 res = PySequence_Contains(w, v);
4973 if (res < 0)
4974 return NULL;
4975 res = !res;
4976 break;
4977 case PyCmp_EXC_MATCH:
4978 if (PyTuple_Check(w)) {
4979 Py_ssize_t i, length;
4980 length = PyTuple_Size(w);
4981 for (i = 0; i < length; i += 1) {
4982 PyObject *exc = PyTuple_GET_ITEM(w, i);
4983 if (!PyExceptionClass_Check(exc)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004984 _PyErr_SetString(tstate, PyExc_TypeError,
4985 CANNOT_CATCH_MSG);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004986 return NULL;
4987 }
4988 }
4989 }
4990 else {
4991 if (!PyExceptionClass_Check(w)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004992 _PyErr_SetString(tstate, PyExc_TypeError,
4993 CANNOT_CATCH_MSG);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004994 return NULL;
4995 }
4996 }
4997 res = PyErr_GivenExceptionMatches(v, w);
4998 break;
4999 default:
5000 return PyObject_RichCompare(v, w, op);
5001 }
5002 v = res ? Py_True : Py_False;
5003 Py_INCREF(v);
5004 return v;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00005005}
5006
Thomas Wouters52152252000-08-17 22:55:00 +00005007static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02005008import_name(PyThreadState *tstate, PyFrameObject *f,
5009 PyObject *name, PyObject *fromlist, PyObject *level)
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005010{
5011 _Py_IDENTIFIER(__import__);
Victor Stinnerdf142fd2016-08-20 00:44:42 +02005012 PyObject *import_func, *res;
5013 PyObject* stack[5];
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005014
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005015 import_func = _PyDict_GetItemIdWithError(f->f_builtins, &PyId___import__);
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005016 if (import_func == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005017 if (!_PyErr_Occurred(tstate)) {
5018 _PyErr_SetString(tstate, PyExc_ImportError, "__import__ not found");
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005019 }
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005020 return NULL;
5021 }
5022
5023 /* Fast path for not overloaded __import__. */
Victor Stinner438a12d2019-05-24 17:01:38 +02005024 if (import_func == tstate->interp->import_func) {
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005025 int ilevel = _PyLong_AsInt(level);
Victor Stinner438a12d2019-05-24 17:01:38 +02005026 if (ilevel == -1 && _PyErr_Occurred(tstate)) {
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005027 return NULL;
5028 }
5029 res = PyImport_ImportModuleLevelObject(
5030 name,
5031 f->f_globals,
5032 f->f_locals == NULL ? Py_None : f->f_locals,
5033 fromlist,
5034 ilevel);
5035 return res;
5036 }
5037
5038 Py_INCREF(import_func);
Victor Stinnerdf142fd2016-08-20 00:44:42 +02005039
5040 stack[0] = name;
5041 stack[1] = f->f_globals;
5042 stack[2] = f->f_locals == NULL ? Py_None : f->f_locals;
5043 stack[3] = fromlist;
5044 stack[4] = level;
Victor Stinner559bb6a2016-08-22 22:48:54 +02005045 res = _PyObject_FastCall(import_func, stack, 5);
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005046 Py_DECREF(import_func);
5047 return res;
5048}
5049
5050static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02005051import_from(PyThreadState *tstate, PyObject *v, PyObject *name)
Guido van Rossume9736fc1990-11-18 17:33:06 +00005052{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005053 PyObject *x;
Antoine Pitrou0373a102014-10-13 20:19:45 +02005054 _Py_IDENTIFIER(__name__);
Xiang Zhang4830f582017-03-21 11:13:42 +08005055 PyObject *fullmodname, *pkgname, *pkgpath, *pkgname_or_unknown, *errmsg;
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00005056
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005057 if (_PyObject_LookupAttr(v, name, &x) != 0) {
Antoine Pitrou0373a102014-10-13 20:19:45 +02005058 return x;
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005059 }
Antoine Pitrou0373a102014-10-13 20:19:45 +02005060 /* Issue #17636: in case this failed because of a circular relative
5061 import, try to fallback on reading the module directly from
5062 sys.modules. */
Antoine Pitrou0373a102014-10-13 20:19:45 +02005063 pkgname = _PyObject_GetAttrId(v, &PyId___name__);
Brett Cannon3008bc02015-08-11 18:01:31 -07005064 if (pkgname == NULL) {
5065 goto error;
5066 }
Oren Milman6db70332017-09-19 14:23:01 +03005067 if (!PyUnicode_Check(pkgname)) {
5068 Py_CLEAR(pkgname);
5069 goto error;
5070 }
Antoine Pitrou0373a102014-10-13 20:19:45 +02005071 fullmodname = PyUnicode_FromFormat("%U.%U", pkgname, name);
Brett Cannon3008bc02015-08-11 18:01:31 -07005072 if (fullmodname == NULL) {
Xiang Zhang4830f582017-03-21 11:13:42 +08005073 Py_DECREF(pkgname);
Antoine Pitrou0373a102014-10-13 20:19:45 +02005074 return NULL;
Brett Cannon3008bc02015-08-11 18:01:31 -07005075 }
Eric Snow3f9eee62017-09-15 16:35:20 -06005076 x = PyImport_GetModule(fullmodname);
Antoine Pitrou0373a102014-10-13 20:19:45 +02005077 Py_DECREF(fullmodname);
Victor Stinner438a12d2019-05-24 17:01:38 +02005078 if (x == NULL && !_PyErr_Occurred(tstate)) {
Brett Cannon3008bc02015-08-11 18:01:31 -07005079 goto error;
5080 }
Matthias Bussonnier1bc15642017-02-22 07:06:50 -08005081 Py_DECREF(pkgname);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005082 return x;
Brett Cannon3008bc02015-08-11 18:01:31 -07005083 error:
Matthias Bussonnierbc4bed42017-02-14 16:05:25 -08005084 pkgpath = PyModule_GetFilenameObject(v);
Matthias Bussonnier1bc15642017-02-22 07:06:50 -08005085 if (pkgname == NULL) {
5086 pkgname_or_unknown = PyUnicode_FromString("<unknown module name>");
5087 if (pkgname_or_unknown == NULL) {
5088 Py_XDECREF(pkgpath);
5089 return NULL;
5090 }
5091 } else {
5092 pkgname_or_unknown = pkgname;
5093 }
Matthias Bussonnierbc4bed42017-02-14 16:05:25 -08005094
5095 if (pkgpath == NULL || !PyUnicode_Check(pkgpath)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005096 _PyErr_Clear(tstate);
Xiang Zhang4830f582017-03-21 11:13:42 +08005097 errmsg = PyUnicode_FromFormat(
5098 "cannot import name %R from %R (unknown location)",
5099 name, pkgname_or_unknown
5100 );
Stefan Krah027b09c2019-03-25 21:50:58 +01005101 /* NULL checks for errmsg and pkgname done by PyErr_SetImportError. */
Xiang Zhang4830f582017-03-21 11:13:42 +08005102 PyErr_SetImportError(errmsg, pkgname, NULL);
5103 }
5104 else {
Anthony Sottile65366bc2019-09-09 08:17:50 -07005105 _Py_IDENTIFIER(__spec__);
5106 PyObject *spec = _PyObject_GetAttrId(v, &PyId___spec__);
Anthony Sottile65366bc2019-09-09 08:17:50 -07005107 const char *fmt =
5108 _PyModuleSpec_IsInitializing(spec) ?
5109 "cannot import name %R from partially initialized module %R "
5110 "(most likely due to a circular import) (%S)" :
5111 "cannot import name %R from %R (%S)";
5112 Py_XDECREF(spec);
5113
5114 errmsg = PyUnicode_FromFormat(fmt, name, pkgname_or_unknown, pkgpath);
Stefan Krah027b09c2019-03-25 21:50:58 +01005115 /* NULL checks for errmsg and pkgname done by PyErr_SetImportError. */
Xiang Zhang4830f582017-03-21 11:13:42 +08005116 PyErr_SetImportError(errmsg, pkgname, pkgpath);
Matthias Bussonnierbc4bed42017-02-14 16:05:25 -08005117 }
5118
Xiang Zhang4830f582017-03-21 11:13:42 +08005119 Py_XDECREF(errmsg);
Matthias Bussonnier1bc15642017-02-22 07:06:50 -08005120 Py_XDECREF(pkgname_or_unknown);
5121 Py_XDECREF(pkgpath);
Brett Cannon3008bc02015-08-11 18:01:31 -07005122 return NULL;
Thomas Wouters52152252000-08-17 22:55:00 +00005123}
Guido van Rossumac7be682001-01-17 15:42:30 +00005124
Thomas Wouters52152252000-08-17 22:55:00 +00005125static int
Victor Stinner438a12d2019-05-24 17:01:38 +02005126import_all_from(PyThreadState *tstate, PyObject *locals, PyObject *v)
Thomas Wouters52152252000-08-17 22:55:00 +00005127{
Martin v. Löwis1c67dd92011-10-14 15:16:45 +02005128 _Py_IDENTIFIER(__all__);
5129 _Py_IDENTIFIER(__dict__);
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005130 _Py_IDENTIFIER(__name__);
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005131 PyObject *all, *dict, *name, *value;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005132 int skip_leading_underscores = 0;
5133 int pos, err;
Thomas Wouters52152252000-08-17 22:55:00 +00005134
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005135 if (_PyObject_LookupAttrId(v, &PyId___all__, &all) < 0) {
5136 return -1; /* Unexpected error */
5137 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005138 if (all == NULL) {
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005139 if (_PyObject_LookupAttrId(v, &PyId___dict__, &dict) < 0) {
5140 return -1;
5141 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005142 if (dict == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005143 _PyErr_SetString(tstate, PyExc_ImportError,
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005144 "from-import-* object has no __dict__ and no __all__");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005145 return -1;
5146 }
5147 all = PyMapping_Keys(dict);
5148 Py_DECREF(dict);
5149 if (all == NULL)
5150 return -1;
5151 skip_leading_underscores = 1;
5152 }
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00005153
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005154 for (pos = 0, err = 0; ; pos++) {
5155 name = PySequence_GetItem(all, pos);
5156 if (name == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005157 if (!_PyErr_ExceptionMatches(tstate, PyExc_IndexError)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005158 err = -1;
Victor Stinner438a12d2019-05-24 17:01:38 +02005159 }
5160 else {
5161 _PyErr_Clear(tstate);
5162 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005163 break;
5164 }
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005165 if (!PyUnicode_Check(name)) {
5166 PyObject *modname = _PyObject_GetAttrId(v, &PyId___name__);
5167 if (modname == NULL) {
5168 Py_DECREF(name);
5169 err = -1;
5170 break;
5171 }
5172 if (!PyUnicode_Check(modname)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005173 _PyErr_Format(tstate, PyExc_TypeError,
5174 "module __name__ must be a string, not %.100s",
5175 Py_TYPE(modname)->tp_name);
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005176 }
5177 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02005178 _PyErr_Format(tstate, PyExc_TypeError,
5179 "%s in %U.%s must be str, not %.100s",
5180 skip_leading_underscores ? "Key" : "Item",
5181 modname,
5182 skip_leading_underscores ? "__dict__" : "__all__",
5183 Py_TYPE(name)->tp_name);
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005184 }
5185 Py_DECREF(modname);
5186 Py_DECREF(name);
5187 err = -1;
5188 break;
5189 }
5190 if (skip_leading_underscores) {
Serhiy Storchakae3b2b4b2017-09-08 09:58:51 +03005191 if (PyUnicode_READY(name) == -1) {
5192 Py_DECREF(name);
5193 err = -1;
5194 break;
5195 }
5196 if (PyUnicode_READ_CHAR(name, 0) == '_') {
5197 Py_DECREF(name);
5198 continue;
5199 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005200 }
5201 value = PyObject_GetAttr(v, name);
5202 if (value == NULL)
5203 err = -1;
5204 else if (PyDict_CheckExact(locals))
5205 err = PyDict_SetItem(locals, name, value);
5206 else
5207 err = PyObject_SetItem(locals, name, value);
5208 Py_DECREF(name);
5209 Py_XDECREF(value);
5210 if (err != 0)
5211 break;
5212 }
5213 Py_DECREF(all);
5214 return err;
Guido van Rossume9736fc1990-11-18 17:33:06 +00005215}
5216
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005217static int
Victor Stinner438a12d2019-05-24 17:01:38 +02005218check_args_iterable(PyThreadState *tstate, PyObject *func, PyObject *args)
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005219{
5220 if (args->ob_type->tp_iter == NULL && !PySequence_Check(args)) {
Jeroen Demeyerbf17d412019-11-05 16:48:04 +01005221 /* check_args_iterable() may be called with a live exception:
5222 * clear it to prevent calling _PyObject_FunctionStr() with an
5223 * exception set. */
5224 PyErr_Clear();
5225 PyObject *funcstr = _PyObject_FunctionStr(func);
5226 if (funcstr != NULL) {
5227 _PyErr_Format(tstate, PyExc_TypeError,
5228 "%U argument after * must be an iterable, not %.200s",
5229 funcstr, Py_TYPE(args)->tp_name);
5230 Py_DECREF(funcstr);
5231 }
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005232 return -1;
5233 }
5234 return 0;
5235}
5236
5237static void
Victor Stinner438a12d2019-05-24 17:01:38 +02005238format_kwargs_error(PyThreadState *tstate, PyObject *func, PyObject *kwargs)
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005239{
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005240 /* _PyDict_MergeEx raises attribute
5241 * error (percolated from an attempt
5242 * to get 'keys' attribute) instead of
5243 * a type error if its second argument
5244 * is not a mapping.
5245 */
Victor Stinner438a12d2019-05-24 17:01:38 +02005246 if (_PyErr_ExceptionMatches(tstate, PyExc_AttributeError)) {
Jeroen Demeyerbf17d412019-11-05 16:48:04 +01005247 PyErr_Clear();
5248 PyObject *funcstr = _PyObject_FunctionStr(func);
5249 if (funcstr != NULL) {
5250 _PyErr_Format(
5251 tstate, PyExc_TypeError,
5252 "%U argument after ** must be a mapping, not %.200s",
5253 funcstr, Py_TYPE(kwargs)->tp_name);
5254 Py_DECREF(funcstr);
5255 }
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005256 }
Victor Stinner438a12d2019-05-24 17:01:38 +02005257 else if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005258 PyObject *exc, *val, *tb;
Victor Stinner438a12d2019-05-24 17:01:38 +02005259 _PyErr_Fetch(tstate, &exc, &val, &tb);
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005260 if (val && PyTuple_Check(val) && PyTuple_GET_SIZE(val) == 1) {
Jeroen Demeyerbf17d412019-11-05 16:48:04 +01005261 PyErr_Clear();
5262 PyObject *funcstr = _PyObject_FunctionStr(func);
5263 if (funcstr != NULL) {
5264 PyObject *key = PyTuple_GET_ITEM(val, 0);
5265 _PyErr_Format(
5266 tstate, PyExc_TypeError,
5267 "%U got multiple values for keyword argument '%S'",
5268 funcstr, key);
5269 Py_DECREF(funcstr);
5270 }
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005271 Py_XDECREF(exc);
5272 Py_XDECREF(val);
5273 Py_XDECREF(tb);
5274 }
5275 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02005276 _PyErr_Restore(tstate, exc, val, tb);
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005277 }
5278 }
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005279}
5280
Guido van Rossumac7be682001-01-17 15:42:30 +00005281static void
Victor Stinner438a12d2019-05-24 17:01:38 +02005282format_exc_check_arg(PyThreadState *tstate, PyObject *exc,
5283 const char *format_str, PyObject *obj)
Paul Prescode68140d2000-08-30 20:25:01 +00005284{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005285 const char *obj_str;
Paul Prescode68140d2000-08-30 20:25:01 +00005286
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005287 if (!obj)
5288 return;
Paul Prescode68140d2000-08-30 20:25:01 +00005289
Serhiy Storchaka06515832016-11-20 09:13:07 +02005290 obj_str = PyUnicode_AsUTF8(obj);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005291 if (!obj_str)
5292 return;
Paul Prescode68140d2000-08-30 20:25:01 +00005293
Victor Stinner438a12d2019-05-24 17:01:38 +02005294 _PyErr_Format(tstate, exc, format_str, obj_str);
Paul Prescode68140d2000-08-30 20:25:01 +00005295}
Guido van Rossum950361c1997-01-24 13:49:28 +00005296
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005297static void
Victor Stinner438a12d2019-05-24 17:01:38 +02005298format_exc_unbound(PyThreadState *tstate, PyCodeObject *co, int oparg)
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005299{
5300 PyObject *name;
5301 /* Don't stomp existing exception */
Victor Stinner438a12d2019-05-24 17:01:38 +02005302 if (_PyErr_Occurred(tstate))
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005303 return;
5304 if (oparg < PyTuple_GET_SIZE(co->co_cellvars)) {
5305 name = PyTuple_GET_ITEM(co->co_cellvars,
5306 oparg);
Victor Stinner438a12d2019-05-24 17:01:38 +02005307 format_exc_check_arg(tstate,
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005308 PyExc_UnboundLocalError,
5309 UNBOUNDLOCAL_ERROR_MSG,
5310 name);
5311 } else {
5312 name = PyTuple_GET_ITEM(co->co_freevars, oparg -
5313 PyTuple_GET_SIZE(co->co_cellvars));
Victor Stinner438a12d2019-05-24 17:01:38 +02005314 format_exc_check_arg(tstate, PyExc_NameError,
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005315 UNBOUNDFREE_ERROR_MSG, name);
5316 }
5317}
5318
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005319static void
Mark Shannonfee55262019-11-21 09:11:43 +00005320format_awaitable_error(PyThreadState *tstate, PyTypeObject *type, int prevprevopcode, int prevopcode)
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005321{
5322 if (type->tp_as_async == NULL || type->tp_as_async->am_await == NULL) {
5323 if (prevopcode == BEFORE_ASYNC_WITH) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005324 _PyErr_Format(tstate, PyExc_TypeError,
5325 "'async with' received an object from __aenter__ "
5326 "that does not implement __await__: %.100s",
5327 type->tp_name);
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005328 }
Mark Shannonfee55262019-11-21 09:11:43 +00005329 else if (prevopcode == WITH_EXCEPT_START || (prevopcode == CALL_FUNCTION && prevprevopcode == DUP_TOP)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005330 _PyErr_Format(tstate, PyExc_TypeError,
5331 "'async with' received an object from __aexit__ "
5332 "that does not implement __await__: %.100s",
5333 type->tp_name);
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005334 }
5335 }
5336}
5337
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005338static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02005339unicode_concatenate(PyThreadState *tstate, PyObject *v, PyObject *w,
Serhiy Storchakaab874002016-09-11 13:48:15 +03005340 PyFrameObject *f, const _Py_CODEUNIT *next_instr)
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005341{
5342 PyObject *res;
5343 if (Py_REFCNT(v) == 2) {
5344 /* In the common case, there are 2 references to the value
5345 * stored in 'variable' when the += is performed: one on the
5346 * value stack (in 'v') and one still stored in the
5347 * 'variable'. We try to delete the variable now to reduce
5348 * the refcnt to 1.
5349 */
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03005350 int opcode, oparg;
5351 NEXTOPARG();
5352 switch (opcode) {
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005353 case STORE_FAST:
5354 {
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005355 PyObject **fastlocals = f->f_localsplus;
5356 if (GETLOCAL(oparg) == v)
5357 SETLOCAL(oparg, NULL);
5358 break;
5359 }
5360 case STORE_DEREF:
5361 {
5362 PyObject **freevars = (f->f_localsplus +
5363 f->f_code->co_nlocals);
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03005364 PyObject *c = freevars[oparg];
Raymond Hettingerc32f9db2016-11-12 04:10:35 -05005365 if (PyCell_GET(c) == v) {
5366 PyCell_SET(c, NULL);
5367 Py_DECREF(v);
5368 }
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005369 break;
5370 }
5371 case STORE_NAME:
5372 {
5373 PyObject *names = f->f_code->co_names;
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03005374 PyObject *name = GETITEM(names, oparg);
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005375 PyObject *locals = f->f_locals;
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005376 if (locals && PyDict_CheckExact(locals)) {
5377 PyObject *w = PyDict_GetItemWithError(locals, name);
5378 if ((w == v && PyDict_DelItem(locals, name) != 0) ||
Victor Stinner438a12d2019-05-24 17:01:38 +02005379 (w == NULL && _PyErr_Occurred(tstate)))
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005380 {
5381 Py_DECREF(v);
5382 return NULL;
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005383 }
5384 }
5385 break;
5386 }
5387 }
5388 }
5389 res = v;
5390 PyUnicode_Append(&res, w);
5391 return res;
5392}
5393
Guido van Rossum950361c1997-01-24 13:49:28 +00005394#ifdef DYNAMIC_EXECUTION_PROFILE
5395
Skip Montanarof118cb12001-10-15 20:51:38 +00005396static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00005397getarray(long a[256])
Guido van Rossum950361c1997-01-24 13:49:28 +00005398{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005399 int i;
5400 PyObject *l = PyList_New(256);
5401 if (l == NULL) return NULL;
5402 for (i = 0; i < 256; i++) {
5403 PyObject *x = PyLong_FromLong(a[i]);
5404 if (x == NULL) {
5405 Py_DECREF(l);
5406 return NULL;
5407 }
Zackery Spytz99d56b52018-12-08 07:16:55 -07005408 PyList_SET_ITEM(l, i, x);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005409 }
5410 for (i = 0; i < 256; i++)
5411 a[i] = 0;
5412 return l;
Guido van Rossum950361c1997-01-24 13:49:28 +00005413}
5414
5415PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00005416_Py_GetDXProfile(PyObject *self, PyObject *args)
Guido van Rossum950361c1997-01-24 13:49:28 +00005417{
5418#ifndef DXPAIRS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005419 return getarray(dxp);
Guido van Rossum950361c1997-01-24 13:49:28 +00005420#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005421 int i;
5422 PyObject *l = PyList_New(257);
5423 if (l == NULL) return NULL;
5424 for (i = 0; i < 257; i++) {
5425 PyObject *x = getarray(dxpairs[i]);
5426 if (x == NULL) {
5427 Py_DECREF(l);
5428 return NULL;
5429 }
Zackery Spytz99d56b52018-12-08 07:16:55 -07005430 PyList_SET_ITEM(l, i, x);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005431 }
5432 return l;
Guido van Rossum950361c1997-01-24 13:49:28 +00005433#endif
5434}
5435
5436#endif
Brett Cannon5c4de282016-09-07 11:16:41 -07005437
5438Py_ssize_t
5439_PyEval_RequestCodeExtraIndex(freefunc free)
5440{
Victor Stinnercaba55b2018-08-03 15:33:52 +02005441 PyInterpreterState *interp = _PyInterpreterState_GET_UNSAFE();
Brett Cannon5c4de282016-09-07 11:16:41 -07005442 Py_ssize_t new_index;
5443
Dino Viehlandf3cffd22017-06-21 14:44:36 -07005444 if (interp->co_extra_user_count == MAX_CO_EXTRA_USERS - 1) {
Brett Cannon5c4de282016-09-07 11:16:41 -07005445 return -1;
5446 }
Dino Viehlandf3cffd22017-06-21 14:44:36 -07005447 new_index = interp->co_extra_user_count++;
5448 interp->co_extra_freefuncs[new_index] = free;
Brett Cannon5c4de282016-09-07 11:16:41 -07005449 return new_index;
5450}
Łukasz Langaa785c872016-09-09 17:37:37 -07005451
5452static void
5453dtrace_function_entry(PyFrameObject *f)
5454{
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +02005455 const char *filename;
5456 const char *funcname;
Łukasz Langaa785c872016-09-09 17:37:37 -07005457 int lineno;
5458
5459 filename = PyUnicode_AsUTF8(f->f_code->co_filename);
5460 funcname = PyUnicode_AsUTF8(f->f_code->co_name);
5461 lineno = PyCode_Addr2Line(f->f_code, f->f_lasti);
5462
5463 PyDTrace_FUNCTION_ENTRY(filename, funcname, lineno);
5464}
5465
5466static void
5467dtrace_function_return(PyFrameObject *f)
5468{
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +02005469 const char *filename;
5470 const char *funcname;
Łukasz Langaa785c872016-09-09 17:37:37 -07005471 int lineno;
5472
5473 filename = PyUnicode_AsUTF8(f->f_code->co_filename);
5474 funcname = PyUnicode_AsUTF8(f->f_code->co_name);
5475 lineno = PyCode_Addr2Line(f->f_code, f->f_lasti);
5476
5477 PyDTrace_FUNCTION_RETURN(filename, funcname, lineno);
5478}
5479
5480/* DTrace equivalent of maybe_call_line_trace. */
5481static void
5482maybe_dtrace_line(PyFrameObject *frame,
5483 int *instr_lb, int *instr_ub, int *instr_prev)
5484{
5485 int line = frame->f_lineno;
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +02005486 const char *co_filename, *co_name;
Łukasz Langaa785c872016-09-09 17:37:37 -07005487
5488 /* If the last instruction executed isn't in the current
5489 instruction window, reset the window.
5490 */
5491 if (frame->f_lasti < *instr_lb || frame->f_lasti >= *instr_ub) {
5492 PyAddrPair bounds;
5493 line = _PyCode_CheckLineNumber(frame->f_code, frame->f_lasti,
5494 &bounds);
5495 *instr_lb = bounds.ap_lower;
5496 *instr_ub = bounds.ap_upper;
5497 }
5498 /* If the last instruction falls at the start of a line or if
5499 it represents a jump backwards, update the frame's line
5500 number and call the trace function. */
5501 if (frame->f_lasti == *instr_lb || frame->f_lasti < *instr_prev) {
5502 frame->f_lineno = line;
5503 co_filename = PyUnicode_AsUTF8(frame->f_code->co_filename);
5504 if (!co_filename)
5505 co_filename = "?";
5506 co_name = PyUnicode_AsUTF8(frame->f_code->co_name);
5507 if (!co_name)
5508 co_name = "?";
5509 PyDTrace_LINE(co_filename, co_name, line);
5510 }
5511 *instr_prev = frame->f_lasti;
5512}
Victor Stinnerf4b1e3d2019-11-04 19:48:34 +01005513
5514
5515/* Implement Py_EnterRecursiveCall() and Py_LeaveRecursiveCall() as functions
5516 for the limited API. */
5517
5518#undef Py_EnterRecursiveCall
5519
5520int Py_EnterRecursiveCall(const char *where)
5521{
Victor Stinnerbe434dc2019-11-05 00:51:22 +01005522 return _Py_EnterRecursiveCall_inline(where);
Victor Stinnerf4b1e3d2019-11-04 19:48:34 +01005523}
5524
5525#undef Py_LeaveRecursiveCall
5526
5527void Py_LeaveRecursiveCall(void)
5528{
Victor Stinnerbe434dc2019-11-05 00:51:22 +01005529 _Py_LeaveRecursiveCall_inline();
Victor Stinnerf4b1e3d2019-11-04 19:48:34 +01005530}