summaryrefslogtreecommitdiff
path: root/Python
diff options
context:
space:
mode:
authorMark Shannon <mark@hotpy.org>2023-03-13 10:34:54 +0000
committerGitHub <noreply@github.com>2023-03-13 10:34:54 +0000
commit233e32f93614255bf5fc7c93cd98af453e58cc98 (patch)
tree9eb812f9894064fb34f5e2ee14a019ec4a58da32 /Python
parent78e4e6c3d71980d4e6687f07afa6ddfc83e29b04 (diff)
downloadcpython-git-233e32f93614255bf5fc7c93cd98af453e58cc98.tar.gz
GH-102300: Reuse objects with refcount == 1 in float specialized binary ops. (GH-102301)
Diffstat (limited to 'Python')
-rw-r--r--Python/bytecodes.c15
-rw-r--r--Python/ceval_macros.h20
-rw-r--r--Python/generated_cases.c.h15
3 files changed, 26 insertions, 24 deletions
diff --git a/Python/bytecodes.c b/Python/bytecodes.c
index dc2a20f22b..178519fcb6 100644
--- a/Python/bytecodes.c
+++ b/Python/bytecodes.c
@@ -195,10 +195,7 @@ dummy_func(
STAT_INC(BINARY_OP, hit);
double dprod = ((PyFloatObject *)left)->ob_fval *
((PyFloatObject *)right)->ob_fval;
- prod = PyFloat_FromDouble(dprod);
- _Py_DECREF_SPECIALIZED(right, _PyFloat_ExactDealloc);
- _Py_DECREF_SPECIALIZED(left, _PyFloat_ExactDealloc);
- ERROR_IF(prod == NULL, error);
+ DECREF_INPUTS_AND_REUSE_FLOAT(left, right, dprod, prod);
}
inst(BINARY_OP_SUBTRACT_INT, (unused/1, left, right -- sub)) {
@@ -218,10 +215,7 @@ dummy_func(
DEOPT_IF(!PyFloat_CheckExact(right), BINARY_OP);
STAT_INC(BINARY_OP, hit);
double dsub = ((PyFloatObject *)left)->ob_fval - ((PyFloatObject *)right)->ob_fval;
- sub = PyFloat_FromDouble(dsub);
- _Py_DECREF_SPECIALIZED(right, _PyFloat_ExactDealloc);
- _Py_DECREF_SPECIALIZED(left, _PyFloat_ExactDealloc);
- ERROR_IF(sub == NULL, error);
+ DECREF_INPUTS_AND_REUSE_FLOAT(left, right, dsub, sub);
}
inst(BINARY_OP_ADD_UNICODE, (unused/1, left, right -- res)) {
@@ -278,10 +272,7 @@ dummy_func(
STAT_INC(BINARY_OP, hit);
double dsum = ((PyFloatObject *)left)->ob_fval +
((PyFloatObject *)right)->ob_fval;
- sum = PyFloat_FromDouble(dsum);
- _Py_DECREF_SPECIALIZED(right, _PyFloat_ExactDealloc);
- _Py_DECREF_SPECIALIZED(left, _PyFloat_ExactDealloc);
- ERROR_IF(sum == NULL, error);
+ DECREF_INPUTS_AND_REUSE_FLOAT(left, right, dsum, sum);
}
inst(BINARY_OP_ADD_INT, (unused/1, left, right -- sum)) {
diff --git a/Python/ceval_macros.h b/Python/ceval_macros.h
index ac1fec77da..98b72ec1b3 100644
--- a/Python/ceval_macros.h
+++ b/Python/ceval_macros.h
@@ -350,3 +350,23 @@ GETITEM(PyObject *v, Py_ssize_t i) {
#define KWNAMES_LEN() \
(kwnames == NULL ? 0 : ((int)PyTuple_GET_SIZE(kwnames)))
+
+#define DECREF_INPUTS_AND_REUSE_FLOAT(left, right, dval, result) \
+do { \
+ if (Py_REFCNT(left) == 1) { \
+ ((PyFloatObject *)left)->ob_fval = (dval); \
+ _Py_DECREF_SPECIALIZED(right, _PyFloat_ExactDealloc);\
+ result = (left); \
+ } \
+ else if (Py_REFCNT(right) == 1) {\
+ ((PyFloatObject *)right)->ob_fval = (dval); \
+ _Py_DECREF_NO_DEALLOC(left); \
+ result = (right); \
+ }\
+ else { \
+ result = PyFloat_FromDouble(dval); \
+ if ((result) == NULL) goto error; \
+ _Py_DECREF_NO_DEALLOC(left); \
+ _Py_DECREF_NO_DEALLOC(right); \
+ } \
+} while (0)
diff --git a/Python/generated_cases.c.h b/Python/generated_cases.c.h
index 3839aeecb9..21073cbf97 100644
--- a/Python/generated_cases.c.h
+++ b/Python/generated_cases.c.h
@@ -263,10 +263,7 @@
STAT_INC(BINARY_OP, hit);
double dprod = ((PyFloatObject *)left)->ob_fval *
((PyFloatObject *)right)->ob_fval;
- prod = PyFloat_FromDouble(dprod);
- _Py_DECREF_SPECIALIZED(right, _PyFloat_ExactDealloc);
- _Py_DECREF_SPECIALIZED(left, _PyFloat_ExactDealloc);
- if (prod == NULL) goto pop_2_error;
+ DECREF_INPUTS_AND_REUSE_FLOAT(left, right, dprod, prod);
STACK_SHRINK(1);
stack_pointer[-1] = prod;
next_instr += 1;
@@ -300,10 +297,7 @@
DEOPT_IF(!PyFloat_CheckExact(right), BINARY_OP);
STAT_INC(BINARY_OP, hit);
double dsub = ((PyFloatObject *)left)->ob_fval - ((PyFloatObject *)right)->ob_fval;
- sub = PyFloat_FromDouble(dsub);
- _Py_DECREF_SPECIALIZED(right, _PyFloat_ExactDealloc);
- _Py_DECREF_SPECIALIZED(left, _PyFloat_ExactDealloc);
- if (sub == NULL) goto pop_2_error;
+ DECREF_INPUTS_AND_REUSE_FLOAT(left, right, dsub, sub);
STACK_SHRINK(1);
stack_pointer[-1] = sub;
next_instr += 1;
@@ -372,10 +366,7 @@
STAT_INC(BINARY_OP, hit);
double dsum = ((PyFloatObject *)left)->ob_fval +
((PyFloatObject *)right)->ob_fval;
- sum = PyFloat_FromDouble(dsum);
- _Py_DECREF_SPECIALIZED(right, _PyFloat_ExactDealloc);
- _Py_DECREF_SPECIALIZED(left, _PyFloat_ExactDealloc);
- if (sum == NULL) goto pop_2_error;
+ DECREF_INPUTS_AND_REUSE_FLOAT(left, right, dsum, sum);
STACK_SHRINK(1);
stack_pointer[-1] = sum;
next_instr += 1;