From 3c3eddcb3d8d910478bb5f4f58fb9d76100029b1 Mon Sep 17 00:00:00 2001 From: Pieter Eendebak Date: Sun, 22 Dec 2024 16:29:55 +0100 Subject: [PATCH 1/5] add freelist to _pylong_new --- Objects/longobject.c | 30 ++++++++++++++++++------------ 1 file changed, 18 insertions(+), 12 deletions(-) diff --git a/Objects/longobject.c b/Objects/longobject.c index bd7ff68d0899c6..53440269bea92a 100644 --- a/Objects/longobject.c +++ b/Objects/longobject.c @@ -156,7 +156,7 @@ PyLongObject * _PyLong_New(Py_ssize_t size) { assert(size >= 0); - PyLongObject *result; + PyLongObject *result = NULL; if (size > (Py_ssize_t)MAX_LONG_DIGITS) { PyErr_SetString(PyExc_OverflowError, "too many digits in integer"); @@ -165,19 +165,25 @@ _PyLong_New(Py_ssize_t size) /* Fast operations for single digit integers (including zero) * assume that there is always at least one digit present. */ Py_ssize_t ndigits = size ? size : 1; - /* Number of bytes needed is: offsetof(PyLongObject, ob_digit) + - sizeof(digit)*size. Previous incarnations of this code used - sizeof() instead of the offsetof, but this risks being - incorrect in the presence of padding between the header - and the digits. */ - result = PyObject_Malloc(offsetof(PyLongObject, long_value.ob_digit) + - ndigits*sizeof(digit)); - if (!result) { - PyErr_NoMemory(); - return NULL; + + if (ndigits==1) { + result = (PyLongObject *)_Py_FREELIST_POP(PyLongObject, ints); + } + if (result == NULL) { + /* Number of bytes needed is: offsetof(PyLongObject, ob_digit) + + sizeof(digit)*size. Previous incarnations of this code used + sizeof() instead of the offsetof, but this risks being + incorrect in the presence of padding between the header + and the digits. */ + result = PyObject_Malloc(offsetof(PyLongObject, long_value.ob_digit) + + ndigits*sizeof(digit)); + if (!result) { + PyErr_NoMemory(); + return NULL; + } + _PyObject_Init((PyObject*)result, &PyLong_Type); } _PyLong_SetSignAndDigitCount(result, size != 0, size); - _PyObject_Init((PyObject*)result, &PyLong_Type); /* The digit has to be initialized explicitly to avoid * use-of-uninitialized-value. */ result->long_value.ob_digit[0] = 0; From a912b8fbdc98b48e534f8ce534d8494a279dccef Mon Sep 17 00:00:00 2001 From: Pieter Eendebak Date: Sun, 22 Dec 2024 16:41:40 +0100 Subject: [PATCH 2/5] add check for no-gil build --- Objects/longobject.c | 2 -- 1 file changed, 2 deletions(-) diff --git a/Objects/longobject.c b/Objects/longobject.c index 53440269bea92a..f816a32a88e206 100644 --- a/Objects/longobject.c +++ b/Objects/longobject.c @@ -3641,13 +3641,11 @@ _PyLong_ExactDealloc(PyObject *self) { assert(PyLong_CheckExact(self)); if (_PyLong_IsCompact((PyLongObject *)self)) { - #ifndef Py_GIL_DISABLED if (compact_int_is_small(self)) { // See PEP 683, section Accidental De-Immortalizing for details _Py_SetImmortal(self); return; } - #endif _Py_FREELIST_FREE(ints, self, PyObject_Free); return; } From 91acd010b0863cb38384276a77ae53a6c290f59d Mon Sep 17 00:00:00 2001 From: Pieter Eendebak Date: Sun, 22 Dec 2024 16:44:16 +0100 Subject: [PATCH 3/5] revert accidental change --- Objects/longobject.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Objects/longobject.c b/Objects/longobject.c index f816a32a88e206..53440269bea92a 100644 --- a/Objects/longobject.c +++ b/Objects/longobject.c @@ -3641,11 +3641,13 @@ _PyLong_ExactDealloc(PyObject *self) { assert(PyLong_CheckExact(self)); if (_PyLong_IsCompact((PyLongObject *)self)) { + #ifndef Py_GIL_DISABLED if (compact_int_is_small(self)) { // See PEP 683, section Accidental De-Immortalizing for details _Py_SetImmortal(self); return; } + #endif _Py_FREELIST_FREE(ints, self, PyObject_Free); return; } From 4dda501b3453962acc61fb32e48c3735d2f40f16 Mon Sep 17 00:00:00 2001 From: "blurb-it[bot]" <43283697+blurb-it[bot]@users.noreply.github.com> Date: Sun, 22 Dec 2024 15:47:50 +0000 Subject: [PATCH 4/5] =?UTF-8?q?=F0=9F=93=9C=F0=9F=A4=96=20Added=20by=20blu?= =?UTF-8?q?rb=5Fit.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../2024-12-22-15-47-44.gh-issue-126868.RpjKez.rst | 1 + 1 file changed, 1 insertion(+) create mode 100644 Misc/NEWS.d/next/Core_and_Builtins/2024-12-22-15-47-44.gh-issue-126868.RpjKez.rst diff --git a/Misc/NEWS.d/next/Core_and_Builtins/2024-12-22-15-47-44.gh-issue-126868.RpjKez.rst b/Misc/NEWS.d/next/Core_and_Builtins/2024-12-22-15-47-44.gh-issue-126868.RpjKez.rst new file mode 100644 index 00000000000000..ede383deb4ad31 --- /dev/null +++ b/Misc/NEWS.d/next/Core_and_Builtins/2024-12-22-15-47-44.gh-issue-126868.RpjKez.rst @@ -0,0 +1 @@ +Increase usage of freelist for :class:`int` allocation. From f1ddf859720c7c92d4c4b1192f60b1dda09c8c32 Mon Sep 17 00:00:00 2001 From: Kumar Aditya Date: Thu, 26 Dec 2024 20:17:26 +0530 Subject: [PATCH 5/5] Update Objects/longobject.c --- Objects/longobject.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Objects/longobject.c b/Objects/longobject.c index 53440269bea92a..d449a01cedf886 100644 --- a/Objects/longobject.c +++ b/Objects/longobject.c @@ -166,7 +166,7 @@ _PyLong_New(Py_ssize_t size) * assume that there is always at least one digit present. */ Py_ssize_t ndigits = size ? size : 1; - if (ndigits==1) { + if (ndigits == 1) { result = (PyLongObject *)_Py_FREELIST_POP(PyLongObject, ints); } if (result == NULL) {