blob: 3bbd0ca9667b0da85fb0ac6a87f4a0f2926d8228 [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 Galindo4c53e632020-01-10 09:24:22 +00003613 if (_Py_TracingPossible(ceval)) {
3614 int needs_new_execution_window = (f->f_lasti < instr_lb || f->f_lasti >= instr_ub);
3615 int needs_line_update = (f->f_lasti == instr_lb || f->f_lasti < instr_prev);
3616 /* Make sure that we trace line after exception if we are in a new execution
3617 * window or we don't need a line update and we are not in the first instruction
3618 * of the line. */
3619 if (needs_new_execution_window || (!needs_line_update && instr_lb > 0)) {
3620 instr_prev = INT_MAX;
3621 }
Mark Shannonfee55262019-11-21 09:11:43 +00003622 }
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003623 /* Resume normal execution */
3624 goto main_loop;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003625 }
3626 } /* unwind stack */
Guido van Rossum374a9221991-04-04 10:40:29 +00003627
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003628 /* End the loop as we still have an error */
3629 break;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003630 } /* main loop */
Guido van Rossumac7be682001-01-17 15:42:30 +00003631
Pablo Galindof00828a2019-05-09 16:52:02 +01003632 assert(retval == NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02003633 assert(_PyErr_Occurred(tstate));
Pablo Galindof00828a2019-05-09 16:52:02 +01003634
3635exit_returning:
3636
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003637 /* Pop remaining stack entries. */
3638 while (!EMPTY()) {
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04003639 PyObject *o = POP();
3640 Py_XDECREF(o);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003641 }
Guido van Rossum35974fb2001-12-06 21:28:18 +00003642
Pablo Galindof00828a2019-05-09 16:52:02 +01003643exit_yielding:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003644 if (tstate->use_tracing) {
Benjamin Peterson51f46162013-01-23 08:38:47 -05003645 if (tstate->c_tracefunc) {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003646 if (call_trace_protected(tstate->c_tracefunc, tstate->c_traceobj,
3647 tstate, f, PyTrace_RETURN, retval)) {
3648 Py_CLEAR(retval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003649 }
3650 }
3651 if (tstate->c_profilefunc) {
Serhiy Storchaka520b7ae2018-02-22 23:33:30 +02003652 if (call_trace_protected(tstate->c_profilefunc, tstate->c_profileobj,
3653 tstate, f, PyTrace_RETURN, retval)) {
Serhiy Storchaka505ff752014-02-09 13:33:53 +02003654 Py_CLEAR(retval);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003655 }
3656 }
3657 }
Guido van Rossuma4240131997-01-21 21:18:36 +00003658
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003659 /* pop frame */
Thomas Woutersce272b62007-09-19 21:19:28 +00003660exit_eval_frame:
Łukasz Langaa785c872016-09-09 17:37:37 -07003661 if (PyDTrace_FUNCTION_RETURN_ENABLED())
3662 dtrace_function_return(f);
Victor Stinnerbe434dc2019-11-05 00:51:22 +01003663 _Py_LeaveRecursiveCall(tstate);
Antoine Pitrou58720d62013-08-05 23:26:40 +02003664 f->f_executing = 0;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003665 tstate->frame = f->f_back;
Guido van Rossumac7be682001-01-17 15:42:30 +00003666
Victor Stinner17269092019-11-05 01:22:12 +01003667 return _Py_CheckFunctionResult(tstate, NULL, retval, "PyEval_EvalFrameEx");
Guido van Rossum374a9221991-04-04 10:40:29 +00003668}
3669
Benjamin Petersonb204a422011-06-05 22:04:07 -05003670static void
Victor Stinner438a12d2019-05-24 17:01:38 +02003671format_missing(PyThreadState *tstate, const char *kind,
3672 PyCodeObject *co, PyObject *names)
Benjamin Petersone109c702011-06-24 09:37:26 -05003673{
3674 int err;
3675 Py_ssize_t len = PyList_GET_SIZE(names);
3676 PyObject *name_str, *comma, *tail, *tmp;
3677
3678 assert(PyList_CheckExact(names));
3679 assert(len >= 1);
3680 /* Deal with the joys of natural language. */
3681 switch (len) {
3682 case 1:
3683 name_str = PyList_GET_ITEM(names, 0);
3684 Py_INCREF(name_str);
3685 break;
3686 case 2:
3687 name_str = PyUnicode_FromFormat("%U and %U",
3688 PyList_GET_ITEM(names, len - 2),
3689 PyList_GET_ITEM(names, len - 1));
3690 break;
3691 default:
3692 tail = PyUnicode_FromFormat(", %U, and %U",
3693 PyList_GET_ITEM(names, len - 2),
3694 PyList_GET_ITEM(names, len - 1));
Benjamin Petersond1ab6082012-06-01 11:18:22 -07003695 if (tail == NULL)
3696 return;
Benjamin Petersone109c702011-06-24 09:37:26 -05003697 /* Chop off the last two objects in the list. This shouldn't actually
3698 fail, but we can't be too careful. */
3699 err = PyList_SetSlice(names, len - 2, len, NULL);
3700 if (err == -1) {
3701 Py_DECREF(tail);
3702 return;
3703 }
3704 /* Stitch everything up into a nice comma-separated list. */
3705 comma = PyUnicode_FromString(", ");
3706 if (comma == NULL) {
3707 Py_DECREF(tail);
3708 return;
3709 }
3710 tmp = PyUnicode_Join(comma, names);
3711 Py_DECREF(comma);
3712 if (tmp == NULL) {
3713 Py_DECREF(tail);
3714 return;
3715 }
3716 name_str = PyUnicode_Concat(tmp, tail);
3717 Py_DECREF(tmp);
3718 Py_DECREF(tail);
3719 break;
3720 }
3721 if (name_str == NULL)
3722 return;
Victor Stinner438a12d2019-05-24 17:01:38 +02003723 _PyErr_Format(tstate, PyExc_TypeError,
3724 "%U() missing %i required %s argument%s: %U",
3725 co->co_name,
3726 len,
3727 kind,
3728 len == 1 ? "" : "s",
3729 name_str);
Benjamin Petersone109c702011-06-24 09:37:26 -05003730 Py_DECREF(name_str);
3731}
3732
3733static void
Victor Stinner438a12d2019-05-24 17:01:38 +02003734missing_arguments(PyThreadState *tstate, PyCodeObject *co,
3735 Py_ssize_t missing, Py_ssize_t defcount,
Benjamin Petersone109c702011-06-24 09:37:26 -05003736 PyObject **fastlocals)
3737{
Victor Stinner74319ae2016-08-25 00:04:09 +02003738 Py_ssize_t i, j = 0;
3739 Py_ssize_t start, end;
3740 int positional = (defcount != -1);
Benjamin Petersone109c702011-06-24 09:37:26 -05003741 const char *kind = positional ? "positional" : "keyword-only";
3742 PyObject *missing_names;
3743
3744 /* Compute the names of the arguments that are missing. */
3745 missing_names = PyList_New(missing);
3746 if (missing_names == NULL)
3747 return;
3748 if (positional) {
3749 start = 0;
Pablo Galindocd74e662019-06-01 18:08:04 +01003750 end = co->co_argcount - defcount;
Benjamin Petersone109c702011-06-24 09:37:26 -05003751 }
3752 else {
Pablo Galindocd74e662019-06-01 18:08:04 +01003753 start = co->co_argcount;
Benjamin Petersone109c702011-06-24 09:37:26 -05003754 end = start + co->co_kwonlyargcount;
3755 }
3756 for (i = start; i < end; i++) {
3757 if (GETLOCAL(i) == NULL) {
3758 PyObject *raw = PyTuple_GET_ITEM(co->co_varnames, i);
3759 PyObject *name = PyObject_Repr(raw);
3760 if (name == NULL) {
3761 Py_DECREF(missing_names);
3762 return;
3763 }
3764 PyList_SET_ITEM(missing_names, j++, name);
3765 }
3766 }
3767 assert(j == missing);
Victor Stinner438a12d2019-05-24 17:01:38 +02003768 format_missing(tstate, kind, co, missing_names);
Benjamin Petersone109c702011-06-24 09:37:26 -05003769 Py_DECREF(missing_names);
3770}
3771
3772static void
Victor Stinner438a12d2019-05-24 17:01:38 +02003773too_many_positional(PyThreadState *tstate, PyCodeObject *co,
3774 Py_ssize_t given, Py_ssize_t defcount,
Victor Stinner74319ae2016-08-25 00:04:09 +02003775 PyObject **fastlocals)
Benjamin Petersonb204a422011-06-05 22:04:07 -05003776{
3777 int plural;
Victor Stinner74319ae2016-08-25 00:04:09 +02003778 Py_ssize_t kwonly_given = 0;
3779 Py_ssize_t i;
Benjamin Petersonb204a422011-06-05 22:04:07 -05003780 PyObject *sig, *kwonly_sig;
Victor Stinner74319ae2016-08-25 00:04:09 +02003781 Py_ssize_t co_argcount = co->co_argcount;
Benjamin Petersonb204a422011-06-05 22:04:07 -05003782
Benjamin Petersone109c702011-06-24 09:37:26 -05003783 assert((co->co_flags & CO_VARARGS) == 0);
3784 /* Count missing keyword-only args. */
Pablo Galindocd74e662019-06-01 18:08:04 +01003785 for (i = co_argcount; i < co_argcount + co->co_kwonlyargcount; i++) {
Victor Stinner74319ae2016-08-25 00:04:09 +02003786 if (GETLOCAL(i) != NULL) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003787 kwonly_given++;
Victor Stinner74319ae2016-08-25 00:04:09 +02003788 }
3789 }
Benjamin Petersone109c702011-06-24 09:37:26 -05003790 if (defcount) {
Pablo Galindocd74e662019-06-01 18:08:04 +01003791 Py_ssize_t atleast = co_argcount - defcount;
Benjamin Petersonb204a422011-06-05 22:04:07 -05003792 plural = 1;
Pablo Galindocd74e662019-06-01 18:08:04 +01003793 sig = PyUnicode_FromFormat("from %zd to %zd", atleast, co_argcount);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003794 }
3795 else {
Pablo Galindocd74e662019-06-01 18:08:04 +01003796 plural = (co_argcount != 1);
3797 sig = PyUnicode_FromFormat("%zd", co_argcount);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003798 }
3799 if (sig == NULL)
3800 return;
3801 if (kwonly_given) {
Victor Stinner74319ae2016-08-25 00:04:09 +02003802 const char *format = " positional argument%s (and %zd keyword-only argument%s)";
3803 kwonly_sig = PyUnicode_FromFormat(format,
3804 given != 1 ? "s" : "",
3805 kwonly_given,
3806 kwonly_given != 1 ? "s" : "");
Benjamin Petersonb204a422011-06-05 22:04:07 -05003807 if (kwonly_sig == NULL) {
3808 Py_DECREF(sig);
3809 return;
3810 }
3811 }
3812 else {
3813 /* This will not fail. */
3814 kwonly_sig = PyUnicode_FromString("");
Benjamin Petersone109c702011-06-24 09:37:26 -05003815 assert(kwonly_sig != NULL);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003816 }
Victor Stinner438a12d2019-05-24 17:01:38 +02003817 _PyErr_Format(tstate, PyExc_TypeError,
3818 "%U() takes %U positional argument%s but %zd%U %s given",
3819 co->co_name,
3820 sig,
3821 plural ? "s" : "",
3822 given,
3823 kwonly_sig,
3824 given == 1 && !kwonly_given ? "was" : "were");
Benjamin Petersonb204a422011-06-05 22:04:07 -05003825 Py_DECREF(sig);
3826 Py_DECREF(kwonly_sig);
3827}
3828
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003829static int
Victor Stinner438a12d2019-05-24 17:01:38 +02003830positional_only_passed_as_keyword(PyThreadState *tstate, PyCodeObject *co,
3831 Py_ssize_t kwcount, PyObject* const* kwnames)
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003832{
3833 int posonly_conflicts = 0;
3834 PyObject* posonly_names = PyList_New(0);
3835
3836 for(int k=0; k < co->co_posonlyargcount; k++){
3837 PyObject* posonly_name = PyTuple_GET_ITEM(co->co_varnames, k);
3838
3839 for (int k2=0; k2<kwcount; k2++){
3840 /* Compare the pointers first and fallback to PyObject_RichCompareBool*/
3841 PyObject* kwname = kwnames[k2];
3842 if (kwname == posonly_name){
3843 if(PyList_Append(posonly_names, kwname) != 0) {
3844 goto fail;
3845 }
3846 posonly_conflicts++;
3847 continue;
3848 }
3849
3850 int cmp = PyObject_RichCompareBool(posonly_name, kwname, Py_EQ);
3851
3852 if ( cmp > 0) {
3853 if(PyList_Append(posonly_names, kwname) != 0) {
3854 goto fail;
3855 }
3856 posonly_conflicts++;
3857 } else if (cmp < 0) {
3858 goto fail;
3859 }
3860
3861 }
3862 }
3863 if (posonly_conflicts) {
3864 PyObject* comma = PyUnicode_FromString(", ");
3865 if (comma == NULL) {
3866 goto fail;
3867 }
3868 PyObject* error_names = PyUnicode_Join(comma, posonly_names);
3869 Py_DECREF(comma);
3870 if (error_names == NULL) {
3871 goto fail;
3872 }
Victor Stinner438a12d2019-05-24 17:01:38 +02003873 _PyErr_Format(tstate, PyExc_TypeError,
3874 "%U() got some positional-only arguments passed"
3875 " as keyword arguments: '%U'",
3876 co->co_name, error_names);
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003877 Py_DECREF(error_names);
3878 goto fail;
3879 }
3880
3881 Py_DECREF(posonly_names);
3882 return 0;
3883
3884fail:
3885 Py_XDECREF(posonly_names);
3886 return 1;
3887
3888}
3889
Guido van Rossumc2e20742006-02-27 22:32:47 +00003890/* This is gonna seem *real weird*, but if you put some other code between
Marcel Plch3a9ccee2018-04-06 23:22:04 +02003891 PyEval_EvalFrame() and _PyEval_EvalFrameDefault() you will need to adjust
Guido van Rossumc2e20742006-02-27 22:32:47 +00003892 the test in the if statements in Misc/gdbinit (pystack and pystackv). */
Skip Montanaro786ea6b2004-03-01 15:44:05 +00003893
Victor Stinnerc22bfaa2017-02-12 19:27:05 +01003894PyObject *
Victor Stinnerb5e170f2019-11-16 01:03:22 +01003895_PyEval_EvalCode(PyThreadState *tstate,
3896 PyObject *_co, PyObject *globals, PyObject *locals,
Serhiy Storchakaa5552f02017-12-15 13:11:11 +02003897 PyObject *const *args, Py_ssize_t argcount,
3898 PyObject *const *kwnames, PyObject *const *kwargs,
Serhiy Storchakab7281052016-09-12 00:52:40 +03003899 Py_ssize_t kwcount, int kwstep,
Serhiy Storchakaa5552f02017-12-15 13:11:11 +02003900 PyObject *const *defs, Py_ssize_t defcount,
Victor Stinner74319ae2016-08-25 00:04:09 +02003901 PyObject *kwdefs, PyObject *closure,
Victor Stinner40ee3012014-06-16 15:59:28 +02003902 PyObject *name, PyObject *qualname)
Tim Peters5ca576e2001-06-18 22:08:13 +00003903{
Victor Stinnerb5e170f2019-11-16 01:03:22 +01003904 assert(tstate != NULL);
3905
Martin v. Löwis4d0d4712010-12-03 20:14:31 +00003906 PyCodeObject* co = (PyCodeObject*)_co;
Antoine Pitrou9ed5f272013-08-13 20:18:52 +02003907 PyFrameObject *f;
3908 PyObject *retval = NULL;
3909 PyObject **fastlocals, **freevars;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003910 PyObject *x, *u;
Pablo Galindocd74e662019-06-01 18:08:04 +01003911 const Py_ssize_t total_args = co->co_argcount + co->co_kwonlyargcount;
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003912 Py_ssize_t i, j, n;
Victor Stinnerc7020012016-08-16 23:40:29 +02003913 PyObject *kwdict;
Tim Peters5ca576e2001-06-18 22:08:13 +00003914
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003915 if (globals == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02003916 _PyErr_SetString(tstate, PyExc_SystemError,
3917 "PyEval_EvalCodeEx: NULL globals");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003918 return NULL;
3919 }
Tim Peters5ca576e2001-06-18 22:08:13 +00003920
Victor Stinnerc7020012016-08-16 23:40:29 +02003921 /* Create the frame */
INADA Naoki5a625d02016-12-24 20:19:08 +09003922 f = _PyFrame_New_NoTrack(tstate, co, globals, locals);
Victor Stinnerc7020012016-08-16 23:40:29 +02003923 if (f == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003924 return NULL;
Victor Stinnerc7020012016-08-16 23:40:29 +02003925 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003926 fastlocals = f->f_localsplus;
3927 freevars = f->f_localsplus + co->co_nlocals;
Tim Peters5ca576e2001-06-18 22:08:13 +00003928
Victor Stinnerc7020012016-08-16 23:40:29 +02003929 /* Create a dictionary for keyword parameters (**kwags) */
Benjamin Petersonb204a422011-06-05 22:04:07 -05003930 if (co->co_flags & CO_VARKEYWORDS) {
3931 kwdict = PyDict_New();
3932 if (kwdict == NULL)
3933 goto fail;
3934 i = total_args;
Victor Stinnerc7020012016-08-16 23:40:29 +02003935 if (co->co_flags & CO_VARARGS) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003936 i++;
Victor Stinnerc7020012016-08-16 23:40:29 +02003937 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05003938 SETLOCAL(i, kwdict);
3939 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003940 else {
3941 kwdict = NULL;
3942 }
3943
Pablo Galindocd74e662019-06-01 18:08:04 +01003944 /* Copy all positional arguments into local variables */
3945 if (argcount > co->co_argcount) {
3946 n = co->co_argcount;
Victor Stinnerc7020012016-08-16 23:40:29 +02003947 }
3948 else {
3949 n = argcount;
3950 }
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003951 for (j = 0; j < n; j++) {
3952 x = args[j];
3953 Py_INCREF(x);
3954 SETLOCAL(j, x);
3955 }
3956
Victor Stinnerc7020012016-08-16 23:40:29 +02003957 /* Pack other positional arguments into the *args argument */
Benjamin Petersonb204a422011-06-05 22:04:07 -05003958 if (co->co_flags & CO_VARARGS) {
Sergey Fedoseev234531b2019-02-25 21:59:12 +05003959 u = _PyTuple_FromArray(args + n, argcount - n);
Victor Stinnerc7020012016-08-16 23:40:29 +02003960 if (u == NULL) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003961 goto fail;
Victor Stinnerc7020012016-08-16 23:40:29 +02003962 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05003963 SETLOCAL(total_args, u);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003964 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003965
Serhiy Storchakab7281052016-09-12 00:52:40 +03003966 /* Handle keyword arguments passed as two strided arrays */
3967 kwcount *= kwstep;
3968 for (i = 0; i < kwcount; i += kwstep) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003969 PyObject **co_varnames;
Serhiy Storchakab7281052016-09-12 00:52:40 +03003970 PyObject *keyword = kwnames[i];
3971 PyObject *value = kwargs[i];
Victor Stinner17061a92016-08-16 23:39:42 +02003972 Py_ssize_t j;
Victor Stinnerc7020012016-08-16 23:40:29 +02003973
Benjamin Petersonb204a422011-06-05 22:04:07 -05003974 if (keyword == NULL || !PyUnicode_Check(keyword)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02003975 _PyErr_Format(tstate, PyExc_TypeError,
3976 "%U() keywords must be strings",
3977 co->co_name);
Benjamin Petersonb204a422011-06-05 22:04:07 -05003978 goto fail;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003979 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003980
Benjamin Petersonb204a422011-06-05 22:04:07 -05003981 /* Speed hack: do raw pointer compares. As names are
3982 normally interned this should almost always hit. */
3983 co_varnames = ((PyTupleObject *)(co->co_varnames))->ob_item;
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003984 for (j = co->co_posonlyargcount; j < total_args; j++) {
Victor Stinner6fea7f72016-08-22 23:17:30 +02003985 PyObject *name = co_varnames[j];
3986 if (name == keyword) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003987 goto kw_found;
Victor Stinner6fea7f72016-08-22 23:17:30 +02003988 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05003989 }
Victor Stinnerc7020012016-08-16 23:40:29 +02003990
Benjamin Petersonb204a422011-06-05 22:04:07 -05003991 /* Slow fallback, just in case */
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01003992 for (j = co->co_posonlyargcount; j < total_args; j++) {
Victor Stinner6fea7f72016-08-22 23:17:30 +02003993 PyObject *name = co_varnames[j];
3994 int cmp = PyObject_RichCompareBool( keyword, name, Py_EQ);
3995 if (cmp > 0) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05003996 goto kw_found;
Victor Stinner6fea7f72016-08-22 23:17:30 +02003997 }
3998 else if (cmp < 0) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00003999 goto fail;
Victor Stinner6fea7f72016-08-22 23:17:30 +02004000 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05004001 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004002
Victor Stinner231d1f32017-01-11 02:12:06 +01004003 assert(j >= total_args);
4004 if (kwdict == NULL) {
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01004005
Victor Stinner438a12d2019-05-24 17:01:38 +02004006 if (co->co_posonlyargcount
4007 && positional_only_passed_as_keyword(tstate, co,
4008 kwcount, kwnames))
4009 {
Pablo Galindo8c77b8c2019-04-29 13:36:57 +01004010 goto fail;
4011 }
4012
Victor Stinner438a12d2019-05-24 17:01:38 +02004013 _PyErr_Format(tstate, PyExc_TypeError,
4014 "%U() got an unexpected keyword argument '%S'",
4015 co->co_name, keyword);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004016 goto fail;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004017 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004018
Christian Heimes0bd447f2013-07-20 14:48:10 +02004019 if (PyDict_SetItem(kwdict, keyword, value) == -1) {
4020 goto fail;
4021 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05004022 continue;
Victor Stinnerc7020012016-08-16 23:40:29 +02004023
Benjamin Petersonb204a422011-06-05 22:04:07 -05004024 kw_found:
4025 if (GETLOCAL(j) != NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004026 _PyErr_Format(tstate, PyExc_TypeError,
4027 "%U() got multiple values for argument '%S'",
4028 co->co_name, keyword);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004029 goto fail;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004030 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05004031 Py_INCREF(value);
4032 SETLOCAL(j, value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004033 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004034
4035 /* Check the number of positional arguments */
Pablo Galindocd74e662019-06-01 18:08:04 +01004036 if ((argcount > co->co_argcount) && !(co->co_flags & CO_VARARGS)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004037 too_many_positional(tstate, co, argcount, defcount, fastlocals);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004038 goto fail;
4039 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004040
4041 /* Add missing positional arguments (copy default values from defs) */
Pablo Galindocd74e662019-06-01 18:08:04 +01004042 if (argcount < co->co_argcount) {
4043 Py_ssize_t m = co->co_argcount - defcount;
Victor Stinner17061a92016-08-16 23:39:42 +02004044 Py_ssize_t missing = 0;
4045 for (i = argcount; i < m; i++) {
4046 if (GETLOCAL(i) == NULL) {
Benjamin Petersone109c702011-06-24 09:37:26 -05004047 missing++;
Victor Stinner17061a92016-08-16 23:39:42 +02004048 }
4049 }
Benjamin Petersone109c702011-06-24 09:37:26 -05004050 if (missing) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004051 missing_arguments(tstate, co, missing, defcount, fastlocals);
Benjamin Petersone109c702011-06-24 09:37:26 -05004052 goto fail;
Benjamin Petersonb204a422011-06-05 22:04:07 -05004053 }
4054 if (n > m)
4055 i = n - m;
4056 else
4057 i = 0;
4058 for (; i < defcount; i++) {
4059 if (GETLOCAL(m+i) == NULL) {
4060 PyObject *def = defs[i];
4061 Py_INCREF(def);
4062 SETLOCAL(m+i, def);
4063 }
4064 }
4065 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004066
4067 /* Add missing keyword arguments (copy default values from kwdefs) */
Benjamin Petersonb204a422011-06-05 22:04:07 -05004068 if (co->co_kwonlyargcount > 0) {
Victor Stinner17061a92016-08-16 23:39:42 +02004069 Py_ssize_t missing = 0;
Pablo Galindocd74e662019-06-01 18:08:04 +01004070 for (i = co->co_argcount; i < total_args; i++) {
Benjamin Petersonb204a422011-06-05 22:04:07 -05004071 PyObject *name;
4072 if (GETLOCAL(i) != NULL)
4073 continue;
4074 name = PyTuple_GET_ITEM(co->co_varnames, i);
4075 if (kwdefs != NULL) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02004076 PyObject *def = PyDict_GetItemWithError(kwdefs, name);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004077 if (def) {
4078 Py_INCREF(def);
4079 SETLOCAL(i, def);
4080 continue;
4081 }
Victor Stinner438a12d2019-05-24 17:01:38 +02004082 else if (_PyErr_Occurred(tstate)) {
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02004083 goto fail;
4084 }
Benjamin Petersonb204a422011-06-05 22:04:07 -05004085 }
Benjamin Petersone109c702011-06-24 09:37:26 -05004086 missing++;
4087 }
4088 if (missing) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004089 missing_arguments(tstate, co, missing, -1, fastlocals);
Benjamin Petersonb204a422011-06-05 22:04:07 -05004090 goto fail;
4091 }
4092 }
4093
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004094 /* Allocate and initialize storage for cell vars, and copy free
Benjamin Peterson90037602011-06-25 22:54:45 -05004095 vars into frame. */
4096 for (i = 0; i < PyTuple_GET_SIZE(co->co_cellvars); ++i) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004097 PyObject *c;
Serhiy Storchaka5bb8b912016-12-16 19:19:02 +02004098 Py_ssize_t arg;
Benjamin Peterson90037602011-06-25 22:54:45 -05004099 /* Possibly account for the cell variable being an argument. */
4100 if (co->co_cell2arg != NULL &&
Guido van Rossum6832c812013-05-10 08:47:42 -07004101 (arg = co->co_cell2arg[i]) != CO_CELL_NOT_AN_ARG) {
Benjamin Peterson90037602011-06-25 22:54:45 -05004102 c = PyCell_New(GETLOCAL(arg));
Benjamin Peterson159ae412013-05-12 18:16:06 -05004103 /* Clear the local copy. */
4104 SETLOCAL(arg, NULL);
Guido van Rossum6832c812013-05-10 08:47:42 -07004105 }
4106 else {
Benjamin Peterson90037602011-06-25 22:54:45 -05004107 c = PyCell_New(NULL);
Guido van Rossum6832c812013-05-10 08:47:42 -07004108 }
Benjamin Peterson159ae412013-05-12 18:16:06 -05004109 if (c == NULL)
4110 goto fail;
Benjamin Peterson90037602011-06-25 22:54:45 -05004111 SETLOCAL(co->co_nlocals + i, c);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004112 }
Victor Stinnerc7020012016-08-16 23:40:29 +02004113
4114 /* Copy closure variables to free variables */
Benjamin Peterson90037602011-06-25 22:54:45 -05004115 for (i = 0; i < PyTuple_GET_SIZE(co->co_freevars); ++i) {
4116 PyObject *o = PyTuple_GET_ITEM(closure, i);
4117 Py_INCREF(o);
4118 freevars[PyTuple_GET_SIZE(co->co_cellvars) + i] = o;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004119 }
Tim Peters5ca576e2001-06-18 22:08:13 +00004120
Yury Selivanoveb636452016-09-08 22:01:51 -07004121 /* Handle generator/coroutine/asynchronous generator */
4122 if (co->co_flags & (CO_GENERATOR | CO_COROUTINE | CO_ASYNC_GENERATOR)) {
Yury Selivanov75445082015-05-11 22:57:16 -04004123 PyObject *gen;
Yury Selivanov5376ba92015-06-22 12:19:30 -04004124 int is_coro = co->co_flags & CO_COROUTINE;
Yury Selivanov94c22632015-06-04 10:16:51 -04004125
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004126 /* Don't need to keep the reference to f_back, it will be set
4127 * when the generator is resumed. */
Serhiy Storchaka505ff752014-02-09 13:33:53 +02004128 Py_CLEAR(f->f_back);
Neil Schemenauer2b13ce82001-06-21 02:41:10 +00004129
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004130 /* Create a new generator that owns the ready to run frame
4131 * and return that as the value. */
Yury Selivanov5376ba92015-06-22 12:19:30 -04004132 if (is_coro) {
4133 gen = PyCoro_New(f, name, qualname);
Yury Selivanoveb636452016-09-08 22:01:51 -07004134 } else if (co->co_flags & CO_ASYNC_GENERATOR) {
4135 gen = PyAsyncGen_New(f, name, qualname);
Yury Selivanov5376ba92015-06-22 12:19:30 -04004136 } else {
4137 gen = PyGen_NewWithQualName(f, name, qualname);
4138 }
INADA Naoki6a3cedf2016-12-26 18:01:46 +09004139 if (gen == NULL) {
Yury Selivanov75445082015-05-11 22:57:16 -04004140 return NULL;
INADA Naoki6a3cedf2016-12-26 18:01:46 +09004141 }
INADA Naoki9c157762016-12-26 18:52:46 +09004142
INADA Naoki6a3cedf2016-12-26 18:01:46 +09004143 _PyObject_GC_TRACK(f);
Yury Selivanov75445082015-05-11 22:57:16 -04004144
Yury Selivanov75445082015-05-11 22:57:16 -04004145 return gen;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004146 }
Tim Peters5ca576e2001-06-18 22:08:13 +00004147
Victor Stinnerb9e68122019-11-14 12:20:46 +01004148 retval = _PyEval_EvalFrame(tstate, f, 0);
Tim Peters5ca576e2001-06-18 22:08:13 +00004149
Thomas Woutersce272b62007-09-19 21:19:28 +00004150fail: /* Jump here from prelude on failure */
Tim Peters5ca576e2001-06-18 22:08:13 +00004151
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004152 /* decref'ing the frame can cause __del__ methods to get invoked,
4153 which can call back into Python. While we're done with the
4154 current Python frame (f), the associated C stack is still in use,
4155 so recursion_depth must be boosted for the duration.
4156 */
INADA Naoki5a625d02016-12-24 20:19:08 +09004157 if (Py_REFCNT(f) > 1) {
4158 Py_DECREF(f);
4159 _PyObject_GC_TRACK(f);
4160 }
4161 else {
4162 ++tstate->recursion_depth;
4163 Py_DECREF(f);
4164 --tstate->recursion_depth;
4165 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004166 return retval;
Tim Peters5ca576e2001-06-18 22:08:13 +00004167}
4168
Victor Stinnerb5e170f2019-11-16 01:03:22 +01004169
4170PyObject *
4171_PyEval_EvalCodeWithName(PyObject *_co, PyObject *globals, PyObject *locals,
4172 PyObject *const *args, Py_ssize_t argcount,
4173 PyObject *const *kwnames, PyObject *const *kwargs,
4174 Py_ssize_t kwcount, int kwstep,
4175 PyObject *const *defs, Py_ssize_t defcount,
4176 PyObject *kwdefs, PyObject *closure,
4177 PyObject *name, PyObject *qualname)
4178{
4179 PyThreadState *tstate = _PyThreadState_GET();
4180 return _PyEval_EvalCode(tstate, _co, globals, locals,
4181 args, argcount,
4182 kwnames, kwargs,
4183 kwcount, kwstep,
4184 defs, defcount,
4185 kwdefs, closure,
4186 name, qualname);
4187}
4188
Victor Stinner40ee3012014-06-16 15:59:28 +02004189PyObject *
4190PyEval_EvalCodeEx(PyObject *_co, PyObject *globals, PyObject *locals,
Serhiy Storchakaa5552f02017-12-15 13:11:11 +02004191 PyObject *const *args, int argcount,
4192 PyObject *const *kws, int kwcount,
4193 PyObject *const *defs, int defcount,
4194 PyObject *kwdefs, PyObject *closure)
Victor Stinner40ee3012014-06-16 15:59:28 +02004195{
4196 return _PyEval_EvalCodeWithName(_co, globals, locals,
Victor Stinner9be7e7b2016-08-19 16:11:43 +02004197 args, argcount,
Zackery Spytzc6ea8972017-07-31 08:24:37 -06004198 kws, kws != NULL ? kws + 1 : NULL,
4199 kwcount, 2,
Victor Stinner9be7e7b2016-08-19 16:11:43 +02004200 defs, defcount,
4201 kwdefs, closure,
Victor Stinner40ee3012014-06-16 15:59:28 +02004202 NULL, NULL);
4203}
Tim Peters5ca576e2001-06-18 22:08:13 +00004204
Benjamin Peterson876b2f22009-06-28 03:18:59 +00004205static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02004206special_lookup(PyThreadState *tstate, PyObject *o, _Py_Identifier *id)
Benjamin Peterson876b2f22009-06-28 03:18:59 +00004207{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004208 PyObject *res;
Benjamin Petersonce798522012-01-22 11:24:29 -05004209 res = _PyObject_LookupSpecial(o, id);
Victor Stinner438a12d2019-05-24 17:01:38 +02004210 if (res == NULL && !_PyErr_Occurred(tstate)) {
4211 _PyErr_SetObject(tstate, PyExc_AttributeError, id->object);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004212 return NULL;
4213 }
4214 return res;
Benjamin Peterson876b2f22009-06-28 03:18:59 +00004215}
4216
4217
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004218/* Logic for the raise statement (too complicated for inlining).
4219 This *consumes* a reference count to each of its arguments. */
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004220static int
Victor Stinner09532fe2019-05-10 23:39:09 +02004221do_raise(PyThreadState *tstate, PyObject *exc, PyObject *cause)
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004222{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004223 PyObject *type = NULL, *value = NULL;
Collin Winter828f04a2007-08-31 00:04:24 +00004224
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004225 if (exc == NULL) {
4226 /* Reraise */
Mark Shannonae3087c2017-10-22 22:41:51 +01004227 _PyErr_StackItem *exc_info = _PyErr_GetTopmostException(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004228 PyObject *tb;
Mark Shannonae3087c2017-10-22 22:41:51 +01004229 type = exc_info->exc_type;
4230 value = exc_info->exc_value;
4231 tb = exc_info->exc_traceback;
Victor Stinnereec93312016-08-18 18:13:10 +02004232 if (type == Py_None || type == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004233 _PyErr_SetString(tstate, PyExc_RuntimeError,
4234 "No active exception to reraise");
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004235 return 0;
4236 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004237 Py_XINCREF(type);
4238 Py_XINCREF(value);
4239 Py_XINCREF(tb);
Victor Stinner438a12d2019-05-24 17:01:38 +02004240 _PyErr_Restore(tstate, type, value, tb);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004241 return 1;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004242 }
Guido van Rossumac7be682001-01-17 15:42:30 +00004243
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004244 /* We support the following forms of raise:
4245 raise
Collin Winter828f04a2007-08-31 00:04:24 +00004246 raise <instance>
4247 raise <type> */
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004248
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004249 if (PyExceptionClass_Check(exc)) {
4250 type = exc;
Victor Stinnera5ed5f02016-12-06 18:45:50 +01004251 value = _PyObject_CallNoArg(exc);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004252 if (value == NULL)
4253 goto raise_error;
Benjamin Peterson5afa03a2011-07-15 14:09:26 -05004254 if (!PyExceptionInstance_Check(value)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004255 _PyErr_Format(tstate, PyExc_TypeError,
4256 "calling %R should have returned an instance of "
4257 "BaseException, not %R",
4258 type, Py_TYPE(value));
4259 goto raise_error;
Benjamin Peterson5afa03a2011-07-15 14:09:26 -05004260 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004261 }
4262 else if (PyExceptionInstance_Check(exc)) {
4263 value = exc;
4264 type = PyExceptionInstance_Class(exc);
4265 Py_INCREF(type);
4266 }
4267 else {
4268 /* Not something you can raise. You get an exception
4269 anyway, just not what you specified :-) */
4270 Py_DECREF(exc);
Victor Stinner438a12d2019-05-24 17:01:38 +02004271 _PyErr_SetString(tstate, PyExc_TypeError,
4272 "exceptions must derive from BaseException");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004273 goto raise_error;
4274 }
Collin Winter828f04a2007-08-31 00:04:24 +00004275
Serhiy Storchakac0191582016-09-27 11:37:10 +03004276 assert(type != NULL);
4277 assert(value != NULL);
4278
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004279 if (cause) {
4280 PyObject *fixed_cause;
4281 if (PyExceptionClass_Check(cause)) {
Victor Stinnera5ed5f02016-12-06 18:45:50 +01004282 fixed_cause = _PyObject_CallNoArg(cause);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004283 if (fixed_cause == NULL)
4284 goto raise_error;
Benjamin Petersond5a1c442012-05-14 22:09:31 -07004285 Py_DECREF(cause);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004286 }
Benjamin Petersond5a1c442012-05-14 22:09:31 -07004287 else if (PyExceptionInstance_Check(cause)) {
4288 fixed_cause = cause;
4289 }
4290 else if (cause == Py_None) {
4291 Py_DECREF(cause);
4292 fixed_cause = NULL;
4293 }
4294 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004295 _PyErr_SetString(tstate, PyExc_TypeError,
4296 "exception causes must derive from "
4297 "BaseException");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004298 goto raise_error;
4299 }
Benjamin Petersond5a1c442012-05-14 22:09:31 -07004300 PyException_SetCause(value, fixed_cause);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004301 }
Collin Winter828f04a2007-08-31 00:04:24 +00004302
Victor Stinner438a12d2019-05-24 17:01:38 +02004303 _PyErr_SetObject(tstate, type, value);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004304 /* PyErr_SetObject incref's its arguments */
Serhiy Storchakac0191582016-09-27 11:37:10 +03004305 Py_DECREF(value);
4306 Py_DECREF(type);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004307 return 0;
Collin Winter828f04a2007-08-31 00:04:24 +00004308
4309raise_error:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004310 Py_XDECREF(value);
4311 Py_XDECREF(type);
4312 Py_XDECREF(cause);
Benjamin Peterson31a58ff2012-10-12 11:34:51 -04004313 return 0;
Guido van Rossum0aa9ee61996-12-10 18:07:35 +00004314}
4315
Tim Petersd6d010b2001-06-21 02:49:55 +00004316/* Iterate v argcnt times and store the results on the stack (via decreasing
Guido van Rossum0368b722007-05-11 16:50:42 +00004317 sp). Return 1 for success, 0 if error.
Antoine Pitrou9a2310d2008-07-25 22:39:39 +00004318
Guido van Rossum0368b722007-05-11 16:50:42 +00004319 If argcntafter == -1, do a simple unpack. If it is >= 0, do an unpack
4320 with a variable target.
4321*/
Tim Petersd6d010b2001-06-21 02:49:55 +00004322
Barry Warsawe42b18f1997-08-25 22:13:04 +00004323static int
Victor Stinner438a12d2019-05-24 17:01:38 +02004324unpack_iterable(PyThreadState *tstate, PyObject *v,
4325 int argcnt, int argcntafter, PyObject **sp)
Barry Warsawe42b18f1997-08-25 22:13:04 +00004326{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004327 int i = 0, j = 0;
4328 Py_ssize_t ll = 0;
4329 PyObject *it; /* iter(v) */
4330 PyObject *w;
4331 PyObject *l = NULL; /* variable list */
Guido van Rossumac7be682001-01-17 15:42:30 +00004332
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004333 assert(v != NULL);
Tim Petersd6d010b2001-06-21 02:49:55 +00004334
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004335 it = PyObject_GetIter(v);
Serhiy Storchaka13a6c092017-12-26 12:30:41 +02004336 if (it == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004337 if (_PyErr_ExceptionMatches(tstate, PyExc_TypeError) &&
Serhiy Storchaka13a6c092017-12-26 12:30:41 +02004338 v->ob_type->tp_iter == NULL && !PySequence_Check(v))
4339 {
Victor Stinner438a12d2019-05-24 17:01:38 +02004340 _PyErr_Format(tstate, PyExc_TypeError,
4341 "cannot unpack non-iterable %.200s object",
4342 v->ob_type->tp_name);
Serhiy Storchaka13a6c092017-12-26 12:30:41 +02004343 }
4344 return 0;
4345 }
Tim Petersd6d010b2001-06-21 02:49:55 +00004346
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004347 for (; i < argcnt; i++) {
4348 w = PyIter_Next(it);
4349 if (w == NULL) {
4350 /* Iterator done, via error or exhaustion. */
Victor Stinner438a12d2019-05-24 17:01:38 +02004351 if (!_PyErr_Occurred(tstate)) {
R David Murray4171bbe2015-04-15 17:08:45 -04004352 if (argcntafter == -1) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004353 _PyErr_Format(tstate, PyExc_ValueError,
4354 "not enough values to unpack "
4355 "(expected %d, got %d)",
4356 argcnt, i);
R David Murray4171bbe2015-04-15 17:08:45 -04004357 }
4358 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004359 _PyErr_Format(tstate, PyExc_ValueError,
4360 "not enough values to unpack "
4361 "(expected at least %d, got %d)",
4362 argcnt + argcntafter, i);
R David Murray4171bbe2015-04-15 17:08:45 -04004363 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004364 }
4365 goto Error;
4366 }
4367 *--sp = w;
4368 }
Tim Petersd6d010b2001-06-21 02:49:55 +00004369
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004370 if (argcntafter == -1) {
4371 /* We better have exhausted the iterator now. */
4372 w = PyIter_Next(it);
4373 if (w == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004374 if (_PyErr_Occurred(tstate))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004375 goto Error;
4376 Py_DECREF(it);
4377 return 1;
4378 }
4379 Py_DECREF(w);
Victor Stinner438a12d2019-05-24 17:01:38 +02004380 _PyErr_Format(tstate, PyExc_ValueError,
4381 "too many values to unpack (expected %d)",
4382 argcnt);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004383 goto Error;
4384 }
Guido van Rossum0368b722007-05-11 16:50:42 +00004385
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004386 l = PySequence_List(it);
4387 if (l == NULL)
4388 goto Error;
4389 *--sp = l;
4390 i++;
Guido van Rossum0368b722007-05-11 16:50:42 +00004391
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004392 ll = PyList_GET_SIZE(l);
4393 if (ll < argcntafter) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004394 _PyErr_Format(tstate, PyExc_ValueError,
R David Murray4171bbe2015-04-15 17:08:45 -04004395 "not enough values to unpack (expected at least %d, got %zd)",
4396 argcnt + argcntafter, argcnt + ll);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004397 goto Error;
4398 }
Guido van Rossum0368b722007-05-11 16:50:42 +00004399
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004400 /* Pop the "after-variable" args off the list. */
4401 for (j = argcntafter; j > 0; j--, i++) {
4402 *--sp = PyList_GET_ITEM(l, ll - j);
4403 }
4404 /* Resize the list. */
4405 Py_SIZE(l) = ll - argcntafter;
4406 Py_DECREF(it);
4407 return 1;
Guido van Rossum0368b722007-05-11 16:50:42 +00004408
Tim Petersd6d010b2001-06-21 02:49:55 +00004409Error:
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004410 for (; i > 0; i--, sp++)
4411 Py_DECREF(*sp);
4412 Py_XDECREF(it);
4413 return 0;
Barry Warsawe42b18f1997-08-25 22:13:04 +00004414}
4415
4416
Guido van Rossum96a42c81992-01-12 02:29:51 +00004417#ifdef LLTRACE
Guido van Rossum3f5da241990-12-20 15:06:42 +00004418static int
Victor Stinner438a12d2019-05-24 17:01:38 +02004419prtrace(PyThreadState *tstate, PyObject *v, const char *str)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004420{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004421 printf("%s ", str);
Victor Stinner438a12d2019-05-24 17:01:38 +02004422 if (PyObject_Print(v, stdout, 0) != 0) {
4423 /* Don't know what else to do */
4424 _PyErr_Clear(tstate);
4425 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004426 printf("\n");
4427 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004428}
Guido van Rossum3f5da241990-12-20 15:06:42 +00004429#endif
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004430
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004431static void
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004432call_exc_trace(Py_tracefunc func, PyObject *self,
4433 PyThreadState *tstate, PyFrameObject *f)
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004434{
Victor Stinneraaa8ed82013-07-10 13:57:55 +02004435 PyObject *type, *value, *traceback, *orig_traceback, *arg;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004436 int err;
Victor Stinner438a12d2019-05-24 17:01:38 +02004437 _PyErr_Fetch(tstate, &type, &value, &orig_traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004438 if (value == NULL) {
4439 value = Py_None;
4440 Py_INCREF(value);
4441 }
Victor Stinner438a12d2019-05-24 17:01:38 +02004442 _PyErr_NormalizeException(tstate, &type, &value, &orig_traceback);
Antoine Pitrou89335212013-11-23 14:05:23 +01004443 traceback = (orig_traceback != NULL) ? orig_traceback : Py_None;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004444 arg = PyTuple_Pack(3, type, value, traceback);
4445 if (arg == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004446 _PyErr_Restore(tstate, type, value, orig_traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004447 return;
4448 }
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004449 err = call_trace(func, self, tstate, f, PyTrace_EXCEPTION, arg);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004450 Py_DECREF(arg);
Victor Stinner438a12d2019-05-24 17:01:38 +02004451 if (err == 0) {
4452 _PyErr_Restore(tstate, type, value, orig_traceback);
4453 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004454 else {
4455 Py_XDECREF(type);
4456 Py_XDECREF(value);
Victor Stinneraaa8ed82013-07-10 13:57:55 +02004457 Py_XDECREF(orig_traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004458 }
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004459}
4460
Amaury Forgeot d'Arcf05149a2007-11-13 01:05:30 +00004461static int
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004462call_trace_protected(Py_tracefunc func, PyObject *obj,
4463 PyThreadState *tstate, PyFrameObject *frame,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004464 int what, PyObject *arg)
Fred Drake4ec5d562001-10-04 19:26:43 +00004465{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004466 PyObject *type, *value, *traceback;
4467 int err;
Victor Stinner438a12d2019-05-24 17:01:38 +02004468 _PyErr_Fetch(tstate, &type, &value, &traceback);
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004469 err = call_trace(func, obj, tstate, frame, what, arg);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004470 if (err == 0)
4471 {
Victor Stinner438a12d2019-05-24 17:01:38 +02004472 _PyErr_Restore(tstate, type, value, traceback);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004473 return 0;
4474 }
4475 else {
4476 Py_XDECREF(type);
4477 Py_XDECREF(value);
4478 Py_XDECREF(traceback);
4479 return -1;
4480 }
Fred Drake4ec5d562001-10-04 19:26:43 +00004481}
4482
Guido van Rossum9c8d70d1992-03-23 18:19:28 +00004483static int
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004484call_trace(Py_tracefunc func, PyObject *obj,
4485 PyThreadState *tstate, PyFrameObject *frame,
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004486 int what, PyObject *arg)
Guido van Rossum96a42c81992-01-12 02:29:51 +00004487{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004488 int result;
4489 if (tstate->tracing)
4490 return 0;
4491 tstate->tracing++;
4492 tstate->use_tracing = 0;
4493 result = func(obj, frame, what, arg);
4494 tstate->use_tracing = ((tstate->c_tracefunc != NULL)
4495 || (tstate->c_profilefunc != NULL));
4496 tstate->tracing--;
4497 return result;
Guido van Rossum96a42c81992-01-12 02:29:51 +00004498}
4499
Guido van Rossuma12fe4e2003-04-09 19:06:21 +00004500PyObject *
4501_PyEval_CallTracing(PyObject *func, PyObject *args)
4502{
Victor Stinner50b48572018-11-01 01:51:40 +01004503 PyThreadState *tstate = _PyThreadState_GET();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004504 int save_tracing = tstate->tracing;
4505 int save_use_tracing = tstate->use_tracing;
4506 PyObject *result;
Guido van Rossuma12fe4e2003-04-09 19:06:21 +00004507
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004508 tstate->tracing = 0;
4509 tstate->use_tracing = ((tstate->c_tracefunc != NULL)
4510 || (tstate->c_profilefunc != NULL));
4511 result = PyObject_Call(func, args, NULL);
4512 tstate->tracing = save_tracing;
4513 tstate->use_tracing = save_use_tracing;
4514 return result;
Guido van Rossuma12fe4e2003-04-09 19:06:21 +00004515}
4516
Alexandre Vassalotti7b82b402009-07-21 04:30:03 +00004517/* See Objects/lnotab_notes.txt for a description of how tracing works. */
Michael W. Hudson006c7522002-11-08 13:08:46 +00004518static int
Tim Peters8a5c3c72004-04-05 19:36:21 +00004519maybe_call_line_trace(Py_tracefunc func, PyObject *obj,
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004520 PyThreadState *tstate, PyFrameObject *frame,
4521 int *instr_lb, int *instr_ub, int *instr_prev)
Michael W. Hudsondd32a912002-08-15 14:59:02 +00004522{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004523 int result = 0;
4524 int line = frame->f_lineno;
Michael W. Hudson006c7522002-11-08 13:08:46 +00004525
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004526 /* If the last instruction executed isn't in the current
4527 instruction window, reset the window.
4528 */
4529 if (frame->f_lasti < *instr_lb || frame->f_lasti >= *instr_ub) {
4530 PyAddrPair bounds;
4531 line = _PyCode_CheckLineNumber(frame->f_code, frame->f_lasti,
4532 &bounds);
4533 *instr_lb = bounds.ap_lower;
4534 *instr_ub = bounds.ap_upper;
4535 }
Nick Coghlan5a851672017-09-08 10:14:16 +10004536 /* If the last instruction falls at the start of a line or if it
4537 represents a jump backwards, update the frame's line number and
4538 then call the trace function if we're tracing source lines.
4539 */
4540 if ((frame->f_lasti == *instr_lb || frame->f_lasti < *instr_prev)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004541 frame->f_lineno = line;
Nick Coghlan5a851672017-09-08 10:14:16 +10004542 if (frame->f_trace_lines) {
4543 result = call_trace(func, obj, tstate, frame, PyTrace_LINE, Py_None);
4544 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004545 }
George King20faa682017-10-18 17:44:22 -07004546 /* Always emit an opcode event if we're tracing all opcodes. */
4547 if (frame->f_trace_opcodes) {
4548 result = call_trace(func, obj, tstate, frame, PyTrace_OPCODE, Py_None);
4549 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004550 *instr_prev = frame->f_lasti;
4551 return result;
Michael W. Hudsondd32a912002-08-15 14:59:02 +00004552}
4553
Fred Drake5755ce62001-06-27 19:19:46 +00004554void
4555PyEval_SetProfile(Py_tracefunc func, PyObject *arg)
Fred Draked0838392001-06-16 21:02:31 +00004556{
Steve Dowerb82e17e2019-05-23 08:45:22 -07004557 if (PySys_Audit("sys.setprofile", NULL) < 0) {
4558 return;
4559 }
4560
Victor Stinner50b48572018-11-01 01:51:40 +01004561 PyThreadState *tstate = _PyThreadState_GET();
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004562 PyObject *temp = tstate->c_profileobj;
4563 Py_XINCREF(arg);
4564 tstate->c_profilefunc = NULL;
4565 tstate->c_profileobj = NULL;
4566 /* Must make sure that tracing is not ignored if 'temp' is freed */
4567 tstate->use_tracing = tstate->c_tracefunc != NULL;
4568 Py_XDECREF(temp);
4569 tstate->c_profilefunc = func;
4570 tstate->c_profileobj = arg;
4571 /* Flag that tracing or profiling is turned on */
4572 tstate->use_tracing = (func != NULL) || (tstate->c_tracefunc != NULL);
Fred Drake5755ce62001-06-27 19:19:46 +00004573}
4574
4575void
4576PyEval_SetTrace(Py_tracefunc func, PyObject *arg)
4577{
Steve Dowerb82e17e2019-05-23 08:45:22 -07004578 if (PySys_Audit("sys.settrace", NULL) < 0) {
4579 return;
4580 }
4581
Victor Stinner09532fe2019-05-10 23:39:09 +02004582 _PyRuntimeState *runtime = &_PyRuntime;
4583 PyThreadState *tstate = _PyRuntimeState_GetThreadState(runtime);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004584 PyObject *temp = tstate->c_traceobj;
Victor Stinner09532fe2019-05-10 23:39:09 +02004585 runtime->ceval.tracing_possible += (func != NULL) - (tstate->c_tracefunc != NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004586 Py_XINCREF(arg);
4587 tstate->c_tracefunc = NULL;
4588 tstate->c_traceobj = NULL;
4589 /* Must make sure that profiling is not ignored if 'temp' is freed */
4590 tstate->use_tracing = tstate->c_profilefunc != NULL;
4591 Py_XDECREF(temp);
4592 tstate->c_tracefunc = func;
4593 tstate->c_traceobj = arg;
4594 /* Flag that tracing or profiling is turned on */
4595 tstate->use_tracing = ((func != NULL)
4596 || (tstate->c_profilefunc != NULL));
Fred Draked0838392001-06-16 21:02:31 +00004597}
4598
Yury Selivanov75445082015-05-11 22:57:16 -04004599void
Victor Stinner838f2642019-06-13 22:41:23 +02004600_PyEval_SetCoroutineOriginTrackingDepth(PyThreadState *tstate, int new_depth)
Nathaniel J. Smithfc2f4072018-01-21 06:44:07 -08004601{
4602 assert(new_depth >= 0);
Nathaniel J. Smithfc2f4072018-01-21 06:44:07 -08004603 tstate->coroutine_origin_tracking_depth = new_depth;
4604}
4605
4606int
4607_PyEval_GetCoroutineOriginTrackingDepth(void)
4608{
Victor Stinner50b48572018-11-01 01:51:40 +01004609 PyThreadState *tstate = _PyThreadState_GET();
Nathaniel J. Smithfc2f4072018-01-21 06:44:07 -08004610 return tstate->coroutine_origin_tracking_depth;
4611}
4612
4613void
Yury Selivanoveb636452016-09-08 22:01:51 -07004614_PyEval_SetAsyncGenFirstiter(PyObject *firstiter)
4615{
Victor Stinner50b48572018-11-01 01:51:40 +01004616 PyThreadState *tstate = _PyThreadState_GET();
Steve Dowerb82e17e2019-05-23 08:45:22 -07004617
4618 if (PySys_Audit("sys.set_asyncgen_hook_firstiter", NULL) < 0) {
4619 return;
4620 }
4621
Yury Selivanoveb636452016-09-08 22:01:51 -07004622 Py_XINCREF(firstiter);
4623 Py_XSETREF(tstate->async_gen_firstiter, firstiter);
4624}
4625
4626PyObject *
4627_PyEval_GetAsyncGenFirstiter(void)
4628{
Victor Stinner50b48572018-11-01 01:51:40 +01004629 PyThreadState *tstate = _PyThreadState_GET();
Yury Selivanoveb636452016-09-08 22:01:51 -07004630 return tstate->async_gen_firstiter;
4631}
4632
4633void
4634_PyEval_SetAsyncGenFinalizer(PyObject *finalizer)
4635{
Victor Stinner50b48572018-11-01 01:51:40 +01004636 PyThreadState *tstate = _PyThreadState_GET();
Steve Dowerb82e17e2019-05-23 08:45:22 -07004637
4638 if (PySys_Audit("sys.set_asyncgen_hook_finalizer", NULL) < 0) {
4639 return;
4640 }
4641
Yury Selivanoveb636452016-09-08 22:01:51 -07004642 Py_XINCREF(finalizer);
4643 Py_XSETREF(tstate->async_gen_finalizer, finalizer);
4644}
4645
4646PyObject *
4647_PyEval_GetAsyncGenFinalizer(void)
4648{
Victor Stinner50b48572018-11-01 01:51:40 +01004649 PyThreadState *tstate = _PyThreadState_GET();
Yury Selivanoveb636452016-09-08 22:01:51 -07004650 return tstate->async_gen_finalizer;
4651}
4652
Victor Stinner438a12d2019-05-24 17:01:38 +02004653static PyFrameObject *
4654_PyEval_GetFrame(PyThreadState *tstate)
4655{
Victor Stinner01b1cc12019-11-20 02:27:56 +01004656 _PyRuntimeState *runtime = tstate->interp->runtime;
4657 return runtime->gilstate.getframe(tstate);
Victor Stinner438a12d2019-05-24 17:01:38 +02004658}
4659
4660PyFrameObject *
4661PyEval_GetFrame(void)
4662{
4663 PyThreadState *tstate = _PyThreadState_GET();
4664 return _PyEval_GetFrame(tstate);
4665}
4666
Guido van Rossumb209a111997-04-29 18:18:01 +00004667PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00004668PyEval_GetBuiltins(void)
Guido van Rossum6135a871995-01-09 17:53:26 +00004669{
Victor Stinner438a12d2019-05-24 17:01:38 +02004670 PyThreadState *tstate = _PyThreadState_GET();
4671 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004672 if (current_frame == NULL)
Victor Stinner438a12d2019-05-24 17:01:38 +02004673 return tstate->interp->builtins;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004674 else
4675 return current_frame->f_builtins;
Guido van Rossum6135a871995-01-09 17:53:26 +00004676}
4677
Serhiy Storchakabb86bf42018-12-11 08:28:18 +02004678/* Convenience function to get a builtin from its name */
4679PyObject *
4680_PyEval_GetBuiltinId(_Py_Identifier *name)
4681{
Victor Stinner438a12d2019-05-24 17:01:38 +02004682 PyThreadState *tstate = _PyThreadState_GET();
Serhiy Storchakabb86bf42018-12-11 08:28:18 +02004683 PyObject *attr = _PyDict_GetItemIdWithError(PyEval_GetBuiltins(), name);
4684 if (attr) {
4685 Py_INCREF(attr);
4686 }
Victor Stinner438a12d2019-05-24 17:01:38 +02004687 else if (!_PyErr_Occurred(tstate)) {
4688 _PyErr_SetObject(tstate, PyExc_AttributeError, _PyUnicode_FromId(name));
Serhiy Storchakabb86bf42018-12-11 08:28:18 +02004689 }
4690 return attr;
4691}
4692
Guido van Rossumb209a111997-04-29 18:18:01 +00004693PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00004694PyEval_GetLocals(void)
Guido van Rossum5b722181993-03-30 17:46:03 +00004695{
Victor Stinner438a12d2019-05-24 17:01:38 +02004696 PyThreadState *tstate = _PyThreadState_GET();
4697 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
Victor Stinner41bb43a2013-10-29 01:19:37 +01004698 if (current_frame == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004699 _PyErr_SetString(tstate, PyExc_SystemError, "frame does not exist");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004700 return NULL;
Victor Stinner41bb43a2013-10-29 01:19:37 +01004701 }
4702
Victor Stinner438a12d2019-05-24 17:01:38 +02004703 if (PyFrame_FastToLocalsWithError(current_frame) < 0) {
Victor Stinner41bb43a2013-10-29 01:19:37 +01004704 return NULL;
Victor Stinner438a12d2019-05-24 17:01:38 +02004705 }
Victor Stinner41bb43a2013-10-29 01:19:37 +01004706
4707 assert(current_frame->f_locals != NULL);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004708 return current_frame->f_locals;
Guido van Rossum5b722181993-03-30 17:46:03 +00004709}
4710
Guido van Rossumb209a111997-04-29 18:18:01 +00004711PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00004712PyEval_GetGlobals(void)
Guido van Rossum3f5da241990-12-20 15:06:42 +00004713{
Victor Stinner438a12d2019-05-24 17:01:38 +02004714 PyThreadState *tstate = _PyThreadState_GET();
4715 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
4716 if (current_frame == NULL) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004717 return NULL;
Victor Stinner438a12d2019-05-24 17:01:38 +02004718 }
Victor Stinner41bb43a2013-10-29 01:19:37 +01004719
4720 assert(current_frame->f_globals != NULL);
4721 return current_frame->f_globals;
Guido van Rossum3f5da241990-12-20 15:06:42 +00004722}
4723
Guido van Rossum6135a871995-01-09 17:53:26 +00004724int
Tim Peters5ba58662001-07-16 02:29:45 +00004725PyEval_MergeCompilerFlags(PyCompilerFlags *cf)
Jeremy Hylton061d1062001-03-22 02:32:48 +00004726{
Victor Stinner438a12d2019-05-24 17:01:38 +02004727 PyThreadState *tstate = _PyThreadState_GET();
4728 PyFrameObject *current_frame = _PyEval_GetFrame(tstate);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004729 int result = cf->cf_flags != 0;
Tim Peters5ba58662001-07-16 02:29:45 +00004730
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004731 if (current_frame != NULL) {
4732 const int codeflags = current_frame->f_code->co_flags;
4733 const int compilerflags = codeflags & PyCF_MASK;
4734 if (compilerflags) {
4735 result = 1;
4736 cf->cf_flags |= compilerflags;
4737 }
Neil Schemenauerc24ea082002-03-22 23:53:36 +00004738#if 0 /* future keyword */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004739 if (codeflags & CO_GENERATOR_ALLOWED) {
4740 result = 1;
4741 cf->cf_flags |= CO_GENERATOR_ALLOWED;
4742 }
Neil Schemenauerc24ea082002-03-22 23:53:36 +00004743#endif
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004744 }
4745 return result;
Jeremy Hylton061d1062001-03-22 02:32:48 +00004746}
4747
Guido van Rossum3f5da241990-12-20 15:06:42 +00004748
Jeremy Hyltonaf68c872005-12-10 18:50:16 +00004749const char *
Tim Peters6d6c1a32001-08-02 04:15:00 +00004750PyEval_GetFuncName(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00004751{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004752 if (PyMethod_Check(func))
4753 return PyEval_GetFuncName(PyMethod_GET_FUNCTION(func));
4754 else if (PyFunction_Check(func))
Serhiy Storchaka06515832016-11-20 09:13:07 +02004755 return PyUnicode_AsUTF8(((PyFunctionObject*)func)->func_name);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004756 else if (PyCFunction_Check(func))
4757 return ((PyCFunctionObject*)func)->m_ml->ml_name;
4758 else
4759 return func->ob_type->tp_name;
Jeremy Hylton512a2372001-04-11 13:52:29 +00004760}
4761
Jeremy Hyltonaf68c872005-12-10 18:50:16 +00004762const char *
Tim Peters6d6c1a32001-08-02 04:15:00 +00004763PyEval_GetFuncDesc(PyObject *func)
Jeremy Hylton512a2372001-04-11 13:52:29 +00004764{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004765 if (PyMethod_Check(func))
4766 return "()";
4767 else if (PyFunction_Check(func))
4768 return "()";
4769 else if (PyCFunction_Check(func))
4770 return "()";
4771 else
4772 return " object";
Jeremy Hylton512a2372001-04-11 13:52:29 +00004773}
4774
Armin Rigo1c2d7e52005-09-20 18:34:01 +00004775#define C_TRACE(x, call) \
Nicholas Bastind858a772004-06-25 23:31:06 +00004776if (tstate->use_tracing && tstate->c_profilefunc) { \
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004777 if (call_trace(tstate->c_profilefunc, tstate->c_profileobj, \
4778 tstate, tstate->frame, \
4779 PyTrace_C_CALL, func)) { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004780 x = NULL; \
4781 } \
4782 else { \
4783 x = call; \
4784 if (tstate->c_profilefunc != NULL) { \
4785 if (x == NULL) { \
4786 call_trace_protected(tstate->c_profilefunc, \
4787 tstate->c_profileobj, \
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004788 tstate, tstate->frame, \
4789 PyTrace_C_EXCEPTION, func); \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004790 /* XXX should pass (type, value, tb) */ \
4791 } else { \
4792 if (call_trace(tstate->c_profilefunc, \
4793 tstate->c_profileobj, \
Victor Stinnerfdeb6ec2013-12-13 02:01:38 +01004794 tstate, tstate->frame, \
4795 PyTrace_C_RETURN, func)) { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004796 Py_DECREF(x); \
4797 x = NULL; \
4798 } \
4799 } \
4800 } \
4801 } \
Nicholas Bastind858a772004-06-25 23:31:06 +00004802} else { \
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004803 x = call; \
4804 }
Nicholas Bastinc69ebe82004-03-24 21:57:10 +00004805
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004806
4807static PyObject *
4808trace_call_function(PyThreadState *tstate,
4809 PyObject *func,
4810 PyObject **args, Py_ssize_t nargs,
4811 PyObject *kwnames)
4812{
4813 PyObject *x;
4814 if (PyCFunction_Check(func)) {
Jeroen Demeyer0d722f32019-07-05 14:48:24 +02004815 C_TRACE(x, _PyObject_Vectorcall(func, args, nargs, kwnames));
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004816 return x;
4817 }
4818 else if (Py_TYPE(func) == &PyMethodDescr_Type && nargs > 0) {
4819 /* We need to create a temporary bound method as argument
4820 for profiling.
4821
4822 If nargs == 0, then this cannot work because we have no
4823 "self". In any case, the call itself would raise
4824 TypeError (foo needs an argument), so we just skip
4825 profiling. */
4826 PyObject *self = args[0];
4827 func = Py_TYPE(func)->tp_descr_get(func, self, (PyObject*)Py_TYPE(self));
4828 if (func == NULL) {
4829 return NULL;
4830 }
Jeroen Demeyer0d722f32019-07-05 14:48:24 +02004831 C_TRACE(x, _PyObject_Vectorcall(func,
4832 args+1, nargs-1,
4833 kwnames));
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004834 Py_DECREF(func);
4835 return x;
4836 }
4837 return _PyObject_Vectorcall(func, args, nargs | PY_VECTORCALL_ARGUMENTS_OFFSET, kwnames);
4838}
4839
Victor Stinner415c5102017-01-11 00:54:57 +01004840/* Issue #29227: Inline call_function() into _PyEval_EvalFrameDefault()
4841 to reduce the stack consumption. */
4842Py_LOCAL_INLINE(PyObject *) _Py_HOT_FUNCTION
Victor Stinner09532fe2019-05-10 23:39:09 +02004843call_function(PyThreadState *tstate, PyObject ***pp_stack, Py_ssize_t oparg, PyObject *kwnames)
Jeremy Hyltone8c04322002-08-16 17:47:26 +00004844{
Victor Stinnerf9b760f2016-09-09 10:17:08 -07004845 PyObject **pfunc = (*pp_stack) - oparg - 1;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004846 PyObject *func = *pfunc;
4847 PyObject *x, *w;
Victor Stinnerd8735722016-09-09 12:36:44 -07004848 Py_ssize_t nkwargs = (kwnames == NULL) ? 0 : PyTuple_GET_SIZE(kwnames);
4849 Py_ssize_t nargs = oparg - nkwargs;
INADA Naoki5566bbb2017-02-03 07:43:03 +09004850 PyObject **stack = (*pp_stack) - nargs - nkwargs;
Jeremy Hyltone8c04322002-08-16 17:47:26 +00004851
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004852 if (tstate->use_tracing) {
4853 x = trace_call_function(tstate, func, stack, nargs, kwnames);
INADA Naoki5566bbb2017-02-03 07:43:03 +09004854 }
Victor Stinner4a7cc882015-03-06 23:35:27 +01004855 else {
Jeroen Demeyeraacc77f2019-05-29 20:31:52 +02004856 x = _PyObject_Vectorcall(func, stack, nargs | PY_VECTORCALL_ARGUMENTS_OFFSET, kwnames);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004857 }
Tim Peters8a5c3c72004-04-05 19:36:21 +00004858
Victor Stinner438a12d2019-05-24 17:01:38 +02004859 assert((x != NULL) ^ (_PyErr_Occurred(tstate) != NULL));
Victor Stinnerf9b760f2016-09-09 10:17:08 -07004860
Victor Stinnerc22bfaa2017-02-12 19:27:05 +01004861 /* Clear the stack of the function object. */
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004862 while ((*pp_stack) > pfunc) {
4863 w = EXT_POP(*pp_stack);
4864 Py_DECREF(w);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004865 }
Victor Stinnerace47d72013-07-18 01:41:08 +02004866
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004867 return x;
Jeremy Hyltone8c04322002-08-16 17:47:26 +00004868}
4869
Jeremy Hylton52820442001-01-03 23:52:36 +00004870static PyObject *
Victor Stinner09532fe2019-05-10 23:39:09 +02004871do_call_core(PyThreadState *tstate, PyObject *func, PyObject *callargs, PyObject *kwdict)
Jeremy Hylton52820442001-01-03 23:52:36 +00004872{
jdemeyere89de732018-09-19 12:06:20 +02004873 PyObject *result;
4874
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004875 if (PyCFunction_Check(func)) {
Jeroen Demeyer7a6873c2019-09-11 13:01:01 +02004876 C_TRACE(result, PyObject_Call(func, callargs, kwdict));
Victor Stinnerf9b760f2016-09-09 10:17:08 -07004877 return result;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004878 }
jdemeyere89de732018-09-19 12:06:20 +02004879 else if (Py_TYPE(func) == &PyMethodDescr_Type) {
jdemeyere89de732018-09-19 12:06:20 +02004880 Py_ssize_t nargs = PyTuple_GET_SIZE(callargs);
4881 if (nargs > 0 && tstate->use_tracing) {
4882 /* We need to create a temporary bound method as argument
4883 for profiling.
4884
4885 If nargs == 0, then this cannot work because we have no
4886 "self". In any case, the call itself would raise
4887 TypeError (foo needs an argument), so we just skip
4888 profiling. */
4889 PyObject *self = PyTuple_GET_ITEM(callargs, 0);
4890 func = Py_TYPE(func)->tp_descr_get(func, self, (PyObject*)Py_TYPE(self));
4891 if (func == NULL) {
4892 return NULL;
4893 }
4894
Victor Stinner4d231bc2019-11-14 13:36:21 +01004895 C_TRACE(result, _PyObject_FastCallDictTstate(
4896 tstate, func,
4897 &_PyTuple_ITEMS(callargs)[1],
4898 nargs - 1,
4899 kwdict));
jdemeyere89de732018-09-19 12:06:20 +02004900 Py_DECREF(func);
4901 return result;
4902 }
Victor Stinner74319ae2016-08-25 00:04:09 +02004903 }
jdemeyere89de732018-09-19 12:06:20 +02004904 return PyObject_Call(func, callargs, kwdict);
Jeremy Hylton52820442001-01-03 23:52:36 +00004905}
4906
Serhiy Storchaka483405b2015-02-17 10:14:30 +02004907/* Extract a slice index from a PyLong or an object with the
Guido van Rossum38fff8c2006-03-07 18:50:55 +00004908 nb_index slot defined, and store in *pi.
4909 Silently reduce values larger than PY_SSIZE_T_MAX to PY_SSIZE_T_MAX,
Xiang Zhang2ddf5a12017-05-10 18:19:41 +08004910 and silently boost values less than PY_SSIZE_T_MIN to PY_SSIZE_T_MIN.
Martin v. Löwisdde99d22006-02-17 15:57:41 +00004911 Return 0 on error, 1 on success.
Tim Peterscb479e72001-12-16 19:11:44 +00004912*/
Guido van Rossum20c6add2000-05-08 14:06:50 +00004913int
Martin v. Löwis18e16552006-02-15 17:27:45 +00004914_PyEval_SliceIndex(PyObject *v, Py_ssize_t *pi)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004915{
Victor Stinner438a12d2019-05-24 17:01:38 +02004916 PyThreadState *tstate = _PyThreadState_GET();
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004917 if (v != Py_None) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004918 Py_ssize_t x;
4919 if (PyIndex_Check(v)) {
4920 x = PyNumber_AsSsize_t(v, NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02004921 if (x == -1 && _PyErr_Occurred(tstate))
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004922 return 0;
4923 }
4924 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004925 _PyErr_SetString(tstate, PyExc_TypeError,
4926 "slice indices must be integers or "
4927 "None or have an __index__ method");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004928 return 0;
4929 }
4930 *pi = x;
4931 }
4932 return 1;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004933}
4934
Serhiy Storchaka80ec8362017-03-19 19:37:40 +02004935int
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004936_PyEval_SliceIndexNotNone(PyObject *v, Py_ssize_t *pi)
Serhiy Storchaka80ec8362017-03-19 19:37:40 +02004937{
Victor Stinner438a12d2019-05-24 17:01:38 +02004938 PyThreadState *tstate = _PyThreadState_GET();
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004939 Py_ssize_t x;
4940 if (PyIndex_Check(v)) {
4941 x = PyNumber_AsSsize_t(v, NULL);
Victor Stinner438a12d2019-05-24 17:01:38 +02004942 if (x == -1 && _PyErr_Occurred(tstate))
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004943 return 0;
4944 }
4945 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02004946 _PyErr_SetString(tstate, PyExc_TypeError,
4947 "slice indices must be integers or "
4948 "have an __index__ method");
Serhiy Storchakad4edfc92017-03-30 18:29:23 +03004949 return 0;
4950 }
4951 *pi = x;
4952 return 1;
Serhiy Storchaka80ec8362017-03-19 19:37:40 +02004953}
4954
4955
Guido van Rossum486364b2007-06-30 05:01:58 +00004956#define CANNOT_CATCH_MSG "catching classes that do not inherit from "\
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004957 "BaseException is not allowed"
Brett Cannonf74225d2007-02-26 21:10:16 +00004958
Guido van Rossumb209a111997-04-29 18:18:01 +00004959static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02004960cmp_outcome(PyThreadState *tstate, int op, PyObject *v, PyObject *w)
Guido van Rossum10dc2e81990-11-18 17:27:39 +00004961{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004962 int res = 0;
4963 switch (op) {
4964 case PyCmp_IS:
4965 res = (v == w);
4966 break;
4967 case PyCmp_IS_NOT:
4968 res = (v != w);
4969 break;
4970 case PyCmp_IN:
4971 res = PySequence_Contains(w, v);
4972 if (res < 0)
4973 return NULL;
4974 break;
4975 case PyCmp_NOT_IN:
4976 res = PySequence_Contains(w, v);
4977 if (res < 0)
4978 return NULL;
4979 res = !res;
4980 break;
4981 case PyCmp_EXC_MATCH:
4982 if (PyTuple_Check(w)) {
4983 Py_ssize_t i, length;
4984 length = PyTuple_Size(w);
4985 for (i = 0; i < length; i += 1) {
4986 PyObject *exc = PyTuple_GET_ITEM(w, i);
4987 if (!PyExceptionClass_Check(exc)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004988 _PyErr_SetString(tstate, PyExc_TypeError,
4989 CANNOT_CATCH_MSG);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004990 return NULL;
4991 }
4992 }
4993 }
4994 else {
4995 if (!PyExceptionClass_Check(w)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02004996 _PyErr_SetString(tstate, PyExc_TypeError,
4997 CANNOT_CATCH_MSG);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00004998 return NULL;
4999 }
5000 }
5001 res = PyErr_GivenExceptionMatches(v, w);
5002 break;
5003 default:
5004 return PyObject_RichCompare(v, w, op);
5005 }
5006 v = res ? Py_True : Py_False;
5007 Py_INCREF(v);
5008 return v;
Guido van Rossum10dc2e81990-11-18 17:27:39 +00005009}
5010
Thomas Wouters52152252000-08-17 22:55:00 +00005011static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02005012import_name(PyThreadState *tstate, PyFrameObject *f,
5013 PyObject *name, PyObject *fromlist, PyObject *level)
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005014{
5015 _Py_IDENTIFIER(__import__);
Victor Stinnerdf142fd2016-08-20 00:44:42 +02005016 PyObject *import_func, *res;
5017 PyObject* stack[5];
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005018
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005019 import_func = _PyDict_GetItemIdWithError(f->f_builtins, &PyId___import__);
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005020 if (import_func == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005021 if (!_PyErr_Occurred(tstate)) {
5022 _PyErr_SetString(tstate, PyExc_ImportError, "__import__ not found");
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005023 }
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005024 return NULL;
5025 }
5026
5027 /* Fast path for not overloaded __import__. */
Victor Stinner438a12d2019-05-24 17:01:38 +02005028 if (import_func == tstate->interp->import_func) {
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005029 int ilevel = _PyLong_AsInt(level);
Victor Stinner438a12d2019-05-24 17:01:38 +02005030 if (ilevel == -1 && _PyErr_Occurred(tstate)) {
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005031 return NULL;
5032 }
5033 res = PyImport_ImportModuleLevelObject(
5034 name,
5035 f->f_globals,
5036 f->f_locals == NULL ? Py_None : f->f_locals,
5037 fromlist,
5038 ilevel);
5039 return res;
5040 }
5041
5042 Py_INCREF(import_func);
Victor Stinnerdf142fd2016-08-20 00:44:42 +02005043
5044 stack[0] = name;
5045 stack[1] = f->f_globals;
5046 stack[2] = f->f_locals == NULL ? Py_None : f->f_locals;
5047 stack[3] = fromlist;
5048 stack[4] = level;
Victor Stinner559bb6a2016-08-22 22:48:54 +02005049 res = _PyObject_FastCall(import_func, stack, 5);
Serhiy Storchaka133138a2016-08-02 22:51:21 +03005050 Py_DECREF(import_func);
5051 return res;
5052}
5053
5054static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02005055import_from(PyThreadState *tstate, PyObject *v, PyObject *name)
Guido van Rossume9736fc1990-11-18 17:33:06 +00005056{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005057 PyObject *x;
Antoine Pitrou0373a102014-10-13 20:19:45 +02005058 _Py_IDENTIFIER(__name__);
Xiang Zhang4830f582017-03-21 11:13:42 +08005059 PyObject *fullmodname, *pkgname, *pkgpath, *pkgname_or_unknown, *errmsg;
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00005060
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005061 if (_PyObject_LookupAttr(v, name, &x) != 0) {
Antoine Pitrou0373a102014-10-13 20:19:45 +02005062 return x;
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005063 }
Antoine Pitrou0373a102014-10-13 20:19:45 +02005064 /* Issue #17636: in case this failed because of a circular relative
5065 import, try to fallback on reading the module directly from
5066 sys.modules. */
Antoine Pitrou0373a102014-10-13 20:19:45 +02005067 pkgname = _PyObject_GetAttrId(v, &PyId___name__);
Brett Cannon3008bc02015-08-11 18:01:31 -07005068 if (pkgname == NULL) {
5069 goto error;
5070 }
Oren Milman6db70332017-09-19 14:23:01 +03005071 if (!PyUnicode_Check(pkgname)) {
5072 Py_CLEAR(pkgname);
5073 goto error;
5074 }
Antoine Pitrou0373a102014-10-13 20:19:45 +02005075 fullmodname = PyUnicode_FromFormat("%U.%U", pkgname, name);
Brett Cannon3008bc02015-08-11 18:01:31 -07005076 if (fullmodname == NULL) {
Xiang Zhang4830f582017-03-21 11:13:42 +08005077 Py_DECREF(pkgname);
Antoine Pitrou0373a102014-10-13 20:19:45 +02005078 return NULL;
Brett Cannon3008bc02015-08-11 18:01:31 -07005079 }
Eric Snow3f9eee62017-09-15 16:35:20 -06005080 x = PyImport_GetModule(fullmodname);
Antoine Pitrou0373a102014-10-13 20:19:45 +02005081 Py_DECREF(fullmodname);
Victor Stinner438a12d2019-05-24 17:01:38 +02005082 if (x == NULL && !_PyErr_Occurred(tstate)) {
Brett Cannon3008bc02015-08-11 18:01:31 -07005083 goto error;
5084 }
Matthias Bussonnier1bc15642017-02-22 07:06:50 -08005085 Py_DECREF(pkgname);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005086 return x;
Brett Cannon3008bc02015-08-11 18:01:31 -07005087 error:
Matthias Bussonnierbc4bed42017-02-14 16:05:25 -08005088 pkgpath = PyModule_GetFilenameObject(v);
Matthias Bussonnier1bc15642017-02-22 07:06:50 -08005089 if (pkgname == NULL) {
5090 pkgname_or_unknown = PyUnicode_FromString("<unknown module name>");
5091 if (pkgname_or_unknown == NULL) {
5092 Py_XDECREF(pkgpath);
5093 return NULL;
5094 }
5095 } else {
5096 pkgname_or_unknown = pkgname;
5097 }
Matthias Bussonnierbc4bed42017-02-14 16:05:25 -08005098
5099 if (pkgpath == NULL || !PyUnicode_Check(pkgpath)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005100 _PyErr_Clear(tstate);
Xiang Zhang4830f582017-03-21 11:13:42 +08005101 errmsg = PyUnicode_FromFormat(
5102 "cannot import name %R from %R (unknown location)",
5103 name, pkgname_or_unknown
5104 );
Stefan Krah027b09c2019-03-25 21:50:58 +01005105 /* NULL checks for errmsg and pkgname done by PyErr_SetImportError. */
Xiang Zhang4830f582017-03-21 11:13:42 +08005106 PyErr_SetImportError(errmsg, pkgname, NULL);
5107 }
5108 else {
Anthony Sottile65366bc2019-09-09 08:17:50 -07005109 _Py_IDENTIFIER(__spec__);
5110 PyObject *spec = _PyObject_GetAttrId(v, &PyId___spec__);
Anthony Sottile65366bc2019-09-09 08:17:50 -07005111 const char *fmt =
5112 _PyModuleSpec_IsInitializing(spec) ?
5113 "cannot import name %R from partially initialized module %R "
5114 "(most likely due to a circular import) (%S)" :
5115 "cannot import name %R from %R (%S)";
5116 Py_XDECREF(spec);
5117
5118 errmsg = PyUnicode_FromFormat(fmt, name, pkgname_or_unknown, pkgpath);
Stefan Krah027b09c2019-03-25 21:50:58 +01005119 /* NULL checks for errmsg and pkgname done by PyErr_SetImportError. */
Xiang Zhang4830f582017-03-21 11:13:42 +08005120 PyErr_SetImportError(errmsg, pkgname, pkgpath);
Matthias Bussonnierbc4bed42017-02-14 16:05:25 -08005121 }
5122
Xiang Zhang4830f582017-03-21 11:13:42 +08005123 Py_XDECREF(errmsg);
Matthias Bussonnier1bc15642017-02-22 07:06:50 -08005124 Py_XDECREF(pkgname_or_unknown);
5125 Py_XDECREF(pkgpath);
Brett Cannon3008bc02015-08-11 18:01:31 -07005126 return NULL;
Thomas Wouters52152252000-08-17 22:55:00 +00005127}
Guido van Rossumac7be682001-01-17 15:42:30 +00005128
Thomas Wouters52152252000-08-17 22:55:00 +00005129static int
Victor Stinner438a12d2019-05-24 17:01:38 +02005130import_all_from(PyThreadState *tstate, PyObject *locals, PyObject *v)
Thomas Wouters52152252000-08-17 22:55:00 +00005131{
Martin v. Löwis1c67dd92011-10-14 15:16:45 +02005132 _Py_IDENTIFIER(__all__);
5133 _Py_IDENTIFIER(__dict__);
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005134 _Py_IDENTIFIER(__name__);
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005135 PyObject *all, *dict, *name, *value;
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005136 int skip_leading_underscores = 0;
5137 int pos, err;
Thomas Wouters52152252000-08-17 22:55:00 +00005138
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005139 if (_PyObject_LookupAttrId(v, &PyId___all__, &all) < 0) {
5140 return -1; /* Unexpected error */
5141 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005142 if (all == NULL) {
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005143 if (_PyObject_LookupAttrId(v, &PyId___dict__, &dict) < 0) {
5144 return -1;
5145 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005146 if (dict == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005147 _PyErr_SetString(tstate, PyExc_ImportError,
Serhiy Storchakaf320be72018-01-25 10:49:40 +02005148 "from-import-* object has no __dict__ and no __all__");
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005149 return -1;
5150 }
5151 all = PyMapping_Keys(dict);
5152 Py_DECREF(dict);
5153 if (all == NULL)
5154 return -1;
5155 skip_leading_underscores = 1;
5156 }
Guido van Rossum18d4d8f2001-01-12 16:24:03 +00005157
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005158 for (pos = 0, err = 0; ; pos++) {
5159 name = PySequence_GetItem(all, pos);
5160 if (name == NULL) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005161 if (!_PyErr_ExceptionMatches(tstate, PyExc_IndexError)) {
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005162 err = -1;
Victor Stinner438a12d2019-05-24 17:01:38 +02005163 }
5164 else {
5165 _PyErr_Clear(tstate);
5166 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005167 break;
5168 }
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005169 if (!PyUnicode_Check(name)) {
5170 PyObject *modname = _PyObject_GetAttrId(v, &PyId___name__);
5171 if (modname == NULL) {
5172 Py_DECREF(name);
5173 err = -1;
5174 break;
5175 }
5176 if (!PyUnicode_Check(modname)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005177 _PyErr_Format(tstate, PyExc_TypeError,
5178 "module __name__ must be a string, not %.100s",
5179 Py_TYPE(modname)->tp_name);
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005180 }
5181 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02005182 _PyErr_Format(tstate, PyExc_TypeError,
5183 "%s in %U.%s must be str, not %.100s",
5184 skip_leading_underscores ? "Key" : "Item",
5185 modname,
5186 skip_leading_underscores ? "__dict__" : "__all__",
5187 Py_TYPE(name)->tp_name);
Xiang Zhangd8b291a2018-03-24 18:39:36 +08005188 }
5189 Py_DECREF(modname);
5190 Py_DECREF(name);
5191 err = -1;
5192 break;
5193 }
5194 if (skip_leading_underscores) {
Serhiy Storchakae3b2b4b2017-09-08 09:58:51 +03005195 if (PyUnicode_READY(name) == -1) {
5196 Py_DECREF(name);
5197 err = -1;
5198 break;
5199 }
5200 if (PyUnicode_READ_CHAR(name, 0) == '_') {
5201 Py_DECREF(name);
5202 continue;
5203 }
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005204 }
5205 value = PyObject_GetAttr(v, name);
5206 if (value == NULL)
5207 err = -1;
5208 else if (PyDict_CheckExact(locals))
5209 err = PyDict_SetItem(locals, name, value);
5210 else
5211 err = PyObject_SetItem(locals, name, value);
5212 Py_DECREF(name);
5213 Py_XDECREF(value);
5214 if (err != 0)
5215 break;
5216 }
5217 Py_DECREF(all);
5218 return err;
Guido van Rossume9736fc1990-11-18 17:33:06 +00005219}
5220
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005221static int
Victor Stinner438a12d2019-05-24 17:01:38 +02005222check_args_iterable(PyThreadState *tstate, PyObject *func, PyObject *args)
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005223{
5224 if (args->ob_type->tp_iter == NULL && !PySequence_Check(args)) {
Jeroen Demeyerbf17d412019-11-05 16:48:04 +01005225 /* check_args_iterable() may be called with a live exception:
5226 * clear it to prevent calling _PyObject_FunctionStr() with an
5227 * exception set. */
5228 PyErr_Clear();
5229 PyObject *funcstr = _PyObject_FunctionStr(func);
5230 if (funcstr != NULL) {
5231 _PyErr_Format(tstate, PyExc_TypeError,
5232 "%U argument after * must be an iterable, not %.200s",
5233 funcstr, Py_TYPE(args)->tp_name);
5234 Py_DECREF(funcstr);
5235 }
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005236 return -1;
5237 }
5238 return 0;
5239}
5240
5241static void
Victor Stinner438a12d2019-05-24 17:01:38 +02005242format_kwargs_error(PyThreadState *tstate, PyObject *func, PyObject *kwargs)
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005243{
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005244 /* _PyDict_MergeEx raises attribute
5245 * error (percolated from an attempt
5246 * to get 'keys' attribute) instead of
5247 * a type error if its second argument
5248 * is not a mapping.
5249 */
Victor Stinner438a12d2019-05-24 17:01:38 +02005250 if (_PyErr_ExceptionMatches(tstate, PyExc_AttributeError)) {
Jeroen Demeyerbf17d412019-11-05 16:48:04 +01005251 PyErr_Clear();
5252 PyObject *funcstr = _PyObject_FunctionStr(func);
5253 if (funcstr != NULL) {
5254 _PyErr_Format(
5255 tstate, PyExc_TypeError,
5256 "%U argument after ** must be a mapping, not %.200s",
5257 funcstr, Py_TYPE(kwargs)->tp_name);
5258 Py_DECREF(funcstr);
5259 }
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005260 }
Victor Stinner438a12d2019-05-24 17:01:38 +02005261 else if (_PyErr_ExceptionMatches(tstate, PyExc_KeyError)) {
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005262 PyObject *exc, *val, *tb;
Victor Stinner438a12d2019-05-24 17:01:38 +02005263 _PyErr_Fetch(tstate, &exc, &val, &tb);
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005264 if (val && PyTuple_Check(val) && PyTuple_GET_SIZE(val) == 1) {
Jeroen Demeyerbf17d412019-11-05 16:48:04 +01005265 PyErr_Clear();
5266 PyObject *funcstr = _PyObject_FunctionStr(func);
5267 if (funcstr != NULL) {
5268 PyObject *key = PyTuple_GET_ITEM(val, 0);
5269 _PyErr_Format(
5270 tstate, PyExc_TypeError,
5271 "%U got multiple values for keyword argument '%S'",
5272 funcstr, key);
5273 Py_DECREF(funcstr);
5274 }
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005275 Py_XDECREF(exc);
5276 Py_XDECREF(val);
5277 Py_XDECREF(tb);
5278 }
5279 else {
Victor Stinner438a12d2019-05-24 17:01:38 +02005280 _PyErr_Restore(tstate, exc, val, tb);
Serhiy Storchakaf1ec3ce2019-01-12 10:12:24 +02005281 }
5282 }
Serhiy Storchaka25e4f772017-08-03 11:37:15 +03005283}
5284
Guido van Rossumac7be682001-01-17 15:42:30 +00005285static void
Victor Stinner438a12d2019-05-24 17:01:38 +02005286format_exc_check_arg(PyThreadState *tstate, PyObject *exc,
5287 const char *format_str, PyObject *obj)
Paul Prescode68140d2000-08-30 20:25:01 +00005288{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005289 const char *obj_str;
Paul Prescode68140d2000-08-30 20:25:01 +00005290
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005291 if (!obj)
5292 return;
Paul Prescode68140d2000-08-30 20:25:01 +00005293
Serhiy Storchaka06515832016-11-20 09:13:07 +02005294 obj_str = PyUnicode_AsUTF8(obj);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005295 if (!obj_str)
5296 return;
Paul Prescode68140d2000-08-30 20:25:01 +00005297
Victor Stinner438a12d2019-05-24 17:01:38 +02005298 _PyErr_Format(tstate, exc, format_str, obj_str);
Paul Prescode68140d2000-08-30 20:25:01 +00005299}
Guido van Rossum950361c1997-01-24 13:49:28 +00005300
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005301static void
Victor Stinner438a12d2019-05-24 17:01:38 +02005302format_exc_unbound(PyThreadState *tstate, PyCodeObject *co, int oparg)
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005303{
5304 PyObject *name;
5305 /* Don't stomp existing exception */
Victor Stinner438a12d2019-05-24 17:01:38 +02005306 if (_PyErr_Occurred(tstate))
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005307 return;
5308 if (oparg < PyTuple_GET_SIZE(co->co_cellvars)) {
5309 name = PyTuple_GET_ITEM(co->co_cellvars,
5310 oparg);
Victor Stinner438a12d2019-05-24 17:01:38 +02005311 format_exc_check_arg(tstate,
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005312 PyExc_UnboundLocalError,
5313 UNBOUNDLOCAL_ERROR_MSG,
5314 name);
5315 } else {
5316 name = PyTuple_GET_ITEM(co->co_freevars, oparg -
5317 PyTuple_GET_SIZE(co->co_cellvars));
Victor Stinner438a12d2019-05-24 17:01:38 +02005318 format_exc_check_arg(tstate, PyExc_NameError,
Amaury Forgeot d'Arcba117ef2010-09-10 21:39:53 +00005319 UNBOUNDFREE_ERROR_MSG, name);
5320 }
5321}
5322
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005323static void
Mark Shannonfee55262019-11-21 09:11:43 +00005324format_awaitable_error(PyThreadState *tstate, PyTypeObject *type, int prevprevopcode, int prevopcode)
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005325{
5326 if (type->tp_as_async == NULL || type->tp_as_async->am_await == NULL) {
5327 if (prevopcode == BEFORE_ASYNC_WITH) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005328 _PyErr_Format(tstate, PyExc_TypeError,
5329 "'async with' received an object from __aenter__ "
5330 "that does not implement __await__: %.100s",
5331 type->tp_name);
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005332 }
Mark Shannonfee55262019-11-21 09:11:43 +00005333 else if (prevopcode == WITH_EXCEPT_START || (prevopcode == CALL_FUNCTION && prevprevopcode == DUP_TOP)) {
Victor Stinner438a12d2019-05-24 17:01:38 +02005334 _PyErr_Format(tstate, PyExc_TypeError,
5335 "'async with' received an object from __aexit__ "
5336 "that does not implement __await__: %.100s",
5337 type->tp_name);
Serhiy Storchakaa68f2f02018-04-03 01:41:38 +03005338 }
5339 }
5340}
5341
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005342static PyObject *
Victor Stinner438a12d2019-05-24 17:01:38 +02005343unicode_concatenate(PyThreadState *tstate, PyObject *v, PyObject *w,
Serhiy Storchakaab874002016-09-11 13:48:15 +03005344 PyFrameObject *f, const _Py_CODEUNIT *next_instr)
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005345{
5346 PyObject *res;
5347 if (Py_REFCNT(v) == 2) {
5348 /* In the common case, there are 2 references to the value
5349 * stored in 'variable' when the += is performed: one on the
5350 * value stack (in 'v') and one still stored in the
5351 * 'variable'. We try to delete the variable now to reduce
5352 * the refcnt to 1.
5353 */
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03005354 int opcode, oparg;
5355 NEXTOPARG();
5356 switch (opcode) {
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005357 case STORE_FAST:
5358 {
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005359 PyObject **fastlocals = f->f_localsplus;
5360 if (GETLOCAL(oparg) == v)
5361 SETLOCAL(oparg, NULL);
5362 break;
5363 }
5364 case STORE_DEREF:
5365 {
5366 PyObject **freevars = (f->f_localsplus +
5367 f->f_code->co_nlocals);
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03005368 PyObject *c = freevars[oparg];
Raymond Hettingerc32f9db2016-11-12 04:10:35 -05005369 if (PyCell_GET(c) == v) {
5370 PyCell_SET(c, NULL);
5371 Py_DECREF(v);
5372 }
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005373 break;
5374 }
5375 case STORE_NAME:
5376 {
5377 PyObject *names = f->f_code->co_names;
Serhiy Storchakaf60bf5f2016-05-25 20:02:01 +03005378 PyObject *name = GETITEM(names, oparg);
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005379 PyObject *locals = f->f_locals;
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005380 if (locals && PyDict_CheckExact(locals)) {
5381 PyObject *w = PyDict_GetItemWithError(locals, name);
5382 if ((w == v && PyDict_DelItem(locals, name) != 0) ||
Victor Stinner438a12d2019-05-24 17:01:38 +02005383 (w == NULL && _PyErr_Occurred(tstate)))
Serhiy Storchakaa24107b2019-02-25 17:59:46 +02005384 {
5385 Py_DECREF(v);
5386 return NULL;
Victor Stinnerd2a915d2011-10-02 20:34:20 +02005387 }
5388 }
5389 break;
5390 }
5391 }
5392 }
5393 res = v;
5394 PyUnicode_Append(&res, w);
5395 return res;
5396}
5397
Guido van Rossum950361c1997-01-24 13:49:28 +00005398#ifdef DYNAMIC_EXECUTION_PROFILE
5399
Skip Montanarof118cb12001-10-15 20:51:38 +00005400static PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00005401getarray(long a[256])
Guido van Rossum950361c1997-01-24 13:49:28 +00005402{
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005403 int i;
5404 PyObject *l = PyList_New(256);
5405 if (l == NULL) return NULL;
5406 for (i = 0; i < 256; i++) {
5407 PyObject *x = PyLong_FromLong(a[i]);
5408 if (x == NULL) {
5409 Py_DECREF(l);
5410 return NULL;
5411 }
Zackery Spytz99d56b52018-12-08 07:16:55 -07005412 PyList_SET_ITEM(l, i, x);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005413 }
5414 for (i = 0; i < 256; i++)
5415 a[i] = 0;
5416 return l;
Guido van Rossum950361c1997-01-24 13:49:28 +00005417}
5418
5419PyObject *
Thomas Woutersf70ef4f2000-07-22 18:47:25 +00005420_Py_GetDXProfile(PyObject *self, PyObject *args)
Guido van Rossum950361c1997-01-24 13:49:28 +00005421{
5422#ifndef DXPAIRS
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005423 return getarray(dxp);
Guido van Rossum950361c1997-01-24 13:49:28 +00005424#else
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005425 int i;
5426 PyObject *l = PyList_New(257);
5427 if (l == NULL) return NULL;
5428 for (i = 0; i < 257; i++) {
5429 PyObject *x = getarray(dxpairs[i]);
5430 if (x == NULL) {
5431 Py_DECREF(l);
5432 return NULL;
5433 }
Zackery Spytz99d56b52018-12-08 07:16:55 -07005434 PyList_SET_ITEM(l, i, x);
Antoine Pitrouf95a1b32010-05-09 15:52:27 +00005435 }
5436 return l;
Guido van Rossum950361c1997-01-24 13:49:28 +00005437#endif
5438}
5439
5440#endif
Brett Cannon5c4de282016-09-07 11:16:41 -07005441
5442Py_ssize_t
5443_PyEval_RequestCodeExtraIndex(freefunc free)
5444{
Victor Stinnercaba55b2018-08-03 15:33:52 +02005445 PyInterpreterState *interp = _PyInterpreterState_GET_UNSAFE();
Brett Cannon5c4de282016-09-07 11:16:41 -07005446 Py_ssize_t new_index;
5447
Dino Viehlandf3cffd22017-06-21 14:44:36 -07005448 if (interp->co_extra_user_count == MAX_CO_EXTRA_USERS - 1) {
Brett Cannon5c4de282016-09-07 11:16:41 -07005449 return -1;
5450 }
Dino Viehlandf3cffd22017-06-21 14:44:36 -07005451 new_index = interp->co_extra_user_count++;
5452 interp->co_extra_freefuncs[new_index] = free;
Brett Cannon5c4de282016-09-07 11:16:41 -07005453 return new_index;
5454}
Łukasz Langaa785c872016-09-09 17:37:37 -07005455
5456static void
5457dtrace_function_entry(PyFrameObject *f)
5458{
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +02005459 const char *filename;
5460 const char *funcname;
Łukasz Langaa785c872016-09-09 17:37:37 -07005461 int lineno;
5462
5463 filename = PyUnicode_AsUTF8(f->f_code->co_filename);
5464 funcname = PyUnicode_AsUTF8(f->f_code->co_name);
5465 lineno = PyCode_Addr2Line(f->f_code, f->f_lasti);
5466
5467 PyDTrace_FUNCTION_ENTRY(filename, funcname, lineno);
5468}
5469
5470static void
5471dtrace_function_return(PyFrameObject *f)
5472{
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +02005473 const char *filename;
5474 const char *funcname;
Łukasz Langaa785c872016-09-09 17:37:37 -07005475 int lineno;
5476
5477 filename = PyUnicode_AsUTF8(f->f_code->co_filename);
5478 funcname = PyUnicode_AsUTF8(f->f_code->co_name);
5479 lineno = PyCode_Addr2Line(f->f_code, f->f_lasti);
5480
5481 PyDTrace_FUNCTION_RETURN(filename, funcname, lineno);
5482}
5483
5484/* DTrace equivalent of maybe_call_line_trace. */
5485static void
5486maybe_dtrace_line(PyFrameObject *frame,
5487 int *instr_lb, int *instr_ub, int *instr_prev)
5488{
5489 int line = frame->f_lineno;
Serhiy Storchaka85b0f5b2016-11-20 10:16:47 +02005490 const char *co_filename, *co_name;
Łukasz Langaa785c872016-09-09 17:37:37 -07005491
5492 /* If the last instruction executed isn't in the current
5493 instruction window, reset the window.
5494 */
5495 if (frame->f_lasti < *instr_lb || frame->f_lasti >= *instr_ub) {
5496 PyAddrPair bounds;
5497 line = _PyCode_CheckLineNumber(frame->f_code, frame->f_lasti,
5498 &bounds);
5499 *instr_lb = bounds.ap_lower;
5500 *instr_ub = bounds.ap_upper;
5501 }
5502 /* If the last instruction falls at the start of a line or if
5503 it represents a jump backwards, update the frame's line
5504 number and call the trace function. */
5505 if (frame->f_lasti == *instr_lb || frame->f_lasti < *instr_prev) {
5506 frame->f_lineno = line;
5507 co_filename = PyUnicode_AsUTF8(frame->f_code->co_filename);
5508 if (!co_filename)
5509 co_filename = "?";
5510 co_name = PyUnicode_AsUTF8(frame->f_code->co_name);
5511 if (!co_name)
5512 co_name = "?";
5513 PyDTrace_LINE(co_filename, co_name, line);
5514 }
5515 *instr_prev = frame->f_lasti;
5516}
Victor Stinnerf4b1e3d2019-11-04 19:48:34 +01005517
5518
5519/* Implement Py_EnterRecursiveCall() and Py_LeaveRecursiveCall() as functions
5520 for the limited API. */
5521
5522#undef Py_EnterRecursiveCall
5523
5524int Py_EnterRecursiveCall(const char *where)
5525{
Victor Stinnerbe434dc2019-11-05 00:51:22 +01005526 return _Py_EnterRecursiveCall_inline(where);
Victor Stinnerf4b1e3d2019-11-04 19:48:34 +01005527}
5528
5529#undef Py_LeaveRecursiveCall
5530
5531void Py_LeaveRecursiveCall(void)
5532{
Victor Stinnerbe434dc2019-11-05 00:51:22 +01005533 _Py_LeaveRecursiveCall_inline();
Victor Stinnerf4b1e3d2019-11-04 19:48:34 +01005534}