From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758743Ab3EZA1B (ORCPT ); Sat, 25 May 2013 20:27:01 -0400 Received: from mail-pd0-f173.google.com ([209.85.192.173]:62461 "EHLO mail-pd0-f173.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1758474Ab3EZA06 (ORCPT ); Sat, 25 May 2013 20:26:58 -0400 From: David Ahern To: linux-kernel@vger.kernel.org Cc: acme@ghostprotocols.net, mingo@kernel.org, fweisbec@gmail.com, peterz@infradead.org, jolsa@redhat.com, namhyung@kernel.org, xiaoguangrong@linux.vnet.ibm.com, runzhen@linux.vnet.ibm.com, David Ahern Subject: [PATCH 13/16] perf kvm: debug for missing vmexit/vmentry event Date: Sat, 25 May 2013 18:24:53 -0600 Message-Id: <1369527896-3650-14-git-send-email-dsahern@gmail.com> X-Mailer: git-send-email 1.7.10.1 In-Reply-To: <1369527896-3650-1-git-send-email-dsahern@gmail.com> References: <1369527896-3650-1-git-send-email-dsahern@gmail.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Expected to have missing events for each vcpu when perf is started. After that should not have missing events. Signed-off-by: David Ahern Cc: Arnaldo Carvalho de Melo Cc: Ingo Molnar Cc: Frederic Weisbecker Cc: Peter Zijlstra Cc: Jiri Olsa Cc: Namhyung Kim Cc: Xiao Guangrong Cc: Runzhen Wang --- tools/perf/builtin-kvm.c | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/tools/perf/builtin-kvm.c b/tools/perf/builtin-kvm.c index c2fede6..76cfe59 100644 --- a/tools/perf/builtin-kvm.c +++ b/tools/perf/builtin-kvm.c @@ -568,11 +568,22 @@ static bool handle_kvm_event(struct perf_kvm_stat *kvm, (kvm->trace_vcpu != vcpu_record->vcpu_id)) return true; - if (kvm->events_ops->is_begin_event(evsel, sample, &key)) + if (kvm->events_ops->is_begin_event(evsel, sample, &key)) { + if (vcpu_record->start_time) { + pr_debug("consecutive begin events (%s) for pid %d, vcpu %d\n", + evsel->name, sample->pid, vcpu_record->vcpu_id); + } return handle_begin_event(kvm, vcpu_record, &key, sample->time); + } + - if (kvm->events_ops->is_end_event(evsel, sample, &key)) + if (kvm->events_ops->is_end_event(evsel, sample, &key)) { + if (vcpu_record->start_time == 0) { + pr_debug("consecutive end events (%s) for pid %d, vcpu %d\n", + evsel->name, sample->pid, vcpu_record->vcpu_id); + } return handle_end_event(kvm, vcpu_record, &key, sample); + } return true; } -- 1.7.10.1