mirror of
https://github.com/python/cpython.git
synced 2025-12-08 06:10:17 +00:00
gh-140550: Use a bool for the Py_mod_gil value (GH-141519)
This needs a single bit, but was stored as a void* in the module struct. This didn't matter due to packing, but now that there's another bool in the struct, we can save a bit of memory by making md_gil a bool. Variables that changed type are renamed, to detect conflicts.
This commit is contained in:
parent
4885ecfbda
commit
a4dd66275b
4 changed files with 24 additions and 21 deletions
|
|
@ -1017,9 +1017,10 @@ struct extensions_cache_value {
|
|||
_Py_ext_module_origin origin;
|
||||
|
||||
#ifdef Py_GIL_DISABLED
|
||||
/* The module's md_gil slot, for legacy modules that are reinitialized from
|
||||
m_dict rather than calling their initialization function again. */
|
||||
void *md_gil;
|
||||
/* The module's md_requires_gil member, for legacy modules that are
|
||||
* reinitialized from m_dict rather than calling their initialization
|
||||
* function again. */
|
||||
bool md_requires_gil;
|
||||
#endif
|
||||
};
|
||||
|
||||
|
|
@ -1350,7 +1351,7 @@ static struct extensions_cache_value *
|
|||
_extensions_cache_set(PyObject *path, PyObject *name,
|
||||
PyModuleDef *def, PyModInitFunction m_init,
|
||||
Py_ssize_t m_index, PyObject *m_dict,
|
||||
_Py_ext_module_origin origin, void *md_gil)
|
||||
_Py_ext_module_origin origin, bool requires_gil)
|
||||
{
|
||||
struct extensions_cache_value *value = NULL;
|
||||
void *key = NULL;
|
||||
|
|
@ -1405,11 +1406,11 @@ _extensions_cache_set(PyObject *path, PyObject *name,
|
|||
/* m_dict is set by set_cached_m_dict(). */
|
||||
.origin=origin,
|
||||
#ifdef Py_GIL_DISABLED
|
||||
.md_gil=md_gil,
|
||||
.md_requires_gil=requires_gil,
|
||||
#endif
|
||||
};
|
||||
#ifndef Py_GIL_DISABLED
|
||||
(void)md_gil;
|
||||
(void)requires_gil;
|
||||
#endif
|
||||
if (init_cached_m_dict(newvalue, m_dict) < 0) {
|
||||
goto finally;
|
||||
|
|
@ -1547,7 +1548,8 @@ _PyImport_CheckGILForModule(PyObject* module, PyObject *module_name)
|
|||
}
|
||||
|
||||
if (!PyModule_Check(module) ||
|
||||
((PyModuleObject *)module)->md_gil == Py_MOD_GIL_USED) {
|
||||
((PyModuleObject *)module)->md_requires_gil)
|
||||
{
|
||||
if (_PyEval_EnableGILPermanent(tstate)) {
|
||||
int warn_result = PyErr_WarnFormat(
|
||||
PyExc_RuntimeWarning,
|
||||
|
|
@ -1725,7 +1727,7 @@ struct singlephase_global_update {
|
|||
Py_ssize_t m_index;
|
||||
PyObject *m_dict;
|
||||
_Py_ext_module_origin origin;
|
||||
void *md_gil;
|
||||
bool md_requires_gil;
|
||||
};
|
||||
|
||||
static struct extensions_cache_value *
|
||||
|
|
@ -1784,7 +1786,7 @@ update_global_state_for_extension(PyThreadState *tstate,
|
|||
#endif
|
||||
cached = _extensions_cache_set(
|
||||
path, name, def, m_init, singlephase->m_index, m_dict,
|
||||
singlephase->origin, singlephase->md_gil);
|
||||
singlephase->origin, singlephase->md_requires_gil);
|
||||
if (cached == NULL) {
|
||||
// XXX Ignore this error? Doing so would effectively
|
||||
// mark the module as not loadable.
|
||||
|
|
@ -1873,7 +1875,7 @@ reload_singlephase_extension(PyThreadState *tstate,
|
|||
if (def->m_base.m_copy != NULL) {
|
||||
// For non-core modules, fetch the GIL slot that was stored by
|
||||
// import_run_extension().
|
||||
((PyModuleObject *)mod)->md_gil = cached->md_gil;
|
||||
((PyModuleObject *)mod)->md_requires_gil = cached->md_requires_gil;
|
||||
}
|
||||
#endif
|
||||
/* We can't set mod->md_def if it's missing,
|
||||
|
|
@ -2128,7 +2130,7 @@ import_run_extension(PyThreadState *tstate, PyModInitFunction p0,
|
|||
.m_index=def->m_base.m_index,
|
||||
.origin=info->origin,
|
||||
#ifdef Py_GIL_DISABLED
|
||||
.md_gil=((PyModuleObject *)mod)->md_gil,
|
||||
.md_requires_gil=((PyModuleObject *)mod)->md_requires_gil,
|
||||
#endif
|
||||
};
|
||||
// gh-88216: Extensions and def->m_base.m_copy can be updated
|
||||
|
|
@ -2323,7 +2325,7 @@ _PyImport_FixupBuiltin(PyThreadState *tstate, PyObject *mod, const char *name,
|
|||
.origin=_Py_ext_module_origin_CORE,
|
||||
#ifdef Py_GIL_DISABLED
|
||||
/* Unused when m_dict == NULL. */
|
||||
.md_gil=NULL,
|
||||
.md_requires_gil=false,
|
||||
#endif
|
||||
};
|
||||
cached = update_global_state_for_extension(
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue