gh-115178: Add Counts of UOp Pairs to pystats (GH-115181)

This commit is contained in:
Jeff Glass 2024-04-16 08:27:18 -05:00 committed by GitHub
parent c053d52edd
commit acf69e09c6
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
6 changed files with 26 additions and 4 deletions

View file

@ -100,6 +100,7 @@ typedef struct _gc_stats {
typedef struct _uop_stats { typedef struct _uop_stats {
uint64_t execution_count; uint64_t execution_count;
uint64_t miss; uint64_t miss;
uint64_t pair_count[MAX_UOP_ID + 1];
} UOpStats; } UOpStats;
#define _Py_UOP_HIST_SIZE 32 #define _Py_UOP_HIST_SIZE 32

View file

@ -310,6 +310,13 @@ extern int _PyStaticCode_Init(PyCodeObject *co);
#define GC_STAT_ADD(gen, name, n) do { if (_Py_stats) _Py_stats->gc_stats[(gen)].name += (n); } while (0) #define GC_STAT_ADD(gen, name, n) do { if (_Py_stats) _Py_stats->gc_stats[(gen)].name += (n); } while (0)
#define OPT_STAT_INC(name) do { if (_Py_stats) _Py_stats->optimization_stats.name++; } while (0) #define OPT_STAT_INC(name) do { if (_Py_stats) _Py_stats->optimization_stats.name++; } while (0)
#define UOP_STAT_INC(opname, name) do { if (_Py_stats) { assert(opname < 512); _Py_stats->optimization_stats.opcode[opname].name++; } } while (0) #define UOP_STAT_INC(opname, name) do { if (_Py_stats) { assert(opname < 512); _Py_stats->optimization_stats.opcode[opname].name++; } } while (0)
#define UOP_PAIR_INC(uopcode, lastuop) \
do { \
if (lastuop && _Py_stats) { \
_Py_stats->optimization_stats.opcode[lastuop].pair_count[uopcode]++; \
} \
lastuop = uopcode; \
} while (0)
#define OPT_UNSUPPORTED_OPCODE(opname) do { if (_Py_stats) _Py_stats->optimization_stats.unsupported_opcode[opname]++; } while (0) #define OPT_UNSUPPORTED_OPCODE(opname) do { if (_Py_stats) _Py_stats->optimization_stats.unsupported_opcode[opname]++; } while (0)
#define OPT_ERROR_IN_OPCODE(opname) do { if (_Py_stats) _Py_stats->optimization_stats.error_in_opcode[opname]++; } while (0) #define OPT_ERROR_IN_OPCODE(opname) do { if (_Py_stats) _Py_stats->optimization_stats.error_in_opcode[opname]++; } while (0)
#define OPT_HIST(length, name) \ #define OPT_HIST(length, name) \
@ -337,6 +344,7 @@ PyAPI_FUNC(PyObject*) _Py_GetSpecializationStats(void);
#define GC_STAT_ADD(gen, name, n) ((void)0) #define GC_STAT_ADD(gen, name, n) ((void)0)
#define OPT_STAT_INC(name) ((void)0) #define OPT_STAT_INC(name) ((void)0)
#define UOP_STAT_INC(opname, name) ((void)0) #define UOP_STAT_INC(opname, name) ((void)0)
#define UOP_PAIR_INC(uopcode, lastuop) ((void)0)
#define OPT_UNSUPPORTED_OPCODE(opname) ((void)0) #define OPT_UNSUPPORTED_OPCODE(opname) ((void)0)
#define OPT_ERROR_IN_OPCODE(opname) ((void)0) #define OPT_ERROR_IN_OPCODE(opname) ((void)0)
#define OPT_HIST(length, name) ((void)0) #define OPT_HIST(length, name) ((void)0)

View file

@ -642,6 +642,7 @@ Neil Girdhar
Matt Giuca Matt Giuca
Andrea Giudiceandrea Andrea Giudiceandrea
Franz Glasner Franz Glasner
Jeff Glass
Wim Glenn Wim Glenn
Michael Goderbauer Michael Goderbauer
Karan Goel Karan Goel

View file

@ -995,6 +995,7 @@ _PyEval_EvalFrameDefault(PyThreadState *tstate, _PyInterpreterFrame *frame, int
; // dummy statement after a label, before a declaration ; // dummy statement after a label, before a declaration
uint16_t uopcode; uint16_t uopcode;
#ifdef Py_STATS #ifdef Py_STATS
int lastuop = 0;
uint64_t trace_uop_execution_counter = 0; uint64_t trace_uop_execution_counter = 0;
#endif #endif
@ -1018,6 +1019,7 @@ _PyEval_EvalFrameDefault(PyThreadState *tstate, _PyInterpreterFrame *frame, int
next_uop++; next_uop++;
OPT_STAT_INC(uops_executed); OPT_STAT_INC(uops_executed);
UOP_STAT_INC(uopcode, execution_count); UOP_STAT_INC(uopcode, execution_count);
UOP_PAIR_INC(uopcode, lastuop);
#ifdef Py_STATS #ifdef Py_STATS
trace_uop_execution_counter++; trace_uop_execution_counter++;
#endif #endif

View file

@ -11,6 +11,7 @@
#include "pycore_object.h" #include "pycore_object.h"
#include "pycore_opcode_metadata.h" // _PyOpcode_Caches #include "pycore_opcode_metadata.h" // _PyOpcode_Caches
#include "pycore_uop_metadata.h" // _PyOpcode_uop_name #include "pycore_uop_metadata.h" // _PyOpcode_uop_name
#include "pycore_uop_ids.h" // MAX_UOP_ID
#include "pycore_opcode_utils.h" // RESUME_AT_FUNC_START #include "pycore_opcode_utils.h" // RESUME_AT_FUNC_START
#include "pycore_pylifecycle.h" // _PyOS_URandomNonblock() #include "pycore_pylifecycle.h" // _PyOS_URandomNonblock()
#include "pycore_runtime.h" // _Py_ID() #include "pycore_runtime.h" // _Py_ID()
@ -269,6 +270,14 @@ print_optimization_stats(FILE *out, OptimizationStats *stats)
} }
} }
for (int i = 1; i <= MAX_UOP_ID; i++){
for (int j = 1; j <= MAX_UOP_ID; j++) {
if (stats->opcode[i].pair_count[j]) {
fprintf(out, "uop[%s].pair_count[%s] : %" PRIu64 "\n",
_PyOpcode_uop_name[i], _PyOpcode_uop_name[j], stats->opcode[i].pair_count[j]);
}
}
}
for (int i = 0; i < MAX_UOP_ID; i++) { for (int i = 0; i < MAX_UOP_ID; i++) {
if (stats->error_in_opcode[i]) { if (stats->error_in_opcode[i]) {
fprintf( fprintf(

View file

@ -736,9 +736,9 @@ def execution_count_section() -> Section:
) )
def pair_count_section() -> Section: def pair_count_section(prefix: str, title=None) -> Section:
def calc_pair_count_table(stats: Stats) -> Rows: def calc_pair_count_table(stats: Stats) -> Rows:
opcode_stats = stats.get_opcode_stats("opcode") opcode_stats = stats.get_opcode_stats(prefix)
pair_counts = opcode_stats.get_pair_counts() pair_counts = opcode_stats.get_pair_counts()
total = opcode_stats.get_total_execution_count() total = opcode_stats.get_total_execution_count()
@ -760,7 +760,7 @@ def calc_pair_count_table(stats: Stats) -> Rows:
return Section( return Section(
"Pair counts", "Pair counts",
"Pair counts for top 100 Tier 1 instructions", f"Pair counts for top 100 {title if title else prefix} pairs",
[ [
Table( Table(
("Pair", "Count:", "Self:", "Cumulative:"), ("Pair", "Count:", "Self:", "Cumulative:"),
@ -1232,6 +1232,7 @@ def iter_optimization_tables(base_stats: Stats, head_stats: Stats | None = None)
) )
], ],
) )
yield pair_count_section(prefix="uop", title="Non-JIT uop")
yield Section( yield Section(
"Unsupported opcodes", "Unsupported opcodes",
"", "",
@ -1292,7 +1293,7 @@ def calc_rows(stats: Stats) -> Rows:
LAYOUT = [ LAYOUT = [
execution_count_section(), execution_count_section(),
pair_count_section(), pair_count_section("opcode"),
pre_succ_pairs_section(), pre_succ_pairs_section(),
specialization_section(), specialization_section(),
specialization_effectiveness_section(), specialization_effectiveness_section(),