The aux_event can be retrieved from the perf_pmu now. Implement a generic support. Reviewed-by: Ian Rogers <irogers@google.com> Tested-by: Ravi Bangoria <ravi.bangoria@amd.com> Tested-by: Leo Yan <leo.yan@linaro.org> Signed-off-by: Kan Liang <kan.liang@linux.intel.com> Cc: james.clark@arm.com Cc: will@kernel.org Cc: mike.leach@linaro.org Cc: renyu.zj@linux.alibaba.com Cc: yuhaixin.yhx@linux.alibaba.com Cc: tmricht@linux.ibm.com Cc: atrajeev@linux.vnet.ibm.com Cc: linux-arm-kernel@lists.infradead.org Cc: john.g.garry@oracle.com Link: https://lore.kernel.org/r/20240123185036.3461837-6-kan.liang@linux.intel.com Signed-off-by: Namhyung Kim <namhyung@kernel.org>
28 lines
977 B
C
28 lines
977 B
C
// SPDX-License-Identifier: GPL-2.0
|
|
#include "linux/string.h"
|
|
#include "util/map_symbol.h"
|
|
#include "util/mem-events.h"
|
|
#include "mem-events.h"
|
|
|
|
|
|
#define MEM_LOADS_AUX 0x8203
|
|
|
|
#define E(t, n, s, l, a) { .tag = t, .name = n, .event_name = s, .ldlat = l, .aux_event = a }
|
|
|
|
struct perf_mem_event perf_mem_events_intel[PERF_MEM_EVENTS__MAX] = {
|
|
E("ldlat-loads", "%s/mem-loads,ldlat=%u/P", "mem-loads", true, 0),
|
|
E("ldlat-stores", "%s/mem-stores/P", "mem-stores", false, 0),
|
|
E(NULL, NULL, NULL, false, 0),
|
|
};
|
|
|
|
struct perf_mem_event perf_mem_events_intel_aux[PERF_MEM_EVENTS__MAX] = {
|
|
E("ldlat-loads", "{%s/mem-loads-aux/,%s/mem-loads,ldlat=%u/}:P", "mem-loads", true, MEM_LOADS_AUX),
|
|
E("ldlat-stores", "%s/mem-stores/P", "mem-stores", false, 0),
|
|
E(NULL, NULL, NULL, false, 0),
|
|
};
|
|
|
|
struct perf_mem_event perf_mem_events_amd[PERF_MEM_EVENTS__MAX] = {
|
|
E(NULL, NULL, NULL, false, 0),
|
|
E(NULL, NULL, NULL, false, 0),
|
|
E("mem-ldst", "%s//", NULL, false, 0),
|
|
};
|