Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

bpo-40521: Make list free list per-interpreter #20642

Merged
merged 1 commit into from
Jun 5, 2020
Merged

bpo-40521: Make list free list per-interpreter #20642

merged 1 commit into from
Jun 5, 2020

Conversation

vstinner
Copy link
Member

@vstinner vstinner commented Jun 4, 2020

Each interpreter now has its own list free list:

  • Move list numfree and free_list into PyInterpreterState.
  • Add _Py_list_state structure.
  • Add tstate parameter to _PyList_ClearFreeList()
    and _PyList_Fini().
  • Remove "#ifdef EXPERIMENTAL_ISOLATED_SUBINTERPRETERS".
  • _PyGC_Fini() clears gcstate->garbage list which can be stored in
    the list free list. Call _PyGC_Fini() before _PyList_Fini() to
    prevent leaking this list.

https://bugs.python.org/issue40521

Each interpreter now has its own list free list:

* Move list numfree and free_list into PyInterpreterState.
* Add _Py_list_state structure.
* Add tstate parameter to _PyList_ClearFreeList()
  and _PyList_Fini().
* Remove "#ifdef EXPERIMENTAL_ISOLATED_SUBINTERPRETERS".
* _PyGC_Fini() clears gcstate->garbage list which can be stored in
  the list free list. Call _PyGC_Fini() before _PyList_Fini() to
  prevent leaking this list.
@vstinner
Copy link
Member Author

vstinner commented Jun 4, 2020

Thanks to "./python -m test -j0 -R 3:3 test_capi test__xxsubinterpreters test_atexit test_threading", I found a leak. It's fixed as part of this PR: "Call _PyGC_Fini() before _PyList_Fini()".

@vstinner vstinner merged commit 88ec919 into python:master Jun 5, 2020
@vstinner vstinner deleted the list_free_list branch June 5, 2020 00:05
arun-mani-j pushed a commit to arun-mani-j/cpython that referenced this pull request Jul 21, 2020
Each interpreter now has its own list free list:

* Move list numfree and free_list into PyInterpreterState.
* Add _Py_list_state structure.
* Add tstate parameter to _PyList_ClearFreeList()
  and _PyList_Fini().
* Remove "#ifdef EXPERIMENTAL_ISOLATED_SUBINTERPRETERS".
* _PyGC_Fini() clears gcstate->garbage list which can be stored in
  the list free list. Call _PyGC_Fini() before _PyList_Fini() to
  prevent leaking this list.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants