From: eranian@google.com
To: linux-kernel@vger.kernel.org
Cc: peterz@infradead.org, mingo@elte.hu, paulus@samba.org,
fweisbec@gmail.com, robert.richter@amd.com, davem@davemloft.net,
perfmon2-devel@lists.sf.net, eranian@gmail.com
Subject: [PATCH] perf_events: fix X86 bogus counts when multiplexing
Date: Wed, 10 Mar 2010 22:17:39 -0800 [thread overview]
Message-ID: <1268288259-4011-1-git-send-email-eranian@google.com> (raw)
This patch fixes a bug in 2.6.33 X86 event scheduling whereby
all counts are bogus as soon as events need to be multiplexed
because the PMU is overcommitted.
The code in hw_perf_enable() was causing multiplexed events
to accumulate collected counts twice causing bogus results.
This is demonstrated on AMD Barcelona with the example
below. First run, no conflict, you obtain the actual counts.
Second run, PMU overcommitted, multiplexing, all events are
over-counted. Third run, patch applied, you obtain the correct
count through scaling.
Intel processors would be affected in the same way.
# perf stat -e instructions,cycles ./noploop 10
noploop for 10 seconds
Performance counter stats for './noploop 10':
10884992991 instructions # 0.495 IPC
21976457932 cycles
10.000906311 seconds time elapsed
# perf stat -e instructions,instructions,instructions,instructions,cycles ./noploop 10
noploop for 10 seconds
Performance counter stats for './noploop 10':
16342703033 instructions # 1.000 IPC (scaled from 80.00%)
16337667144 instructions # 0.999 IPC (scaled from 80.00%)
16342494809 instructions # 1.000 IPC (scaled from 80.00%)
16344432632 instructions # 1.000 IPC (scaled from 80.00%)
16346620711 cycles (scaled from 80.00%)
10.015941304 seconds time elapsed
# perf stat -e instructions,instructions,instructions,instructions,cycles ./noploop 10
noploop for 10 seconds
Performance counter stats for './noploop 10':
10865832804 instructions # 0.495 IPC (scaled from 80.00%)
10866436957 instructions # 0.495 IPC (scaled from 80.00%)
10866172153 instructions # 0.495 IPC (scaled from 80.00%)
10866276672 instructions # 0.495 IPC (scaled from 80.00%)
21944300714 cycles (scaled from 80.00%)
10.000686860 seconds time elapsed
Signed-off-by: Stephane Eranian <eranian@google.com>
--
perf_event.c | 2 --
1 file changed, 2 deletions(-)
diff --git a/arch/x86/kernel/cpu/perf_event.c b/arch/x86/kernel/cpu/perf_event.c
index 97cddbf..ef5d63f 100644
--- a/arch/x86/kernel/cpu/perf_event.c
+++ b/arch/x86/kernel/cpu/perf_event.c
@@ -818,8 +818,6 @@ void hw_perf_enable(void)
match_prev_assignment(hwc, cpuc, i))
continue;
- x86_pmu_stop(event);
-
hwc->idx = -1;
}
next reply other threads:[~2010-03-11 6:18 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-03-11 6:17 eranian [this message]
2010-03-11 8:32 ` [PATCH] perf_events: fix X86 bogus counts when multiplexing Peter Zijlstra
2010-03-11 12:37 ` Peter Zijlstra
2010-03-11 14:41 ` [tip:perf/urgent] perf, x86: Fix hw_perf_enable() event assignment tip-bot for Peter Zijlstra
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1268288259-4011-1-git-send-email-eranian@google.com \
--to=eranian@google.com \
--cc=davem@davemloft.net \
--cc=eranian@gmail.com \
--cc=fweisbec@gmail.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@elte.hu \
--cc=paulus@samba.org \
--cc=perfmon2-devel@lists.sf.net \
--cc=peterz@infradead.org \
--cc=robert.richter@amd.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox