Commit aaff7623 authored by Suzuki K Poulose's avatar Suzuki K Poulose Committed by Greg Kroah-Hartman

coresight: etm: Clean up device specific data

Track the coresight device instead of the real device.
Signed-off-by: default avatarSuzuki K Poulose <suzuki.poulose@arm.com>
Signed-off-by: default avatarMathieu Poirier <mathieu.poirier@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent ec62db1b
...@@ -208,7 +208,6 @@ struct etm_config { ...@@ -208,7 +208,6 @@ struct etm_config {
/** /**
* struct etm_drvdata - specifics associated to an ETM component * struct etm_drvdata - specifics associated to an ETM component
* @base: memory mapped base address for this component. * @base: memory mapped base address for this component.
* @dev: the device entity associated to this component.
* @atclk: optional clock for the core parts of the ETM. * @atclk: optional clock for the core parts of the ETM.
* @csdev: component vitals needed by the framework. * @csdev: component vitals needed by the framework.
* @spinlock: only one at a time pls. * @spinlock: only one at a time pls.
...@@ -232,7 +231,6 @@ struct etm_config { ...@@ -232,7 +231,6 @@ struct etm_config {
*/ */
struct etm_drvdata { struct etm_drvdata {
void __iomem *base; void __iomem *base;
struct device *dev;
struct clk *atclk; struct clk *atclk;
struct coresight_device *csdev; struct coresight_device *csdev;
spinlock_t spinlock; spinlock_t spinlock;
...@@ -260,7 +258,7 @@ static inline void etm_writel(struct etm_drvdata *drvdata, ...@@ -260,7 +258,7 @@ static inline void etm_writel(struct etm_drvdata *drvdata,
{ {
if (drvdata->use_cp14) { if (drvdata->use_cp14) {
if (etm_writel_cp14(off, val)) { if (etm_writel_cp14(off, val)) {
dev_err(drvdata->dev, dev_err(&drvdata->csdev->dev,
"invalid CP14 access to ETM reg: %#x", off); "invalid CP14 access to ETM reg: %#x", off);
} }
} else { } else {
...@@ -274,7 +272,7 @@ static inline unsigned int etm_readl(struct etm_drvdata *drvdata, u32 off) ...@@ -274,7 +272,7 @@ static inline unsigned int etm_readl(struct etm_drvdata *drvdata, u32 off)
if (drvdata->use_cp14) { if (drvdata->use_cp14) {
if (etm_readl_cp14(off, &val)) { if (etm_readl_cp14(off, &val)) {
dev_err(drvdata->dev, dev_err(&drvdata->csdev->dev,
"invalid CP14 access to ETM reg: %#x", off); "invalid CP14 access to ETM reg: %#x", off);
} }
} else { } else {
......
...@@ -48,7 +48,7 @@ static ssize_t etmsr_show(struct device *dev, ...@@ -48,7 +48,7 @@ static ssize_t etmsr_show(struct device *dev,
unsigned long flags, val; unsigned long flags, val;
struct etm_drvdata *drvdata = dev_get_drvdata(dev->parent); struct etm_drvdata *drvdata = dev_get_drvdata(dev->parent);
pm_runtime_get_sync(drvdata->dev); pm_runtime_get_sync(dev->parent);
spin_lock_irqsave(&drvdata->spinlock, flags); spin_lock_irqsave(&drvdata->spinlock, flags);
CS_UNLOCK(drvdata->base); CS_UNLOCK(drvdata->base);
...@@ -56,7 +56,7 @@ static ssize_t etmsr_show(struct device *dev, ...@@ -56,7 +56,7 @@ static ssize_t etmsr_show(struct device *dev,
CS_LOCK(drvdata->base); CS_LOCK(drvdata->base);
spin_unlock_irqrestore(&drvdata->spinlock, flags); spin_unlock_irqrestore(&drvdata->spinlock, flags);
pm_runtime_put(drvdata->dev); pm_runtime_put(dev->parent);
return sprintf(buf, "%#lx\n", val); return sprintf(buf, "%#lx\n", val);
} }
...@@ -131,7 +131,7 @@ static ssize_t mode_store(struct device *dev, ...@@ -131,7 +131,7 @@ static ssize_t mode_store(struct device *dev,
if (config->mode & ETM_MODE_STALL) { if (config->mode & ETM_MODE_STALL) {
if (!(drvdata->etmccr & ETMCCR_FIFOFULL)) { if (!(drvdata->etmccr & ETMCCR_FIFOFULL)) {
dev_warn(drvdata->dev, "stall mode not supported\n"); dev_warn(dev, "stall mode not supported\n");
ret = -EINVAL; ret = -EINVAL;
goto err_unlock; goto err_unlock;
} }
...@@ -141,7 +141,7 @@ static ssize_t mode_store(struct device *dev, ...@@ -141,7 +141,7 @@ static ssize_t mode_store(struct device *dev,
if (config->mode & ETM_MODE_TIMESTAMP) { if (config->mode & ETM_MODE_TIMESTAMP) {
if (!(drvdata->etmccer & ETMCCER_TIMESTAMP)) { if (!(drvdata->etmccer & ETMCCER_TIMESTAMP)) {
dev_warn(drvdata->dev, "timestamp not supported\n"); dev_warn(dev, "timestamp not supported\n");
ret = -EINVAL; ret = -EINVAL;
goto err_unlock; goto err_unlock;
} }
...@@ -945,7 +945,7 @@ static ssize_t seq_curr_state_show(struct device *dev, ...@@ -945,7 +945,7 @@ static ssize_t seq_curr_state_show(struct device *dev,
goto out; goto out;
} }
pm_runtime_get_sync(drvdata->dev); pm_runtime_get_sync(dev->parent);
spin_lock_irqsave(&drvdata->spinlock, flags); spin_lock_irqsave(&drvdata->spinlock, flags);
CS_UNLOCK(drvdata->base); CS_UNLOCK(drvdata->base);
...@@ -953,7 +953,7 @@ static ssize_t seq_curr_state_show(struct device *dev, ...@@ -953,7 +953,7 @@ static ssize_t seq_curr_state_show(struct device *dev,
CS_LOCK(drvdata->base); CS_LOCK(drvdata->base);
spin_unlock_irqrestore(&drvdata->spinlock, flags); spin_unlock_irqrestore(&drvdata->spinlock, flags);
pm_runtime_put(drvdata->dev); pm_runtime_put(dev->parent);
out: out:
return sprintf(buf, "%#lx\n", val); return sprintf(buf, "%#lx\n", val);
} }
......
...@@ -165,7 +165,7 @@ static void etm_set_prog(struct etm_drvdata *drvdata) ...@@ -165,7 +165,7 @@ static void etm_set_prog(struct etm_drvdata *drvdata)
*/ */
isb(); isb();
if (coresight_timeout_etm(drvdata, ETMSR, ETMSR_PROG_BIT, 1)) { if (coresight_timeout_etm(drvdata, ETMSR, ETMSR_PROG_BIT, 1)) {
dev_err(drvdata->dev, dev_err(&drvdata->csdev->dev,
"%s: timeout observed when probing at offset %#x\n", "%s: timeout observed when probing at offset %#x\n",
__func__, ETMSR); __func__, ETMSR);
} }
...@@ -184,7 +184,7 @@ static void etm_clr_prog(struct etm_drvdata *drvdata) ...@@ -184,7 +184,7 @@ static void etm_clr_prog(struct etm_drvdata *drvdata)
*/ */
isb(); isb();
if (coresight_timeout_etm(drvdata, ETMSR, ETMSR_PROG_BIT, 0)) { if (coresight_timeout_etm(drvdata, ETMSR, ETMSR_PROG_BIT, 0)) {
dev_err(drvdata->dev, dev_err(&drvdata->csdev->dev,
"%s: timeout observed when probing at offset %#x\n", "%s: timeout observed when probing at offset %#x\n",
__func__, ETMSR); __func__, ETMSR);
} }
...@@ -425,7 +425,7 @@ static int etm_enable_hw(struct etm_drvdata *drvdata) ...@@ -425,7 +425,7 @@ static int etm_enable_hw(struct etm_drvdata *drvdata)
done: done:
CS_LOCK(drvdata->base); CS_LOCK(drvdata->base);
dev_dbg(drvdata->dev, "cpu: %d enable smp call done: %d\n", dev_dbg(&drvdata->csdev->dev, "cpu: %d enable smp call done: %d\n",
drvdata->cpu, rc); drvdata->cpu, rc);
return rc; return rc;
} }
...@@ -455,6 +455,7 @@ int etm_get_trace_id(struct etm_drvdata *drvdata) ...@@ -455,6 +455,7 @@ int etm_get_trace_id(struct etm_drvdata *drvdata)
{ {
unsigned long flags; unsigned long flags;
int trace_id = -1; int trace_id = -1;
struct device *etm_dev = drvdata->csdev->dev.parent;
if (!drvdata) if (!drvdata)
goto out; goto out;
...@@ -462,7 +463,7 @@ int etm_get_trace_id(struct etm_drvdata *drvdata) ...@@ -462,7 +463,7 @@ int etm_get_trace_id(struct etm_drvdata *drvdata)
if (!local_read(&drvdata->mode)) if (!local_read(&drvdata->mode))
return drvdata->traceid; return drvdata->traceid;
pm_runtime_get_sync(drvdata->dev); pm_runtime_get_sync(etm_dev);
spin_lock_irqsave(&drvdata->spinlock, flags); spin_lock_irqsave(&drvdata->spinlock, flags);
...@@ -471,7 +472,7 @@ int etm_get_trace_id(struct etm_drvdata *drvdata) ...@@ -471,7 +472,7 @@ int etm_get_trace_id(struct etm_drvdata *drvdata)
CS_LOCK(drvdata->base); CS_LOCK(drvdata->base);
spin_unlock_irqrestore(&drvdata->spinlock, flags); spin_unlock_irqrestore(&drvdata->spinlock, flags);
pm_runtime_put(drvdata->dev); pm_runtime_put(etm_dev);
out: out:
return trace_id; return trace_id;
...@@ -526,7 +527,7 @@ static int etm_enable_sysfs(struct coresight_device *csdev) ...@@ -526,7 +527,7 @@ static int etm_enable_sysfs(struct coresight_device *csdev)
spin_unlock(&drvdata->spinlock); spin_unlock(&drvdata->spinlock);
if (!ret) if (!ret)
dev_dbg(drvdata->dev, "ETM tracing enabled\n"); dev_dbg(&csdev->dev, "ETM tracing enabled\n");
return ret; return ret;
} }
...@@ -581,7 +582,8 @@ static void etm_disable_hw(void *info) ...@@ -581,7 +582,8 @@ static void etm_disable_hw(void *info)
CS_LOCK(drvdata->base); CS_LOCK(drvdata->base);
dev_dbg(drvdata->dev, "cpu: %d disable smp call done\n", drvdata->cpu); dev_dbg(&drvdata->csdev->dev,
"cpu: %d disable smp call done\n", drvdata->cpu);
} }
static void etm_disable_perf(struct coresight_device *csdev) static void etm_disable_perf(struct coresight_device *csdev)
...@@ -628,7 +630,7 @@ static void etm_disable_sysfs(struct coresight_device *csdev) ...@@ -628,7 +630,7 @@ static void etm_disable_sysfs(struct coresight_device *csdev)
spin_unlock(&drvdata->spinlock); spin_unlock(&drvdata->spinlock);
cpus_read_unlock(); cpus_read_unlock();
dev_dbg(drvdata->dev, "ETM tracing disabled\n"); dev_dbg(&csdev->dev, "ETM tracing disabled\n");
} }
static void etm_disable(struct coresight_device *csdev, static void etm_disable(struct coresight_device *csdev,
...@@ -803,7 +805,6 @@ static int etm_probe(struct amba_device *adev, const struct amba_id *id) ...@@ -803,7 +805,6 @@ static int etm_probe(struct amba_device *adev, const struct amba_id *id)
drvdata->use_cp14 = of_property_read_bool(np, "arm,cp14"); drvdata->use_cp14 = of_property_read_bool(np, "arm,cp14");
} }
drvdata->dev = &adev->dev;
dev_set_drvdata(dev, drvdata); dev_set_drvdata(dev, drvdata);
/* Validity for the resource is already checked by the AMBA core */ /* Validity for the resource is already checked by the AMBA core */
...@@ -871,7 +872,8 @@ static int etm_probe(struct amba_device *adev, const struct amba_id *id) ...@@ -871,7 +872,8 @@ static int etm_probe(struct amba_device *adev, const struct amba_id *id)
} }
pm_runtime_put(&adev->dev); pm_runtime_put(&adev->dev);
dev_info(dev, "%s initialized\n", (char *)coresight_get_uci_data(id)); dev_info(&drvdata->csdev->dev,
"%s initialized\n", (char *)coresight_get_uci_data(id));
if (boot_enable) { if (boot_enable) {
coresight_enable(drvdata->csdev); coresight_enable(drvdata->csdev);
drvdata->boot_enable = true; drvdata->boot_enable = true;
......
...@@ -88,6 +88,7 @@ static int etm4_enable_hw(struct etmv4_drvdata *drvdata) ...@@ -88,6 +88,7 @@ static int etm4_enable_hw(struct etmv4_drvdata *drvdata)
{ {
int i, rc; int i, rc;
struct etmv4_config *config = &drvdata->config; struct etmv4_config *config = &drvdata->config;
struct device *etm_dev = &drvdata->csdev->dev;
CS_UNLOCK(drvdata->base); CS_UNLOCK(drvdata->base);
...@@ -102,7 +103,7 @@ static int etm4_enable_hw(struct etmv4_drvdata *drvdata) ...@@ -102,7 +103,7 @@ static int etm4_enable_hw(struct etmv4_drvdata *drvdata)
/* wait for TRCSTATR.IDLE to go up */ /* wait for TRCSTATR.IDLE to go up */
if (coresight_timeout(drvdata->base, TRCSTATR, TRCSTATR_IDLE_BIT, 1)) if (coresight_timeout(drvdata->base, TRCSTATR, TRCSTATR_IDLE_BIT, 1))
dev_err(drvdata->dev, dev_err(etm_dev,
"timeout while waiting for Idle Trace Status\n"); "timeout while waiting for Idle Trace Status\n");
writel_relaxed(config->pe_sel, drvdata->base + TRCPROCSELR); writel_relaxed(config->pe_sel, drvdata->base + TRCPROCSELR);
...@@ -184,13 +185,13 @@ static int etm4_enable_hw(struct etmv4_drvdata *drvdata) ...@@ -184,13 +185,13 @@ static int etm4_enable_hw(struct etmv4_drvdata *drvdata)
/* wait for TRCSTATR.IDLE to go back down to '0' */ /* wait for TRCSTATR.IDLE to go back down to '0' */
if (coresight_timeout(drvdata->base, TRCSTATR, TRCSTATR_IDLE_BIT, 0)) if (coresight_timeout(drvdata->base, TRCSTATR, TRCSTATR_IDLE_BIT, 0))
dev_err(drvdata->dev, dev_err(etm_dev,
"timeout while waiting for Idle Trace Status\n"); "timeout while waiting for Idle Trace Status\n");
done: done:
CS_LOCK(drvdata->base); CS_LOCK(drvdata->base);
dev_dbg(drvdata->dev, "cpu: %d enable smp call done: %d\n", dev_dbg(etm_dev, "cpu: %d enable smp call done: %d\n",
drvdata->cpu, rc); drvdata->cpu, rc);
return rc; return rc;
} }
...@@ -400,7 +401,7 @@ static int etm4_enable_sysfs(struct coresight_device *csdev) ...@@ -400,7 +401,7 @@ static int etm4_enable_sysfs(struct coresight_device *csdev)
spin_unlock(&drvdata->spinlock); spin_unlock(&drvdata->spinlock);
if (!ret) if (!ret)
dev_dbg(drvdata->dev, "ETM tracing enabled\n"); dev_dbg(&csdev->dev, "ETM tracing enabled\n");
return ret; return ret;
} }
...@@ -461,7 +462,8 @@ static void etm4_disable_hw(void *info) ...@@ -461,7 +462,8 @@ static void etm4_disable_hw(void *info)
CS_LOCK(drvdata->base); CS_LOCK(drvdata->base);
dev_dbg(drvdata->dev, "cpu: %d disable smp call done\n", drvdata->cpu); dev_dbg(&drvdata->csdev->dev,
"cpu: %d disable smp call done\n", drvdata->cpu);
} }
static int etm4_disable_perf(struct coresight_device *csdev, static int etm4_disable_perf(struct coresight_device *csdev,
...@@ -511,7 +513,7 @@ static void etm4_disable_sysfs(struct coresight_device *csdev) ...@@ -511,7 +513,7 @@ static void etm4_disable_sysfs(struct coresight_device *csdev)
spin_unlock(&drvdata->spinlock); spin_unlock(&drvdata->spinlock);
cpus_read_unlock(); cpus_read_unlock();
dev_dbg(drvdata->dev, "ETM tracing disabled\n"); dev_dbg(&csdev->dev, "ETM tracing disabled\n");
} }
static void etm4_disable(struct coresight_device *csdev, static void etm4_disable(struct coresight_device *csdev,
...@@ -1095,7 +1097,6 @@ static int etm4_probe(struct amba_device *adev, const struct amba_id *id) ...@@ -1095,7 +1097,6 @@ static int etm4_probe(struct amba_device *adev, const struct amba_id *id)
adev->dev.platform_data = pdata; adev->dev.platform_data = pdata;
} }
drvdata->dev = &adev->dev;
dev_set_drvdata(dev, drvdata); dev_set_drvdata(dev, drvdata);
/* Validity for the resource is already checked by the AMBA core */ /* Validity for the resource is already checked by the AMBA core */
...@@ -1157,7 +1158,7 @@ static int etm4_probe(struct amba_device *adev, const struct amba_id *id) ...@@ -1157,7 +1158,7 @@ static int etm4_probe(struct amba_device *adev, const struct amba_id *id)
} }
pm_runtime_put(&adev->dev); pm_runtime_put(&adev->dev);
dev_info(dev, "CPU%d: ETM v%d.%d initialized\n", dev_info(&drvdata->csdev->dev, "CPU%d: ETM v%d.%d initialized\n",
drvdata->cpu, drvdata->arch >> 4, drvdata->arch & 0xf); drvdata->cpu, drvdata->arch >> 4, drvdata->arch & 0xf);
if (boot_enable) { if (boot_enable) {
......
...@@ -284,7 +284,6 @@ struct etmv4_config { ...@@ -284,7 +284,6 @@ struct etmv4_config {
/** /**
* struct etm4_drvdata - specifics associated to an ETM component * struct etm4_drvdata - specifics associated to an ETM component
* @base: Memory mapped base address for this component. * @base: Memory mapped base address for this component.
* @dev: The device entity associated to this component.
* @csdev: Component vitals needed by the framework. * @csdev: Component vitals needed by the framework.
* @spinlock: Only one at a time pls. * @spinlock: Only one at a time pls.
* @mode: This tracer's mode, i.e sysFS, Perf or disabled. * @mode: This tracer's mode, i.e sysFS, Perf or disabled.
...@@ -340,7 +339,6 @@ struct etmv4_config { ...@@ -340,7 +339,6 @@ struct etmv4_config {
*/ */
struct etmv4_drvdata { struct etmv4_drvdata {
void __iomem *base; void __iomem *base;
struct device *dev;
struct coresight_device *csdev; struct coresight_device *csdev;
spinlock_t spinlock; spinlock_t spinlock;
local_t mode; local_t mode;
......
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