https://github.com/python/cpython/commit/bde72839d76d0b52f0f1753920cc88f723df340a
commit: bde72839d76d0b52f0f1753920cc88f723df340a
branch: 3.13
author: Miss Islington (bot) <31488909+miss-isling...@users.noreply.github.com>
committer: brandtbucher <brandtbuc...@gmail.com>
date: 2025-04-07T19:16:23-07:00
summary:

[3.13] GH-130673: Gracefully handle missing sections in JIT build (GH-131749)

(cherry picked from commit a26a301f8b09c1825b288fc8649f8174576361f4)
Co-authored-by: Bojun Ren <bj.ren.cod...@outlook.com>
Co-authored-by: Bénédikt Tran <10796600+picn...@users.noreply.github.com>

files:
A Misc/NEWS.d/next/Build/2025-03-06-20-55-34.gh-issue-130673.T3RSCI.rst
M Tools/jit/_targets.py
M Tools/jit/ignore-tests-emulated-linux.txt

diff --git 
a/Misc/NEWS.d/next/Build/2025-03-06-20-55-34.gh-issue-130673.T3RSCI.rst 
b/Misc/NEWS.d/next/Build/2025-03-06-20-55-34.gh-issue-130673.T3RSCI.rst
new file mode 100644
index 00000000000000..20c52c3e3722b2
--- /dev/null
+++ b/Misc/NEWS.d/next/Build/2025-03-06-20-55-34.gh-issue-130673.T3RSCI.rst
@@ -0,0 +1,2 @@
+Fix potential ``KeyError`` when handling object sections during JIT building
+process.
diff --git a/Tools/jit/_targets.py b/Tools/jit/_targets.py
index cebfad5a7467d2..50b5d923a355ce 100644
--- a/Tools/jit/_targets.py
+++ b/Tools/jit/_targets.py
@@ -330,7 +330,11 @@ def _handle_section(
         if section_type == "SHT_RELA":
             assert "SHF_INFO_LINK" in flags, flags
             assert not section["Symbols"]
-            value, base = group.symbols[section["Info"]]
+            maybe_symbol = group.symbols.get(section["Info"])
+            if maybe_symbol is None:
+                # These are relocations for a section we're not emitting. Skip:
+                return
+            value, base = maybe_symbol
             if value is _stencils.HoleValue.CODE:
                 stencil = group.code
             else:
diff --git a/Tools/jit/ignore-tests-emulated-linux.txt 
b/Tools/jit/ignore-tests-emulated-linux.txt
index dbb364673b5c1a..ca51b75f07f1ec 100644
--- a/Tools/jit/ignore-tests-emulated-linux.txt
+++ b/Tools/jit/ignore-tests-emulated-linux.txt
@@ -25,6 +25,7 @@ test.test_pathlib.PosixPathTest.test_is_mount_root
 test.test_pathlib.test_pathlib.PathSubclassTest.test_is_mount_root
 test.test_pathlib.test_pathlib.PathTest.test_is_mount_root
 test.test_pathlib.test_pathlib.PosixPathTest.test_is_mount_root
+test.test_posix.PosixTester.test_fexecve
 test.test_posix.TestPosixSpawn.test_close_file
 test.test_posix.TestPosixSpawnP.test_close_file
 test.test_posixpath.PosixPathTest.test_ismount

_______________________________________________
Python-checkins mailing list -- python-checkins@python.org
To unsubscribe send an email to python-checkins-le...@python.org
https://mail.python.org/mailman3/lists/python-checkins.python.org/
Member address: arch...@mail-archive.com

Reply via email to