summaryrefslogtreecommitdiffstats
path: root/Python/optimizer_bytecodes.c
diff options
context:
space:
mode:
authorKen Jin <kenjin@python.org>2025-12-15 22:22:18 (GMT)
committerGitHub <noreply@github.com>2025-12-15 22:22:18 (GMT)
commit790a46a449bc1778d47fffa65308905ff43fe33e (patch)
tree5779008a33f118cc144ea7a705b1ef537c4a0ddd /Python/optimizer_bytecodes.c
parent0978b9a7d5eedab19d7d39bd703ed5b55fd7aa5f (diff)
downloadcpython-790a46a449bc1778d47fffa65308905ff43fe33e.zip
cpython-790a46a449bc1778d47fffa65308905ff43fe33e.tar.gz
cpython-790a46a449bc1778d47fffa65308905ff43fe33e.tar.bz2
gh-134584: JIT: Eliminate redundant refcount ops for X_INT (GH-142765)
Diffstat (limited to 'Python/optimizer_bytecodes.c')
-rw-r--r--Python/optimizer_bytecodes.c23
1 files changed, 12 insertions, 11 deletions
diff --git a/Python/optimizer_bytecodes.c b/Python/optimizer_bytecodes.c
index 9e9af61..b97b4c3 100644
--- a/Python/optimizer_bytecodes.c
+++ b/Python/optimizer_bytecodes.c
@@ -251,37 +251,37 @@ dummy_func(void) {
}
}
- op(_BINARY_OP_ADD_INT, (left, right -- res)) {
- REPLACE_OPCODE_IF_EVALUATES_PURE(left, right);
+ op(_BINARY_OP_ADD_INT, (left, right -- res, l, r)) {
res = sym_new_compact_int(ctx);
+ l = left;
+ r = right;
}
- op(_BINARY_OP_SUBTRACT_INT, (left, right -- res)) {
- REPLACE_OPCODE_IF_EVALUATES_PURE(left, right);
+ op(_BINARY_OP_SUBTRACT_INT, (left, right -- res, l, r)) {
res = sym_new_compact_int(ctx);
+ l = left;
+ r = right;
}
- op(_BINARY_OP_MULTIPLY_INT, (left, right -- res)) {
- REPLACE_OPCODE_IF_EVALUATES_PURE(left, right);
+ op(_BINARY_OP_MULTIPLY_INT, (left, right -- res, l, r)) {
res = sym_new_compact_int(ctx);
+ l = left;
+ r = right;
}
op(_BINARY_OP_ADD_FLOAT, (left, right -- res, l, r)) {
- REPLACE_OPCODE_IF_EVALUATES_PURE(left, right);
res = sym_new_type(ctx, &PyFloat_Type);
l = left;
r = right;
}
op(_BINARY_OP_SUBTRACT_FLOAT, (left, right -- res, l, r)) {
- REPLACE_OPCODE_IF_EVALUATES_PURE(left, right);
res = sym_new_type(ctx, &PyFloat_Type);
l = left;
r = right;
}
op(_BINARY_OP_MULTIPLY_FLOAT, (left, right -- res, l, r)) {
- REPLACE_OPCODE_IF_EVALUATES_PURE(left, right);
res = sym_new_type(ctx, &PyFloat_Type);
l = left;
r = right;
@@ -446,9 +446,10 @@ dummy_func(void) {
}
}
- op(_COMPARE_OP_INT, (left, right -- res)) {
- REPLACE_OPCODE_IF_EVALUATES_PURE(left, right);
+ op(_COMPARE_OP_INT, (left, right -- res, l, r)) {
res = sym_new_type(ctx, &PyBool_Type);
+ l = left;
+ r = right;
}
op(_COMPARE_OP_FLOAT, (left, right -- res)) {