]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
gh-152375: Fix undefined behaviour in the `INSTRUMENTED_JUMP` macro (#152376)
authorStan Ulbrych <stan@python.org>
Mon, 29 Jun 2026 09:06:04 +0000 (11:06 +0200)
committerGitHub <noreply@github.com>
Mon, 29 Jun 2026 09:06:04 +0000 (11:06 +0200)
Misc/NEWS.d/next/Core_and_Builtins/2026-06-27-10-05-12.gh-issue-152375.L-ZBk6.rst [new file with mode: 0644]
Python/ceval_macros.h

diff --git a/Misc/NEWS.d/next/Core_and_Builtins/2026-06-27-10-05-12.gh-issue-152375.L-ZBk6.rst b/Misc/NEWS.d/next/Core_and_Builtins/2026-06-27-10-05-12.gh-issue-152375.L-ZBk6.rst
new file mode 100644 (file)
index 0000000..db6ae30
--- /dev/null
@@ -0,0 +1,2 @@
+Fix undefined behaviour when a :mod:`sys.monitoring` callback raised an
+exception while the program was following a branch or loop.
index 0de4477426af35869ba37e64e8ac96da95e6faf3..b13884bf8214d413d84b75f05c5862f4de33e70e 100644 (file)
@@ -389,14 +389,15 @@ static void dtrace_function_return(_PyInterpreterFrame *);
 // for an exception handler, displaying the traceback, and so on
 #define INSTRUMENTED_JUMP(src, dest, event) \
 do { \
+    _Py_CODEUNIT *_dest = (dest); \
     if (tstate->tracing) {\
-        next_instr = dest; \
+        next_instr = _dest; \
     } else { \
         _PyFrame_SetStackPointer(frame, stack_pointer); \
-        next_instr = _Py_call_instrumentation_jump(this_instr, tstate, event, frame, src, dest); \
+        next_instr = _Py_call_instrumentation_jump(this_instr, tstate, event, frame, src, _dest); \
         stack_pointer = _PyFrame_GetStackPointer(frame); \
         if (next_instr == NULL) { \
-            next_instr = (dest)+1; \
+            next_instr = _dest + 1; \
             JUMP_TO_LABEL(error); \
         } \
     } \