OSDN Git Service

coresight: Properly address errors in sink::disable() functions
authorMathieu Poirier <mathieu.poirier@linaro.org>
Thu, 25 Apr 2019 19:52:57 +0000 (13:52 -0600)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 25 Apr 2019 20:00:17 +0000 (22:00 +0200)
When disabling a sink the reference counter ensures the operation goes
through if nobody else is using it.  As such if drvdata::mode is already
set do CS_MODE_DISABLED, it is an error and should be reported as such.

Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Reviewed-by: Suzuki K Poulose <suzuki.poulose@arm.com>
Tested-by: Leo Yan <leo.yan@linaro.org>
Tested-by: Robert Walker <robert.walker@arm.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/hwtracing/coresight/coresight-etb10.c
drivers/hwtracing/coresight/coresight-tmc-etf.c
drivers/hwtracing/coresight/coresight-tmc-etr.c

index 8e63863..6b73bc2 100644 (file)
@@ -333,11 +333,10 @@ static int etb_disable(struct coresight_device *csdev)
                return -EBUSY;
        }
 
-       /* Disable the ETB only if it needs to */
-       if (drvdata->mode != CS_MODE_DISABLED) {
-               etb_disable_hw(drvdata);
-               drvdata->mode = CS_MODE_DISABLED;
-       }
+       /* Complain if we (somehow) got out of sync */
+       WARN_ON_ONCE(drvdata->mode == CS_MODE_DISABLED);
+       etb_disable_hw(drvdata);
+       drvdata->mode = CS_MODE_DISABLED;
        spin_unlock_irqrestore(&drvdata->spinlock, flags);
 
        dev_dbg(drvdata->dev, "ETB disabled\n");
index d50a608..30f8686 100644 (file)
@@ -297,11 +297,10 @@ static int tmc_disable_etf_sink(struct coresight_device *csdev)
                return -EBUSY;
        }
 
-       /* Disable the TMC only if it needs to */
-       if (drvdata->mode != CS_MODE_DISABLED) {
-               tmc_etb_disable_hw(drvdata);
-               drvdata->mode = CS_MODE_DISABLED;
-       }
+       /* Complain if we (somehow) got out of sync */
+       WARN_ON_ONCE(drvdata->mode == CS_MODE_DISABLED);
+       tmc_etb_disable_hw(drvdata);
+       drvdata->mode = CS_MODE_DISABLED;
 
        spin_unlock_irqrestore(&drvdata->spinlock, flags);
 
index 6a8f39d..9a0b346 100644 (file)
@@ -1417,11 +1417,10 @@ static int tmc_disable_etr_sink(struct coresight_device *csdev)
                return -EBUSY;
        }
 
-       /* Disable the TMC only if it needs to */
-       if (drvdata->mode != CS_MODE_DISABLED) {
-               tmc_etr_disable_hw(drvdata);
-               drvdata->mode = CS_MODE_DISABLED;
-       }
+       /* Complain if we (somehow) got out of sync */
+       WARN_ON_ONCE(drvdata->mode == CS_MODE_DISABLED);
+       tmc_etr_disable_hw(drvdata);
+       drvdata->mode = CS_MODE_DISABLED;
 
        spin_unlock_irqrestore(&drvdata->spinlock, flags);