diff options
| -rw-r--r-- | tools/perf/builtin-kvm.c | 27 |
1 files changed, 12 insertions, 15 deletions
diff --git a/tools/perf/builtin-kvm.c b/tools/perf/builtin-kvm.c index 214ec0e7492b..75f354459005 100644 --- a/tools/perf/builtin-kvm.c +++ b/tools/perf/builtin-kvm.c | |||
| @@ -99,7 +99,6 @@ struct perf_kvm_stat { | |||
| 99 | int trace_vcpu; | 99 | int trace_vcpu; |
| 100 | 100 | ||
| 101 | struct exit_reasons_table *exit_reasons; | 101 | struct exit_reasons_table *exit_reasons; |
| 102 | int exit_reasons_size; | ||
| 103 | const char *exit_reasons_isa; | 102 | const char *exit_reasons_isa; |
| 104 | 103 | ||
| 105 | struct kvm_events_ops *events_ops; | 104 | struct kvm_events_ops *events_ops; |
| @@ -158,20 +157,19 @@ static bool exit_event_end(struct perf_evsel *evsel, | |||
| 158 | return kvm_entry_event(evsel); | 157 | return kvm_entry_event(evsel); |
| 159 | } | 158 | } |
| 160 | 159 | ||
| 161 | static struct exit_reasons_table vmx_exit_reasons[] = { | 160 | #define define_exit_reasons_table(name, symbols) \ |
| 162 | VMX_EXIT_REASONS | 161 | static struct exit_reasons_table name[] = { \ |
| 163 | }; | 162 | symbols, { -1, NULL } \ |
| 163 | } | ||
| 164 | 164 | ||
| 165 | static struct exit_reasons_table svm_exit_reasons[] = { | 165 | define_exit_reasons_table(vmx_exit_reasons, VMX_EXIT_REASONS); |
| 166 | SVM_EXIT_REASONS | 166 | define_exit_reasons_table(svm_exit_reasons, SVM_EXIT_REASONS); |
| 167 | }; | ||
| 168 | 167 | ||
| 169 | static const char *get_exit_reason(struct perf_kvm_stat *kvm, u64 exit_code) | 168 | static const char *get_exit_reason(struct perf_kvm_stat *kvm, |
| 169 | struct exit_reasons_table *tbl, | ||
| 170 | u64 exit_code) | ||
| 170 | { | 171 | { |
| 171 | int i = kvm->exit_reasons_size; | 172 | while (tbl->reason != NULL) { |
| 172 | struct exit_reasons_table *tbl = kvm->exit_reasons; | ||
| 173 | |||
| 174 | while (i--) { | ||
| 175 | if (tbl->exit_code == exit_code) | 173 | if (tbl->exit_code == exit_code) |
| 176 | return tbl->reason; | 174 | return tbl->reason; |
| 177 | tbl++; | 175 | tbl++; |
| @@ -186,7 +184,8 @@ static void exit_event_decode_key(struct perf_kvm_stat *kvm, | |||
| 186 | struct event_key *key, | 184 | struct event_key *key, |
| 187 | char decode[20]) | 185 | char decode[20]) |
| 188 | { | 186 | { |
| 189 | const char *exit_reason = get_exit_reason(kvm, key->key); | 187 | const char *exit_reason = get_exit_reason(kvm, kvm->exit_reasons, |
| 188 | key->key); | ||
| 190 | 189 | ||
| 191 | scnprintf(decode, 20, "%s", exit_reason); | 190 | scnprintf(decode, 20, "%s", exit_reason); |
| 192 | } | 191 | } |
| @@ -862,7 +861,6 @@ static int cpu_isa_config(struct perf_kvm_stat *kvm) | |||
| 862 | 861 | ||
| 863 | if (isa == 1) { | 862 | if (isa == 1) { |
| 864 | kvm->exit_reasons = vmx_exit_reasons; | 863 | kvm->exit_reasons = vmx_exit_reasons; |
| 865 | kvm->exit_reasons_size = ARRAY_SIZE(vmx_exit_reasons); | ||
| 866 | kvm->exit_reasons_isa = "VMX"; | 864 | kvm->exit_reasons_isa = "VMX"; |
| 867 | } | 865 | } |
| 868 | 866 | ||
| @@ -1586,7 +1584,6 @@ static int kvm_cmd_stat(const char *file_name, int argc, const char **argv) | |||
| 1586 | .sort_key = "sample", | 1584 | .sort_key = "sample", |
| 1587 | 1585 | ||
| 1588 | .exit_reasons = svm_exit_reasons, | 1586 | .exit_reasons = svm_exit_reasons, |
| 1589 | .exit_reasons_size = ARRAY_SIZE(svm_exit_reasons), | ||
| 1590 | .exit_reasons_isa = "SVM", | 1587 | .exit_reasons_isa = "SVM", |
| 1591 | }; | 1588 | }; |
| 1592 | 1589 | ||
