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

coresight: funnel: Clean up device book keeping

In preparation to use a consistent device naming scheme,
clean up the device link tracking in funnel driver.
Use the "coresight" device instead of the "real" parent device
for all internal purposes. All other requests (e.g, power management,
DMA operations) must use the "real" device which is the parent 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 5aafd9bf
...@@ -32,14 +32,12 @@ ...@@ -32,14 +32,12 @@
/** /**
* struct funnel_drvdata - specifics associated to a funnel component * struct funnel_drvdata - specifics associated to a funnel 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 funnel. * @atclk: optional clock for the core parts of the funnel.
* @csdev: component vitals needed by the framework. * @csdev: component vitals needed by the framework.
* @priority: port selection order. * @priority: port selection order.
*/ */
struct funnel_drvdata { struct funnel_drvdata {
void __iomem *base; void __iomem *base;
struct device *dev;
struct clk *atclk; struct clk *atclk;
struct coresight_device *csdev; struct coresight_device *csdev;
unsigned long priority; unsigned long priority;
...@@ -80,7 +78,7 @@ static int funnel_enable(struct coresight_device *csdev, int inport, ...@@ -80,7 +78,7 @@ static int funnel_enable(struct coresight_device *csdev, int inport,
rc = dynamic_funnel_enable_hw(drvdata, inport); rc = dynamic_funnel_enable_hw(drvdata, inport);
if (!rc) if (!rc)
dev_dbg(drvdata->dev, "FUNNEL inport %d enabled\n", inport); dev_dbg(&csdev->dev, "FUNNEL inport %d enabled\n", inport);
return rc; return rc;
} }
...@@ -110,7 +108,7 @@ static void funnel_disable(struct coresight_device *csdev, int inport, ...@@ -110,7 +108,7 @@ static void funnel_disable(struct coresight_device *csdev, int inport,
if (drvdata->base) if (drvdata->base)
dynamic_funnel_disable_hw(drvdata, inport); dynamic_funnel_disable_hw(drvdata, inport);
dev_dbg(drvdata->dev, "FUNNEL inport %d disabled\n", inport); dev_dbg(&csdev->dev, "FUNNEL inport %d disabled\n", inport);
} }
static const struct coresight_ops_link funnel_link_ops = { static const struct coresight_ops_link funnel_link_ops = {
...@@ -165,11 +163,11 @@ static ssize_t funnel_ctrl_show(struct device *dev, ...@@ -165,11 +163,11 @@ static ssize_t funnel_ctrl_show(struct device *dev,
u32 val; u32 val;
struct funnel_drvdata *drvdata = dev_get_drvdata(dev->parent); struct funnel_drvdata *drvdata = dev_get_drvdata(dev->parent);
pm_runtime_get_sync(drvdata->dev); pm_runtime_get_sync(dev->parent);
val = get_funnel_ctrl_hw(drvdata); val = get_funnel_ctrl_hw(drvdata);
pm_runtime_put(drvdata->dev); pm_runtime_put(dev->parent);
return sprintf(buf, "%#x\n", val); return sprintf(buf, "%#x\n", val);
} }
...@@ -205,7 +203,6 @@ static int funnel_probe(struct device *dev, struct resource *res) ...@@ -205,7 +203,6 @@ static int funnel_probe(struct device *dev, struct resource *res)
if (!drvdata) if (!drvdata)
return -ENOMEM; return -ENOMEM;
drvdata->dev = dev;
drvdata->atclk = devm_clk_get(dev, "atclk"); /* optional */ drvdata->atclk = devm_clk_get(dev, "atclk"); /* optional */
if (!IS_ERR(drvdata->atclk)) { if (!IS_ERR(drvdata->atclk)) {
ret = clk_prepare_enable(drvdata->atclk); ret = clk_prepare_enable(drvdata->atclk);
......
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