summaryrefslogtreecommitdiffstats
path: root/Python/bytecodes.c
diff options
context:
space:
mode:
authorMark Shannon <mark@hotpy.org>2024-04-29 06:54:05 (GMT)
committerGitHub <noreply@github.com>2024-04-29 06:54:05 (GMT)
commitab6eda0ee59587e84cb417dd84452b9c6845434c (patch)
treea8b35575dc02021f8e043926023763895b477cf9 /Python/bytecodes.c
parentaa8f6d2708bce1462544d2e2cae05a2595ffd9ec (diff)
downloadcpython-ab6eda0ee59587e84cb417dd84452b9c6845434c.zip
cpython-ab6eda0ee59587e84cb417dd84452b9c6845434c.tar.gz
cpython-ab6eda0ee59587e84cb417dd84452b9c6845434c.tar.bz2
GH-118095: Allow a variant of RESUME_CHECK in tier 2 (GH-118286)
Diffstat (limited to 'Python/bytecodes.c')
-rw-r--r--Python/bytecodes.c23
1 files changed, 23 insertions, 0 deletions
diff --git a/Python/bytecodes.c b/Python/bytecodes.c
index fe3d613..f688856 100644
--- a/Python/bytecodes.c
+++ b/Python/bytecodes.c
@@ -4258,6 +4258,29 @@ dummy_func(
}
+ /* Special version of RESUME_CHECK that (when paired with _EVAL_BREAKER_EXIT)
+ * is safe for tier 2. Progress is guaranteed because _EVAL_BREAKER_EXIT calls
+ * _Py_HandlePending which clears the eval_breaker so that _TIER2_RESUME_CHECK
+ * will not exit if it is immediately executed again. */
+ tier2 op(_TIER2_RESUME_CHECK, (--)) {
+#if defined(__EMSCRIPTEN__)
+ EXIT_IF(_Py_emscripten_signal_clock == 0);
+ _Py_emscripten_signal_clock -= Py_EMSCRIPTEN_SIGNAL_HANDLING;
+#endif
+ uintptr_t eval_breaker = _Py_atomic_load_uintptr_relaxed(&tstate->eval_breaker);
+ EXIT_IF(eval_breaker & _PY_EVAL_EVENTS_MASK);
+ assert(eval_breaker == FT_ATOMIC_LOAD_UINTPTR_ACQUIRE(_PyFrame_GetCode(frame)->_co_instrumentation_version));
+ }
+
+ tier2 op(_EVAL_BREAKER_EXIT, (--)) {
+ _Py_CHECK_EMSCRIPTEN_SIGNALS_PERIODICALLY();
+ QSBR_QUIESCENT_STATE(tstate);
+ if (_Py_HandlePending(tstate) != 0) {
+ GOTO_UNWIND();
+ }
+ EXIT_TO_TRACE();
+ }
+
// END BYTECODES //
}