blob: 0b897b083682bb0eee9e400a1a3329ac3ee2374f [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,
Jiri Olsae2f56da2015-06-04 15:50:55 +020020 PERF_STAT_EVSEL_ID__MAX,
21};
22
23struct perf_stat {
24 struct stats res_stats[3];
25 enum perf_stat_evsel_id id;
26};
27
Jiri Olsaf87027b2015-06-03 16:25:59 +020028enum aggr_mode {
29 AGGR_NONE,
30 AGGR_GLOBAL,
31 AGGR_SOCKET,
32 AGGR_CORE,
Jiri Olsa32b8af82015-06-26 11:29:27 +020033 AGGR_THREAD,
Jiri Olsaf87027b2015-06-03 16:25:59 +020034};
35
Jiri Olsa1ac77e12015-06-26 11:29:09 +020036struct perf_counts_values {
37 union {
38 struct {
39 u64 val;
40 u64 ena;
41 u64 run;
42 };
43 u64 values[3];
44 };
45};
46
47struct perf_counts {
48 s8 scaled;
49 struct perf_counts_values aggr;
Jiri Olsa57b28912015-06-26 11:29:12 +020050 struct xyarray *values;
Jiri Olsa1ac77e12015-06-26 11:29:09 +020051};
52
Jiri Olsa421a50f2015-07-21 14:31:22 +020053struct perf_stat_config {
54 enum aggr_mode aggr_mode;
Jiri Olsa711a5722015-07-21 14:31:23 +020055 bool scale;
Jiri Olsa58215222015-07-21 14:31:24 +020056 FILE *output;
Jiri Olsaec0d3d12015-07-21 14:31:25 +020057 unsigned int interval;
Jiri Olsa421a50f2015-07-21 14:31:22 +020058};
59
Jiri Olsa1ac77e12015-06-26 11:29:09 +020060static inline struct perf_counts_values*
Jiri Olsaa6fa0032015-06-26 11:29:11 +020061perf_counts(struct perf_counts *counts, int cpu, int thread)
Jiri Olsa1ac77e12015-06-26 11:29:09 +020062{
Jiri Olsa57b28912015-06-26 11:29:12 +020063 return xyarray__entry(counts->values, cpu, thread);
Jiri Olsa1ac77e12015-06-26 11:29:09 +020064}
65
Xiao Guangrong0007ece2012-09-17 16:31:14 +080066void update_stats(struct stats *stats, u64 val);
67double avg_stats(struct stats *stats);
68double stddev_stats(struct stats *stats);
69double rel_stddev_stats(double stddev, double avg);
70
David Ahernffe4f3c2013-08-02 14:05:40 -060071static inline void init_stats(struct stats *stats)
72{
73 stats->n = 0.0;
74 stats->mean = 0.0;
75 stats->M2 = 0.0;
76 stats->min = (u64) -1;
77 stats->max = 0;
78}
Jiri Olsae2f56da2015-06-04 15:50:55 +020079
80struct perf_evsel;
Jiri Olsa24e34f62015-06-26 11:29:16 +020081struct perf_evlist;
82
Jiri Olsae2f56da2015-06-04 15:50:55 +020083bool __perf_evsel_stat__is(struct perf_evsel *evsel,
84 enum perf_stat_evsel_id id);
85
86#define perf_stat_evsel__is(evsel, id) \
87 __perf_evsel_stat__is(evsel, PERF_STAT_EVSEL_ID__ ## id)
88
89void perf_stat_evsel_id_init(struct perf_evsel *evsel);
90
Jiri Olsaf87027b2015-06-03 16:25:59 +020091extern struct stats walltime_nsecs_stats;
92
93void perf_stat__reset_shadow_stats(void);
94void perf_stat__update_shadow_stats(struct perf_evsel *counter, u64 *count,
95 int cpu);
96void perf_stat__print_shadow_stats(FILE *out, struct perf_evsel *evsel,
97 double avg, int cpu, enum aggr_mode aggr);
98
Jiri Olsaa6fa0032015-06-26 11:29:11 +020099struct perf_counts *perf_counts__new(int ncpus, int nthreads);
Jiri Olsa9df38e82015-06-14 10:19:27 +0200100void perf_counts__delete(struct perf_counts *counts);
101
Jiri Olsaa8e02322015-06-26 11:29:10 +0200102void perf_evsel__reset_counts(struct perf_evsel *evsel);
Jiri Olsaa6fa0032015-06-26 11:29:11 +0200103int perf_evsel__alloc_counts(struct perf_evsel *evsel, int ncpus, int nthreads);
Jiri Olsaa9a3a4d2015-06-14 10:19:26 +0200104void perf_evsel__free_counts(struct perf_evsel *evsel);
Jiri Olsa9689edf2015-06-26 11:29:14 +0200105
106void perf_evsel__reset_stat_priv(struct perf_evsel *evsel);
107int perf_evsel__alloc_stat_priv(struct perf_evsel *evsel);
108void perf_evsel__free_stat_priv(struct perf_evsel *evsel);
Jiri Olsaa9395122015-06-26 11:29:15 +0200109
110int perf_evsel__alloc_prev_raw_counts(struct perf_evsel *evsel,
111 int ncpus, int nthreads);
112void perf_evsel__free_prev_raw_counts(struct perf_evsel *evsel);
Jiri Olsa24e34f62015-06-26 11:29:16 +0200113
Jiri Olsaa7d0a102015-06-26 11:29:17 +0200114int perf_evsel__alloc_stats(struct perf_evsel *evsel, bool alloc_raw);
115
Jiri Olsa24e34f62015-06-26 11:29:16 +0200116int perf_evlist__alloc_stats(struct perf_evlist *evlist, bool alloc_raw);
117void perf_evlist__free_stats(struct perf_evlist *evlist);
118void perf_evlist__reset_stats(struct perf_evlist *evlist);
Jiri Olsaf80010e2015-07-21 14:31:27 +0200119
120int perf_stat_process_counter(struct perf_stat_config *config,
121 struct perf_evsel *counter);
Xiao Guangrong0007ece2012-09-17 16:31:14 +0800122#endif