Commit 42708bac authored by Mike Leach's avatar Mike Leach Committed by Suzuki K Poulose

coresight: etmX.X: stm: Remove trace_id() callback

CoreSight sources provide a callback (.trace_id) in the standard source
ops which returns the ID to the core code. This was used to check that
sources all had a unique Trace ID.

Uniqueness is now gauranteed by the Trace ID allocation system, and the
check code has been removed from the core.

This patch removes the unneeded and unused .trace_id source ops
from the ops structure and implementations in etm3x, etm4x and stm.
Signed-off-by: default avatarMike Leach <mike.leach@linaro.org>
Reviewed-by: default avatarSuzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: default avatarSuzuki K Poulose <suzuki.poulose@arm.com>
Link: https://lore.kernel.org/r/20230116124928.5440-8-mike.leach@linaro.org
parent 9edf2910
...@@ -283,7 +283,6 @@ static inline unsigned int etm_readl(struct etm_drvdata *drvdata, u32 off) ...@@ -283,7 +283,6 @@ static inline unsigned int etm_readl(struct etm_drvdata *drvdata, u32 off)
} }
extern const struct attribute_group *coresight_etm_groups[]; extern const struct attribute_group *coresight_etm_groups[];
int etm_get_trace_id(struct etm_drvdata *drvdata);
void etm_set_default(struct etm_config *config); void etm_set_default(struct etm_config *config);
void etm_config_trace_mode(struct etm_config *config); void etm_config_trace_mode(struct etm_config *config);
struct etm_config *get_etm_config(struct etm_drvdata *drvdata); struct etm_config *get_etm_config(struct etm_drvdata *drvdata);
......
...@@ -455,42 +455,6 @@ static int etm_cpu_id(struct coresight_device *csdev) ...@@ -455,42 +455,6 @@ static int etm_cpu_id(struct coresight_device *csdev)
return drvdata->cpu; return drvdata->cpu;
} }
int etm_get_trace_id(struct etm_drvdata *drvdata)
{
unsigned long flags;
int trace_id = -1;
struct device *etm_dev;
if (!drvdata)
goto out;
etm_dev = drvdata->csdev->dev.parent;
if (!local_read(&drvdata->mode))
return drvdata->traceid;
pm_runtime_get_sync(etm_dev);
spin_lock_irqsave(&drvdata->spinlock, flags);
CS_UNLOCK(drvdata->base);
trace_id = (etm_readl(drvdata, ETMTRACEIDR) & ETM_TRACEID_MASK);
CS_LOCK(drvdata->base);
spin_unlock_irqrestore(&drvdata->spinlock, flags);
pm_runtime_put(etm_dev);
out:
return trace_id;
}
static int etm_trace_id(struct coresight_device *csdev)
{
struct etm_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent);
return etm_get_trace_id(drvdata);
}
int etm_read_alloc_trace_id(struct etm_drvdata *drvdata) int etm_read_alloc_trace_id(struct etm_drvdata *drvdata)
{ {
int trace_id; int trace_id;
...@@ -737,7 +701,6 @@ static void etm_disable(struct coresight_device *csdev, ...@@ -737,7 +701,6 @@ static void etm_disable(struct coresight_device *csdev,
static const struct coresight_ops_source etm_source_ops = { static const struct coresight_ops_source etm_source_ops = {
.cpu_id = etm_cpu_id, .cpu_id = etm_cpu_id,
.trace_id = etm_trace_id,
.enable = etm_enable, .enable = etm_enable,
.disable = etm_disable, .disable = etm_disable,
}; };
......
...@@ -231,13 +231,6 @@ static int etm4_cpu_id(struct coresight_device *csdev) ...@@ -231,13 +231,6 @@ static int etm4_cpu_id(struct coresight_device *csdev)
return drvdata->cpu; return drvdata->cpu;
} }
static int etm4_trace_id(struct coresight_device *csdev)
{
struct etmv4_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent);
return drvdata->trcid;
}
int etm4_read_alloc_trace_id(struct etmv4_drvdata *drvdata) int etm4_read_alloc_trace_id(struct etmv4_drvdata *drvdata)
{ {
int trace_id; int trace_id;
...@@ -1023,7 +1016,6 @@ static void etm4_disable(struct coresight_device *csdev, ...@@ -1023,7 +1016,6 @@ static void etm4_disable(struct coresight_device *csdev,
static const struct coresight_ops_source etm4_source_ops = { static const struct coresight_ops_source etm4_source_ops = {
.cpu_id = etm4_cpu_id, .cpu_id = etm4_cpu_id,
.trace_id = etm4_trace_id,
.enable = etm4_enable, .enable = etm4_enable,
.disable = etm4_disable, .disable = etm4_disable,
}; };
......
...@@ -281,15 +281,7 @@ static void stm_disable(struct coresight_device *csdev, ...@@ -281,15 +281,7 @@ static void stm_disable(struct coresight_device *csdev,
} }
} }
static int stm_trace_id(struct coresight_device *csdev)
{
struct stm_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent);
return drvdata->traceid;
}
static const struct coresight_ops_source stm_source_ops = { static const struct coresight_ops_source stm_source_ops = {
.trace_id = stm_trace_id,
.enable = stm_enable, .enable = stm_enable,
.disable = stm_disable, .disable = stm_disable,
}; };
......
...@@ -314,14 +314,11 @@ struct coresight_ops_link { ...@@ -314,14 +314,11 @@ struct coresight_ops_link {
* Operations available for sources. * Operations available for sources.
* @cpu_id: returns the value of the CPU number this component * @cpu_id: returns the value of the CPU number this component
* is associated to. * is associated to.
* @trace_id: returns the value of the component's trace ID as known
* to the HW.
* @enable: enables tracing for a source. * @enable: enables tracing for a source.
* @disable: disables tracing for a source. * @disable: disables tracing for a source.
*/ */
struct coresight_ops_source { struct coresight_ops_source {
int (*cpu_id)(struct coresight_device *csdev); int (*cpu_id)(struct coresight_device *csdev);
int (*trace_id)(struct coresight_device *csdev);
int (*enable)(struct coresight_device *csdev, int (*enable)(struct coresight_device *csdev,
struct perf_event *event, u32 mode); struct perf_event *event, u32 mode);
void (*disable)(struct coresight_device *csdev, void (*disable)(struct coresight_device *csdev,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment