blob: 6f0fa05b62b6e2196a3c75021dfe799eb34115a4 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Alexander Yarygin9daa8122014-07-03 18:29:05 +04002#ifndef __PERF_KVM_STAT_H
3#define __PERF_KVM_STAT_H
4
Anju T Sudhakar8067b3d2019-07-18 23:47:47 +05305#ifdef HAVE_KVM_STAT_SUPPORT
6
Alexander Yarygin9daa8122014-07-03 18:29:05 +04007#include "tool.h"
8#include "stat.h"
Arnaldo Carvalho de Meloaeb00b12019-08-22 15:40:29 -03009#include "record.h"
Alexander Yarygin9daa8122014-07-03 18:29:05 +040010
Jiri Olsa32dcd022019-07-21 13:23:51 +020011struct evsel;
Jiri Olsa63503db2019-07-21 13:23:52 +020012struct evlist;
Arnaldo Carvalho de Melo56919032019-01-29 12:42:55 +010013struct perf_session;
14
Alexander Yarygin9daa8122014-07-03 18:29:05 +040015struct event_key {
16 #define INVALID_KEY (~0ULL)
17 u64 key;
18 int info;
Alexander Yarygin3be8e2a2014-07-03 18:29:07 +040019 struct exit_reasons_table *exit_reasons;
Alexander Yarygin9daa8122014-07-03 18:29:05 +040020};
21
22struct kvm_event_stats {
23 u64 time;
24 struct stats stats;
25};
26
27struct kvm_event {
28 struct list_head hash_entry;
29 struct rb_node rb;
30
31 struct event_key key;
32
33 struct kvm_event_stats total;
34
35 #define DEFAULT_VCPU_NUM 8
36 int max_vcpu;
37 struct kvm_event_stats *vcpu;
38};
39
40typedef int (*key_cmp_fun)(struct kvm_event*, struct kvm_event*, int);
41
42struct kvm_event_key {
43 const char *name;
44 key_cmp_fun key;
45};
46
47struct perf_kvm_stat;
48
Alexander Yarygin3be8e2a2014-07-03 18:29:07 +040049struct child_event_ops {
Jiri Olsa32dcd022019-07-21 13:23:51 +020050 void (*get_key)(struct evsel *evsel,
Alexander Yarygin3be8e2a2014-07-03 18:29:07 +040051 struct perf_sample *sample,
52 struct event_key *key);
53 const char *name;
54};
55
Alexander Yarygin9daa8122014-07-03 18:29:05 +040056struct kvm_events_ops {
Jiri Olsa32dcd022019-07-21 13:23:51 +020057 bool (*is_begin_event)(struct evsel *evsel,
Alexander Yarygin9daa8122014-07-03 18:29:05 +040058 struct perf_sample *sample,
59 struct event_key *key);
Jiri Olsa32dcd022019-07-21 13:23:51 +020060 bool (*is_end_event)(struct evsel *evsel,
Alexander Yarygin9daa8122014-07-03 18:29:05 +040061 struct perf_sample *sample, struct event_key *key);
Alexander Yarygin3be8e2a2014-07-03 18:29:07 +040062 struct child_event_ops *child_ops;
Alexander Yarygin9daa8122014-07-03 18:29:05 +040063 void (*decode_key)(struct perf_kvm_stat *kvm, struct event_key *key,
64 char *decode);
65 const char *name;
66};
67
68struct exit_reasons_table {
69 unsigned long exit_code;
70 const char *reason;
71};
72
73#define EVENTS_BITS 12
74#define EVENTS_CACHE_SIZE (1UL << EVENTS_BITS)
75
76struct perf_kvm_stat {
77 struct perf_tool tool;
78 struct record_opts opts;
Jiri Olsa63503db2019-07-21 13:23:52 +020079 struct evlist *evlist;
Alexander Yarygin9daa8122014-07-03 18:29:05 +040080 struct perf_session *session;
81
82 const char *file_name;
83 const char *report_event;
84 const char *sort_key;
85 int trace_vcpu;
86
87 struct exit_reasons_table *exit_reasons;
88 const char *exit_reasons_isa;
89
90 struct kvm_events_ops *events_ops;
91 key_cmp_fun compare;
92 struct list_head kvm_events_cache[EVENTS_CACHE_SIZE];
93
94 u64 total_time;
95 u64 total_count;
96 u64 lost_events;
97 u64 duration;
98
Alexander Yarygin9daa8122014-07-03 18:29:05 +040099 struct intlist *pid_list;
100
101 struct rb_root result;
102
103 int timerfd;
104 unsigned int display_time;
105 bool live;
Yunlong Song8cc5ec1f2015-04-02 21:47:13 +0800106 bool force;
Alexander Yarygin9daa8122014-07-03 18:29:05 +0400107};
108
109struct kvm_reg_events_ops {
110 const char *name;
111 struct kvm_events_ops *ops;
112};
113
Jiri Olsa32dcd022019-07-21 13:23:51 +0200114void exit_event_get_key(struct evsel *evsel,
Alexander Yarygin9daa8122014-07-03 18:29:05 +0400115 struct perf_sample *sample,
116 struct event_key *key);
Jiri Olsa32dcd022019-07-21 13:23:51 +0200117bool exit_event_begin(struct evsel *evsel,
Alexander Yarygin9daa8122014-07-03 18:29:05 +0400118 struct perf_sample *sample,
119 struct event_key *key);
Jiri Olsa32dcd022019-07-21 13:23:51 +0200120bool exit_event_end(struct evsel *evsel,
Alexander Yarygin9daa8122014-07-03 18:29:05 +0400121 struct perf_sample *sample,
122 struct event_key *key);
123void exit_event_decode_key(struct perf_kvm_stat *kvm,
124 struct event_key *key,
125 char *decode);
126
Jiri Olsa32dcd022019-07-21 13:23:51 +0200127bool kvm_exit_event(struct evsel *evsel);
128bool kvm_entry_event(struct evsel *evsel);
Hemant Kumar066d3592016-01-28 12:03:06 +0530129int setup_kvm_events_tp(struct perf_kvm_stat *kvm);
Alexander Yarygin9daa8122014-07-03 18:29:05 +0400130
131#define define_exit_reasons_table(name, symbols) \
132 static struct exit_reasons_table name[] = { \
133 symbols, { -1, NULL } \
134 }
135
136/*
137 * arch specific callbacks and data structures
138 */
139int cpu_isa_init(struct perf_kvm_stat *kvm, const char *cpuid);
140
Hemant Kumar48deaa72016-01-28 12:03:05 +0530141extern const char *kvm_events_tp[];
Alexander Yarygin9daa8122014-07-03 18:29:05 +0400142extern struct kvm_reg_events_ops kvm_reg_events_ops[];
Alexander Yarygin54c801f2014-07-03 18:29:06 +0400143extern const char * const kvm_skip_events[];
Hemant Kumar162607e2016-01-28 12:03:04 +0530144extern const char *vcpu_id_str;
145extern const int decode_str_len;
146extern const char *kvm_exit_reason;
147extern const char *kvm_entry_trace;
148extern const char *kvm_exit_trace;
Anju T Sudhakar8067b3d2019-07-18 23:47:47 +0530149#endif /* HAVE_KVM_STAT_SUPPORT */
Alexander Yarygin9daa8122014-07-03 18:29:05 +0400150
Anju T Sudhakar124eb5f2019-07-18 23:47:48 +0530151extern int kvm_add_default_arch_event(int *argc, const char **argv);
Alexander Yarygin9daa8122014-07-03 18:29:05 +0400152#endif /* __PERF_KVM_STAT_H */