blob: 7522bf10b03e2fcbf26b9c67bebd41e56bff310b [file] [log] [blame]
Xiao Guangrong0007ece2012-09-17 16:31:14 +08001#ifndef __PERF_STATS_H
2#define __PERF_STATS_H
3
Borislav Petkovd944c4e2014-04-25 21:31:02 +02004#include <linux/types.h>
Jiri Olsaf87027b2015-06-03 16:25:59 +02005#include <stdio.h>
Jiri Olsaa8e02322015-06-26 11:29:10 +02006#include "xyarray.h"
Xiao Guangrong0007ece2012-09-17 16:31:14 +08007
8struct stats
9{
10 double n, mean, M2;
David Ahernffe4f3c2013-08-02 14:05:40 -060011 u64 max, min;
Xiao Guangrong0007ece2012-09-17 16:31:14 +080012};
13
Jiri Olsae2f56da2015-06-04 15:50:55 +020014enum perf_stat_evsel_id {
15 PERF_STAT_EVSEL_ID__NONE = 0,
Jiri Olsa4c358d52015-06-03 16:25:52 +020016 PERF_STAT_EVSEL_ID__CYCLES_IN_TX,
17 PERF_STAT_EVSEL_ID__TRANSACTION_START,
18 PERF_STAT_EVSEL_ID__ELISION_START,
19 PERF_STAT_EVSEL_ID__CYCLES_IN_TX_CP,
Andi Kleen239bd472016-05-24 12:52:37 -070020 PERF_STAT_EVSEL_ID__TOPDOWN_TOTAL_SLOTS,
21 PERF_STAT_EVSEL_ID__TOPDOWN_SLOTS_ISSUED,
22 PERF_STAT_EVSEL_ID__TOPDOWN_SLOTS_RETIRED,
23 PERF_STAT_EVSEL_ID__TOPDOWN_FETCH_BUBBLES,
24 PERF_STAT_EVSEL_ID__TOPDOWN_RECOVERY_BUBBLES,
Kan Liangdaefd0b2017-05-26 12:05:38 -070025 PERF_STAT_EVSEL_ID__SMI_NUM,
26 PERF_STAT_EVSEL_ID__APERF,
Jiri Olsae2f56da2015-06-04 15:50:55 +020027 PERF_STAT_EVSEL_ID__MAX,
28};
29
Jiri Olsa581cc8a2015-10-16 12:41:03 +020030struct perf_stat_evsel {
Jiri Olsae2f56da2015-06-04 15:50:55 +020031 struct stats res_stats[3];
32 enum perf_stat_evsel_id id;
33};
34
Jiri Olsaf87027b2015-06-03 16:25:59 +020035enum aggr_mode {
36 AGGR_NONE,
37 AGGR_GLOBAL,
38 AGGR_SOCKET,
39 AGGR_CORE,
Jiri Olsa32b8af82015-06-26 11:29:27 +020040 AGGR_THREAD,
Jiri Olsa208df992015-10-16 12:41:04 +020041 AGGR_UNSET,
Jiri Olsaf87027b2015-06-03 16:25:59 +020042};
43
Jiri Olsa421a50f2015-07-21 14:31:22 +020044struct perf_stat_config {
45 enum aggr_mode aggr_mode;
Jiri Olsa711a5722015-07-21 14:31:23 +020046 bool scale;
Jiri Olsa58215222015-07-21 14:31:24 +020047 FILE *output;
Jiri Olsaec0d3d12015-07-21 14:31:25 +020048 unsigned int interval;
Jiri Olsa421a50f2015-07-21 14:31:22 +020049};
50
Xiao Guangrong0007ece2012-09-17 16:31:14 +080051void update_stats(struct stats *stats, u64 val);
52double avg_stats(struct stats *stats);
53double stddev_stats(struct stats *stats);
54double rel_stddev_stats(double stddev, double avg);
55
David Ahernffe4f3c2013-08-02 14:05:40 -060056static inline void init_stats(struct stats *stats)
57{
58 stats->n = 0.0;
59 stats->mean = 0.0;
60 stats->M2 = 0.0;
61 stats->min = (u64) -1;
62 stats->max = 0;
63}
Jiri Olsae2f56da2015-06-04 15:50:55 +020064
65struct perf_evsel;
Jiri Olsa24e34f62015-06-26 11:29:16 +020066struct perf_evlist;
67
Jiri Olsae2f56da2015-06-04 15:50:55 +020068bool __perf_evsel_stat__is(struct perf_evsel *evsel,
69 enum perf_stat_evsel_id id);
70
71#define perf_stat_evsel__is(evsel, id) \
72 __perf_evsel_stat__is(evsel, PERF_STAT_EVSEL_ID__ ## id)
73
74void perf_stat_evsel_id_init(struct perf_evsel *evsel);
75
Jiri Olsaf87027b2015-06-03 16:25:59 +020076extern struct stats walltime_nsecs_stats;
77
Andi Kleen140aead2016-01-30 09:06:49 -080078typedef void (*print_metric_t)(void *ctx, const char *color, const char *unit,
79 const char *fmt, double val);
80typedef void (*new_line_t )(void *ctx);
81
Andi Kleenfb4605b2016-03-01 10:57:52 -080082void perf_stat__init_shadow_stats(void);
Jiri Olsaf87027b2015-06-03 16:25:59 +020083void perf_stat__reset_shadow_stats(void);
84void perf_stat__update_shadow_stats(struct perf_evsel *counter, u64 *count,
85 int cpu);
Andi Kleen140aead2016-01-30 09:06:49 -080086struct perf_stat_output_ctx {
87 void *ctx;
88 print_metric_t print_metric;
89 new_line_t new_line;
Andi Kleen37932c12017-03-20 13:17:08 -070090 bool force_header;
Andi Kleen140aead2016-01-30 09:06:49 -080091};
92
93void perf_stat__print_shadow_stats(struct perf_evsel *evsel,
94 double avg, int cpu,
95 struct perf_stat_output_ctx *out);
Andi Kleen37932c12017-03-20 13:17:08 -070096void perf_stat__collect_metric_expr(struct perf_evlist *);
Jiri Olsaf87027b2015-06-03 16:25:59 +020097
Jiri Olsa24e34f62015-06-26 11:29:16 +020098int perf_evlist__alloc_stats(struct perf_evlist *evlist, bool alloc_raw);
99void perf_evlist__free_stats(struct perf_evlist *evlist);
100void perf_evlist__reset_stats(struct perf_evlist *evlist);
Jiri Olsaf80010e2015-07-21 14:31:27 +0200101
102int perf_stat_process_counter(struct perf_stat_config *config,
103 struct perf_evsel *counter);
Jiri Olsa0ea0e352015-10-25 15:51:32 +0100104struct perf_tool;
105union perf_event;
106struct perf_session;
107int perf_event__process_stat_event(struct perf_tool *tool,
108 union perf_event *event,
109 struct perf_session *session);
Jiri Olsae08a4562015-10-25 15:51:35 +0100110
111size_t perf_event__fprintf_stat(union perf_event *event, FILE *fp);
112size_t perf_event__fprintf_stat_round(union perf_event *event, FILE *fp);
113size_t perf_event__fprintf_stat_config(union perf_event *event, FILE *fp);
Xiao Guangrong0007ece2012-09-17 16:31:14 +0800114#endif