summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Shannon <mark@hotpy.org>2022-02-10 15:55:52 (GMT)
committerGitHub <noreply@github.com>2022-02-10 15:55:52 (GMT)
commit1a6411f5738895fa48d35a93435f7c7b6c17bdb9 (patch)
tree7a845e0e2d395ee07079cc604081c1dd5d72a7e0
parente19059ecd80d39dca378cd19f72c5008b1957976 (diff)
downloadcpython-1a6411f5738895fa48d35a93435f7c7b6c17bdb9.zip
cpython-1a6411f5738895fa48d35a93435f7c7b6c17bdb9.tar.gz
cpython-1a6411f5738895fa48d35a93435f7c7b6c17bdb9.tar.bz2
Gather stats for PRECALL_METHOD. (GH-31259)
-rw-r--r--Python/ceval.c15
-rw-r--r--Python/specialize.c1
2 files changed, 14 insertions, 2 deletions
diff --git a/Python/ceval.c b/Python/ceval.c
index c3703a7..ffce6b7 100644
--- a/Python/ceval.c
+++ b/Python/ceval.c
@@ -4451,8 +4451,11 @@ handle_eval_breaker:
assert(call_shape.kwnames == NULL);
#ifdef Py_STATS
extern int _PySpecialization_ClassifyCallable(PyObject *);
- _py_stats.opcode_stats[PRECALL_FUNCTION].specialization.failure++;
- _py_stats.opcode_stats[PRECALL_FUNCTION].specialization.failure_kinds[_PySpecialization_ClassifyCallable(call_shape.callable)]++;
+ SpecializationStats *stats =
+ &_py_stats.opcode_stats[PRECALL_FUNCTION].specialization;
+ stats->failure++;
+ int kind = _PySpecialization_ClassifyCallable(call_shape.callable);
+ stats->failure_kinds[kind]++;
#endif
DISPATCH();
}
@@ -4493,6 +4496,14 @@ handle_eval_breaker:
call_shape.total_args = nargs;
assert(call_shape.kwnames == NULL);
+#ifdef Py_STATS
+ extern int _PySpecialization_ClassifyCallable(PyObject *);
+ SpecializationStats *stats =
+ &_py_stats.opcode_stats[PRECALL_METHOD].specialization;
+ stats->failure++;
+ int kind = _PySpecialization_ClassifyCallable(call_shape.callable);
+ stats->failure_kinds[kind]++;
+#endif
DISPATCH();
}
diff --git a/Python/specialize.c b/Python/specialize.c
index 940ab17..b051f45 100644
--- a/Python/specialize.c
+++ b/Python/specialize.c
@@ -176,6 +176,7 @@ print_spec_stats(FILE *out, OpcodeStats *stats)
* even though we don't specialize them yet. */
fprintf(out, " opcode[%d].specializable : 1\n", FOR_ITER);
fprintf(out, " opcode[%d].specializable : 1\n", PRECALL_FUNCTION);
+ fprintf(out, " opcode[%d].specializable : 1\n", PRECALL_METHOD);
fprintf(out, " opcode[%d].specializable : 1\n", UNPACK_SEQUENCE);
for (int i = 0; i < 256; i++) {
if (adaptive_opcodes[i]) {