]> git.ipfire.org Git - thirdparty/Python/cpython.git/commit
bpo-40071: Fix potential crash in _functoolsmodule.c (GH-19273)
authorPaulo Henrique Silva <ph.silva@carta.com>
Wed, 1 Apr 2020 15:06:21 +0000 (12:06 -0300)
committerGitHub <noreply@github.com>
Wed, 1 Apr 2020 15:06:21 +0000 (17:06 +0200)
commiteacc07439591c97f69ab4a3d17391b009cd78ae2
tree927aae704029b9ca14d08c96b2d236bbe8d3de84
parent00002e6d8b0ccdb6e0d9e98a9a7f9c9edfdf1311
bpo-40071: Fix potential crash in _functoolsmodule.c (GH-19273)

Changes on 7dd549eb0893 made _functools compatible with
PEP-489 and we could have multiple modules instances loaded.

But, right now there is no way to make `kwd_mark` global into
a per module instance variable. kwd_mark is used on lru_cache_new
which does not have a reference to a PyModule*, necessary to use
PyModule_GetState.

PEP-573 will solve this problem and will allow us to move the global
state to per-module data and properly clear the state when unloading
a module instance.

This change temporarily disable cleaning of kwd_mark to avoid NULL
pointer dereference if we clear kwd_mark and other module instances
still alive use it.
Modules/_functoolsmodule.c