summaryrefslogtreecommitdiffstats
path: root/Python
diff options
context:
space:
mode:
authorDonghee Na <donghee.na@python.org>2024-12-02 15:14:40 (GMT)
committerGitHub <noreply@github.com>2024-12-02 15:14:40 (GMT)
commit7c2bd9b2266665ff4010b6c6c175bab18e08e4f8 (patch)
tree83fa851c015d5c6ebe95a873fb4134f61ee478e1 /Python
parent3e812253ab6b2f98fc5d17bfb82947e392b0b2a2 (diff)
downloadcpython-7c2bd9b2266665ff4010b6c6c175bab18e08e4f8.zip
cpython-7c2bd9b2266665ff4010b6c6c175bab18e08e4f8.tar.gz
cpython-7c2bd9b2266665ff4010b6c6c175bab18e08e4f8.tar.bz2
gh-115999: Use light-weight lock for UNPACK_SEQUENCE_LIST (gh-127514)
Diffstat (limited to 'Python')
-rw-r--r--Python/bytecodes.c13
-rw-r--r--Python/executor_cases.c.h22
-rw-r--r--Python/generated_cases.c.h19
3 files changed, 12 insertions, 42 deletions
diff --git a/Python/bytecodes.c b/Python/bytecodes.c
index c07ec42..e96674c 100644
--- a/Python/bytecodes.c
+++ b/Python/bytecodes.c
@@ -1438,14 +1438,9 @@ dummy_func(
inst(UNPACK_SEQUENCE_LIST, (unused/1, seq -- values[oparg])) {
PyObject *seq_o = PyStackRef_AsPyObjectBorrow(seq);
DEOPT_IF(!PyList_CheckExact(seq_o));
- #ifdef Py_GIL_DISABLED
- PyCriticalSection cs;
- PyCriticalSection_Begin(&cs, seq_o);
- #endif
+ DEOPT_IF(!LOCK_OBJECT(seq_o));
if (PyList_GET_SIZE(seq_o) != oparg) {
- #ifdef Py_GIL_DISABLED
- PyCriticalSection_End(&cs);
- #endif
+ UNLOCK_OBJECT(seq_o);
DEOPT_IF(true);
}
STAT_INC(UNPACK_SEQUENCE, hit);
@@ -1453,9 +1448,7 @@ dummy_func(
for (int i = oparg; --i >= 0; ) {
*values++ = PyStackRef_FromPyObjectNew(items[i]);
}
- #ifdef Py_GIL_DISABLED
- PyCriticalSection_End(&cs);
- #endif
+ UNLOCK_OBJECT(seq_o);
DECREF_INPUTS();
}
diff --git a/Python/executor_cases.c.h b/Python/executor_cases.c.h
index c91257b..5808146 100644
--- a/Python/executor_cases.c.h
+++ b/Python/executor_cases.c.h
@@ -1728,18 +1728,12 @@
UOP_STAT_INC(uopcode, miss);
JUMP_TO_JUMP_TARGET();
}
- #ifdef Py_GIL_DISABLED
- PyCriticalSection cs;
- _PyFrame_SetStackPointer(frame, stack_pointer);
- PyCriticalSection_Begin(&cs, seq_o);
- stack_pointer = _PyFrame_GetStackPointer(frame);
- #endif
+ if (!LOCK_OBJECT(seq_o)) {
+ UOP_STAT_INC(uopcode, miss);
+ JUMP_TO_JUMP_TARGET();
+ }
if (PyList_GET_SIZE(seq_o) != oparg) {
- #ifdef Py_GIL_DISABLED
- _PyFrame_SetStackPointer(frame, stack_pointer);
- PyCriticalSection_End(&cs);
- stack_pointer = _PyFrame_GetStackPointer(frame);
- #endif
+ UNLOCK_OBJECT(seq_o);
if (true) {
UOP_STAT_INC(uopcode, miss);
JUMP_TO_JUMP_TARGET();
@@ -1750,11 +1744,7 @@
for (int i = oparg; --i >= 0; ) {
*values++ = PyStackRef_FromPyObjectNew(items[i]);
}
- #ifdef Py_GIL_DISABLED
- _PyFrame_SetStackPointer(frame, stack_pointer);
- PyCriticalSection_End(&cs);
- stack_pointer = _PyFrame_GetStackPointer(frame);
- #endif
+ UNLOCK_OBJECT(seq_o);
PyStackRef_CLOSE(seq);
stack_pointer += -1 + oparg;
assert(WITHIN_STACK_BOUNDS());
diff --git a/Python/generated_cases.c.h b/Python/generated_cases.c.h
index 45bcc42..e1f9515 100644
--- a/Python/generated_cases.c.h
+++ b/Python/generated_cases.c.h
@@ -8040,18 +8040,9 @@
values = &stack_pointer[-1];
PyObject *seq_o = PyStackRef_AsPyObjectBorrow(seq);
DEOPT_IF(!PyList_CheckExact(seq_o), UNPACK_SEQUENCE);
- #ifdef Py_GIL_DISABLED
- PyCriticalSection cs;
- _PyFrame_SetStackPointer(frame, stack_pointer);
- PyCriticalSection_Begin(&cs, seq_o);
- stack_pointer = _PyFrame_GetStackPointer(frame);
- #endif
+ DEOPT_IF(!LOCK_OBJECT(seq_o), UNPACK_SEQUENCE);
if (PyList_GET_SIZE(seq_o) != oparg) {
- #ifdef Py_GIL_DISABLED
- _PyFrame_SetStackPointer(frame, stack_pointer);
- PyCriticalSection_End(&cs);
- stack_pointer = _PyFrame_GetStackPointer(frame);
- #endif
+ UNLOCK_OBJECT(seq_o);
DEOPT_IF(true, UNPACK_SEQUENCE);
}
STAT_INC(UNPACK_SEQUENCE, hit);
@@ -8059,11 +8050,7 @@
for (int i = oparg; --i >= 0; ) {
*values++ = PyStackRef_FromPyObjectNew(items[i]);
}
- #ifdef Py_GIL_DISABLED
- _PyFrame_SetStackPointer(frame, stack_pointer);
- PyCriticalSection_End(&cs);
- stack_pointer = _PyFrame_GetStackPointer(frame);
- #endif
+ UNLOCK_OBJECT(seq_o);
PyStackRef_CLOSE(seq);
stack_pointer += -1 + oparg;
assert(WITHIN_STACK_BOUNDS());