From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755111Ab0C2JLi (ORCPT ); Mon, 29 Mar 2010 05:11:38 -0400 Received: from casper.infradead.org ([85.118.1.10]:49162 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754981Ab0C2JLg (ORCPT ); Mon, 29 Mar 2010 05:11:36 -0400 Subject: Re: [PATCH 1/2] perf: Correctly align perf event tracing buffer From: Peter Zijlstra To: Frederic Weisbecker Cc: Ingo Molnar , LKML , Arnaldo Carvalho de Melo , Paul Mackerras , David Miller , Steven Rostedt In-Reply-To: <1269753066-17246-2-git-send-regression-fweisbec@gmail.com> References: <1269753066-17246-1-git-send-regression-fweisbec@gmail.com> <1269753066-17246-2-git-send-regression-fweisbec@gmail.com> Content-Type: text/plain; charset="UTF-8" Date: Mon, 29 Mar 2010 10:51:31 +0200 Message-ID: <1269852691.12097.162.camel@laptop> Mime-Version: 1.0 X-Mailer: Evolution 2.28.3 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sun, 2010-03-28 at 07:11 +0200, Frederic Weisbecker wrote: > The trace event buffer used by perf to record raw sample events > is typed as an array of char and may then not be aligned to 8 > by alloc_percpu(). > > But we need it to be aligned to 8 in sparc64 because we cast > this buffer into a random structure type built by the TRACE_EVENT() > macro to store the traces. So if a random 64 bits field is accessed > inside, it may be not under an expected good alignment. > > Use an array of long instead to force the appropriate alignment, and > perform a compile time check to ensure the size in byte of the buffer > is a multiple of sizeof(long) so that its actual size doesn't get > shrinked under us. > > This fixes unaligned accesses reported while using perf lock > in sparc 64. > > Suggested-by: David Miller > Suggested-by: Tejun Heo > Signed-off-by: Frederic Weisbecker > Cc: Peter Zijlstra > Cc: Arnaldo Carvalho de Melo > Cc: Paul Mackerras > Cc: Ingo Molnar > Cc: David Miller > Cc: Steven Rostedt > --- > kernel/trace/trace_event_perf.c | 11 +++++++++-- > 1 files changed, 9 insertions(+), 2 deletions(-) > > diff --git a/kernel/trace/trace_event_perf.c b/kernel/trace/trace_event_perf.c > index 0709e4f..69941f3 100644 > --- a/kernel/trace/trace_event_perf.c > +++ b/kernel/trace/trace_event_perf.c > @@ -15,7 +15,12 @@ EXPORT_PER_CPU_SYMBOL_GPL(perf_trace_regs); > static char *perf_trace_buf; > static char *perf_trace_buf_nmi; > > -typedef typeof(char [PERF_MAX_TRACE_SIZE]) perf_trace_t ; > +/* > + * Force it to be aligned to unsigned long to avoid misaligned accesses > + * suprises > + */ > +typedef typeof(unsigned long [PERF_MAX_TRACE_SIZE / sizeof(unsigned long)]) > + perf_trace_t; > wouldn't __aligned(8) be simpler?