summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEric Snow <ericsnowcurrently@gmail.com>2023-03-09 01:04:16 (GMT)
committerGitHub <noreply@github.com>2023-03-09 01:04:16 (GMT)
commit5e5acd291f4387876afc641163e9f8ae5c65086c (patch)
treeb1ae91adf3e2ea87b110c6f1d95b265c084d7201
parent66ff374d4f353ae427c148d2a1d141d223303a82 (diff)
downloadcpython-5e5acd291f4387876afc641163e9f8ae5c65086c.zip
cpython-5e5acd291f4387876afc641163e9f8ae5c65086c.tar.gz
cpython-5e5acd291f4387876afc641163e9f8ae5c65086c.tar.bz2
gh-100227: Move next_keys_version to PyInterpreterState (gh-102335)
https://github.com/python/cpython/issues/100227
-rw-r--r--Include/internal/pycore_dict.h3
-rw-r--r--Include/internal/pycore_dict_state.h4
-rw-r--r--Include/internal/pycore_runtime_init.h6
-rw-r--r--Objects/dictobject.c7
-rw-r--r--Python/specialize.c16
5 files changed, 23 insertions, 13 deletions
diff --git a/Include/internal/pycore_dict.h b/Include/internal/pycore_dict.h
index 1af5e59..12c3c70 100644
--- a/Include/internal/pycore_dict.h
+++ b/Include/internal/pycore_dict.h
@@ -37,7 +37,8 @@ extern PyObject *_PyDict_FromKeys(PyObject *, PyObject *, PyObject *);
/* Gets a version number unique to the current state of the keys of dict, if possible.
* Returns the version number, or zero if it was not possible to get a version number. */
-extern uint32_t _PyDictKeys_GetVersionForCurrentState(PyDictKeysObject *dictkeys);
+extern uint32_t _PyDictKeys_GetVersionForCurrentState(
+ PyInterpreterState *interp, PyDictKeysObject *dictkeys);
extern size_t _PyDict_KeysSize(PyDictKeysObject *keys);
diff --git a/Include/internal/pycore_dict_state.h b/Include/internal/pycore_dict_state.h
index 77375ea..c5142ee 100644
--- a/Include/internal/pycore_dict_state.h
+++ b/Include/internal/pycore_dict_state.h
@@ -14,7 +14,6 @@ struct _Py_dict_runtime_state {
* It is incremented each time that a dictionary is created and each
* time that a dictionary is modified. */
uint64_t global_version;
- uint32_t next_keys_version;
};
@@ -30,6 +29,8 @@ struct _Py_dict_runtime_state {
#define DICT_MAX_WATCHERS 8
struct _Py_dict_state {
+ uint32_t next_keys_version;
+
#if PyDict_MAXFREELIST > 0
/* Dictionary reuse scheme to save calls to malloc and free */
PyDictObject *free_list[PyDict_MAXFREELIST];
@@ -37,6 +38,7 @@ struct _Py_dict_state {
int numfree;
int keys_numfree;
#endif
+
PyDict_WatchCallback watchers[DICT_MAX_WATCHERS];
};
diff --git a/Include/internal/pycore_runtime_init.h b/Include/internal/pycore_runtime_init.h
index aeabcfd..efc82b4 100644
--- a/Include/internal/pycore_runtime_init.h
+++ b/Include/internal/pycore_runtime_init.h
@@ -65,9 +65,6 @@ extern PyTypeObject _PyExc_MemoryError;
.float_format = _py_float_format_unknown, \
.double_format = _py_float_format_unknown, \
}, \
- .dict_state = { \
- .next_keys_version = 2, \
- }, \
.types = { \
.next_version_tag = 1, \
}, \
@@ -113,6 +110,9 @@ extern PyTypeObject _PyExc_MemoryError;
}, \
}, \
.dtoa = _dtoa_state_INIT(&(INTERP)), \
+ .dict_state = { \
+ .next_keys_version = 2, \
+ }, \
.func_state = { \
.next_version = 1, \
}, \
diff --git a/Objects/dictobject.c b/Objects/dictobject.c
index a60f275..b58e93f 100644
--- a/Objects/dictobject.c
+++ b/Objects/dictobject.c
@@ -5655,15 +5655,16 @@ _PyDictKeys_DecRef(PyDictKeysObject *keys)
dictkeys_decref(keys);
}
-uint32_t _PyDictKeys_GetVersionForCurrentState(PyDictKeysObject *dictkeys)
+uint32_t _PyDictKeys_GetVersionForCurrentState(PyInterpreterState *interp,
+ PyDictKeysObject *dictkeys)
{
if (dictkeys->dk_version != 0) {
return dictkeys->dk_version;
}
- if (_PyRuntime.dict_state.next_keys_version == 0) {
+ if (interp->dict_state.next_keys_version == 0) {
return 0;
}
- uint32_t v = _PyRuntime.dict_state.next_keys_version++;
+ uint32_t v = interp->dict_state.next_keys_version++;
dictkeys->dk_version = v;
return v;
}
diff --git a/Python/specialize.c b/Python/specialize.c
index 3405d2b..0a7af89 100644
--- a/Python/specialize.c
+++ b/Python/specialize.c
@@ -512,7 +512,8 @@ specialize_module_load_attr(
SPEC_FAIL_OUT_OF_RANGE);
return -1;
}
- uint32_t keys_version = _PyDictKeys_GetVersionForCurrentState(dict->ma_keys);
+ uint32_t keys_version = _PyDictKeys_GetVersionForCurrentState(
+ _PyInterpreterState_GET(), dict->ma_keys);
if (keys_version == 0) {
SPECIALIZATION_FAIL(LOAD_ATTR, SPEC_FAIL_OUT_OF_VERSIONS);
return -1;
@@ -1063,7 +1064,8 @@ PyObject *descr, DescriptorClassification kind)
SPECIALIZATION_FAIL(LOAD_ATTR, SPEC_FAIL_ATTR_SHADOWED);
return 0;
}
- uint32_t keys_version = _PyDictKeys_GetVersionForCurrentState(keys);
+ uint32_t keys_version = _PyDictKeys_GetVersionForCurrentState(
+ _PyInterpreterState_GET(), keys);
if (keys_version == 0) {
SPECIALIZATION_FAIL(LOAD_ATTR, SPEC_FAIL_OUT_OF_VERSIONS);
return 0;
@@ -1134,12 +1136,14 @@ _Py_Specialize_LoadGlobal(
SPECIALIZATION_FAIL(LOAD_GLOBAL, SPEC_FAIL_EXPECTED_ERROR);
goto fail;
}
+ PyInterpreterState *interp = _PyInterpreterState_GET();
if (index != DKIX_EMPTY) {
if (index != (uint16_t)index) {
SPECIALIZATION_FAIL(LOAD_GLOBAL, SPEC_FAIL_OUT_OF_RANGE);
goto fail;
}
- uint32_t keys_version = _PyDictKeys_GetVersionForCurrentState(globals_keys);
+ uint32_t keys_version = _PyDictKeys_GetVersionForCurrentState(
+ interp, globals_keys);
if (keys_version == 0) {
SPECIALIZATION_FAIL(LOAD_GLOBAL, SPEC_FAIL_OUT_OF_VERSIONS);
goto fail;
@@ -1167,12 +1171,14 @@ _Py_Specialize_LoadGlobal(
SPECIALIZATION_FAIL(LOAD_GLOBAL, SPEC_FAIL_OUT_OF_RANGE);
goto fail;
}
- uint32_t globals_version = _PyDictKeys_GetVersionForCurrentState(globals_keys);
+ uint32_t globals_version = _PyDictKeys_GetVersionForCurrentState(
+ interp, globals_keys);
if (globals_version == 0) {
SPECIALIZATION_FAIL(LOAD_GLOBAL, SPEC_FAIL_OUT_OF_VERSIONS);
goto fail;
}
- uint32_t builtins_version = _PyDictKeys_GetVersionForCurrentState(builtin_keys);
+ uint32_t builtins_version = _PyDictKeys_GetVersionForCurrentState(
+ interp, builtin_keys);
if (builtins_version == 0) {
SPECIALIZATION_FAIL(LOAD_GLOBAL, SPEC_FAIL_OUT_OF_VERSIONS);
goto fail;