| // SPDX-License-Identifier: GPL-2.0 | 
 | #include <string.h> | 
 | #include <stdio.h> | 
 | #include <sys/types.h> | 
 | #include <dirent.h> | 
 | #include <fcntl.h> | 
 | #include <linux/stddef.h> | 
 | #include <linux/perf_event.h> | 
 | #include <linux/zalloc.h> | 
 | #include <api/fs/fs.h> | 
 | #include <errno.h> | 
 |  | 
 | #include "../../../util/intel-pt.h" | 
 | #include "../../../util/intel-bts.h" | 
 | #include "../../../util/pmu.h" | 
 | #include "../../../util/fncache.h" | 
 | #include "../../../util/pmus.h" | 
 | #include "mem-events.h" | 
 | #include "env.h" | 
 |  | 
 | void perf_pmu__arch_init(struct perf_pmu *pmu __maybe_unused) | 
 | { | 
 | #ifdef HAVE_AUXTRACE_SUPPORT | 
 | 	if (!strcmp(pmu->name, INTEL_PT_PMU_NAME)) { | 
 | 		pmu->auxtrace = true; | 
 | 		pmu->selectable = true; | 
 | 		pmu->perf_event_attr_init_default = intel_pt_pmu_default_config; | 
 | 	} | 
 | 	if (!strcmp(pmu->name, INTEL_BTS_PMU_NAME)) { | 
 | 		pmu->auxtrace = true; | 
 | 		pmu->selectable = true; | 
 | 	} | 
 | #endif | 
 |  | 
 | 	if (x86__is_amd_cpu()) { | 
 | 		if (!strcmp(pmu->name, "ibs_op")) | 
 | 			pmu->mem_events = perf_mem_events_amd; | 
 | 	} else if (pmu->is_core) { | 
 | 		if (perf_pmu__have_event(pmu, "mem-loads-aux")) | 
 | 			pmu->mem_events = perf_mem_events_intel_aux; | 
 | 		else | 
 | 			pmu->mem_events = perf_mem_events_intel; | 
 | 	} | 
 | } |