mirror of
https://github.com/python/cpython.git
synced 2025-08-04 08:59:19 +00:00
bpo-43760: Check for tracing using 'bitwise or' instead of branch in dispatch. (GH-28723)
This commit is contained in:
parent
ef6196028f
commit
bd627eb7ed
7 changed files with 249 additions and 217 deletions
453
Python/ceval.c
453
Python/ceval.c
File diff suppressed because it is too large
Load diff
|
@ -32,6 +32,7 @@ def write_contents(f):
|
|||
"""
|
||||
opcode = find_module('opcode')
|
||||
targets = ['_unknown_opcode'] * 256
|
||||
targets[255] = "TARGET_DO_TRACING"
|
||||
for opname, op in opcode.opmap.items():
|
||||
targets[op] = "TARGET_%s" % opname
|
||||
next_op = 1
|
||||
|
|
2
Python/opcode_targets.h
generated
2
Python/opcode_targets.h
generated
|
@ -254,5 +254,5 @@ static void *opcode_targets[256] = {
|
|||
&&_unknown_opcode,
|
||||
&&_unknown_opcode,
|
||||
&&_unknown_opcode,
|
||||
&&_unknown_opcode
|
||||
&&TARGET_DO_TRACING
|
||||
};
|
||||
|
|
|
@ -268,7 +268,7 @@ sys_audit_tstate(PyThreadState *ts, const char *event,
|
|||
break;
|
||||
}
|
||||
if (canTrace) {
|
||||
ts->cframe->use_tracing = (ts->c_tracefunc || ts->c_profilefunc);
|
||||
ts->cframe->use_tracing = (ts->c_tracefunc || ts->c_profilefunc) ? 255 : 0;
|
||||
ts->tracing--;
|
||||
}
|
||||
PyObject* args[2] = {eventName, eventArgs};
|
||||
|
@ -283,7 +283,7 @@ sys_audit_tstate(PyThreadState *ts, const char *event,
|
|||
Py_DECREF(o);
|
||||
Py_CLEAR(hook);
|
||||
}
|
||||
ts->cframe->use_tracing = (ts->c_tracefunc || ts->c_profilefunc);
|
||||
ts->cframe->use_tracing = (ts->c_tracefunc || ts->c_profilefunc) ? 255 : 0;
|
||||
ts->tracing--;
|
||||
if (_PyErr_Occurred(ts)) {
|
||||
goto exit;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue