KEMBAR78
gh-100227: Isolate the Import State to Each Interpreter by ericsnowcurrently · Pull Request #101941 · python/cpython · GitHub
Skip to content

Conversation

@ericsnowcurrently
Copy link
Member

@ericsnowcurrently ericsnowcurrently commented Feb 15, 2023

Specific changes:

  • move the import lock to PyInterpreterState
  • move the "find_and_load" diagnostic state to PyInterpreterState

Note that the import lock exists to keep multiple imports of the same module in the same interpreter (but in different threads) from stomping on each other. Independently, we use a distinct global lock to protect globally shared import state, especially related to loaded extension modules. For now we can rely on the GIL as that lock but with a per-interpreter GIL we'll need a new global lock.

The remaining state in _PyRuntimeState.imports will continue being global.

@corona10 corona10 added the 🔨 test-with-refleak-buildbots Test PR w/ refleak buildbots; report in status section label Feb 16, 2023
@bedevere-bot
Copy link

🤖 New build scheduled with the buildbot fleet by @corona10 for commit 0dbb320 🤖

If you want to schedule another build, you need to add the 🔨 test-with-refleak-buildbots label again.

@bedevere-bot bedevere-bot removed the 🔨 test-with-refleak-buildbots Test PR w/ refleak buildbots; report in status section label Feb 16, 2023
@ericsnowcurrently
Copy link
Member Author

FYI, I ran the benchmarks on this and it reported a 1% speedup, which wasn't expected. :)

@ericsnowcurrently ericsnowcurrently merged commit cf6e7c5 into python:main Mar 9, 2023
@ericsnowcurrently ericsnowcurrently deleted the isolate-import-state branch March 9, 2023 16:46
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants