mirror of
https://github.com/python/cpython.git
synced 2025-10-17 20:28:43 +00:00
GH-91079: Revert "GH-91079: Implement C stack limits using addresses, not counters. (GH-130007)" for now (GH130413)
Revert "GH-91079: Implement C stack limits using addresses, not counters. (GH-130007)" for now
Unfortunatlely, the change broke some buildbots.
This reverts commit 2498c22fa0
.
This commit is contained in:
parent
0ff1611574
commit
ef29104f7d
47 changed files with 1466 additions and 1220 deletions
11
Python/generated_cases.c.h
generated
11
Python/generated_cases.c.h
generated
|
@ -2222,7 +2222,7 @@
|
|||
JUMP_TO_PREDICTED(CALL);
|
||||
}
|
||||
// CPython promises to check all non-vectorcall function calls.
|
||||
if (_Py_ReachedRecursionLimit(tstate)) {
|
||||
if (tstate->c_recursion_remaining <= 0) {
|
||||
UPDATE_MISS_STATS(CALL);
|
||||
assert(_PyOpcode_Deopt[opcode] == (CALL));
|
||||
JUMP_TO_PREDICTED(CALL);
|
||||
|
@ -2230,6 +2230,7 @@
|
|||
STAT_INC(CALL, hit);
|
||||
PyCFunction cfunc = PyCFunction_GET_FUNCTION(callable_o);
|
||||
_PyStackRef arg = args[0];
|
||||
_Py_EnterRecursiveCallTstateUnchecked(tstate);
|
||||
_PyFrame_SetStackPointer(frame, stack_pointer);
|
||||
PyObject *res_o = _PyCFunction_TrampolineCall(cfunc, PyCFunction_GET_SELF(callable_o), PyStackRef_AsPyObjectBorrow(arg));
|
||||
stack_pointer = _PyFrame_GetStackPointer(frame);
|
||||
|
@ -3598,13 +3599,14 @@
|
|||
JUMP_TO_PREDICTED(CALL);
|
||||
}
|
||||
// CPython promises to check all non-vectorcall function calls.
|
||||
if (_Py_ReachedRecursionLimit(tstate)) {
|
||||
if (tstate->c_recursion_remaining <= 0) {
|
||||
UPDATE_MISS_STATS(CALL);
|
||||
assert(_PyOpcode_Deopt[opcode] == (CALL));
|
||||
JUMP_TO_PREDICTED(CALL);
|
||||
}
|
||||
STAT_INC(CALL, hit);
|
||||
PyCFunction cfunc = meth->ml_meth;
|
||||
_Py_EnterRecursiveCallTstateUnchecked(tstate);
|
||||
_PyFrame_SetStackPointer(frame, stack_pointer);
|
||||
PyObject *res_o = _PyCFunction_TrampolineCall(cfunc, self, NULL);
|
||||
stack_pointer = _PyFrame_GetStackPointer(frame);
|
||||
|
@ -3694,7 +3696,7 @@
|
|||
JUMP_TO_PREDICTED(CALL);
|
||||
}
|
||||
// CPython promises to check all non-vectorcall function calls.
|
||||
if (_Py_ReachedRecursionLimit(tstate)) {
|
||||
if (tstate->c_recursion_remaining <= 0) {
|
||||
UPDATE_MISS_STATS(CALL);
|
||||
assert(_PyOpcode_Deopt[opcode] == (CALL));
|
||||
JUMP_TO_PREDICTED(CALL);
|
||||
|
@ -3709,6 +3711,7 @@
|
|||
}
|
||||
STAT_INC(CALL, hit);
|
||||
PyCFunction cfunc = meth->ml_meth;
|
||||
_Py_EnterRecursiveCallTstateUnchecked(tstate);
|
||||
_PyFrame_SetStackPointer(frame, stack_pointer);
|
||||
PyObject *res_o = _PyCFunction_TrampolineCall(cfunc,
|
||||
PyStackRef_AsPyObjectBorrow(self_stackref),
|
||||
|
@ -7289,6 +7292,7 @@
|
|||
/* Restore previous frame and return. */
|
||||
tstate->current_frame = frame->previous;
|
||||
assert(!_PyErr_Occurred(tstate));
|
||||
tstate->c_recursion_remaining += PY_EVAL_C_STACK_UNITS;
|
||||
PyObject *result = PyStackRef_AsPyObjectSteal(retval);
|
||||
stack_pointer += -1;
|
||||
assert(WITHIN_STACK_BOUNDS());
|
||||
|
@ -12077,6 +12081,7 @@ JUMP_TO_LABEL(error);
|
|||
if (frame->owner == FRAME_OWNED_BY_INTERPRETER) {
|
||||
/* Restore previous frame and exit */
|
||||
tstate->current_frame = frame->previous;
|
||||
tstate->c_recursion_remaining += PY_EVAL_C_STACK_UNITS;
|
||||
return NULL;
|
||||
}
|
||||
next_instr = frame->instr_ptr;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue