#ifndef INCLUDE__PERF_ARM_SPE_H__
#define INCLUDE__PERF_ARM_SPE_H__
#define ARM_SPE_PMU_NAME "arm_spe_"
enum {
ARM_SPE_PMU_TYPE,
ARM_SPE_PER_CPU_MMAPS,
ARM_SPE_AUXTRACE_V1_PRIV_MAX,
};
#define ARM_SPE_AUXTRACE_V1_PRIV_SIZE \
(ARM_SPE_AUXTRACE_V1_PRIV_MAX * sizeof(u64))
enum {
ARM_SPE_HEADER_VERSION,
ARM_SPE_HEADER_SIZE,
ARM_SPE_PMU_TYPE_V2,
ARM_SPE_CPUS_NUM,
ARM_SPE_AUXTRACE_PRIV_MAX,
};
enum {
ARM_SPE_MAGIC,
ARM_SPE_CPU,
ARM_SPE_CPU_NR_PARAMS,
ARM_SPE_CPU_MIDR,
ARM_SPE_CPU_PMU_TYPE,
ARM_SPE_CAP_MIN_IVAL,
ARM_SPE_CAP_EVENT_FILTER,
ARM_SPE_CPU_PRIV_MAX,
};
#define ARM_SPE_HEADER_CURRENT_VERSION 2
union perf_event;
struct perf_session;
struct perf_pmu;
struct auxtrace_record *arm_spe_recording_init(int *err,
struct perf_pmu *arm_spe_pmu);
int arm_spe_process_auxtrace_info(union perf_event *event,
struct perf_session *session);
void arm_spe_pmu_default_config(const struct perf_pmu *arm_spe_pmu,
struct perf_event_attr *attr);
#endif