Commit 6c817a95 authored by Mathieu Poirier's avatar Mathieu Poirier Committed by Greg Kroah-Hartman

coresight: Adding return code to sink::disable() operation

In preparation to handle device reference counting inside of the sink
drivers, add a return code to the sink::disable() operation so that
proper action can be taken if a sink has not been disabled.
Signed-off-by: default avatarMathieu Poirier <mathieu.poirier@linaro.org>
Reviewed-by: default avatarSuzuki K Poulose <suzuki.poulose@arm.com>
Tested-by: default avatarLeo Yan <leo.yan@linaro.org>
Tested-by: default avatarRobert Walker <robert.walker@arm.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent a54e14f8
...@@ -317,7 +317,7 @@ static void etb_disable_hw(struct etb_drvdata *drvdata) ...@@ -317,7 +317,7 @@ static void etb_disable_hw(struct etb_drvdata *drvdata)
coresight_disclaim_device(drvdata->base); coresight_disclaim_device(drvdata->base);
} }
static void etb_disable(struct coresight_device *csdev) static int etb_disable(struct coresight_device *csdev)
{ {
struct etb_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent); struct etb_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent);
unsigned long flags; unsigned long flags;
...@@ -332,6 +332,7 @@ static void etb_disable(struct coresight_device *csdev) ...@@ -332,6 +332,7 @@ static void etb_disable(struct coresight_device *csdev)
spin_unlock_irqrestore(&drvdata->spinlock, flags); spin_unlock_irqrestore(&drvdata->spinlock, flags);
dev_dbg(drvdata->dev, "ETB disabled\n"); dev_dbg(drvdata->dev, "ETB disabled\n");
return 0;
} }
static void *etb_alloc_buffer(struct coresight_device *csdev, int cpu, static void *etb_alloc_buffer(struct coresight_device *csdev, int cpu,
......
...@@ -273,7 +273,7 @@ static int tmc_enable_etf_sink(struct coresight_device *csdev, ...@@ -273,7 +273,7 @@ static int tmc_enable_etf_sink(struct coresight_device *csdev,
return 0; return 0;
} }
static void tmc_disable_etf_sink(struct coresight_device *csdev) static int tmc_disable_etf_sink(struct coresight_device *csdev)
{ {
unsigned long flags; unsigned long flags;
struct tmc_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent); struct tmc_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent);
...@@ -281,7 +281,7 @@ static void tmc_disable_etf_sink(struct coresight_device *csdev) ...@@ -281,7 +281,7 @@ static void tmc_disable_etf_sink(struct coresight_device *csdev)
spin_lock_irqsave(&drvdata->spinlock, flags); spin_lock_irqsave(&drvdata->spinlock, flags);
if (drvdata->reading) { if (drvdata->reading) {
spin_unlock_irqrestore(&drvdata->spinlock, flags); spin_unlock_irqrestore(&drvdata->spinlock, flags);
return; return -EBUSY;
} }
/* Disable the TMC only if it needs to */ /* Disable the TMC only if it needs to */
...@@ -293,6 +293,7 @@ static void tmc_disable_etf_sink(struct coresight_device *csdev) ...@@ -293,6 +293,7 @@ static void tmc_disable_etf_sink(struct coresight_device *csdev)
spin_unlock_irqrestore(&drvdata->spinlock, flags); spin_unlock_irqrestore(&drvdata->spinlock, flags);
dev_dbg(drvdata->dev, "TMC-ETB/ETF disabled\n"); dev_dbg(drvdata->dev, "TMC-ETB/ETF disabled\n");
return 0;
} }
static int tmc_enable_etf_link(struct coresight_device *csdev, static int tmc_enable_etf_link(struct coresight_device *csdev,
......
...@@ -1393,7 +1393,7 @@ static int tmc_enable_etr_sink(struct coresight_device *csdev, ...@@ -1393,7 +1393,7 @@ static int tmc_enable_etr_sink(struct coresight_device *csdev,
return -EINVAL; return -EINVAL;
} }
static void tmc_disable_etr_sink(struct coresight_device *csdev) static int tmc_disable_etr_sink(struct coresight_device *csdev)
{ {
unsigned long flags; unsigned long flags;
struct tmc_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent); struct tmc_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent);
...@@ -1401,7 +1401,7 @@ static void tmc_disable_etr_sink(struct coresight_device *csdev) ...@@ -1401,7 +1401,7 @@ static void tmc_disable_etr_sink(struct coresight_device *csdev)
spin_lock_irqsave(&drvdata->spinlock, flags); spin_lock_irqsave(&drvdata->spinlock, flags);
if (drvdata->reading) { if (drvdata->reading) {
spin_unlock_irqrestore(&drvdata->spinlock, flags); spin_unlock_irqrestore(&drvdata->spinlock, flags);
return; return -EBUSY;
} }
/* Disable the TMC only if it needs to */ /* Disable the TMC only if it needs to */
...@@ -1413,6 +1413,7 @@ static void tmc_disable_etr_sink(struct coresight_device *csdev) ...@@ -1413,6 +1413,7 @@ static void tmc_disable_etr_sink(struct coresight_device *csdev)
spin_unlock_irqrestore(&drvdata->spinlock, flags); spin_unlock_irqrestore(&drvdata->spinlock, flags);
dev_dbg(drvdata->dev, "TMC-ETR disabled\n"); dev_dbg(drvdata->dev, "TMC-ETR disabled\n");
return 0;
} }
static const struct coresight_ops_sink tmc_etr_sink_ops = { static const struct coresight_ops_sink tmc_etr_sink_ops = {
......
...@@ -94,13 +94,14 @@ static void tpiu_disable_hw(struct tpiu_drvdata *drvdata) ...@@ -94,13 +94,14 @@ static void tpiu_disable_hw(struct tpiu_drvdata *drvdata)
CS_LOCK(drvdata->base); CS_LOCK(drvdata->base);
} }
static void tpiu_disable(struct coresight_device *csdev) static int tpiu_disable(struct coresight_device *csdev)
{ {
struct tpiu_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent); struct tpiu_drvdata *drvdata = dev_get_drvdata(csdev->dev.parent);
tpiu_disable_hw(drvdata); tpiu_disable_hw(drvdata);
dev_dbg(drvdata->dev, "TPIU disabled\n"); dev_dbg(drvdata->dev, "TPIU disabled\n");
return 0;
} }
static const struct coresight_ops_sink tpiu_sink_ops = { static const struct coresight_ops_sink tpiu_sink_ops = {
......
...@@ -239,9 +239,13 @@ static int coresight_enable_sink(struct coresight_device *csdev, ...@@ -239,9 +239,13 @@ static int coresight_enable_sink(struct coresight_device *csdev,
static void coresight_disable_sink(struct coresight_device *csdev) static void coresight_disable_sink(struct coresight_device *csdev)
{ {
int ret;
if (atomic_dec_return(csdev->refcnt) == 0) { if (atomic_dec_return(csdev->refcnt) == 0) {
if (sink_ops(csdev)->disable) { if (sink_ops(csdev)->disable) {
sink_ops(csdev)->disable(csdev); ret = sink_ops(csdev)->disable(csdev);
if (ret)
return;
csdev->enable = false; csdev->enable = false;
} }
} }
......
...@@ -192,7 +192,7 @@ struct coresight_device { ...@@ -192,7 +192,7 @@ struct coresight_device {
*/ */
struct coresight_ops_sink { struct coresight_ops_sink {
int (*enable)(struct coresight_device *csdev, u32 mode, void *data); int (*enable)(struct coresight_device *csdev, u32 mode, void *data);
void (*disable)(struct coresight_device *csdev); int (*disable)(struct coresight_device *csdev);
void *(*alloc_buffer)(struct coresight_device *csdev, int cpu, void *(*alloc_buffer)(struct coresight_device *csdev, int cpu,
void **pages, int nr_pages, bool overwrite); void **pages, int nr_pages, bool overwrite);
void (*free_buffer)(void *config); void (*free_buffer)(void *config);
......
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