adb97f18b4
[ Upstream commit d9c5c083416500e95da098c01be092b937def7fa ] Following the patch 'perf stat: Fix --no-scale', an alignment trap happens in process_counter_values() on ARMv7 platforms due to the attempt to copy non 64 bits aligned double words (pointed by 'count') via a NEON vectored instruction ('vld1' with 64 bits alignment constraint). This patch sets a 64 bits alignment constraint on 'contents[]' field in 'struct xyarray' since the 'count' pointer used above points to such a structure. Signed-off-by: Gerald Baeza <gerald.baeza@st.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Alexandre Torgue <alexandre.torgue@st.com> Cc: Andi Kleen <ak@linux.intel.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Mathieu Poirier <mathieu.poirier@linaro.org> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Link: http://lkml.kernel.org/r/1566464769-16374-1-git-send-email-gerald.baeza@st.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
36 lines
754 B
C
36 lines
754 B
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
#ifndef _PERF_XYARRAY_H_
|
|
#define _PERF_XYARRAY_H_ 1
|
|
|
|
#include <linux/compiler.h>
|
|
#include <sys/types.h>
|
|
|
|
struct xyarray {
|
|
size_t row_size;
|
|
size_t entry_size;
|
|
size_t entries;
|
|
size_t max_x;
|
|
size_t max_y;
|
|
char contents[] __aligned(8);
|
|
};
|
|
|
|
struct xyarray *xyarray__new(int xlen, int ylen, size_t entry_size);
|
|
void xyarray__delete(struct xyarray *xy);
|
|
void xyarray__reset(struct xyarray *xy);
|
|
|
|
static inline void *xyarray__entry(struct xyarray *xy, int x, int y)
|
|
{
|
|
return &xy->contents[x * xy->row_size + y * xy->entry_size];
|
|
}
|
|
|
|
static inline int xyarray__max_y(struct xyarray *xy)
|
|
{
|
|
return xy->max_y;
|
|
}
|
|
|
|
static inline int xyarray__max_x(struct xyarray *xy)
|
|
{
|
|
return xy->max_x;
|
|
}
|
|
|
|
#endif /* _PERF_XYARRAY_H_ */
|