|
@@ -7,6 +7,7 @@
|
|
|
#ifndef _CORESIGHT_ETM_PERF_H
|
|
|
#define _CORESIGHT_ETM_PERF_H
|
|
|
|
|
|
+#include <linux/percpu-defs.h>
|
|
|
#include "coresight-priv.h"
|
|
|
|
|
|
struct coresight_device;
|
|
@@ -42,14 +43,39 @@ struct etm_filters {
|
|
|
bool ssstatus;
|
|
|
};
|
|
|
|
|
|
+/**
|
|
|
+ * struct etm_event_data - Coresight specifics associated to an event
|
|
|
+ * @work: Handle to free allocated memory outside IRQ context.
|
|
|
+ * @mask: Hold the CPU(s) this event was set for.
|
|
|
+ * @snk_config: The sink configuration.
|
|
|
+ * @path: An array of path, each slot for one CPU.
|
|
|
+ */
|
|
|
+struct etm_event_data {
|
|
|
+ struct work_struct work;
|
|
|
+ cpumask_t mask;
|
|
|
+ void *snk_config;
|
|
|
+ struct list_head * __percpu *path;
|
|
|
+};
|
|
|
|
|
|
#ifdef CONFIG_CORESIGHT
|
|
|
int etm_perf_symlink(struct coresight_device *csdev, bool link);
|
|
|
+static inline void *etm_perf_sink_config(struct perf_output_handle *handle)
|
|
|
+{
|
|
|
+ struct etm_event_data *data = perf_get_aux(handle);
|
|
|
|
|
|
+ if (data)
|
|
|
+ return data->snk_config;
|
|
|
+ return NULL;
|
|
|
+}
|
|
|
#else
|
|
|
static inline int etm_perf_symlink(struct coresight_device *csdev, bool link)
|
|
|
{ return -EINVAL; }
|
|
|
|
|
|
+static inline void *etm_perf_sink_config(struct perf_output_handle *handle)
|
|
|
+{
|
|
|
+ return NULL;
|
|
|
+}
|
|
|
+
|
|
|
#endif /* CONFIG_CORESIGHT */
|
|
|
|
|
|
#endif
|