[Python-checkins] bpo-36301: Fix Py_Main() memory leaks (GH-12420)
Victor Stinner
webhook-mailer at python.org
Mon Mar 18 17:24:32 EDT 2019
https://github.com/python/cpython/commit/c183444f7e2640b054956474d71aae6e8d31a543
commit: c183444f7e2640b054956474d71aae6e8d31a543
branch: master
author: Victor Stinner <vstinner at redhat.com>
committer: GitHub <noreply at github.com>
date: 2019-03-18T22:24:28+01:00
summary:
bpo-36301: Fix Py_Main() memory leaks (GH-12420)
bpo-36301, bpo-36333:
* Fix memory allocator used by _PyPathConfig_ClearGlobal():
force the default allocator.
* _PyPreConfig_ReadFromArgv(): free init_ctype_locale memory.
* pymain_main(): call pymain_free() on init error
Co-Authored-By: Stéphane Wirtel <stephane at wirtel.be>
files:
M Modules/main.c
M Python/pathconfig.c
M Python/preconfig.c
diff --git a/Modules/main.c b/Modules/main.c
index 5c7f7e45673a..50fecc9103d9 100644
--- a/Modules/main.c
+++ b/Modules/main.c
@@ -888,13 +888,13 @@ pymain_main(_PyArgv *args)
PyInterpreterState *interp;
err = pymain_init(args, &interp);
if (_Py_INIT_FAILED(err)) {
- _Py_ExitInitError(err);
+ goto exit_init_error;
}
int exitcode = 0;
err = pymain_run_python(interp, &exitcode);
if (_Py_INIT_FAILED(err)) {
- _Py_ExitInitError(err);
+ goto exit_init_error;
}
if (Py_FinalizeEx() < 0) {
@@ -910,6 +910,10 @@ pymain_main(_PyArgv *args)
}
return exitcode;
+
+exit_init_error:
+ pymain_free();
+ _Py_ExitInitError(err);
}
diff --git a/Python/pathconfig.c b/Python/pathconfig.c
index fb2d19e2797a..0ee87c42525f 100644
--- a/Python/pathconfig.c
+++ b/Python/pathconfig.c
@@ -149,7 +149,12 @@ _PyPathConfig_SetGlobal(const _PyPathConfig *config)
void
_PyPathConfig_ClearGlobal(void)
{
+ PyMemAllocatorEx old_alloc;
+ _PyMem_SetDefaultAllocator(PYMEM_DOMAIN_RAW, &old_alloc);
+
_PyPathConfig_Clear(&_Py_path_config);
+
+ PyMem_SetAllocator(PYMEM_DOMAIN_RAW, &old_alloc);
}
diff --git a/Python/preconfig.c b/Python/preconfig.c
index a86ece57cfce..1efc7ee5c56e 100644
--- a/Python/preconfig.c
+++ b/Python/preconfig.c
@@ -758,6 +758,7 @@ _PyPreConfig_ReadFromArgv(_PyPreConfig *config, const _PyArgv *args)
done:
if (init_ctype_locale != NULL) {
setlocale(LC_CTYPE, init_ctype_locale);
+ PyMem_RawFree(init_ctype_locale);
}
_PyPreConfig_Clear(&save_config);
Py_UTF8Mode = init_utf8_mode ;
More information about the Python-checkins
mailing list