mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00
gh-109094: remove unnecessary updates of frame->prev_instr in instrumentation functions (#109076)
This commit is contained in:
parent
403ab1306a
commit
96396962ce
2 changed files with 11 additions and 6 deletions
|
@ -1057,8 +1057,6 @@ _Py_call_instrumentation_jump(
|
|||
assert(event == PY_MONITORING_EVENT_JUMP ||
|
||||
event == PY_MONITORING_EVENT_BRANCH);
|
||||
assert(frame->prev_instr == instr);
|
||||
/* Event should occur after the jump */
|
||||
frame->prev_instr = target;
|
||||
PyCodeObject *code = _PyFrame_GetCode(frame);
|
||||
int to = (int)(target - _PyCode_CODE(code));
|
||||
PyObject *to_obj = PyLong_FromLong(to * (int)sizeof(_Py_CODEUNIT));
|
||||
|
@ -1071,12 +1069,10 @@ _Py_call_instrumentation_jump(
|
|||
if (err) {
|
||||
return NULL;
|
||||
}
|
||||
if (frame->prev_instr != target) {
|
||||
if (frame->prev_instr != instr) {
|
||||
/* The callback has caused a jump (by setting the line number) */
|
||||
return frame->prev_instr;
|
||||
}
|
||||
/* Reset prev_instr for INSTRUMENTED_LINE */
|
||||
frame->prev_instr = instr;
|
||||
return target;
|
||||
}
|
||||
|
||||
|
@ -1125,7 +1121,7 @@ _Py_Instrumentation_GetLine(PyCodeObject *code, int index)
|
|||
int
|
||||
_Py_call_instrumentation_line(PyThreadState *tstate, _PyInterpreterFrame* frame, _Py_CODEUNIT *instr, _Py_CODEUNIT *prev)
|
||||
{
|
||||
frame->prev_instr = instr;
|
||||
assert(frame->prev_instr == instr);
|
||||
PyCodeObject *code = _PyFrame_GetCode(frame);
|
||||
assert(is_version_up_to_date(code, tstate->interp));
|
||||
assert(instrumentation_cross_checks(tstate->interp, code));
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue