]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
[3.13] gh-152375: Fix undefined behaviour in the `INSTRUMENTED_JUMP` macro (GH-152376...
authorStan Ulbrych <stan@python.org>
Mon, 29 Jun 2026 10:04:56 +0000 (12:04 +0200)
committerGitHub <noreply@github.com>
Mon, 29 Jun 2026 10:04:56 +0000 (10:04 +0000)
(cherry picked from commit cdec9acd63c33d9b822700de8f63eb94d86e1c93)

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 1ab83856fd99041e95c628e5083f5eab3ee11f9b..ab96ebdfea294cc716867878c3fcfc6650b45ea3 100644 (file)
@@ -359,14 +359,15 @@ do { \
 // 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(tstate, event, frame, src, dest); \
+        next_instr = _Py_call_instrumentation_jump(tstate, event, frame, src, _dest); \
         stack_pointer = _PyFrame_GetStackPointer(frame); \
         if (next_instr == NULL) { \
-            next_instr = (dest)+1; \
+            next_instr = _dest + 1; \
             goto error; \
         } \
     } \